shiplightai 0.1.75 → 0.1.77
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/debugger-pw.cjs +49 -49
- package/dist/cjs/fixture.cjs +97 -97
- package/dist/cjs/index.cjs +14 -14
- package/dist/cjs/reporter.cjs +2 -2
- package/dist/cli.js +75 -75
- package/dist/debugger-pw.js +48 -48
- package/dist/fixture.d.ts +71 -1
- package/dist/fixture.js +97 -97
- package/dist/index.js +13 -13
- package/dist/reporter.js +2 -2
- package/package.json +5 -5
package/dist/cjs/index.cjs
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
"use strict";var sc=Object.create;var Ti=Object.defineProperty;var lc=Object.getOwnPropertyDescriptor;var cc=Object.getOwnPropertyNames;var dc=Object.getPrototypeOf,uc=Object.prototype.hasOwnProperty;var v=(e,t)=>()=>(e&&(t=e(e=0)),t);var ze=(e,t)=>{for(var i in t)Ti(e,i,{get:t[i],enumerable:!0})},bo=(e,t,i,a)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of cc(t))!uc.call(e,n)&&n!==i&&Ti(e,n,{get:()=>t[n],enumerable:!(a=lc(t,n))||a.enumerable});return e};var X=(e,t,i)=>(i=e!=null?sc(dc(e)):{},bo(t||!e||!e.__esModule?Ti(i,"default",{value:e,enumerable:!0}):i,e)),hc=e=>bo(Ti({},"__esModule",{value:!0}),e);function ed(){return globalThis[tr]}function td(e){globalThis[tr]=e}function sa(e){let t=[],i=Be.resolve(e),a=Be.resolve(process.cwd());for(;;){let n=Be.join(i,".env");if(Li.existsSync(n)&&t.push(n),i===a)break;let o=Be.dirname(i);if(o===i)break;i=o}return t}function ir(e){let t=sa(e),i={};for(let[a,n]of Object.entries(process.env))n!==void 0&&(i[a]=n);for(let a=t.length-1;a>=0;a--)Object.assign(i,er.default.parse(Li.readFileSync(t[a])));td(i)}function Ni(){let e=ed();return e===void 0?process.env:e}var Li,Be,er,tr,Di=v(()=>{"use strict";Li=X(require("fs"),1),Be=X(require("path"),1),er=X(require("dotenv"),1),tr="__shiplightDotenvCache__"});function nr(e,t){let i=t?.trim();return i?i.endsWith("/")?i.slice(0,-1):i:e.startsWith(id)?nd:ad}var id,nd,ad,ar=v(()=>{"use strict";id="shp_",nd="https://nova-api.shiplight.ai",ad="https://api.shiplight.ai"});var la={};ze(la,{lookupActionStores:()=>sd,updateActionStores:()=>ld});function or(){let e=Ni(),t=e.SHIPLIGHT_API_TOKEN;return t?{apiUrl:nr(t,e.SHIPLIGHT_API_URL),apiToken:t}:null}async function sd(e){let t=or();if(!t||e.length===0)return new Map;try{let i=new AbortController,a=setTimeout(()=>i.abort(),od),n=await fetch(`${t.apiUrl}/action-entity-cache/lookup`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t.apiToken}`},body:JSON.stringify({test_paths:e}),signal:i.signal});if(clearTimeout(a),!n.ok)return console.warn(`[shiplight] Cache lookup failed: HTTP ${n.status}`),new Map;let o=await n.json(),r=new Map;for(let[s,l]of Object.entries(o.stores??{}))r.set(s,l);return r}catch(i){return i instanceof Error&&i.name!=="AbortError"&&console.warn("[shiplight] Cache lookup error:",i.message),new Map}}async function ld(e){let t=or();if(!t||e.size===0)return 0;try{let i=new AbortController,a=setTimeout(()=>i.abort(),rd),n={};for(let[s,l]of e)n[s]=l;let o=await fetch(`${t.apiUrl}/action-entity-cache/update`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t.apiToken}`},body:JSON.stringify({stores:n}),signal:i.signal});return clearTimeout(a),o.ok?(await o.json()).updated??0:(console.warn(`[shiplight] Cache update failed: HTTP ${o.status}`),0)}catch(i){return i instanceof Error&&i.name!=="AbortError"&&console.warn("[shiplight] Cache update error:",i.message),0}}var od,rd,ca=v(()=>{"use strict";ar();Di();od=2e3,rd=5e3});function pa(e){ha.updateConfig(e)}function j(){return ha.getConfig()}var pd,ha,Ri,ne=v(()=>{"use strict";pd=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}},ha=new pd,Ri=ha});var md,gd,u,R=v(()=>{"use strict";ne();md=class{getLevel(){return Ri.get("logLevel")}isStderrOnly(){return Ri.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){Ri.set("logLevel",e)}},gd=new md,u=gd});
|
|
1
|
+
"use strict";var sc=Object.create;var Ti=Object.defineProperty;var lc=Object.getOwnPropertyDescriptor;var cc=Object.getOwnPropertyNames;var dc=Object.getPrototypeOf,uc=Object.prototype.hasOwnProperty;var v=(e,t)=>()=>(e&&(t=e(e=0)),t);var ze=(e,t)=>{for(var i in t)Ti(e,i,{get:t[i],enumerable:!0})},bo=(e,t,i,a)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of cc(t))!uc.call(e,n)&&n!==i&&Ti(e,n,{get:()=>t[n],enumerable:!(a=lc(t,n))||a.enumerable});return e};var X=(e,t,i)=>(i=e!=null?sc(dc(e)):{},bo(t||!e||!e.__esModule?Ti(i,"default",{value:e,enumerable:!0}):i,e)),hc=e=>bo(Ti({},"__esModule",{value:!0}),e);function ed(){return globalThis[tr]}function td(e){globalThis[tr]=e}function sa(e){let t=[],i=Be.resolve(e),a=Be.resolve(process.cwd());for(;;){let n=Be.join(i,".env");if(Li.existsSync(n)&&t.push(n),i===a)break;let o=Be.dirname(i);if(o===i)break;i=o}return t}function ir(e){let t=sa(e),i={};for(let[a,n]of Object.entries(process.env))n!==void 0&&(i[a]=n);for(let a=t.length-1;a>=0;a--)Object.assign(i,er.default.parse(Li.readFileSync(t[a])));td(i)}function Ni(){let e=ed();return e===void 0?process.env:e}var Li,Be,er,tr,Di=v(()=>{"use strict";Li=X(require("fs"),1),Be=X(require("path"),1),er=X(require("dotenv"),1),tr="__shiplightDotenvCache__"});function nr(e,t){let i=t?.trim();return i?i.endsWith("/")?i.slice(0,-1):i:e.startsWith(id)?nd:ad}var id,nd,ad,ar=v(()=>{"use strict";id="shp_",nd="https://nova-api.shiplight.ai",ad="https://api.shiplight.ai"});var la={};ze(la,{lookupActionStores:()=>sd,updateActionStores:()=>ld});function or(){let e=Ni(),t=e.SHIPLIGHT_API_TOKEN;return t?{apiUrl:nr(t,e.SHIPLIGHT_API_URL),apiToken:t}:null}async function sd(e){let t=or();if(!t||e.length===0)return new Map;try{let i=new AbortController,a=setTimeout(()=>i.abort(),od),n=await fetch(`${t.apiUrl}/action-entity-cache/lookup`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t.apiToken}`},body:JSON.stringify({test_paths:e}),signal:i.signal});if(clearTimeout(a),!n.ok)return console.warn(`[shiplight] Cache lookup failed: HTTP ${n.status}`),new Map;let o=await n.json(),r=new Map;for(let[s,l]of Object.entries(o.stores??{}))r.set(s,l);return r}catch(i){return i instanceof Error&&i.name!=="AbortError"&&console.warn("[shiplight] Cache lookup error:",i.message),new Map}}async function ld(e){let t=or();if(!t||e.size===0)return 0;try{let i=new AbortController,a=setTimeout(()=>i.abort(),rd),n={};for(let[s,l]of e)n[s]=l;let o=await fetch(`${t.apiUrl}/action-entity-cache/update`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t.apiToken}`},body:JSON.stringify({stores:n}),signal:i.signal});return clearTimeout(a),o.ok?(await o.json()).updated??0:(console.warn(`[shiplight] Cache update failed: HTTP ${o.status}`),0)}catch(i){return i instanceof Error&&i.name!=="AbortError"&&console.warn("[shiplight] Cache update error:",i.message),0}}var od,rd,ca=v(()=>{"use strict";ar();Di();od=2e3,rd=5e3});function pa(e){ha.updateConfig(e)}function j(){return ha.getConfig()}var pd,ha,Ri,ne=v(()=>{"use strict";pd=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}},ha=new pd,Ri=ha});var md,gd,u,R=v(()=>{"use strict";ne();md=class{getLevel(){return Ri.get("logLevel")}isStderrOnly(){return Ri.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){Ri.set("logLevel",e)}},gd=new md,u=gd});var ma,fd,w,ae=v(()=>{"use strict";ne();ma=require("fs"),fd=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=j().agentLogPath;if(e)try{(0,ma.appendFileSync)(e,`
|
|
2
2
|
=== Agent Execution Log ===
|
|
3
3
|
Started: ${new Date().toISOString()}
|
|
4
4
|
|
|
5
|
-
`),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=j().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();(0,
|
|
5
|
+
`),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=j().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();(0,ma.appendFileSync)(t,`[${i}] ${e}
|
|
6
6
|
`)}catch{}}}section(e){this.log(`
|
|
7
7
|
${"=".repeat(60)}
|
|
8
8
|
${e}
|
|
@@ -11,7 +11,7 @@ ${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
|
|
|
11
11
|
${e}`),this.log(`
|
|
12
12
|
User Prompt:
|
|
13
13
|
${t}`)}response(e){this.log(`LLM Response:
|
|
14
|
-
${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!j().agentLogPath}},w=new fd});var Wi,wd,bd,yd,xd,mr,Ui,fa,gr,wa,ba,ge=v(()=>{"use strict";Wi=Object.defineProperty,wd=Object.getOwnPropertyDescriptor,bd=Object.getOwnPropertyNames,yd=Object.prototype.hasOwnProperty,xd=(e,t,i)=>t in e?Wi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,mr=(e,t)=>()=>(e&&(t=e(e=0)),t),Ui=(e,t)=>{for(var i in t)Wi(e,i,{get:t[i],enumerable:!0})},fa=(e,t,i,a)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of bd(t))!yd.call(e,n)&&n!==i&&Wi(e,n,{get:()=>t[n],enumerable:!(a=wd(t,n))||a.enumerable});return e},gr=(e,t,i)=>(fa(e,t,"default"),i&&fa(i,t,"default")),wa=e=>fa(Wi({},"__esModule",{value:!0}),e),ba=(e,t,i)=>xd(e,typeof t!="symbol"?t+"":t,i)});function P(e,t){return t??e?.getActionSettings()?.action_timeout_ms??xa}function vd(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function O(e,t){let i=Fe(t);return i?new Function("page",`return ${i}`)(e):null}async function ya(e,t=[]){let i=e;for(let a of t){let n=await i.locator(a).elementHandle();if(!n)return null;let o=await n.contentFrame();if(await n.dispose(),!o)return null;i=o}return i}function _d(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 kd(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Sd(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=kd(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let a=Sd(e);if(a){let n=JSON.stringify(a);return`${t}.locator(${n}).first()`}return null}var Bi,Et,xa,fe,I,F=v(()=>{"use strict";ge();Bi={};Ui(Bi,{ACTION_TIMEOUT:()=>xa,GOTO_TIMEOUT:()=>fe,LOCATOR_TIMEOUT:()=>Et,getActionTimeoutMs:()=>P,getFrameContext:()=>ya,getLocator:()=>O,getMinimalActionEntity:()=>_d,getPageLocatorExpression:()=>Fe,sanitizeForComment:()=>vd});I=mr(()=>{Et=5e3,xa=1e4,fe=2e4})});async function va(e,t,i=[],a=[]){try{let n=await ya(e,i);if(!n)return u.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(a.length>0){let s=a[0];if(!s)return u.warn(`Missing shadow host xpath for element: ${t}`),null;let l=n.locator(`xpath=${fr(s)}`),c=Ed(t);if(o=await(c?l.locator(`css=${c}`):l.locator(`xpath=${fr(t)}`)).elementHandle({timeout:Et}),!o)return u.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await n.locator(`xpath=${t}`).elementHandle({timeout:Et}),!o)return u.warn(`Could not find element with xpath: ${t}`),null;let r=await n.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,o);return await o.dispose(),r?(u.debug(`Generated locator for ${t}: ${r}`),r):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(n){return u.error(`Error in pickBestLocator: ${n}`),null}}async function _a(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(a=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(a):null,t);return await t.dispose(),i?(u.debug(`Generated locator: ${i}`),i):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return u.error(`Error in pickBestLocator: ${i}`),null}}function fr(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Ed(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),a=[];for(let n of i){let o=n.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!o)return null;let r=o[1].toLowerCase(),s=o[2]?`:nth-of-type(${o[2]})`:"";a.push(`${r}${s}`)}return a.join(" > ")}var Ge=v(()=>{"use strict";R();F();I()});async function Tt(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(l=>l()),window._highlightCleanupFunctions=[])});let a=await e.screenshot({type:"png",fullPage:!1}),{default:n}=await import("sharp"),o=n(a),{width:r=0,height:s=0}=await o.metadata();return w.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await o.resize(t,i).png().toBuffer():a).toString("base64")}async function Se(e,t,i){let a=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),n=a.asElement();if(!n)throw await a.dispose(),new Error(`No element found at (${t}, ${i})`);let o=await n.boundingBox();if(!o)throw await a.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(o.x+o.width/2),relative_y:i-(o.y+o.height/2),element:n}}async function Gi(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(n=>{let o=[],r=n;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let s=1,l=r.previousElementSibling;for(;l;)l.tagName===r.tagName&&s++,l=l.previousElementSibling;o.unshift(`${r.tagName.toLowerCase()}[${s}]`),r=r.parentElement}return o.length?`/${o.join("/")}`:null}).catch(()=>null),a=await _a(e,t);return{xpath:i??void 0,locator:a??void 0,frame_path:[]}}function ji(e,t,i){return{action_description:e,action_data:t,locator:i.locator??void 0,xpath:i.xpath??void 0,frame_path:i.frame_path}}var Ze=v(()=>{"use strict";ae();Ge()});function Ki(e,t){let i=t?.trim();return i?Md(i):e.startsWith(Td)?Ad:$d}function wr(e,t){return`${Ki(e,t)}/llm/v1`}function br(e,t){return`${Ki(e,t)}/llm/v1`}function yr(e,t){return`${Ki(e,t)}/llm/v1beta`}function xr(e,t){return`${Ki(e,t)}/llm`}function Md(e){return e.endsWith("/")?e.slice(0,-1):e}var Td,Ad,$d,He=v(()=>{"use strict";Td="shp_",Ad="https://nova-api.shiplight.ai",$d="https://api.shiplight.ai"});function zi(){let e=(j().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function kr(e){let t=j().env||{};if(zi()){let n=t.GOOGLE_CLOUD_PROJECT;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let o=e.startsWith("gemini-3")?"global":t.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return u.debug(`Using Vertex AI provider: model=${e}, location=${o}`),(0,_r.createVertex)({project:n,location:o})(e)}let i=t.GOOGLE_API_KEY;if(i)return u.debug(`Using Google AI provider (API key): model=${e}`),(0,ka.createGoogleGenerativeAI)({apiKey:i})(e);let a=t.SHIPLIGHT_API_TOKEN;if(a){let n=yr(a,t.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${n}`),(0,ka.createGoogleGenerativeAI)({apiKey:a,baseURL:n})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function Sr(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},a={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:vr.MEDIA_RESOLUTION_HIGH},n;switch(t){case"gemini-3-flash-preview":n={...a};break;default:n={...i},e===1&&(n.mediaResolution=vr.MEDIA_RESOLUTION_HIGH)}return zi()?{vertex:n}:{google:n}}var ka,_r,vr,Qe=v(()=>{"use strict";He();R();ne();ka=require("@ai-sdk/google"),_r=require("@ai-sdk/google-vertex"),vr={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});function we(e,t){return Math.round(e/1e3*t)}async function Pd(e,t,i,a,n){let o=null,r=null;try{switch(t){case"click_at":{let s=we(i.x,a),l=we(i.y,n),c=await Se(e,s,l);o={action_name:"click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"right_click_at":{let s=we(i.x,a),l=we(i.y,n),c=await Se(e,s,l);o={action_name:"right_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"double_click_at":{let s=we(i.x,a),l=we(i.y,n),c=await Se(e,s,l);o={action_name:"double_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"drag_and_drop":{let s=we(i.x,a),l=we(i.y,n),c=we(i.destination_x,a),d=we(i.destination_y,n),h=await Se(e,s,l);o={action_name:"drag_drop",kwargs:{relative_x:h.relative_x,relative_y:h.relative_y,delta_x:c-s,delta_y:d-l}},r=h.element;break}default:w.log(`Unsupported Gemini function: ${t}`)}}catch(s){w.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:o,locatorInfo:await Gi(e,r)}}async function Tr(e){let{statement:t,page:i,screenshotB64:a,viewportWidth:n,viewportHeight:o,modelId:r}=e,s=r||Cd,l=j(),c;if(zi()){let x=l.env?.GOOGLE_CLOUD_PROJECT;if(!x)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let S=l.env?.GOOGLE_CLOUD_LOCATION??"global";c={vertexai:!0,project:x,location:S}}else{let x=l.env?.GOOGLE_API_KEY;if(x)u.debug(`Using Google AI provider (API key): model=${s}`),c={apiKey:x};else{let S=l.env?.SHIPLIGHT_API_TOKEN;if(S){let E=xr(S,l.env?.SHIPLIGHT_API_URL);u.debug(`Using Shiplight LLM proxy (Google CUA): model=${s}, baseUrl=${E}`),c={apiKey:S,httpOptions:{baseUrl:E}}}else return{status:"error",error:"Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment."}}}let d=new Vi.GoogleGenAI(c);w.log(`Sending request to Gemini CUA (model=${s})...`);let h=await d.models.generateContent({model:s,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:a}}]}],config:{tools:[{computerUse:{environment:Vi.Environment.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Id}],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(x=>x.functionCall);if(!g)return{status:"error",reasoning:m.content?.parts?.filter(x=>x.text).map(x=>x.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:f,args:y}=g.functionCall;w.log(`Generated function call: ${f} with args ${JSON.stringify(y)}`),u.debug(`Generated function call: ${f} with args ${JSON.stringify(y)}`);let{action_data:b,locatorInfo:p}=await Pd(i,f,y,n,o);return b?{status:"success",actionEntity:ji(t,b,p),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${f}`}}var Vi,Er,Id,Cd,Xi=v(()=>{"use strict";Ze();ae();Qe();He();R();ne();Vi=require("@google/genai");Er={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"]},Id=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:Er},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:Er}];Cd="gemini-3-flash-preview"});function $r(e){return e!=null&&typeof e=="object"}function et(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function Ar(e){return typeof e=="string"?e:void 0}function Od(e){let t,i;return Array.isArray(e)?(t=et(e[0]),i=et(e[1])):$r(e)&&(t=et(e.x),i=et(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function Mr(e){if(!$r(e))return{};let t=Array.isArray(e.path)?e.path.map(Od).filter(i=>i!==null):void 0;return{type:Ar(e.type),x:et(e.x),y:et(e.y),button:Ar(e.button),path:t}}var Yi=v(()=>{"use strict"});async function Ld(e,t){let i=Mr(t),a=null,n=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let o=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await Se(e,i.x,i.y);a={action_name:o,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},n=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let o=await Se(e,i.x,i.y);a={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},n=o.element;break}case"drag":{if(!i.path||i.path.length<2)break;let o=i.path[0],r=i.path[i.path.length-1],s=await Se(e,o.x,o.y);a={action_name:"drag_drop",kwargs:{relative_x:s.relative_x,relative_y:s.relative_y,delta_x:r.x-o.x,delta_y:r.y-o.y}},n=s.element;break}}return{action_data:a,locatorInfo:await Gi(e,n)}}async function Cr(e){let{statement:t,page:i,viewportWidth:a,viewportHeight:n,modelId:o}=e,r=o||Nd,s=await Tt(i,a,n),l=j(),c=l.env?.OPENAI_API_KEY;if(!c)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let d=l.env?.OPENAI_BASE_URL,h=new Pr.default({apiKey:c,...d&&{baseURL:d}}),m=h.responses.create.bind(h.responses);w.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 f(S,E){let A={model:r,tools:[Dd],input:S,temperature:.1};return E&&(A.previous_response_id=E),m(A)}let y=await f(g,void 0),b;for(let S=0;S<Ir;S++){w.log(`Received response from OpenAI CUA (turn ${S+1})`);let E=y.output.find(L=>L.type==="computer_call");if(!E)return{status:"error",reasoning:y.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let A=E.actions??[];if(A.length>1&&w.log(`[openai CUA] dropping ${A.length-1} batched action(s); only the first is executed`),b=A[0],!b)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(b.type!=="screenshot")break;s=await Tt(i,a,n);let M=[{type:"computer_call_output",call_id:E.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`,detail:"original"}}];y=await f(M,y.id)}if(!b)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(b.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${Ir} turns`};w.log(`Generated action: ${JSON.stringify(b)}`);let{action_data:p,locatorInfo:x}=await Ld(i,b);return p?{status:"success",actionEntity:ji(t,p,x),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(b)}`}}var Pr,Nd,Dd,Ir,Ji=v(()=>{"use strict";Ze();Yi();ae();ne();Pr=X(require("openai"),1);Nd="gpt-5.4",Dd={type:"computer"},Ir=4});function Rd(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Fd(){return Rd(j().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function Lr(e){let t=j();if(Fd()){let n=t.env?.GOOGLE_CLOUD_PROJECT,o=t.env?.GOOGLE_CLOUD_LOCATION;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!o)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=${n}, location=${o}`),(0,Or.createVertexAnthropic)({project:n,location:o})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return u.debug(`Using Anthropic provider: model=${e}`),(0,Sa.createAnthropic)({apiKey:i})(e);let a=t.env?.SHIPLIGHT_API_TOKEN;if(a){let n=br(a,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${n}`),(0,Sa.createAnthropic)({apiKey:a,baseURL:n})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function Ea(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var Sa,Or,At=v(()=>{"use strict";He();R();ne();Sa=require("@ai-sdk/anthropic"),Or=require("@ai-sdk/google-vertex/anthropic")});function Nr(e){let t=j(),i=t.env?.OPENAI_API_KEY;if(i){let n=t.env?.OPENAI_BASE_URL;return u.debug(`Using OpenAI provider: model=${e}${n?`, baseURL=${n}`:""}`),(0,Ta.createOpenAI)({apiKey:i,baseURL:n})(e)}let a=t.env?.SHIPLIGHT_API_TOKEN;if(a){let n=wr(a,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${n}`),(0,Ta.createOpenAI)({apiKey:a,baseURL:n})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function Dr(e){return{}}var Ta,$t=v(()=>{"use strict";He();R();ne();Ta=require("@ai-sdk/openai")});function Fr(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(Hd.test(e))return"openai"}function qi(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(Wd.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function Ee(e){let{provider:t,modelId:i}=qi(e),a=t??Fr(i);if(!a)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., "${a}:gpt-5.4-mini").`);let n=Rr[a];if(!n)throw new Error(`Provider "${a}" is not yet implemented. Supported providers: ${Object.keys(Rr).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return n(i)}function Te(e,t){let{provider:i,modelId:a}=qi(e),n=i??Fr(a);return n==="anthropic"||n==="vertex"?Ea(a):n==="openai"||n==="azure"?Dr(a):n==="bedrock"?a.startsWith("anthropic.")?Ea(a):{}:Sr(t,a)}var Hd,Wd,Rr,Ae=v(()=>{"use strict";At();Qe();$t();Hd=/^(gpt-|o\d|chatgpt-)/;Wd=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);Rr={anthropic:Lr,google:kr,openai:Nr}});function Bd(e){return e.startsWith("gemini-")?"google":"openai"}async function tt(e,t,i={}){let{page:a}=t,n=a.viewportSize();if(!n)return{status:"error",error:"Viewport size not available"};let{width:o,height:r}=n;w.log(`Viewport: ${o}x${r}`);let s=await Tt(a,o,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:c}=qi(l),d=Bd(c),h=Ud[d];w.log(`Using CUA provider: ${d} (model: ${c})`);let m={statement:e,page:a,screenshotB64:s,viewportWidth:o,viewportHeight:r,modelId:c};try{return await h(m)}catch(g){return w.error(`CUA provider "${d}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var Ud,it=v(()=>{"use strict";Xi();Ji();Ze();ae();Ae();Ud={google:Tr,openai:Cr}});function Gd(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 a=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,n=[],o=0,r;for(;(r=a.exec(e))!==null;){let l=e.slice(o,r.index);l&&n.push({type:"text",text:l});let c=r[2];i.has(c)?n.push({type:"image",image:new URL(i.get(c))}):n.push({type:"text",text:r[0]}),o=r.index+r[0].length}let s=e.slice(o);return s&&n.push({type:"text",text:s}),n.length===0&&n.push({type:"text",text:e}),n}function jd(e){let t=[];for(let i of e){let a=i.content||"",n=i.images||[],o=Gd(a,n);t.length>0&&o.length>0&&t.push({type:"text",text:`
|
|
14
|
+
${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!j().agentLogPath}},w=new fd});var Fi,wd,bd,yd,xd,pr,Hi,ga,mr,fa,wa,ge=v(()=>{"use strict";Fi=Object.defineProperty,wd=Object.getOwnPropertyDescriptor,bd=Object.getOwnPropertyNames,yd=Object.prototype.hasOwnProperty,xd=(e,t,i)=>t in e?Fi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,pr=(e,t)=>()=>(e&&(t=e(e=0)),t),Hi=(e,t)=>{for(var i in t)Fi(e,i,{get:t[i],enumerable:!0})},ga=(e,t,i,a)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of bd(t))!yd.call(e,n)&&n!==i&&Fi(e,n,{get:()=>t[n],enumerable:!(a=wd(t,n))||a.enumerable});return e},mr=(e,t,i)=>(ga(e,t,"default"),i&&ga(i,t,"default")),fa=e=>ga(Fi({},"__esModule",{value:!0}),e),wa=(e,t,i)=>xd(e,typeof t!="symbol"?t+"":t,i)});function P(e,t){return t??e?.getActionSettings()?.action_timeout_ms??ya}function vd(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function O(e,t){let i=Fe(t);return i?new Function("page",`return ${i}`)(e):null}async function ba(e,t=[]){let i=e;for(let a of t){let n=await i.locator(a).elementHandle();if(!n)return null;let o=await n.contentFrame();if(await n.dispose(),!o)return null;i=o}return i}function _d(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 kd(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Sd(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=kd(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let a=Sd(e);if(a){let n=JSON.stringify(a);return`${t}.locator(${n}).first()`}return null}var Wi,kt,ya,fe,I,F=v(()=>{"use strict";ge();Wi={};Hi(Wi,{ACTION_TIMEOUT:()=>ya,GOTO_TIMEOUT:()=>fe,LOCATOR_TIMEOUT:()=>kt,getActionTimeoutMs:()=>P,getFrameContext:()=>ba,getLocator:()=>O,getMinimalActionEntity:()=>_d,getPageLocatorExpression:()=>Fe,sanitizeForComment:()=>vd});I=pr(()=>{kt=5e3,ya=1e4,fe=2e4})});async function xa(e,t,i=[],a=[]){try{let n=await ba(e,i);if(!n)return u.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(a.length>0){let s=a[0];if(!s)return u.warn(`Missing shadow host xpath for element: ${t}`),null;let l=n.locator(`xpath=${gr(s)}`),c=Ed(t);if(o=await(c?l.locator(`css=${c}`):l.locator(`xpath=${gr(t)}`)).elementHandle({timeout:kt}),!o)return u.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await n.locator(`xpath=${t}`).elementHandle({timeout:kt}),!o)return u.warn(`Could not find element with xpath: ${t}`),null;let r=await n.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,o);return await o.dispose(),r?(u.debug(`Generated locator for ${t}: ${r}`),r):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(n){return u.error(`Error in pickBestLocator: ${n}`),null}}async function va(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(a=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(a):null,t);return await t.dispose(),i?(u.debug(`Generated locator: ${i}`),i):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return u.error(`Error in pickBestLocator: ${i}`),null}}function gr(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Ed(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),a=[];for(let n of i){let o=n.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!o)return null;let r=o[1].toLowerCase(),s=o[2]?`:nth-of-type(${o[2]})`:"";a.push(`${r}${s}`)}return a.join(" > ")}var Ge=v(()=>{"use strict";R();F();I()});async function St(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(l=>l()),window._highlightCleanupFunctions=[])});let a=await e.screenshot({type:"png",fullPage:!1}),{default:n}=await import("sharp"),o=n(a),{width:r=0,height:s=0}=await o.metadata();return w.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await o.resize(t,i).png().toBuffer():a).toString("base64")}async function Se(e,t,i){let a=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),n=a.asElement();if(!n)throw await a.dispose(),new Error(`No element found at (${t}, ${i})`);let o=await n.boundingBox();if(!o)throw await a.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(o.x+o.width/2),relative_y:i-(o.y+o.height/2),element:n}}async function Ui(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(n=>{let o=[],r=n;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let s=1,l=r.previousElementSibling;for(;l;)l.tagName===r.tagName&&s++,l=l.previousElementSibling;o.unshift(`${r.tagName.toLowerCase()}[${s}]`),r=r.parentElement}return o.length?`/${o.join("/")}`:null}).catch(()=>null),a=await va(e,t);return{xpath:i??void 0,locator:a??void 0,frame_path:[]}}function Bi(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 Ze=v(()=>{"use strict";ae();Ge()});function Gi(e,t){let i=t?.trim();return i?Md(i):e.startsWith(Td)?Ad:$d}function fr(e,t){return`${Gi(e,t)}/llm/v1`}function wr(e,t){return`${Gi(e,t)}/llm/v1`}function br(e,t){return`${Gi(e,t)}/llm/v1beta`}function yr(e,t){return`${Gi(e,t)}/llm`}function Md(e){return e.endsWith("/")?e.slice(0,-1):e}var Td,Ad,$d,He=v(()=>{"use strict";Td="shp_",Ad="https://nova-api.shiplight.ai",$d="https://api.shiplight.ai"});function ji(){let e=(j().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function _r(e){let t=j().env||{};if(ji()){let n=t.GOOGLE_CLOUD_PROJECT;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let o=e.startsWith("gemini-3")?"global":t.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return u.debug(`Using Vertex AI provider: model=${e}, location=${o}`),(0,vr.createVertex)({project:n,location:o})(e)}let i=t.GOOGLE_API_KEY;if(i)return u.debug(`Using Google AI provider (API key): model=${e}`),(0,_a.createGoogleGenerativeAI)({apiKey:i})(e);let a=t.SHIPLIGHT_API_TOKEN;if(a){let n=br(a,t.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${n}`),(0,_a.createGoogleGenerativeAI)({apiKey:a,baseURL:n})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function kr(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},a={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:xr.MEDIA_RESOLUTION_HIGH},n;switch(t){case"gemini-3-flash-preview":n={...a};break;default:n={...i},e===1&&(n.mediaResolution=xr.MEDIA_RESOLUTION_HIGH)}return ji()?{vertex:n}:{google:n}}var _a,vr,xr,Qe=v(()=>{"use strict";He();R();ne();_a=require("@ai-sdk/google"),vr=require("@ai-sdk/google-vertex"),xr={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});function we(e,t){return Math.round(e/1e3*t)}async function Pd(e,t,i,a,n){let o=null,r=null;try{switch(t){case"click_at":{let s=we(i.x,a),l=we(i.y,n),c=await Se(e,s,l);o={action_name:"click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"right_click_at":{let s=we(i.x,a),l=we(i.y,n),c=await Se(e,s,l);o={action_name:"right_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"double_click_at":{let s=we(i.x,a),l=we(i.y,n),c=await Se(e,s,l);o={action_name:"double_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"drag_and_drop":{let s=we(i.x,a),l=we(i.y,n),c=we(i.destination_x,a),d=we(i.destination_y,n),h=await Se(e,s,l);o={action_name:"drag_drop",kwargs:{relative_x:h.relative_x,relative_y:h.relative_y,delta_x:c-s,delta_y:d-l}},r=h.element;break}default:w.log(`Unsupported Gemini function: ${t}`)}}catch(s){w.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:o,locatorInfo:await Ui(e,r)}}async function Er(e){let{statement:t,page:i,screenshotB64:a,viewportWidth:n,viewportHeight:o,modelId:r}=e,s=r||Cd,l=j(),c;if(ji()){let x=l.env?.GOOGLE_CLOUD_PROJECT;if(!x)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let S=l.env?.GOOGLE_CLOUD_LOCATION??"global";c={vertexai:!0,project:x,location:S}}else{let x=l.env?.GOOGLE_API_KEY;if(x)u.debug(`Using Google AI provider (API key): model=${s}`),c={apiKey:x};else{let S=l.env?.SHIPLIGHT_API_TOKEN;if(S){let E=yr(S,l.env?.SHIPLIGHT_API_URL);u.debug(`Using Shiplight LLM proxy (Google CUA): model=${s}, baseUrl=${E}`),c={apiKey:S,httpOptions:{baseUrl:E}}}else return{status:"error",error:"Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment."}}}let d=new Ki.GoogleGenAI(c);w.log(`Sending request to Gemini CUA (model=${s})...`);let h=await d.models.generateContent({model:s,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:a}}]}],config:{tools:[{computerUse:{environment:Ki.Environment.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Id}],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(x=>x.functionCall);if(!g)return{status:"error",reasoning:m.content?.parts?.filter(x=>x.text).map(x=>x.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:f,args:y}=g.functionCall;w.log(`Generated function call: ${f} with args ${JSON.stringify(y)}`),u.debug(`Generated function call: ${f} with args ${JSON.stringify(y)}`);let{action_data:b,locatorInfo:p}=await Pd(i,f,y,n,o);return b?{status:"success",actionEntity:Bi(t,b,p),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${f}`}}var Ki,Sr,Id,Cd,zi=v(()=>{"use strict";Ze();ae();Qe();He();R();ne();Ki=require("@google/genai");Sr={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"]},Id=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:Sr},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:Sr}];Cd="gemini-3-flash-preview"});function Ar(e){return e!=null&&typeof e=="object"}function et(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function Tr(e){return typeof e=="string"?e:void 0}function Od(e){let t,i;return Array.isArray(e)?(t=et(e[0]),i=et(e[1])):Ar(e)&&(t=et(e.x),i=et(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function $r(e){if(!Ar(e))return{};let t=Array.isArray(e.path)?e.path.map(Od).filter(i=>i!==null):void 0;return{type:Tr(e.type),x:et(e.x),y:et(e.y),button:Tr(e.button),path:t}}var Vi=v(()=>{"use strict"});async function Ld(e,t){let i=$r(t),a=null,n=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let o=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await Se(e,i.x,i.y);a={action_name:o,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},n=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let o=await Se(e,i.x,i.y);a={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},n=o.element;break}case"drag":{if(!i.path||i.path.length<2)break;let o=i.path[0],r=i.path[i.path.length-1],s=await Se(e,o.x,o.y);a={action_name:"drag_drop",kwargs:{relative_x:s.relative_x,relative_y:s.relative_y,delta_x:r.x-o.x,delta_y:r.y-o.y}},n=s.element;break}}return{action_data:a,locatorInfo:await Ui(e,n)}}async function Pr(e){let{statement:t,page:i,viewportWidth:a,viewportHeight:n,modelId:o}=e,r=o||Nd,s=await St(i,a,n),l=j(),c=l.env?.OPENAI_API_KEY;if(!c)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let d=l.env?.OPENAI_BASE_URL,h=new Ir.default({apiKey:c,...d&&{baseURL:d}}),m=h.responses.create.bind(h.responses);w.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 f(S,E){let A={model:r,tools:[Dd],input:S,temperature:.1};return E&&(A.previous_response_id=E),m(A)}let y=await f(g,void 0),b;for(let S=0;S<Mr;S++){w.log(`Received response from OpenAI CUA (turn ${S+1})`);let E=y.output.find(L=>L.type==="computer_call");if(!E)return{status:"error",reasoning:y.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let A=E.actions??[];if(A.length>1&&w.log(`[openai CUA] dropping ${A.length-1} batched action(s); only the first is executed`),b=A[0],!b)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(b.type!=="screenshot")break;s=await St(i,a,n);let M=[{type:"computer_call_output",call_id:E.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`,detail:"original"}}];y=await f(M,y.id)}if(!b)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(b.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${Mr} turns`};w.log(`Generated action: ${JSON.stringify(b)}`);let{action_data:p,locatorInfo:x}=await Ld(i,b);return p?{status:"success",actionEntity:Bi(t,p,x),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(b)}`}}var Ir,Nd,Dd,Mr,Xi=v(()=>{"use strict";Ze();Vi();ae();ne();Ir=X(require("openai"),1);Nd="gpt-5.4",Dd={type:"computer"},Mr=4});function Cr(e){let t=j(),i=t.env?.OPENAI_API_KEY;if(i){let n=t.env?.OPENAI_BASE_URL;return u.debug(`Using OpenAI provider: model=${e}${n?`, baseURL=${n}`:""}`),(0,ka.createOpenAI)({apiKey:i,baseURL:n})(e)}let a=t.env?.SHIPLIGHT_API_TOKEN;if(a){let n=fr(a,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${n}`),(0,ka.createOpenAI)({apiKey:a,baseURL:n})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function Or(e){return{}}var ka,Et=v(()=>{"use strict";He();R();ne();ka=require("@ai-sdk/openai")});function Rd(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Fd(){return Rd(j().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function Nr(e){let t=j();if(Fd()){let n=t.env?.GOOGLE_CLOUD_PROJECT,o=t.env?.GOOGLE_CLOUD_LOCATION;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!o)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=${n}, location=${o}`),(0,Lr.createVertexAnthropic)({project:n,location:o})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return u.debug(`Using Anthropic provider: model=${e}`),(0,Sa.createAnthropic)({apiKey:i})(e);let a=t.env?.SHIPLIGHT_API_TOKEN;if(a){let n=wr(a,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${n}`),(0,Sa.createAnthropic)({apiKey:a,baseURL:n})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function Ea(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var Sa,Lr,Tt=v(()=>{"use strict";He();R();ne();Sa=require("@ai-sdk/anthropic"),Lr=require("@ai-sdk/google-vertex/anthropic")});function Rr(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(Hd.test(e))return"openai"}function Yi(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(Wd.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function Ee(e){let{provider:t,modelId:i}=Yi(e),a=t??Rr(i);if(!a)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., "${a}:gpt-5.4-mini").`);let n=Dr[a];if(!n)throw new Error(`Provider "${a}" is not yet implemented. Supported providers: ${Object.keys(Dr).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return n(i)}function Te(e,t){let{provider:i,modelId:a}=Yi(e),n=i??Rr(a);return n==="anthropic"||n==="vertex"?Ea(a):n==="openai"||n==="azure"?Or(a):n==="bedrock"?a.startsWith("anthropic.")?Ea(a):{}:kr(t,a)}var Hd,Wd,Dr,Ae=v(()=>{"use strict";Qe();Et();Tt();Hd=/^(gpt-|o\d|chatgpt-)/;Wd=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);Dr={anthropic:Nr,google:_r,openai:Cr}});function Bd(e){return e.startsWith("gemini-")?"google":"openai"}async function tt(e,t,i={}){let{page:a}=t,n=a.viewportSize();if(!n)return{status:"error",error:"Viewport size not available"};let{width:o,height:r}=n;w.log(`Viewport: ${o}x${r}`);let s=await St(a,o,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:c}=Yi(l),d=Bd(c),h=Ud[d];w.log(`Using CUA provider: ${d} (model: ${c})`);let m={statement:e,page:a,screenshotB64:s,viewportWidth:o,viewportHeight:r,modelId:c};try{return await h(m)}catch(g){return w.error(`CUA provider "${d}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var Ud,it=v(()=>{"use strict";zi();Xi();Ze();ae();Ae();Ud={google:Er,openai:Pr}});function Ji(e){let t=(0,Fr.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 At(t),t}function At(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))At(i)}e.type==="array"&&e.items&&At(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(At);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&At(i)}}var Fr,$t=v(()=>{"use strict";Fr=require("zod-to-json-schema")});var Ta,qi=v(()=>{"use strict";$t();Ta=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:Ji(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:Ji(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:Ji(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});function Gd(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 a=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,n=[],o=0,r;for(;(r=a.exec(e))!==null;){let l=e.slice(o,r.index);l&&n.push({type:"text",text:l});let c=r[2];i.has(c)?n.push({type:"image",image:new URL(i.get(c))}):n.push({type:"text",text:r[0]}),o=r.index+r[0].length}let s=e.slice(o);return s&&n.push({type:"text",text:s}),n.length===0&&n.push({type:"text",text:e}),n}function jd(e){let t=[];for(let i of e){let a=i.content||"",n=i.images||[],o=Gd(a,n);t.length>0&&o.length>0&&t.push({type:"text",text:`
|
|
15
15
|
|
|
16
16
|
`}),t.push(...o)}return t}function Zi(e,t=Hr){if(t){let i=jd(e);if(i.length===0)return[];let a={type:"text",text:`
|
|
17
17
|
|
|
@@ -137,10 +137,10 @@ Based on the above information, please determine the right action to accomplish
|
|
|
137
137
|
`):"";return{currentTabText:i!==null?`Current tab: ${i}
|
|
138
138
|
`:"",tabsText:n}}async function Xd(e,t){let{currentTabText:i,tabsText:a}=await Vd(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:a}}async function en(e,t){let{page:i,domService:a,agentServices:n}=e,o=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=n.getInteractiveClassNames(),s=n.getIframeFallbackDomains(),{domState:l,screenshotBase64:c,slicedScreenshotsBase64:d}=await a.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:s,useCleanScreenshot:o.useCleanScreenshot,useSlicedScreenshots:o.useSlicedScreenshots,resizeSlicedScreenshots:o.resizeSlicedScreenshots,useAccessibilityTree:o.useAccessibilityTree,actionIntent:o.actionIntent}),h=l.elementTree.clickableElementsToString(),m=await Xd(i,h);return d&&(m.slicedScreenshotsBase64=d),{domTree:h,screenshotBase64:c,slicedScreenshotsBase64:d,domState:l,pageContext:m}}var It=v(()=>{"use strict"});function tn(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 Pt=v(()=>{"use strict"});var ce,Aa,H,$e=v(()=>{"use strict";ce=require("zod"),Aa=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 a=this.tools.get(e);if(!a)throw new Error(`Tool not found: ${e}`);try{let n=t?.description,o={...t};delete o.description;let r=a.schema.parse(o),s={...i,actionDescription:n};return await a.execute(r,s)}catch(n){if(n instanceof ce.z.ZodError){let o=n.issues.map(r=>`${r.path.join(".")}: ${r.message}`).join(", ");return{success:!1,error:`Invalid arguments for tool '${e}': ${o}`,actionEntity:{action_description:t?.description||`${e} (validation failed)`,action_data:{action_name:e,kwargs:t},feedback:`Validation error: ${o}`}}}throw n}}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),a=this.getTools().filter(n=>i.has(n.name));return this.buildUnionSchemaFromTools(a,t)}buildUnionSchemaFromTools(e,t=!1){if(e.length===0)return ce.z.object({done:ce.z.any()});let i=e.map(r=>{let s=r.schema;if(t&&s instanceof ce.z.ZodObject){let l=s._def.shape();s=ce.z.object({...l,description:ce.z.string().describe("Semantic, human-readable description of the action")})}if(s instanceof ce.z.ZodObject){let l=s._def.shape();Object.keys(l).length===0&&(s=ce.z.object({_empty:ce.z.boolean().optional()}))}return ce.z.object({[r.name]:s})});if(i.length===1)return i[0];let[a,n,...o]=i;return ce.z.union([a,n,...o])}},H=new Aa});async function W(e,t){if(t<0)return;let{page:i,domService:a}=e;return(e.domState||await a.getClickableElements(i)).selectorMap.get(t)}function Yd(e){let t=e.split("/").filter(n=>n);if(t.length===0)return"*";let i=t[t.length-1],a=i.match(/^(\w+)(?:\[(\d+)\])?$/);if(a){let[,n,o]=a;return o?`${n}:nth-of-type(${o})`:n}return i}function Jd(e,t=!0){try{let i=Yd(e.xpath);if(e.attributes.class&&t){let n=/^[a-zA-Z_][a-zA-Z0-9_-]*$/,o=e.attributes.class.split(/\s+/);for(let r of o)r.trim()&&n.test(r)&&(i+=`.${r}`)}let a=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(n=>a.add(n));for(let[n,o]of Object.entries(e.attributes)){if(n==="class"||!n.trim()||!a.has(n))continue;let r=n.replace(/:/g,"\\:");if(o==="")i+=`[${r}]`;else if(/["'<>`\n\r\t]/.test(o)){let s=o;o.includes(`
|
|
139
139
|
`)&&(s=o.split(`
|
|
140
|
-
`)[0]),s=s.replace(/\s+/g," ").trim();let l=s.replace(/"/g,'\\"');i+=`[${r}*="${l}"]`}else i+=`[${r}="${o}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function qd(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 Jd(e,!1)}function Gr(e){let t=[],i=e;for(;i&&i.parent!==null;){let o=i.parent;t.push(o),i=o}t.reverse();let a=[],n=t.filter(o=>o.tagName==="iframe");for(let o of n){let r=qd(o);u.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),a.push(r)}return a}async function N(e,t){let i=null,a=Gr(t);return t.xpath&&(i=await
|
|
140
|
+
`)[0]),s=s.replace(/\s+/g," ").trim();let l=s.replace(/"/g,'\\"');i+=`[${r}*="${l}"]`}else i+=`[${r}="${o}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function qd(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 Jd(e,!1)}function Gr(e){let t=[],i=e;for(;i&&i.parent!==null;){let o=i.parent;t.push(o),i=o}t.reverse();let a=[],n=t.filter(o=>o.tagName==="iframe");for(let o of n){let r=qd(o);u.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),a.push(r)}return a}async function N(e,t){let i=null,a=Gr(t);return t.xpath&&(i=await xa(e,t.xpath,a,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:a}}var K=v(()=>{"use strict";Ge();R()});function Zd(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 Qd(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 eu(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let a=i.image,n=Qd(a);if(n)return{type:"image",file:n};let o=typeof a=="string"?a:"";return{type:"image",file:o.startsWith("data:")?o:`data:image/png;base64,${o}`}}return{type:"text",text:i.text}}):t.content}))}async function jr(e,t,i={}){let{page:a,agentServices:n}=t,o=n.getModel(),r=i.temperature??0,s=n.retrieveKnowledges(e).catch(J=>(w.log(`Failed to retrieve knowledges: ${J.message}`),[])),l=n.isSlicedScreenshotsEnabled(),c=n.isResizeSlicedScreenshotsEnabled(),d=n.isKnowledgeImagesEnabled(),h=n.isAccessibilityTreeEnabled(),m=n.isActionIntentFilteringEnabled(),g=m?Zd(e):"all";m&&g!=="all"&&w.log(`Action intent filtering: detected '${g}' intent from statement`);let{screenshotBase64:f,domState:y,pageContext:b}=await en(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:c,useAccessibilityTree:h,actionIntent:g});t.domState=y;let p=new Ta(H).getToolDefinitions().map(J=>{let Ke=J.function;return`${Ke.name}: ${Ke.description}
|
|
141
141
|
Parameters: ${JSON.stringify(Ke.parameters,null,2)}`}).join(`
|
|
142
142
|
|
|
143
|
-
`),x=Ur(p),S=await s,E=Br(b,e,t.variables,t.executionHistory,S.length>0?S:void 0,f,l,void 0,d,t.sensitiveKeys),A=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(J=>{J.role==="user"?A.push({role:"user",content:J.content}):J.role==="assistant"&&A.push({role:"assistant",content:J.content})}),A.push({role:"user",content:E});let M=eu(A),L=H.buildActionUnionSchema(),D=Ct.z.object({thought:Ct.z.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:Ct.z.string().describe("Detailed description of the action to be performed").optional().default(""),action:L,completes_instruction:Ct.z.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),C=Array.isArray(E)?E.filter(J=>J.type==="image").length:0,Y=Te(o,C),ie=await(0,nn.generateText)({model:Ee(o),system:x,messages:A,temperature:r,output:nn.Output.object({schema:D}),providerOptions:Y}),ve=ie.reasoningText;u.info(`Action Generation Reasoning: ${ve}`);let V=ie.output,q=JSON.stringify(V,null,2);u.info(`Generate Action Raw Output: ${q}`);let _e=[],We=tn(ie.usage,o);We&&_e.push(We);let Oe={systemPrompt:x,userPrompt:M,rawLlmResponse:q,tokenUsages:_e},Le=V.thought||"",Ne=V.description||"",U=V.action||{},Z=V.completes_instruction||!1;if(!U||Object.keys(U).length===0)return{status:"error",reasoning:Le||Ne||"No action generated",goalAccomplished:Z,error:"Agent did not generate any action",debugInfo:Oe};let Q=Object.keys(U)[0];if(Q==="done")return{status:"error",reasoning:Le||Ne||"Task marked as done",goalAccomplished:Z,error:"Agent indicated task is done without generating an action",debugInfo:Oe};if(Q==="perform_accurate_operation")return await tt(e,t,i);if(!Z){let J="Can't complete the instruction in one action";return{status:"error",reasoning:Le||Ne||J,goalAccomplished:!1,error:J,debugInfo:Oe}}let ue=U[Q]||{},fo={};if(typeof ue.element_index=="number"){let J=ue.element_index;if(J<0)return{status:"error",reasoning:Le||Ne||"No action generated",goalAccomplished:Z,error:"Agent did not generate any action",debugInfo:Oe};let Ke=y.selectorMap.get(J);Ke&&(fo=await N(a,Ke))}let wo=Ne;return Q==="verify"&&(wo=e,ue.statement=e),{status:"success",actionEntity:{...fo,action_description:wo||Le||`${Q}(${JSON.stringify(ue)})`,action_data:{action_name:Q,kwargs:ue}},reasoning:Le||Ne,goalAccomplished:Z,debugInfo:Oe}}var nn,Ct,an=v(()=>{"use strict";
|
|
143
|
+
`),x=Ur(p),S=await s,E=Br(b,e,t.variables,t.executionHistory,S.length>0?S:void 0,f,l,void 0,d,t.sensitiveKeys),A=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(J=>{J.role==="user"?A.push({role:"user",content:J.content}):J.role==="assistant"&&A.push({role:"assistant",content:J.content})}),A.push({role:"user",content:E});let M=eu(A),L=H.buildActionUnionSchema(),D=Ct.z.object({thought:Ct.z.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:Ct.z.string().describe("Detailed description of the action to be performed").optional().default(""),action:L,completes_instruction:Ct.z.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),C=Array.isArray(E)?E.filter(J=>J.type==="image").length:0,Y=Te(o,C),ie=await(0,nn.generateText)({model:Ee(o),system:x,messages:A,temperature:r,output:nn.Output.object({schema:D}),providerOptions:Y}),ve=ie.reasoningText;u.info(`Action Generation Reasoning: ${ve}`);let V=ie.output,q=JSON.stringify(V,null,2);u.info(`Generate Action Raw Output: ${q}`);let _e=[],We=tn(ie.usage,o);We&&_e.push(We);let Oe={systemPrompt:x,userPrompt:M,rawLlmResponse:q,tokenUsages:_e},Le=V.thought||"",Ne=V.description||"",U=V.action||{},Z=V.completes_instruction||!1;if(!U||Object.keys(U).length===0)return{status:"error",reasoning:Le||Ne||"No action generated",goalAccomplished:Z,error:"Agent did not generate any action",debugInfo:Oe};let Q=Object.keys(U)[0];if(Q==="done")return{status:"error",reasoning:Le||Ne||"Task marked as done",goalAccomplished:Z,error:"Agent indicated task is done without generating an action",debugInfo:Oe};if(Q==="perform_accurate_operation")return await tt(e,t,i);if(!Z){let J="Can't complete the instruction in one action";return{status:"error",reasoning:Le||Ne||J,goalAccomplished:!1,error:J,debugInfo:Oe}}let ue=U[Q]||{},fo={};if(typeof ue.element_index=="number"){let J=ue.element_index;if(J<0)return{status:"error",reasoning:Le||Ne||"No action generated",goalAccomplished:Z,error:"Agent did not generate any action",debugInfo:Oe};let Ke=y.selectorMap.get(J);Ke&&(fo=await N(a,Ke))}let wo=Ne;return Q==="verify"&&(wo=e,ue.statement=e),{status:"success",actionEntity:{...fo,action_description:wo||Le||`${Q}(${JSON.stringify(ue)})`,action_data:{action_name:Q,kwargs:ue}},reasoning:Le||Ne,goalAccomplished:Z,debugInfo:Oe}}var nn,Ct,an=v(()=>{"use strict";it();qi();Qi();It();Pt();$e();ae();Ae();K();R();nn=require("ai"),Ct=require("zod")});function tu(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 $a(e,t,i={}){return i.usePureVision?tt(e,t,i):jr(e,t,i)}function nu(){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 au(){return`# Role
|
|
144
144
|
You are an experienced QA person for web applications.
|
|
145
145
|
You are tasked to verify the validity of a given statement based on the screenshot and element tree of a web page.
|
|
146
146
|
`}async function Kr(e,t,i={}){let{page:a,executionHistory:n}=t,o=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),s=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),c=t.agentServices.isAccessibilityTreeEnabled(),{domTree:d,screenshotBase64:h,slicedScreenshotsBase64:m,domState:g,pageContext:f}=await en(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:s,useAccessibilityTree:c});t.domState=g;let y="";n&&n.length>0&&(y=`
|
|
@@ -4082,7 +4082,7 @@ Based on the above information, please determine if the statement is true.
|
|
|
4082
4082
|
} : null,
|
|
4083
4083
|
clientRects: clientRectsArray
|
|
4084
4084
|
};
|
|
4085
|
-
}`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){u.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=Oa){let i=[];try{let{root:a}=await e.send("DOM.getDocument",{depth:0}),n=Ca.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:a.nodeId,selector:n});u.debug(`\u{1F50D} Checking ${Math.min(o.length,t)} elements for event listeners`);for(let r of o.slice(0,t))try{let{object:s}=await e.send("DOM.resolveNode",{nodeId:r});if(!s.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:s.objectId}),c=l.filter(d=>Pa.has(d.type));if(c.length>0){let{node:d}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:d.backendNodeId,eventTypes:c.map(h=>h.type)})}await e.send("Runtime.releaseObject",{objectId:s.objectId})}catch{}u.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(a){u.warn("Failed to get elements with event listeners:",a)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new Me("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),a=0;for(let n of e){let o=n.axNode.role?.value||"",r=n.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(o),l=new Me(n.tagName,n.xpath,n.attributes,[],n.isVisible,!0,o==="scrollbar",s,n.isTopElement,n.isInViewport,!1,a,n.boundingRect?{topLeft:{x:n.boundingRect.x,y:n.boundingRect.y},topRight:{x:n.boundingRect.x+n.boundingRect.width,y:n.boundingRect.y},bottomLeft:{x:n.boundingRect.x,y:n.boundingRect.y+n.boundingRect.height},bottomRight:{x:n.boundingRect.x+n.boundingRect.width,y:n.boundingRect.y+n.boundingRect.height},center:{x:n.boundingRect.x+n.boundingRect.width/2,y:n.boundingRect.y+n.boundingRect.height/2},width:n.boundingRect.width,height:n.boundingRect.height}:null,null,null,[],i);if(r){let c=new Ft(r,!0,l);l.children.push(c)}i.children.push(l),t.set(a,l),a++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:a}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:a,colors:n})=>{let o="playwright-highlight-container",r=document.getElementById(o);r||(r=document.createElement("div"),r.id=o,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),a.forEach((s,l)=>{if(!s.boundingRect)return;let c=n[l%n.length],d=s.boundingRect,h=document.createElement("div");h.style.position="fixed",h.style.border=`1px solid ${c}`,h.style.backgroundColor="transparent",h.style.pointerEvents="none",h.style.boxSizing="border-box",h.style.top=`${d.y}px`,h.style.left=`${d.x}px`,h.style.width=`${d.width}px`,h.style.height=`${d.height}px`,r.appendChild(h);let m=document.createElement("div");m.style.position="fixed",m.style.background=c,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,d.y-16),f=Math.max(0,Math.min(d.x+d.width-20,window.innerWidth-25));m.style.top=`${g}px`,m.style.left=`${f}px`,r.appendChild(m)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let a=document.getElementById("playwright-highlight-container");a&&a.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(n=>n()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),u.debug("\u2705 Highlights removed from page")}catch(a){u.warn("Failed to remove highlights:",a.message)}for(let a of e.frames()){let n=a.url();if(!(!n.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(n,t)))try{await a.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(s=>s.map(l=>l.src)),i=s=>{try{let l=new URL(s);return["doubleclick.net","adroll.com","googletagmanager.com"].some(c=>l.hostname.includes(c))}catch{return!1}},a=e.url(),n=new URL(a).hostname,o=e.frames(),r=[];for(let s of o){let l=s.url();try{let c=new URL(l).hostname;c&&c!==n&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,a,n,o,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(su(e.url()))return[new Me("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let c={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:a,debugMode:!1,interactiveClassNames:n,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};u.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let d,h=null;if(this.useDomTreeTs&&t)try{let b={...c,phase:"boxes",grayscaleImage:null},p=await e.evaluate(({code:L,argsObj:D})=>new Function("return "+L)()(D),{code:this.jsCode,argsObj:b});u.debug(`\u{1F4E6} Phase 1: Drew ${p.elementData?.length||0} bounding boxes`);let x=await e.screenshot({type:"png",fullPage:!1});u.debug("\u{1F4F8} Captured screenshot with bounding boxes");let S=performance.now(),E=await Xr(x);h=E.pixels;let A=Math.round(performance.now()-S);u.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${E.width}x${E.height}) in ${A}ms`);let M={...c,phase:"labels",grayscaleImage:h,elementData:p.elementData};d=await e.evaluate(({code:L,argsObj:D})=>new Function("return "+L)()(D),{code:this.jsCode,argsObj:M}),d.map=p.map,d.rootId=p.rootId,d.highlightCount=p.highlightCount,d.perfMetrics=p.perfMetrics,u.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(b){u.warn("Two-phase rendering failed, falling back to legacy mode:",b.message),h=null;let p={...c,grayscaleImage:null};d=await e.evaluate(({code:x,argsObj:S})=>new Function("return "+x)()(S),{code:this.jsCode,argsObj:p}),u.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{d=await e.evaluate(({code:b,argsObj:p})=>new Function("return "+b)()(p),{code:this.jsCode,argsObj:c}),u.debug("\u2705 JavaScript DOM analysis completed")}catch(b){throw u.error("Error evaluating JavaScript:",b.message),b}if(!d||typeof d!="object")throw u.error("JavaScript returned invalid result:",d),new Error("JavaScript DOM analysis returned invalid result");if(!d.map||!d.rootId)throw u.error("JavaScript result missing map or rootId:",JSON.stringify(d,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&d.highlightCount===0){u.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let b={...c,actionIntent:"all"};d=await e.evaluate(({code:p,argsObj:x})=>new Function("return "+p)()(x),{code:this.jsCode,argsObj:b})}let m=Object.entries(d.map).filter(([,b])=>b.tagName==="iframe");u.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${m.length}`);for(let[b,p]of m){let x=p;u.debug(`\u{1F50D} [ext-iframe] iframe node id=${b} src=${x.attributes?.src} inaccessibleFrame=${x.inaccessibleFrame}`)}let g=e.frames();u.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let b of g)u.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${b.url()}`);let f=[];for(let[b,p]of Object.entries(d.map)){let x=p;this.shouldProcessWithPlaywrightFrameFallback(x,o)&&f.push({nodeId:b,src:x.attributes.src})}if(u.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${f.length}`),f.length>0){u.debug(`\u{1F50C} Found ${f.length} inaccessible iframe(s) for Playwright fallback, processing`);let b=-1;for(let p of Object.values(d.map)){let x=p;x.highlightIndex!=null&&(b=Math.max(b,x.highlightIndex))}u.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${b}`);for(let p=0;p<f.length;p++){let{nodeId:x,src:S}=f[p];u.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${p}]: ${S}`);let E=D=>{try{let C=new URL(D);if(C.protocol==="chrome-extension:"&&C.hostname)return`chrome-extension://${C.hostname}`;let Y=C.origin;return Y==="null"?null:Y}catch{return null}},A=E(S);u.debug(`\u{1F50D} [ext-iframe] iframe src origin=${A??"null"}`);let M=null,L=e.frames().find(D=>{let C=D.url();if(C===S)return M="exact",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${C}`),!0;let Y=E(C);return u.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${C} origin=${Y??"null"} vs srcOrigin=${A??"null"}`),A&&Y===A?(M="origin",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${C}`),!0):!1});if(!L){u.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${S}`),u.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(D=>D.url()).join(", ")}`);continue}u.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${S} (frame url: ${L.url()})`);try{let D={...c,initialHighlightIndex:b+1,domTreeRoot:"body"};u.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${D.initialHighlightIndex}`);let C=await L.evaluate(({code:V,argsObj:q})=>new Function("return "+V)()(q),{code:this.jsCode,argsObj:D});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 Y=Object.values(C.map).filter(V=>V.highlightIndex!=null);u.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${Y.length}`);for(let V of Y){let q=V;u.debug(`\u{1F50D} [ext-iframe] - <${q.tagName}> highlightIndex=${q.highlightIndex} text="${q.children?.length?"...":""}"`)}for(let V of Object.values(C.map)){let q=V;q.highlightIndex!=null&&(b=Math.max(b,q.highlightIndex))}let ie=`ext_${p}_`;for(let[V,q]of Object.entries(C.map)){let _e={...q};_e.children&&(_e.children=_e.children.map(We=>`${ie}${We}`)),d.map[`${ie}${V}`]=_e}let ve=d.map[x];ve?(ve.children=[...ve.children||[],`${ie}${C.rootId}`],u.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${x}`)):u.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${x} not found in map`),u.debug(`\u2705 Merged fallback iframe content from: ${S}`)}catch(D){u.warn(`Failed to process fallback iframe ${S}:`,D)}}}if(d&&d.perfMetrics){let b=d.perfMetrics.nodeMetrics?.totalNodes??0,p=0;if(d.map)for(let S of Object.values(d.map))typeof S=="object"&&S!==null&&S.isInteractive&&p++;let x=e.url().length>50?e.url().slice(0,50)+"...":e.url();u.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${x} interactive=${p}/${b}`)}u.debug("\u{1F504} Starting TypeScript DOM tree construction...");let y=await this.constructDomTree(d);return u.debug("\u2705 TypeScript DOM tree construction completed"),y}async constructDomTree(e){let t=e.map,i=e.rootId,a=new Map,n=new Map,o=new Map;for(let[s,l]of Object.entries(t)){let[c,d]=this.parseNode(l);c!==null&&(n.set(s,c),o.set(s,d),c instanceof Me&&c.highlightIndex!==null&&a.set(c.highlightIndex,c))}for(let[s,l]of o){let c=n.get(s);if(c instanceof Me)for(let d of l){let h=n.get(d);h&&(h.parent=c,c.children.push(h))}}let r=n.get(i);if(!r||!(r instanceof Me))throw new Error("Failed to parse HTML to dictionary");return[r,a]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new Ft(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??[],a=new Me(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),n=e.children||[];return[a,n]}}});var Qr,es,Dw,ln=v(()=>{"use strict";Qr=require("zod"),es=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Dw=Qr.z.object({})});var ts,cn=v(()=>{"use strict";F();I();ts=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.keys;if(!n||typeof n!="string")throw new Error("Missing or invalid keys for send keys on element action");let o=O(e,t),r=P(i,t.action_data?.kwargs?.timeout_ms);if(o)await o.press(n,{timeout:r}),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 n=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(n)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",a=P();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${a} });`]}}});var lu,is,at,Ht=v(()=>{"use strict";ge();lu=X(require("playwright/test"),1),is=X(require("playwright/test"),1),at={};Ui(at,{default:()=>is.default});gr(at,lu)});var La,ns,Kw,dn=v(()=>{"use strict";Ht();La=require("zod"),ns=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.code;if(!n)throw new Error("Missing code for js_code action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","expect","agent",`
|
|
4085
|
+
}`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){u.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=Oa){let i=[];try{let{root:a}=await e.send("DOM.getDocument",{depth:0}),n=Ca.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:a.nodeId,selector:n});u.debug(`\u{1F50D} Checking ${Math.min(o.length,t)} elements for event listeners`);for(let r of o.slice(0,t))try{let{object:s}=await e.send("DOM.resolveNode",{nodeId:r});if(!s.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:s.objectId}),c=l.filter(d=>Pa.has(d.type));if(c.length>0){let{node:d}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:d.backendNodeId,eventTypes:c.map(h=>h.type)})}await e.send("Runtime.releaseObject",{objectId:s.objectId})}catch{}u.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(a){u.warn("Failed to get elements with event listeners:",a)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new Me("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),a=0;for(let n of e){let o=n.axNode.role?.value||"",r=n.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(o),l=new Me(n.tagName,n.xpath,n.attributes,[],n.isVisible,!0,o==="scrollbar",s,n.isTopElement,n.isInViewport,!1,a,n.boundingRect?{topLeft:{x:n.boundingRect.x,y:n.boundingRect.y},topRight:{x:n.boundingRect.x+n.boundingRect.width,y:n.boundingRect.y},bottomLeft:{x:n.boundingRect.x,y:n.boundingRect.y+n.boundingRect.height},bottomRight:{x:n.boundingRect.x+n.boundingRect.width,y:n.boundingRect.y+n.boundingRect.height},center:{x:n.boundingRect.x+n.boundingRect.width/2,y:n.boundingRect.y+n.boundingRect.height/2},width:n.boundingRect.width,height:n.boundingRect.height}:null,null,null,[],i);if(r){let c=new Ft(r,!0,l);l.children.push(c)}i.children.push(l),t.set(a,l),a++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:a}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:a,colors:n})=>{let o="playwright-highlight-container",r=document.getElementById(o);r||(r=document.createElement("div"),r.id=o,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),a.forEach((s,l)=>{if(!s.boundingRect)return;let c=n[l%n.length],d=s.boundingRect,h=document.createElement("div");h.style.position="fixed",h.style.border=`1px solid ${c}`,h.style.backgroundColor="transparent",h.style.pointerEvents="none",h.style.boxSizing="border-box",h.style.top=`${d.y}px`,h.style.left=`${d.x}px`,h.style.width=`${d.width}px`,h.style.height=`${d.height}px`,r.appendChild(h);let m=document.createElement("div");m.style.position="fixed",m.style.background=c,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,d.y-16),f=Math.max(0,Math.min(d.x+d.width-20,window.innerWidth-25));m.style.top=`${g}px`,m.style.left=`${f}px`,r.appendChild(m)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let a=document.getElementById("playwright-highlight-container");a&&a.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(n=>n()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),u.debug("\u2705 Highlights removed from page")}catch(a){u.warn("Failed to remove highlights:",a.message)}for(let a of e.frames()){let n=a.url();if(!(!n.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(n,t)))try{await a.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(s=>s.map(l=>l.src)),i=s=>{try{let l=new URL(s);return["doubleclick.net","adroll.com","googletagmanager.com"].some(c=>l.hostname.includes(c))}catch{return!1}},a=e.url(),n=new URL(a).hostname,o=e.frames(),r=[];for(let s of o){let l=s.url();try{let c=new URL(l).hostname;c&&c!==n&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,a,n,o,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(su(e.url()))return[new Me("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let c={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:a,debugMode:!1,interactiveClassNames:n,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};u.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let d,h=null;if(this.useDomTreeTs&&t)try{let b={...c,phase:"boxes",grayscaleImage:null},p=await e.evaluate(({code:L,argsObj:D})=>new Function("return "+L)()(D),{code:this.jsCode,argsObj:b});u.debug(`\u{1F4E6} Phase 1: Drew ${p.elementData?.length||0} bounding boxes`);let x=await e.screenshot({type:"png",fullPage:!1});u.debug("\u{1F4F8} Captured screenshot with bounding boxes");let S=performance.now(),E=await Xr(x);h=E.pixels;let A=Math.round(performance.now()-S);u.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${E.width}x${E.height}) in ${A}ms`);let M={...c,phase:"labels",grayscaleImage:h,elementData:p.elementData};d=await e.evaluate(({code:L,argsObj:D})=>new Function("return "+L)()(D),{code:this.jsCode,argsObj:M}),d.map=p.map,d.rootId=p.rootId,d.highlightCount=p.highlightCount,d.perfMetrics=p.perfMetrics,u.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(b){u.warn("Two-phase rendering failed, falling back to legacy mode:",b.message),h=null;let p={...c,grayscaleImage:null};d=await e.evaluate(({code:x,argsObj:S})=>new Function("return "+x)()(S),{code:this.jsCode,argsObj:p}),u.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{d=await e.evaluate(({code:b,argsObj:p})=>new Function("return "+b)()(p),{code:this.jsCode,argsObj:c}),u.debug("\u2705 JavaScript DOM analysis completed")}catch(b){throw u.error("Error evaluating JavaScript:",b.message),b}if(!d||typeof d!="object")throw u.error("JavaScript returned invalid result:",d),new Error("JavaScript DOM analysis returned invalid result");if(!d.map||!d.rootId)throw u.error("JavaScript result missing map or rootId:",JSON.stringify(d,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&d.highlightCount===0){u.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let b={...c,actionIntent:"all"};d=await e.evaluate(({code:p,argsObj:x})=>new Function("return "+p)()(x),{code:this.jsCode,argsObj:b})}let m=Object.entries(d.map).filter(([,b])=>b.tagName==="iframe");u.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${m.length}`);for(let[b,p]of m){let x=p;u.debug(`\u{1F50D} [ext-iframe] iframe node id=${b} src=${x.attributes?.src} inaccessibleFrame=${x.inaccessibleFrame}`)}let g=e.frames();u.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let b of g)u.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${b.url()}`);let f=[];for(let[b,p]of Object.entries(d.map)){let x=p;this.shouldProcessWithPlaywrightFrameFallback(x,o)&&f.push({nodeId:b,src:x.attributes.src})}if(u.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${f.length}`),f.length>0){u.debug(`\u{1F50C} Found ${f.length} inaccessible iframe(s) for Playwright fallback, processing`);let b=-1;for(let p of Object.values(d.map)){let x=p;x.highlightIndex!=null&&(b=Math.max(b,x.highlightIndex))}u.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${b}`);for(let p=0;p<f.length;p++){let{nodeId:x,src:S}=f[p];u.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${p}]: ${S}`);let E=D=>{try{let C=new URL(D);if(C.protocol==="chrome-extension:"&&C.hostname)return`chrome-extension://${C.hostname}`;let Y=C.origin;return Y==="null"?null:Y}catch{return null}},A=E(S);u.debug(`\u{1F50D} [ext-iframe] iframe src origin=${A??"null"}`);let M=null,L=e.frames().find(D=>{let C=D.url();if(C===S)return M="exact",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${C}`),!0;let Y=E(C);return u.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${C} origin=${Y??"null"} vs srcOrigin=${A??"null"}`),A&&Y===A?(M="origin",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${C}`),!0):!1});if(!L){u.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${S}`),u.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(D=>D.url()).join(", ")}`);continue}u.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${S} (frame url: ${L.url()})`);try{let D={...c,initialHighlightIndex:b+1,domTreeRoot:"body"};u.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${D.initialHighlightIndex}`);let C=await L.evaluate(({code:V,argsObj:q})=>new Function("return "+V)()(q),{code:this.jsCode,argsObj:D});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 Y=Object.values(C.map).filter(V=>V.highlightIndex!=null);u.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${Y.length}`);for(let V of Y){let q=V;u.debug(`\u{1F50D} [ext-iframe] - <${q.tagName}> highlightIndex=${q.highlightIndex} text="${q.children?.length?"...":""}"`)}for(let V of Object.values(C.map)){let q=V;q.highlightIndex!=null&&(b=Math.max(b,q.highlightIndex))}let ie=`ext_${p}_`;for(let[V,q]of Object.entries(C.map)){let _e={...q};_e.children&&(_e.children=_e.children.map(We=>`${ie}${We}`)),d.map[`${ie}${V}`]=_e}let ve=d.map[x];ve?(ve.children=[...ve.children||[],`${ie}${C.rootId}`],u.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${x}`)):u.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${x} not found in map`),u.debug(`\u2705 Merged fallback iframe content from: ${S}`)}catch(D){u.warn(`Failed to process fallback iframe ${S}:`,D)}}}if(d&&d.perfMetrics){let b=d.perfMetrics.nodeMetrics?.totalNodes??0,p=0;if(d.map)for(let S of Object.values(d.map))typeof S=="object"&&S!==null&&S.isInteractive&&p++;let x=e.url().length>50?e.url().slice(0,50)+"...":e.url();u.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${x} interactive=${p}/${b}`)}u.debug("\u{1F504} Starting TypeScript DOM tree construction...");let y=await this.constructDomTree(d);return u.debug("\u2705 TypeScript DOM tree construction completed"),y}async constructDomTree(e){let t=e.map,i=e.rootId,a=new Map,n=new Map,o=new Map;for(let[s,l]of Object.entries(t)){let[c,d]=this.parseNode(l);c!==null&&(n.set(s,c),o.set(s,d),c instanceof Me&&c.highlightIndex!==null&&a.set(c.highlightIndex,c))}for(let[s,l]of o){let c=n.get(s);if(c instanceof Me)for(let d of l){let h=n.get(d);h&&(h.parent=c,c.children.push(h))}}let r=n.get(i);if(!r||!(r instanceof Me))throw new Error("Failed to parse HTML to dictionary");return[r,a]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new Ft(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??[],a=new Me(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),n=e.children||[];return[a,n]}}});var Qr,es,Dw,ln=v(()=>{"use strict";Qr=require("zod"),es=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Dw=Qr.z.object({})});var ts,cn=v(()=>{"use strict";F();I();ts=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.keys;if(!n||typeof n!="string")throw new Error("Missing or invalid keys for send keys on element action");let o=O(e,t),r=P(i,t.action_data?.kwargs?.timeout_ms);if(o)await o.press(n,{timeout:r}),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 n=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(n)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",a=P();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${a} });`]}}});var lu,is,at,Ht=v(()=>{"use strict";ge();lu=X(require("playwright/test"),1),is=X(require("playwright/test"),1),at={};Hi(at,{default:()=>is.default});mr(at,lu)});var La,ns,Kw,dn=v(()=>{"use strict";Ht();La=require("zod"),ns=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.code;if(!n)throw new Error("Missing code for js_code action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","expect","agent",`
|
|
4086
4086
|
return (async () => {
|
|
4087
4087
|
${n}
|
|
4088
4088
|
})();
|
|
@@ -4096,7 +4096,7 @@ Based on the above information, please determine if the statement is true.
|
|
|
4096
4096
|
${n}
|
|
4097
4097
|
})();
|
|
4098
4098
|
`)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
|
|
4099
|
-
`):["// Skipping js_action: missing code"]}}});var ss,mn=v(()=>{"use strict";F();I();ss=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");if(typeof a.kwargs.relative_x=="number"&&typeof a.kwargs.relative_y=="number"){let n=O(e,t);if(n){await n.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await n.boundingBox();if(o){let r=o.x+a.kwargs.relative_x+o.width/2,s=o.y+a.kwargs.relative_y+o.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s),await e.waitForTimeout(500)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof a.kwargs.x=="number"&&typeof a.kwargs.y=="number")await e.mouse.move(a.kwargs.x,a.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(a.kwargs.x,a.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(a=>` ${a},`),"});"]}}});var ls,gn=v(()=>{"use strict";F();I();ls=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");if(typeof a.kwargs.relative_x=="number"&&typeof a.kwargs.relative_y=="number"){let n=O(e,t);if(n){await n.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await n.boundingBox();if(o){let r=o.x+a.kwargs.relative_x+o.width/2,s=o.y+a.kwargs.relative_y+o.height/2;await e.mouse.dblclick(r,s,{delay:50}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof a.kwargs.x=="number"&&typeof a.kwargs.y=="number")await e.mouse.dblclick(a.kwargs.x,a.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(a=>` ${a},`),"});"]}}});var cs,fn=v(()=>{"use strict";F();I();cs=class{async execute(e,t,i){let a=i.getActionSettings().drag_drop_steps??10,n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs,r=[o.coord_source_x,o.coord_source_y],s=[o.coord_target_x,o.coord_target_y];if(typeof o.relative_x=="number"&&typeof o.relative_y=="number"&&typeof o.delta_x=="number"&&typeof o.delta_y=="number"){let l=O(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let c=await(await l).boundingBox();if(!c)throw new Error("Could not get bounding box for drag_drop element");let d=c.x+o.relative_x+c.width/2,h=c.y+o.relative_y+c.height/2,m=d+o.delta_x,g=h+o.delta_y;await e.mouse.move(d,h),await e.mouse.down(),a>0?await e.mouse.move(m,g,{steps:a}):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,c]=r,[d,h]=s;await e.mouse.move(l,c),await e.mouse.down(),a>0?await e.mouse.move(d,h,{steps:a}):await e.mouse.move(d,h),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],a={};return typeof t.relative_x=="number"&&(a.relative_x=t.relative_x),typeof t.relative_y=="number"&&(a.relative_y=t.relative_y),typeof t.delta_x=="number"&&(a.delta_x=t.delta_x),typeof t.delta_y=="number"&&(a.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(a.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(a.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(a.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(a.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(a)} }`),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(n=>` ${n},`),"});"]}}});var wn=v(()=>{"use strict";nt()});var ds,ot=v(()=>{"use strict";ds=(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))(ds||{})});var rt={};ze(rt,{evaluateStatement:()=>ct,executeAction:()=>Wt,executeStep:()=>lt,generateActionStep:()=>Ut,runTask:()=>dt});var st=v(()=>{"use strict";Bt();rn();an();Hi();it();Xi();Ji();Ze();Yi();Qi();It();Pt();$e();St();Mt();wn();je();Lt();Nt();nt();Dt();Rt();ae();Ae();At();Qe();$t();He();K();Ge();R();ne();ot();F();ge()});var Na,us,Xb,bn=v(()=>{"use strict";Na=require("zod"),us=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.statement;if(!n)throw new Error("Missing statement for ai_action");let o=a.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(st(),rt)),s=await r(n,e,i,{usePureVision:o});if(s.status!=="success")throw new Error(s.error||"Action execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let a=JSON.stringify(i),n=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${a}, '${t||""}', ${n});`]}},Xb=Na.z.object({statement:Na.z.string().describe('The action to perform (e.g., "click the submit button")')})});var Da,hs,qb,yn=v(()=>{"use strict";Da=require("zod"),hs=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.statement;if(!n)throw new Error("Missing statement for ai_step");let{runTask:o}=await Promise.resolve().then(()=>(st(),rt)),r=await o(n,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"]}},qb=Da.z.object({statement:Da.z.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});function ms(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:cu,async execute(i,a){let{timeout_seconds:n=10}=i,{page:o,agentServices:r}=a;try{let s={action_description:`Wait for download to complete (timeout: ${n}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:n}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:"Download completed"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:n}},feedback:s.message}}}}})}var Ra,ps,cu,Gt=v(()=>{"use strict";Ra=require("zod"),ps=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,n)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},cu=Ra.z.object({timeout_seconds:Ra.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function fs(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:du,async execute(i,a){let{condition:n,timeout_seconds:o=60}=i,{page:r,agentServices:s}=a;try{let l={action_description:`Wait until: ${n}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:n,timeout_seconds:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Condition met: ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${n} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:n,timeout_seconds:o}},feedback:l.message}}}}})}var xn,gs,du,jt=v(()=>{"use strict";xn=require("zod"),gs=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.condition;if(!n)throw new Error("Missing condition for ai_wait_until");let o=(a.kwargs.timeout_seconds||60)*1e3,r=5e3,s=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(st(),rt));for(;Date.now()-s<o;){if((await l(n,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${n}`)}transpile(e,t){let i=e.action_data?.kwargs?.condition,a=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${a}, '${t}');`]:["// Skipping ai_wait_until: missing condition"]}},du=xn.z.object({condition:xn.z.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:xn.z.number().positive().optional().describe("Timeout in seconds (default: 60)")})});async function uu(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function ws(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function ys(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:hu,usesElementIndex:!0,async execute(i,a){let{element_index:n,delta_x:o,delta_y:r}=i,{page:s,agentServices:l}=a;try{let c=await W(a,n);if(!c)return{success:!1,error:`Element with index ${n} not found`,actionEntity:ws(`Scroll on element ${n} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:n,delta_x:o,delta_y:r})};let d=await uu("scroll_on_element",`Scroll on element ${n} horizontally: ${o}px, vertically: ${r}px`,c,s,{delta_x:o,delta_y:r});return await t.execute(s,d,l),{success:!0,actionEntity:d,message:`Scrolled on element ${n} horizontally: ${o}px, vertically: ${r}px`}}catch(c){return{success:!1,error:c.message,actionEntity:ws(`Scroll on element ${n} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:n,delta_x:o,delta_y:r})}}}})}var ut,bs,hu,Kt=v(()=>{"use strict";K();F();ut=require("zod");I();bs=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.delta_x||0,o=a.kwargs.delta_y||0,r=O(e,t),s=P(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(n,o);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Fe(e);if(!t){let n=e.action_data?.kwargs?.delta_x||0,o=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${n}, delta_y: ${o} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,a=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${P()} });`,`await page.mouse.wheel(${i}, ${a});`]}};hu=ut.z.object({element_index:ut.z.number().int().describe("Index of the scrollable element"),delta_x:ut.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:ut.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:ut.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function vs(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:pu,async execute(i,a){let{text:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l={action_description:s||`Scroll to text "${n}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:n}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${n}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${n}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:n}},feedback:l.message}}}}})}var Fa,xs,pu,zt=v(()=>{"use strict";Fa=require("zod"),xs=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let a=i.kwargs.text;if(a)await e.getByText(a,{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();`]}},pu=Fa.z.object({text:Fa.z.string().describe("Text to scroll to on the page")})});async function mu(e,t,i,a){return{...await N(t,e),action_description:a||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function _s(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 Ss(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:gu,usesElementIndex:!0,async execute(i,a){let{element_index:n,option:o}=i,{page:r,agentServices:s,actionDescription:l}=a;try{let c=await W(a,n);if(!c)return{success:!1,error:`Dropdown element with index ${n} not found`,actionEntity:_s(l||`Select option in dropdown ${n}`,{index:n,option:o})};let d=await mu(c,r,o,l);return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Selected option "${o}" in dropdown ${n}`}}catch(c){return{success:!1,error:c.message,actionEntity:_s(`Select option in dropdown ${n}`,{index:n,option:o})}}}})}var Vt,ks,gu,Xt=v(()=>{"use strict";K();F();Vt=require("zod");I();ks=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.text||a.kwargs.option,o=O(e,t),r=P(i,t.action_data?.kwargs?.timeout_ms);if(o&&n)await o.selectOption(n,{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(a=>` ${a},`),"});"]}};gu=Vt.z.object({element_index:Vt.z.number().int().describe("Index of the dropdown/select element"),option:Vt.z.string().describe("Option value, label, or index to select"),timeout_ms:Vt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function fu(e,t,i,a){return{...await N(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:a}}}}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 Ts(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">).
|
|
4099
|
+
`):["// Skipping js_action: missing code"]}}});var ss,mn=v(()=>{"use strict";F();I();ss=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");if(typeof a.kwargs.relative_x=="number"&&typeof a.kwargs.relative_y=="number"){let n=O(e,t);if(n){await n.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await n.boundingBox();if(o){let r=o.x+a.kwargs.relative_x+o.width/2,s=o.y+a.kwargs.relative_y+o.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s),await e.waitForTimeout(500)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof a.kwargs.x=="number"&&typeof a.kwargs.y=="number")await e.mouse.move(a.kwargs.x,a.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(a.kwargs.x,a.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(a=>` ${a},`),"});"]}}});var ls,gn=v(()=>{"use strict";F();I();ls=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");if(typeof a.kwargs.relative_x=="number"&&typeof a.kwargs.relative_y=="number"){let n=O(e,t);if(n){await n.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await n.boundingBox();if(o){let r=o.x+a.kwargs.relative_x+o.width/2,s=o.y+a.kwargs.relative_y+o.height/2;await e.mouse.dblclick(r,s,{delay:50}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof a.kwargs.x=="number"&&typeof a.kwargs.y=="number")await e.mouse.dblclick(a.kwargs.x,a.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(a=>` ${a},`),"});"]}}});var cs,fn=v(()=>{"use strict";F();I();cs=class{async execute(e,t,i){let a=i.getActionSettings().drag_drop_steps??10,n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs,r=[o.coord_source_x,o.coord_source_y],s=[o.coord_target_x,o.coord_target_y];if(typeof o.relative_x=="number"&&typeof o.relative_y=="number"&&typeof o.delta_x=="number"&&typeof o.delta_y=="number"){let l=O(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let c=await(await l).boundingBox();if(!c)throw new Error("Could not get bounding box for drag_drop element");let d=c.x+o.relative_x+c.width/2,h=c.y+o.relative_y+c.height/2,m=d+o.delta_x,g=h+o.delta_y;await e.mouse.move(d,h),await e.mouse.down(),a>0?await e.mouse.move(m,g,{steps:a}):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,c]=r,[d,h]=s;await e.mouse.move(l,c),await e.mouse.down(),a>0?await e.mouse.move(d,h,{steps:a}):await e.mouse.move(d,h),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],a={};return typeof t.relative_x=="number"&&(a.relative_x=t.relative_x),typeof t.relative_y=="number"&&(a.relative_y=t.relative_y),typeof t.delta_x=="number"&&(a.delta_x=t.delta_x),typeof t.delta_y=="number"&&(a.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(a.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(a.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(a.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(a.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(a)} }`),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(n=>` ${n},`),"});"]}}});var wn=v(()=>{"use strict";nt()});var ds,ot=v(()=>{"use strict";ds=(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))(ds||{})});var rt={};ze(rt,{evaluateStatement:()=>ct,executeAction:()=>Wt,executeStep:()=>lt,generateActionStep:()=>Ut,runTask:()=>dt});var st=v(()=>{"use strict";Bt();rn();an();it();zi();Xi();Ze();Vi();qi();Qi();It();Pt();$e();$t();Mt();wn();je();Lt();Nt();nt();Dt();Rt();ae();Ae();Qe();Et();Tt();He();K();Ge();R();ne();ot();F();ge()});var Na,us,Xb,bn=v(()=>{"use strict";Na=require("zod"),us=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.statement;if(!n)throw new Error("Missing statement for ai_action");let o=a.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(st(),rt)),s=await r(n,e,i,{usePureVision:o});if(s.status!=="success")throw new Error(s.error||"Action execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let a=JSON.stringify(i),n=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${a}, '${t||""}', ${n});`]}},Xb=Na.z.object({statement:Na.z.string().describe('The action to perform (e.g., "click the submit button")')})});var Da,hs,qb,yn=v(()=>{"use strict";Da=require("zod"),hs=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.statement;if(!n)throw new Error("Missing statement for ai_step");let{runTask:o}=await Promise.resolve().then(()=>(st(),rt)),r=await o(n,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"]}},qb=Da.z.object({statement:Da.z.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});function ms(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:cu,async execute(i,a){let{timeout_seconds:n=10}=i,{page:o,agentServices:r}=a;try{let s={action_description:`Wait for download to complete (timeout: ${n}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:n}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:"Download completed"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:n}},feedback:s.message}}}}})}var Ra,ps,cu,Gt=v(()=>{"use strict";Ra=require("zod"),ps=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,n)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},cu=Ra.z.object({timeout_seconds:Ra.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function fs(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:du,async execute(i,a){let{condition:n,timeout_seconds:o=60}=i,{page:r,agentServices:s}=a;try{let l={action_description:`Wait until: ${n}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:n,timeout_seconds:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Condition met: ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${n} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:n,timeout_seconds:o}},feedback:l.message}}}}})}var xn,gs,du,jt=v(()=>{"use strict";xn=require("zod"),gs=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.condition;if(!n)throw new Error("Missing condition for ai_wait_until");let o=(a.kwargs.timeout_seconds||60)*1e3,r=5e3,s=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(st(),rt));for(;Date.now()-s<o;){if((await l(n,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${n}`)}transpile(e,t){let i=e.action_data?.kwargs?.condition,a=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${a}, '${t}');`]:["// Skipping ai_wait_until: missing condition"]}},du=xn.z.object({condition:xn.z.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:xn.z.number().positive().optional().describe("Timeout in seconds (default: 60)")})});async function uu(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function ws(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function ys(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:hu,usesElementIndex:!0,async execute(i,a){let{element_index:n,delta_x:o,delta_y:r}=i,{page:s,agentServices:l}=a;try{let c=await W(a,n);if(!c)return{success:!1,error:`Element with index ${n} not found`,actionEntity:ws(`Scroll on element ${n} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:n,delta_x:o,delta_y:r})};let d=await uu("scroll_on_element",`Scroll on element ${n} horizontally: ${o}px, vertically: ${r}px`,c,s,{delta_x:o,delta_y:r});return await t.execute(s,d,l),{success:!0,actionEntity:d,message:`Scrolled on element ${n} horizontally: ${o}px, vertically: ${r}px`}}catch(c){return{success:!1,error:c.message,actionEntity:ws(`Scroll on element ${n} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:n,delta_x:o,delta_y:r})}}}})}var ut,bs,hu,Kt=v(()=>{"use strict";K();F();ut=require("zod");I();bs=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.delta_x||0,o=a.kwargs.delta_y||0,r=O(e,t),s=P(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(n,o);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Fe(e);if(!t){let n=e.action_data?.kwargs?.delta_x||0,o=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${n}, delta_y: ${o} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,a=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${P()} });`,`await page.mouse.wheel(${i}, ${a});`]}};hu=ut.z.object({element_index:ut.z.number().int().describe("Index of the scrollable element"),delta_x:ut.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:ut.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:ut.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function vs(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:pu,async execute(i,a){let{text:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l={action_description:s||`Scroll to text "${n}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:n}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${n}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${n}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:n}},feedback:l.message}}}}})}var Fa,xs,pu,zt=v(()=>{"use strict";Fa=require("zod"),xs=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let a=i.kwargs.text;if(a)await e.getByText(a,{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();`]}},pu=Fa.z.object({text:Fa.z.string().describe("Text to scroll to on the page")})});async function mu(e,t,i,a){return{...await N(t,e),action_description:a||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function _s(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 Ss(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:gu,usesElementIndex:!0,async execute(i,a){let{element_index:n,option:o}=i,{page:r,agentServices:s,actionDescription:l}=a;try{let c=await W(a,n);if(!c)return{success:!1,error:`Dropdown element with index ${n} not found`,actionEntity:_s(l||`Select option in dropdown ${n}`,{index:n,option:o})};let d=await mu(c,r,o,l);return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Selected option "${o}" in dropdown ${n}`}}catch(c){return{success:!1,error:c.message,actionEntity:_s(`Select option in dropdown ${n}`,{index:n,option:o})}}}})}var Vt,ks,gu,Xt=v(()=>{"use strict";K();F();Vt=require("zod");I();ks=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.text||a.kwargs.option,o=O(e,t),r=P(i,t.action_data?.kwargs?.timeout_ms);if(o&&n)await o.selectOption(n,{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(a=>` ${a},`),"});"]}};gu=Vt.z.object({element_index:Vt.z.number().int().describe("Index of the dropdown/select element"),option:Vt.z.string().describe("Option value, label, or index to select"),timeout_ms:Vt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function fu(e,t,i,a){return{...await N(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:a}}}}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 Ts(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
4100
|
|
|
4101
4101
|
IMPORTANT: ONLY use this action for input elements that have type="date" attribute (native HTML date picker).
|
|
4102
4102
|
Do NOT use it for custom/non-native date pickers
|
|
@@ -4109,7 +4109,7 @@ Use the exact text string in select_dropdown_option`,i.addNote(n)}else i.addNote
|
|
|
4109
4109
|
})();
|
|
4110
4110
|
`)(e,at.expect,a)}catch(n){throw new Error(`Assertion failed: ${n instanceof Error?n.message:String(n)}`)}}transpile(e,t){let i=e.action_data?.kwargs,a=typeof i?.code=="string",n=a?i?.statement||e.action_description:e.action_description||i?.statement,o=JSON.stringify(t||"");if(a){let r=i.code;if(!wl(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(n){let s=r.split(`
|
|
4111
4111
|
`),l=JSON.stringify(n);return["{ const _t = Date.now(); try {",...s.map(c=>` ${c}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${l}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${l}\`);`,` await agent.assert(page, ${l}, ${o});`,"} }"]}return r.split(`
|
|
4112
|
-
`)}return n?[`await agent.assert(page, ${JSON.stringify(n)}, ${o});`]:["// Skipping verify: missing statement or code"]}},Vu=Za.z.object({statement:Za.z.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});function xl(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:Xu,async execute(i,a){let{element_description:n,variable_name:o}=i,{page:r,agentServices:s}=a;try{let l={action_description:`Extract ${n} to ${o}`,action_data:{action_name:"ai_extract",kwargs:{element_description:n,variable_name:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${n} to ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${n} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:n,variable_name:o}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var On,yl,Xu,vi=v(()=>{"use strict";On=require("zod"),yl=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.element_description,o=a.kwargs.variable_name;if(!n||!o)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${n} and save to ${o}`,{executeStep:s}=await Promise.resolve().then(()=>(st(),rt)),l=await s(r,e,i);if(l.status!=="success")throw new Error(l.error||"Extraction failed")}transpile(e,t){let i=e.action_data?.kwargs?.element_description,a=e.action_data?.kwargs?.variable_name;if(!i||!a)return["// Skipping ai_extract: missing element_description or variable_name"];let n=JSON.stringify(i),o=JSON.stringify(a);return[`await agent.extract(page, ${n}, ${o}, '${t||""}');`]}},Xu=On.z.object({element_description:On.z.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:On.z.string().describe("Name of the variable to store the extracted value")})});var Yu,Ju,Ln,Nn=v(()=>{"use strict";Yu=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Ju=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],Ln=class{static isAiAction(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:Yu.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 a=i.element_description,n=i.variable_name;return a&&n?`Extract ${a} and save to ${n}`: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:!Ju.includes(t)}}});var Qa,eo,to,io=v(()=>{"use strict";ln();cn();dn();un();hn();pn();mn();gn();fn();bn();yn();Gt();jt();Kt();zt();Xt();Jt();qt();Qt();ei();ti();ii();ni();ai();ri();si();li();ci();ui();hi();mi();gi();fi();wi();bi();yi();xi();vi();Nn();F();ge();Qa=class T{static registerAction(t,i){T.actions.set(t,i)}constructor(){T.initialized||(this.registerBuiltinActions(),T.initialized=!0)}registerBuiltinActions(){T.registerAction("go_to_url",new Va),T.registerAction("go_back",new Zs),T.registerAction("reload_page",new Hs),T.registerAction("close_tab",new dl),T.registerAction("switch_tab",new As),T.registerAction("click",new $n),T.registerAction("hover",new Xa),T.registerAction("right_click",new ja),T.registerAction("double_click",new qa),T.registerAction("click_by_coordinates",new ss),T.registerAction("right_click_by_coordinates",new as),T.registerAction("double_click_by_coordinates",new ls),T.registerAction("drag_drop",new cs),T.registerAction("input_text",new Ya),T.registerAction("clear_input",new rl),T.registerAction("press",new Ga),T.registerAction("send_keys_on_element",new ts),T.registerAction("scroll_on_element",new bs),T.registerAction("scroll_to_text",new xs),T.registerAction("scroll",new oi),T.registerAction("upload_file",new Os),T.registerAction("wait_for_download_complete",new ps),T.registerAction("get_dropdown_options",new Ys),T.registerAction("select_dropdown_option",new ks),T.registerAction("set_date_for_native_date_picker",new Es),T.registerAction("verify",new Cn),T.registerAction("ai_action",new us),T.registerAction("ai_extract",new yl),T.registerAction("ai_step",new hs),T.registerAction("ai_wait_until",new gs),T.registerAction("generate_2fa_code",new zs),T.registerAction("wait",new Ns),T.registerAction("wait_for_page_ready",new es),T.registerAction("save_variable",new Gs),T.registerAction("js_code",new ns),T.registerAction("js_action",new rs),T.registerAction("function",new os),T.registerAction("done",new hl),T.registerAction("click_element",new $n),T.registerAction("click_element_by_index",new $n),T.registerAction("hover_element_by_index",new Xa),T.registerAction("right_click_on_element",new ja),T.registerAction("double_click_on_element",new qa),T.registerAction("scroll_down",new oi),T.registerAction("scroll_up",new oi),T.registerAction("scroll_element",new oi),T.registerAction("send_keys",new Ga),T.registerAction("open_tab",new Va),T.registerAction("fill",new Ya),T.registerAction("ai_assert",new Cn),T.registerAction("assert",new Cn)}getAction(t){return T.actions.get(t)}hasAction(t){return T.actions.has(t)}getActionNames(){return Array.from(T.actions.keys())}async execute(t,i,a){if(!a)throw new Error("AgentServices not found");let n=i.action_data?.action_name;if(!n)throw new Error("Action name not found in action_data");let o=this.getAction(n);if(!o)throw new Error(`Unknown action: ${n}`);await o.execute(t,i,a)}transpile(t,i,a){let{sanitizeForComment:n}=(I(),
|
|
4112
|
+
`)}return n?[`await agent.assert(page, ${JSON.stringify(n)}, ${o});`]:["// Skipping verify: missing statement or code"]}},Vu=Za.z.object({statement:Za.z.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});function xl(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:Xu,async execute(i,a){let{element_description:n,variable_name:o}=i,{page:r,agentServices:s}=a;try{let l={action_description:`Extract ${n} to ${o}`,action_data:{action_name:"ai_extract",kwargs:{element_description:n,variable_name:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${n} to ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${n} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:n,variable_name:o}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var On,yl,Xu,vi=v(()=>{"use strict";On=require("zod"),yl=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.element_description,o=a.kwargs.variable_name;if(!n||!o)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${n} and save to ${o}`,{executeStep:s}=await Promise.resolve().then(()=>(st(),rt)),l=await s(r,e,i);if(l.status!=="success")throw new Error(l.error||"Extraction failed")}transpile(e,t){let i=e.action_data?.kwargs?.element_description,a=e.action_data?.kwargs?.variable_name;if(!i||!a)return["// Skipping ai_extract: missing element_description or variable_name"];let n=JSON.stringify(i),o=JSON.stringify(a);return[`await agent.extract(page, ${n}, ${o}, '${t||""}');`]}},Xu=On.z.object({element_description:On.z.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:On.z.string().describe("Name of the variable to store the extracted value")})});var Yu,Ju,Ln,Nn=v(()=>{"use strict";Yu=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Ju=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],Ln=class{static isAiAction(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:Yu.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 a=i.element_description,n=i.variable_name;return a&&n?`Extract ${a} and save to ${n}`: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:!Ju.includes(t)}}});var Qa,eo,to,io=v(()=>{"use strict";ln();cn();dn();un();hn();pn();mn();gn();fn();bn();yn();Gt();jt();Kt();zt();Xt();Jt();qt();Qt();ei();ti();ii();ni();ai();ri();si();li();ci();ui();hi();mi();gi();fi();wi();bi();yi();xi();vi();Nn();F();ge();Qa=class T{static registerAction(t,i){T.actions.set(t,i)}constructor(){T.initialized||(this.registerBuiltinActions(),T.initialized=!0)}registerBuiltinActions(){T.registerAction("go_to_url",new Va),T.registerAction("go_back",new Zs),T.registerAction("reload_page",new Hs),T.registerAction("close_tab",new dl),T.registerAction("switch_tab",new As),T.registerAction("click",new $n),T.registerAction("hover",new Xa),T.registerAction("right_click",new ja),T.registerAction("double_click",new qa),T.registerAction("click_by_coordinates",new ss),T.registerAction("right_click_by_coordinates",new as),T.registerAction("double_click_by_coordinates",new ls),T.registerAction("drag_drop",new cs),T.registerAction("input_text",new Ya),T.registerAction("clear_input",new rl),T.registerAction("press",new Ga),T.registerAction("send_keys_on_element",new ts),T.registerAction("scroll_on_element",new bs),T.registerAction("scroll_to_text",new xs),T.registerAction("scroll",new oi),T.registerAction("upload_file",new Os),T.registerAction("wait_for_download_complete",new ps),T.registerAction("get_dropdown_options",new Ys),T.registerAction("select_dropdown_option",new ks),T.registerAction("set_date_for_native_date_picker",new Es),T.registerAction("verify",new Cn),T.registerAction("ai_action",new us),T.registerAction("ai_extract",new yl),T.registerAction("ai_step",new hs),T.registerAction("ai_wait_until",new gs),T.registerAction("generate_2fa_code",new zs),T.registerAction("wait",new Ns),T.registerAction("wait_for_page_ready",new es),T.registerAction("save_variable",new Gs),T.registerAction("js_code",new ns),T.registerAction("js_action",new rs),T.registerAction("function",new os),T.registerAction("done",new hl),T.registerAction("click_element",new $n),T.registerAction("click_element_by_index",new $n),T.registerAction("hover_element_by_index",new Xa),T.registerAction("right_click_on_element",new ja),T.registerAction("double_click_on_element",new qa),T.registerAction("scroll_down",new oi),T.registerAction("scroll_up",new oi),T.registerAction("scroll_element",new oi),T.registerAction("send_keys",new Ga),T.registerAction("open_tab",new Va),T.registerAction("fill",new Ya),T.registerAction("ai_assert",new Cn),T.registerAction("assert",new Cn)}getAction(t){return T.actions.get(t)}hasAction(t){return T.actions.has(t)}getActionNames(){return Array.from(T.actions.keys())}async execute(t,i,a){if(!a)throw new Error("AgentServices not found");let n=i.action_data?.action_name;if(!n)throw new Error("Action name not found in action_data");let o=this.getAction(n);if(!o)throw new Error(`Unknown action: ${n}`);await o.execute(t,i,a)}transpile(t,i,a){let{sanitizeForComment:n}=(I(),fa(Wi)),o=t.action_description||"",r=t.action_data?.action_name||"",s=this.getAction(r);if(!s)return[`// ${i}: Unknown action: ${r}`];let l=s.transpile(t,i);if(Ln.isAiAction(t))return[`// ${i}: ${n(o)}`,"page = agent.agentServices.validatePage(page);",...l];let c=JSON.stringify(o),d=l.map(g=>` ${g}`),h=Ln.canSelfHeal(t),m=a?JSON.stringify(a):"undefined";return[`// ${i}: ${n(o)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...d,`}, ${c}, '${i}', ${m}, ${h});`]}transpileUncachedAction(t,i,a=!1,n=!1,o){let{sanitizeForComment:r}=(I(),fa(Wi));if(!t)return[`// ${i}: Skipping - no description`];let s=JSON.stringify(t);if(n){let l=o?`, { stmtUid: ${JSON.stringify(o)} }`:"";return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${s}, '${i}'${l});`]}return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${s}, '${i}', ${a});`]}};Qa.actions=new Map,Qa.initialized=!1;eo=Qa,to=eo});var ht={};ze(ht,{ActionHandler:()=>eo,default:()=>to});var pt=v(()=>{"use strict";io();ln();cn();dn();un();hn();pn();mn();gn();fn();bn();yn();Gt();jt();Kt();zt();Xt();Jt();qt();Qt();ei();ti();ii();ni();ai();ri();si();li();ci();ui();hi();mi();gi();fi();wi();bi();yi();xi();Ht();vi();Pn();Zt();K();Ge();R();ne();ot();Nn();F();ge()});function Dn(e,t,i){let a=()=>e.stepHistory.length===0?"":`**Recent Steps**:
|
|
4113
4113
|
${e.stepHistory.slice(-3).map(l=>{let c=`${l.outcome.success?"\u2713":"\u2717"} Step ${l.stepNumber}: ${l.goal}`;if(l.actions.length>1)l.actions.forEach((d,h)=>{let m=d.action_description||"Unknown action";c+=`
|
|
4114
4114
|
\u2192 Action ${h+1}: ${m}`});else if(l.actions.length===1){let d=l.actions[0]?.action_description||"Unknown action";c+=`
|
|
4115
4115
|
\u2192 ${d}`}if(!l.outcome.success&&l.outcome.error){let d=l.outcome.error.substring(0,100);c+=`
|
|
@@ -4298,7 +4298,7 @@ ${g.join(`
|
|
|
4298
4298
|
`,a+=`- Use the EXACT placeholder name as shown above
|
|
4299
4299
|
`,a+=`- Do NOT use the actual value directly in the action
|
|
4300
4300
|
`,a+=`- The values shown are for context only to help you understand what data is available
|
|
4301
|
-
`,a+='- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")',a}}});var gt=v(()=>{"use strict"});async function ih(e,t){let i=new Set,a=Date.now(),n=new Set(["document","stylesheet","image","font","script","iframe"]),o=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["analytics","tracking","telemetry","beacon","metrics","doubleclick","adsystem","adserver","advertising","facebook.com/plugins","platform.twitter","linkedin.com/embed","livechat","zendesk","intercom","crisp.chat","hotjar","push-notifications","onesignal","pushwoosh","heartbeat","ping","alive","webrtc","rtmp://","wss://","cloudfront.net","fastly.net"],s=h=>{let m=h.toLowerCase();return m.startsWith("data:")||m.startsWith("blob:")?!0:r.some(g=>m.includes(g))},l=h=>{let m=h.resourceType(),g=h.url();if(!n.has(m)||s(g))return;let f=h.headers();f.purpose==="prefetch"||["video","audio"].includes(f["sec-fetch-dest"])||(i.add(h),a=Date.now())},c=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(y=>g.includes(y))){i.delete(m);return}if(![...o].some(y=>g.startsWith(y))){i.delete(m);return}let f=h.headers()["content-length"];if(f)try{if(parseInt(f,10)>5*1024*1024){i.delete(m);return}}catch{}i.delete(m),a=Date.now()},d=Date.now()-th;for(let h of await e.requests()){let m=h.resourceType(),g=h.url(),f=h.timing();n.has(m)&&!s(g)&&f.responseEnd===-1&&f.startTime>=d&&(i.add(h),a=Date.now())}u.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",c);try{let h=Date.now(),m=eh;for(;;){await new Promise(f=>setTimeout(f,100));let g=Date.now();if(i.size===0&&g-a>=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",c)}}async function Pe(e,t=Qu,i=Zu){let a=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),ih(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 n=Date.now()-a,o=Math.max(i-n,0);o>0&&await new Promise(r=>setTimeout(r,o))}var Zu,Qu,eh,th,Ce=v(()=>{"use strict";gt();R();Zu=.5*1e3,Qu=30*1e3,eh=1*1e3,th=3*1e3});function nh(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 El(e,t,i={}){let a=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let n=i.maxSteps??15,o=3,r=t.agentServices.getModel(),s=t.domService||new be(t.agentServices.getDomServiceOptions()),l={...t,domService:s};w.init(),w.section("Task Execution Started"),w.log(`Task: ${e}`),w.log(`Max steps: ${n}`),w.log(`Model: ${r}`);let c={currentStep:0,maxSteps:n,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},d=[],h=Rn(i.customPrompt),m=new Hn(h);w.log(`System prompt length: ${h.length} chars`);let g=!1,f="",y=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:n});c.currentStep<n;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");c.currentStep++;let b=Date.now();w.section(`Step ${c.currentStep}/${n}`),w.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:c.currentStep});try{w.log("Waiting for page to stabilize..."),await Pe(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 L=l.agentServices.getInteractiveClassNames(),D=l.agentServices.getIframeFallbackDomains();p=await kl(l.page,l.domService,L,D),w.log("Context prepared")}catch(L){if(L.message.includes("Execution context was destroyed")){w.log("Page navigating, waiting for load..."),await Pe(l.page);let D=l.agentServices.getInteractiveClassNames(),C=l.agentServices.getIframeFallbackDomains();p=await kl(l.page,l.domService,D,C)}else throw w.error("Error preparing context",L),L}m.addStateMessage(e,p.currentUrl,p.domTree,p.screenshotBase64,c,{isFinalStep:c.currentStep===n-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let x=await oh(m,r,i,p.screenshotBase64);if(x.tokenUsages&&x.tokenUsages.length>0&&d.push(...x.tokenUsages),!x.stepOutput){if(w.error("Failed to get valid LLM response"),c.consecutiveFailures++,c.consecutiveFailures>=o){f="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let S=x.stepOutput;ch(c.currentStep,n,S);let E=await sh(S,l,p.domState,c.currentStep,i.onEvent,p.screenshotBase64,x.debugInfo);y.push(...E.actionEntities);let A=lh(c.currentStep,S,E,c,b,x.debugInfo,x.tokenUsages),M=Date.now()-b;if(i.onEvent?.({type:"step_complete",step:c.currentStep,duration:M}),c.consecutiveFailures>=o){w.error(`Too many consecutive failures (${c.consecutiveFailures}), stopping`),f=`Reached the maximum allowed consecutive failures. Most recent error: ${c.lastFailReason}`;break}if(E.doneResult){g=E.doneResult.success,f=E.doneResult.summary;break}if(E.completesInstruction){g=!0,f="Instruction completed";break}}return c.currentStep>=n&&!g&&(f="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:c.currentStep,duration:Date.now()-a}),w.log(`Build success result: summary=${f}, completed=${g}, actions=${y.length}, tokens=${d.length}`),dh(c,y,g,f,a,d,r)}catch(b){let p=b.message;return w.error(`Task execution failed: ${p}`,b),i.onEvent?.({type:"error",error:p,recoverable:!1}),uh(c,p,a,d,r)}}async function kl(e,t,i,a){let{domState:n,screenshotBase64:o}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:a}),r=n.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:o,domState:n}}function ah(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let a=i.image,n=typeof a=="string"?a:"";return{type:"image",file:n.startsWith("data:")?n:`data:image/png;base64,${n}`}}return{type:"text",text:i.text}}):t.content}))}async function oh(e,t,i,a){let n=i.temperature??0,{system:o,messages:r}=e.getMessages(),s=0;for(let h of r)Array.isArray(h.content)&&(s+=h.content.filter(m=>m.type==="image").length);let l=Te(t,s),c={model:Ee(t),system:o,messages:r,temperature:n,providerOptions:l},d=3;for(let h=0;h<d;h++)try{let m=Date.now();w.log(`Calling LLM (${t})...`);let g=await(0,Sl.generateText)(c),f=Date.now()-m,y=g,b=y.usage;w.llmCall(t,f,b);let p=y.reasoningText;p&&(w.thinking(p),i.onEvent?.({type:"thinking",text:p})),e.addAssistantMessage(g.text);let x={systemPrompt:o,userPrompt:ah(r),rawLlmResponse:g.text,reasoningContent:p,screenshotWithSom:a},S=[],E=nh(b,t);E&&S.push(E);let A=rh(g.text);if(!A)if(h<d-1){w.log(`Attempt ${h+1}/${d}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise(M=>setTimeout(M,i.retryDelay||1e3));continue}else return w.error("All parsing attempts failed"),{stepOutput:null,debugInfo:x,tokenUsages:S};return{stepOutput:A,debugInfo:x,tokenUsages:S}}catch(m){if(h<d-1){w.log(`Attempt ${h+1}/${d}: 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 rh(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 a of i.actions){if(!a.action_name)return w.error("Action missing required field: action_name"),null;if(!a.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 sh(e,t,i,a,n,o,r){let s=[],l=!0,c=null;w.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let d=null,h={...t,domState:i},m=o;for(let g of e.actions){if(g.action_name==="done"){d={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let f={},y=g.kwargs?.element_index??g.kwargs?.index;if(typeof y=="number"){let p=i.selectorMap.get(y);p&&(f=await N(t.page,p))}let b={...f,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let p=await H.execute(g.action_name,g.kwargs,h);g.action_name==="perform_accurate_operation"&&(b=p.actionEntity);let x=await h.agentServices.getCurrentPage();if(x&&(h.page=x,t.page=h.page),p?.success===!1){l=!1,w.log("Action failed, stopping execution of remaining actions in this step"),c=p.error||"Action execution failed";break}s.push(b),n?.({type:"action",action_entity:b,step:a,debugInfo:r})}catch(p){l=!1,c=p.message,w.error(`Action execution failed: ${p.message}`);break}}return{allSuccess:l,failReason:c,actionEntities:s,doneResult:d,completesInstruction:e.completes_instruction??!1}}function lh(e,t,i,a,n,o,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:n,duration:Date.now()-n,outcome:{success:i.allSuccess},debugInfo:o,tokenUsages:r};if(a.lastGoal=t.current_goal,t.evaluation_previous_goal&&(a.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let l=t.memory.trim();a.memory.includes(l)||(a.memory.push(l),a.memory.length>10&&(a.memory=a.memory.slice(-10)))}return i.allSuccess?(a.consecutiveFailures=0,a.lastFailReason=null):(a.consecutiveFailures++,a.lastFailReason=i.failReason),a.stepHistory.push(s),s}function ch(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 a=i.actions[0];w.log(`Action: ${a.action_name}(${JSON.stringify(a.kwargs)}) - ${a.description}`)}else w.log(`Actions (${i.actions.length}):`),i.actions.forEach((a,n)=>{w.log(` ${n+1}. ${a.action_name}(${JSON.stringify(a.kwargs)}) - ${a.description}`)})}function dh(e,t,i,a,n,o,r){let s=o.reduce((d,h)=>d+h.prompt_tokens,0),l=o.reduce((d,h)=>d+h.completion_tokens,0),c=o.reduce((d,h)=>d+h.total_tokens,0);return{success:!0,completed:i,summary:a,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-n,model:r,successfulSteps:e.stepHistory.filter(d=>d.outcome.success).length,failedSteps:e.stepHistory.filter(d=>!d.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:c,tokenUsages:o}}}function uh(e,t,i,a,n){let o=a.reduce((l,c)=>l+c.prompt_tokens,0),r=a.reduce((l,c)=>l+c.completion_tokens,0),s=a.reduce((l,c)=>l+c.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:n,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:o,completionTokens:r,totalTokens:s,tokenUsages:a}}}var Sl,Tl=v(()=>{"use strict";no();Fn();$e();je();ae();Ce();Ae();K();Sl=require("ai")});var Al={};ze(Al,{TaskMessageManager:()=>Hn,formatFinalStepWarning:()=>vl,formatTaskContext:()=>Dn,getBrowserTaskJSONPrompt:()=>Rn,runTaskLoop:()=>El});var $l=v(()=>{"use strict";Tl();no();Fn();$e();wn();je();Lt();Nt();nt();Dt();Rt();ae();Ce();gt();Ae();At();Qe();$t();He();K();Ge();R();ne();ot();F();ge()});async function Wt(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:a}=e.action_data;if(H.has(i)){let n=await H.execute(i,a,t),o=n?.success!==!1,r=n?.error||n?.message;return{success:o,error:o?void 0:r}}else{let{page:n,agentServices:o}=t;return await(await hh()).execute(n,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function hh(){if(Wn)return Wn;let e=await Promise.resolve().then(()=>(pt(),ht));return Wn=new e.default,Wn}async function Ut(e,t,i,a={},n){let o=n||{page:t,agentServices:i,domService:new be(i.getDomServiceOptions()),executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},r=i.replaceVariables(e),s=await $a(r,o,a);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 lt(e,t,i,a={},n){let o=n||{page:t,agentServices:i,domService:new be(i.getDomServiceOptions()),executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},r=i.replaceVariables(e),s=await $a(r,o,a);if(s.status==="error"||!s.actionEntity)return{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error||"No action generated",debugInfo:s.debugInfo};let{actionEntity:l,reasoning:c,goalAccomplished:d,debugInfo:h}=s,m=await Wt(l,o);return m.success?(c&&i.addNote(c),{status:"success",completed:d||!1,actionEntities:[l],explanation:c,debugInfo:h}):{status:"error",completed:!1,actionEntities:[l],error:m.error||"Action execution failed",debugInfo:h}}async function ct(e,t,i,a={}){let n={page:t,agentServices:i,domService:new be(i.getDomServiceOptions()),executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},o=i.replaceVariables(e);return a.useCleanScreenshotForAssertion??(a.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Kr(o,n,a)}async function dt(e,t,i,a,n={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>($l(),Al)),r=a?l=>{a(l)}:void 0,s=await o(e,{page:t,agentServices:i,domService:void 0,executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},{maxSteps:n.maxSteps,onEvent:r,abortSignal:n.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 Wn,Bt=v(()=>{"use strict";rn();$e();je();Wn=null});function oo(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,a=o=>{let r=o.startsWith("$")?o.slice(1):o,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},n=e;return n=n.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(o,r)=>{let s=a(r.trim());return s!==void 0?s:o}),n=n.replace(/<secret>\$?([\w-]+)<\/secret>/g,(o,r)=>{let s=a(r);return s!==void 0?s:o}),n=n.replace(/\$\{([^}]+)\}/g,(o,r)=>{let s=a(r.trim());return s!==void 0?s:o}),n=n.replace(/\$([a-zA-Z_]\w*)/g,(o,r)=>{let s=a(r);return s!==void 0?s:o}),n}var gk,k,bk,Tk,Mk,Vl,hk,Xl,yh,xh,Bn,pk,mk,Gn,Yl,ro,vh,zl,_h,_i,kh,Sh,Eh,de,Th,Ah,wk,$k,ft=v(()=>{"use strict";ge();gk=require("uuid"),k=require("zod"),bk=require("yaml"),Tk=require("uuid"),Mk=require("yaml");Vl=112,hk=1080-Vl,Xl=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Xl||{}),yh={"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"}},xh={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"]},Bn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),xh[e].map(a=>yh[a]).filter(a=>a.defaultBrowserType&&i.includes(a.defaultBrowserType))},pk={desktop:{label:"Desktop",type:"desktop",devices:Bn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Bn("mobile")}},mk={desktop:{label:"Desktop",type:"desktop",devices:Bn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Bn("mobile",!0)}},Gn=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Gn||{}),Yl=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Yl||{}),ro=class Jl{constructor(){ba(this,"data",{}),ba(this,"sensitive",new Set)}get(t){return this.data[t]}set(t,i,a=!1){this.data[t]=i,a?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,a]of Object.entries(t.getAll()))this.set(i,a,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new Jl;if(t.data){let a=new Set(t.sensitiveKeys||[]);for(let[n,o]of Object.entries(t.data))i.set(n,o,a.has(n))}return i}},vh=k.z.enum(["JS_CODE","AI_MODE"]),zl=k.z.object({type:vh,expression:k.z.string()}),_h=k.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),_i=k.z.object({uid:k.z.string(),type:_h,comment:k.z.string().optional()}),kh=k.z.object({action_data:k.z.object({action_name:k.z.string(),kwargs:k.z.record(k.z.any()).optional(),args:k.z.array(k.z.any()).optional()}),action_description:k.z.string().optional(),url:k.z.string().optional(),xpath:k.z.string().nullable().optional(),locator:k.z.string().nullable().optional(),css_selector:k.z.string().nullable().optional(),unique_selector:k.z.string().nullable().optional(),element_index:k.z.number().nullable().optional(),frame_path:k.z.array(k.z.any()).optional(),artifacts:k.z.record(k.z.any()).optional(),feedback:k.z.string().optional(),original_browser_use_action:k.z.any().optional()}).passthrough(),Sh=_i.extend({type:k.z.literal("DRAFT"),description:k.z.string()}),Eh=_i.extend({type:k.z.literal("ACTION"),description:k.z.string(),action_entity:kh.optional(),locator:k.z.string().optional(),use_pure_vision:k.z.boolean().optional()}),de=k.z.lazy(()=>k.z.union([Sh,Eh,_i.extend({type:k.z.literal("STEP"),description:k.z.string().optional().default(""),statements:k.z.array(de),reference_id:k.z.number().optional(),template_path:k.z.string().optional(),template_params:k.z.record(k.z.string()).optional()}),_i.extend({type:k.z.literal("IF_ELSE"),description:k.z.string().optional(),condition:zl,then:k.z.array(de),else:k.z.array(de).optional()}),_i.extend({type:k.z.literal("WHILE_LOOP"),description:k.z.string().optional(),condition:zl,body:k.z.array(de),timeout_ms:k.z.number().optional()})])),Th=k.z.object({name:k.z.string(),statements:k.z.array(de),teardown:k.z.array(de).optional(),skip:k.z.union([k.z.boolean(),k.z.string()]).optional(),timeout:k.z.number().optional(),fail:k.z.union([k.z.boolean(),k.z.string()]).optional(),only:k.z.boolean().optional(),slow:k.z.boolean().optional()}),Ah=k.z.object({tests:k.z.array(Th).min(1),beforeAll:k.z.array(de).optional(),afterAll:k.z.array(de).optional(),beforeEach:k.z.array(de).optional(),afterEach:k.z.array(de).optional()}),wk=k.z.object({comment:k.z.string().optional(),version:k.z.string().optional(),goal:k.z.string().optional(),url:k.z.string().optional(),baseURL:k.z.string().optional(),final_feedback:k.z.string().optional(),completed:k.z.boolean().optional(),success:k.z.boolean().optional(),statements:k.z.array(de).optional(),teardown:k.z.array(de).optional(),last_modified_at:k.z.string().optional(),testGroup:Ah.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"}),$k=1024*1024});async function ql(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,a=`
|
|
4301
|
+
`,a+='- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")',a}}});var gt=v(()=>{"use strict"});async function ih(e,t){let i=new Set,a=Date.now(),n=new Set(["document","stylesheet","image","font","script","iframe"]),o=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["analytics","tracking","telemetry","beacon","metrics","doubleclick","adsystem","adserver","advertising","facebook.com/plugins","platform.twitter","linkedin.com/embed","livechat","zendesk","intercom","crisp.chat","hotjar","push-notifications","onesignal","pushwoosh","heartbeat","ping","alive","webrtc","rtmp://","wss://","cloudfront.net","fastly.net"],s=h=>{let m=h.toLowerCase();return m.startsWith("data:")||m.startsWith("blob:")?!0:r.some(g=>m.includes(g))},l=h=>{let m=h.resourceType(),g=h.url();if(!n.has(m)||s(g))return;let f=h.headers();f.purpose==="prefetch"||["video","audio"].includes(f["sec-fetch-dest"])||(i.add(h),a=Date.now())},c=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(y=>g.includes(y))){i.delete(m);return}if(![...o].some(y=>g.startsWith(y))){i.delete(m);return}let f=h.headers()["content-length"];if(f)try{if(parseInt(f,10)>5*1024*1024){i.delete(m);return}}catch{}i.delete(m),a=Date.now()},d=Date.now()-th;for(let h of await e.requests()){let m=h.resourceType(),g=h.url(),f=h.timing();n.has(m)&&!s(g)&&f.responseEnd===-1&&f.startTime>=d&&(i.add(h),a=Date.now())}u.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",c);try{let h=Date.now(),m=eh;for(;;){await new Promise(f=>setTimeout(f,100));let g=Date.now();if(i.size===0&&g-a>=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",c)}}async function Pe(e,t=Qu,i=Zu){let a=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),ih(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 n=Date.now()-a,o=Math.max(i-n,0);o>0&&await new Promise(r=>setTimeout(r,o))}var Zu,Qu,eh,th,Ce=v(()=>{"use strict";gt();R();Zu=.5*1e3,Qu=30*1e3,eh=1*1e3,th=3*1e3});function nh(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 El(e,t,i={}){let a=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let n=i.maxSteps??15,o=3,r=t.agentServices.getModel(),s=t.domService||new be(t.agentServices.getDomServiceOptions()),l={...t,domService:s};w.init(),w.section("Task Execution Started"),w.log(`Task: ${e}`),w.log(`Max steps: ${n}`),w.log(`Model: ${r}`);let c={currentStep:0,maxSteps:n,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},d=[],h=Rn(i.customPrompt),m=new Hn(h);w.log(`System prompt length: ${h.length} chars`);let g=!1,f="",y=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:n});c.currentStep<n;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");c.currentStep++;let b=Date.now();w.section(`Step ${c.currentStep}/${n}`),w.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:c.currentStep});try{w.log("Waiting for page to stabilize..."),await Pe(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 L=l.agentServices.getInteractiveClassNames(),D=l.agentServices.getIframeFallbackDomains();p=await kl(l.page,l.domService,L,D),w.log("Context prepared")}catch(L){if(L.message.includes("Execution context was destroyed")){w.log("Page navigating, waiting for load..."),await Pe(l.page);let D=l.agentServices.getInteractiveClassNames(),C=l.agentServices.getIframeFallbackDomains();p=await kl(l.page,l.domService,D,C)}else throw w.error("Error preparing context",L),L}m.addStateMessage(e,p.currentUrl,p.domTree,p.screenshotBase64,c,{isFinalStep:c.currentStep===n-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let x=await oh(m,r,i,p.screenshotBase64);if(x.tokenUsages&&x.tokenUsages.length>0&&d.push(...x.tokenUsages),!x.stepOutput){if(w.error("Failed to get valid LLM response"),c.consecutiveFailures++,c.consecutiveFailures>=o){f="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let S=x.stepOutput;ch(c.currentStep,n,S);let E=await sh(S,l,p.domState,c.currentStep,i.onEvent,p.screenshotBase64,x.debugInfo);y.push(...E.actionEntities);let A=lh(c.currentStep,S,E,c,b,x.debugInfo,x.tokenUsages),M=Date.now()-b;if(i.onEvent?.({type:"step_complete",step:c.currentStep,duration:M}),c.consecutiveFailures>=o){w.error(`Too many consecutive failures (${c.consecutiveFailures}), stopping`),f=`Reached the maximum allowed consecutive failures. Most recent error: ${c.lastFailReason}`;break}if(E.doneResult){g=E.doneResult.success,f=E.doneResult.summary;break}if(E.completesInstruction){g=!0,f="Instruction completed";break}}return c.currentStep>=n&&!g&&(f="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:c.currentStep,duration:Date.now()-a}),w.log(`Build success result: summary=${f}, completed=${g}, actions=${y.length}, tokens=${d.length}`),dh(c,y,g,f,a,d,r)}catch(b){let p=b.message;return w.error(`Task execution failed: ${p}`,b),i.onEvent?.({type:"error",error:p,recoverable:!1}),uh(c,p,a,d,r)}}async function kl(e,t,i,a){let{domState:n,screenshotBase64:o}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:a}),r=n.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:o,domState:n}}function ah(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let a=i.image,n=typeof a=="string"?a:"";return{type:"image",file:n.startsWith("data:")?n:`data:image/png;base64,${n}`}}return{type:"text",text:i.text}}):t.content}))}async function oh(e,t,i,a){let n=i.temperature??0,{system:o,messages:r}=e.getMessages(),s=0;for(let h of r)Array.isArray(h.content)&&(s+=h.content.filter(m=>m.type==="image").length);let l=Te(t,s),c={model:Ee(t),system:o,messages:r,temperature:n,providerOptions:l},d=3;for(let h=0;h<d;h++)try{let m=Date.now();w.log(`Calling LLM (${t})...`);let g=await(0,Sl.generateText)(c),f=Date.now()-m,y=g,b=y.usage;w.llmCall(t,f,b);let p=y.reasoningText;p&&(w.thinking(p),i.onEvent?.({type:"thinking",text:p})),e.addAssistantMessage(g.text);let x={systemPrompt:o,userPrompt:ah(r),rawLlmResponse:g.text,reasoningContent:p,screenshotWithSom:a},S=[],E=nh(b,t);E&&S.push(E);let A=rh(g.text);if(!A)if(h<d-1){w.log(`Attempt ${h+1}/${d}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise(M=>setTimeout(M,i.retryDelay||1e3));continue}else return w.error("All parsing attempts failed"),{stepOutput:null,debugInfo:x,tokenUsages:S};return{stepOutput:A,debugInfo:x,tokenUsages:S}}catch(m){if(h<d-1){w.log(`Attempt ${h+1}/${d}: 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 rh(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 a of i.actions){if(!a.action_name)return w.error("Action missing required field: action_name"),null;if(!a.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 sh(e,t,i,a,n,o,r){let s=[],l=!0,c=null;w.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let d=null,h={...t,domState:i},m=o;for(let g of e.actions){if(g.action_name==="done"){d={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let f={},y=g.kwargs?.element_index??g.kwargs?.index;if(typeof y=="number"){let p=i.selectorMap.get(y);p&&(f=await N(t.page,p))}let b={...f,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let p=await H.execute(g.action_name,g.kwargs,h);g.action_name==="perform_accurate_operation"&&(b=p.actionEntity);let x=await h.agentServices.getCurrentPage();if(x&&(h.page=x,t.page=h.page),p?.success===!1){l=!1,w.log("Action failed, stopping execution of remaining actions in this step"),c=p.error||"Action execution failed";break}s.push(b),n?.({type:"action",action_entity:b,step:a,debugInfo:r})}catch(p){l=!1,c=p.message,w.error(`Action execution failed: ${p.message}`);break}}return{allSuccess:l,failReason:c,actionEntities:s,doneResult:d,completesInstruction:e.completes_instruction??!1}}function lh(e,t,i,a,n,o,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:n,duration:Date.now()-n,outcome:{success:i.allSuccess},debugInfo:o,tokenUsages:r};if(a.lastGoal=t.current_goal,t.evaluation_previous_goal&&(a.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let l=t.memory.trim();a.memory.includes(l)||(a.memory.push(l),a.memory.length>10&&(a.memory=a.memory.slice(-10)))}return i.allSuccess?(a.consecutiveFailures=0,a.lastFailReason=null):(a.consecutiveFailures++,a.lastFailReason=i.failReason),a.stepHistory.push(s),s}function ch(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 a=i.actions[0];w.log(`Action: ${a.action_name}(${JSON.stringify(a.kwargs)}) - ${a.description}`)}else w.log(`Actions (${i.actions.length}):`),i.actions.forEach((a,n)=>{w.log(` ${n+1}. ${a.action_name}(${JSON.stringify(a.kwargs)}) - ${a.description}`)})}function dh(e,t,i,a,n,o,r){let s=o.reduce((d,h)=>d+h.prompt_tokens,0),l=o.reduce((d,h)=>d+h.completion_tokens,0),c=o.reduce((d,h)=>d+h.total_tokens,0);return{success:!0,completed:i,summary:a,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-n,model:r,successfulSteps:e.stepHistory.filter(d=>d.outcome.success).length,failedSteps:e.stepHistory.filter(d=>!d.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:c,tokenUsages:o}}}function uh(e,t,i,a,n){let o=a.reduce((l,c)=>l+c.prompt_tokens,0),r=a.reduce((l,c)=>l+c.completion_tokens,0),s=a.reduce((l,c)=>l+c.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:n,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:o,completionTokens:r,totalTokens:s,tokenUsages:a}}}var Sl,Tl=v(()=>{"use strict";no();Fn();$e();je();ae();Ce();Ae();K();Sl=require("ai")});var Al={};ze(Al,{TaskMessageManager:()=>Hn,formatFinalStepWarning:()=>vl,formatTaskContext:()=>Dn,getBrowserTaskJSONPrompt:()=>Rn,runTaskLoop:()=>El});var $l=v(()=>{"use strict";Tl();no();Fn();$e();wn();je();Lt();Nt();nt();Dt();Rt();ae();Ce();gt();Ae();Qe();Et();Tt();He();K();Ge();R();ne();ot();F();ge()});async function Wt(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:a}=e.action_data;if(H.has(i)){let n=await H.execute(i,a,t),o=n?.success!==!1,r=n?.error||n?.message;return{success:o,error:o?void 0:r}}else{let{page:n,agentServices:o}=t;return await(await hh()).execute(n,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function hh(){if(Wn)return Wn;let e=await Promise.resolve().then(()=>(pt(),ht));return Wn=new e.default,Wn}async function Ut(e,t,i,a={},n){let o=n||{page:t,agentServices:i,domService:new be(i.getDomServiceOptions()),executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},r=i.replaceVariables(e),s=await $a(r,o,a);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 lt(e,t,i,a={},n){let o=n||{page:t,agentServices:i,domService:new be(i.getDomServiceOptions()),executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},r=i.replaceVariables(e),s=await $a(r,o,a);if(s.status==="error"||!s.actionEntity)return{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error||"No action generated",debugInfo:s.debugInfo};let{actionEntity:l,reasoning:c,goalAccomplished:d,debugInfo:h}=s,m=await Wt(l,o);return m.success?(c&&i.addNote(c),{status:"success",completed:d||!1,actionEntities:[l],explanation:c,debugInfo:h}):{status:"error",completed:!1,actionEntities:[l],error:m.error||"Action execution failed",debugInfo:h}}async function ct(e,t,i,a={}){let n={page:t,agentServices:i,domService:new be(i.getDomServiceOptions()),executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},o=i.replaceVariables(e);return a.useCleanScreenshotForAssertion??(a.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Kr(o,n,a)}async function dt(e,t,i,a,n={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>($l(),Al)),r=a?l=>{a(l)}:void 0,s=await o(e,{page:t,agentServices:i,domService:void 0,executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},{maxSteps:n.maxSteps,onEvent:r,abortSignal:n.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 Wn,Bt=v(()=>{"use strict";rn();$e();je();Wn=null});function oo(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,a=o=>{let r=o.startsWith("$")?o.slice(1):o,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},n=e;return n=n.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(o,r)=>{let s=a(r.trim());return s!==void 0?s:o}),n=n.replace(/<secret>\$?([\w-]+)<\/secret>/g,(o,r)=>{let s=a(r);return s!==void 0?s:o}),n=n.replace(/\$\{([^}]+)\}/g,(o,r)=>{let s=a(r.trim());return s!==void 0?s:o}),n=n.replace(/\$([a-zA-Z_]\w*)/g,(o,r)=>{let s=a(r);return s!==void 0?s:o}),n}var gk,k,bk,Tk,Mk,Vl,hk,Xl,yh,xh,Bn,pk,mk,Gn,Yl,ro,vh,zl,_h,_i,kh,Sh,Eh,de,Th,Ah,wk,$k,ft=v(()=>{"use strict";ge();gk=require("uuid"),k=require("zod"),bk=require("yaml"),Tk=require("uuid"),Mk=require("yaml");Vl=112,hk=1080-Vl,Xl=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Xl||{}),yh={"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"}},xh={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"]},Bn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),xh[e].map(a=>yh[a]).filter(a=>a.defaultBrowserType&&i.includes(a.defaultBrowserType))},pk={desktop:{label:"Desktop",type:"desktop",devices:Bn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Bn("mobile")}},mk={desktop:{label:"Desktop",type:"desktop",devices:Bn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Bn("mobile",!0)}},Gn=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Gn||{}),Yl=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Yl||{}),ro=class Jl{constructor(){wa(this,"data",{}),wa(this,"sensitive",new Set)}get(t){return this.data[t]}set(t,i,a=!1){this.data[t]=i,a?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,a]of Object.entries(t.getAll()))this.set(i,a,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new Jl;if(t.data){let a=new Set(t.sensitiveKeys||[]);for(let[n,o]of Object.entries(t.data))i.set(n,o,a.has(n))}return i}},vh=k.z.enum(["JS_CODE","AI_MODE"]),zl=k.z.object({type:vh,expression:k.z.string()}),_h=k.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),_i=k.z.object({uid:k.z.string(),type:_h,comment:k.z.string().optional()}),kh=k.z.object({action_data:k.z.object({action_name:k.z.string(),kwargs:k.z.record(k.z.any()).optional(),args:k.z.array(k.z.any()).optional()}),action_description:k.z.string().optional(),url:k.z.string().optional(),xpath:k.z.string().nullable().optional(),locator:k.z.string().nullable().optional(),css_selector:k.z.string().nullable().optional(),unique_selector:k.z.string().nullable().optional(),element_index:k.z.number().nullable().optional(),frame_path:k.z.array(k.z.any()).optional(),artifacts:k.z.record(k.z.any()).optional(),feedback:k.z.string().optional(),original_browser_use_action:k.z.any().optional()}).passthrough(),Sh=_i.extend({type:k.z.literal("DRAFT"),description:k.z.string()}),Eh=_i.extend({type:k.z.literal("ACTION"),description:k.z.string(),action_entity:kh.optional(),locator:k.z.string().optional(),use_pure_vision:k.z.boolean().optional()}),de=k.z.lazy(()=>k.z.union([Sh,Eh,_i.extend({type:k.z.literal("STEP"),description:k.z.string().optional().default(""),statements:k.z.array(de),reference_id:k.z.number().optional(),template_path:k.z.string().optional(),template_params:k.z.record(k.z.string()).optional()}),_i.extend({type:k.z.literal("IF_ELSE"),description:k.z.string().optional(),condition:zl,then:k.z.array(de),else:k.z.array(de).optional()}),_i.extend({type:k.z.literal("WHILE_LOOP"),description:k.z.string().optional(),condition:zl,body:k.z.array(de),timeout_ms:k.z.number().optional()})])),Th=k.z.object({name:k.z.string(),statements:k.z.array(de),teardown:k.z.array(de).optional(),skip:k.z.union([k.z.boolean(),k.z.string()]).optional(),timeout:k.z.number().optional(),fail:k.z.union([k.z.boolean(),k.z.string()]).optional(),only:k.z.boolean().optional(),slow:k.z.boolean().optional()}),Ah=k.z.object({tests:k.z.array(Th).min(1),beforeAll:k.z.array(de).optional(),afterAll:k.z.array(de).optional(),beforeEach:k.z.array(de).optional(),afterEach:k.z.array(de).optional()}),wk=k.z.object({comment:k.z.string().optional(),version:k.z.string().optional(),goal:k.z.string().optional(),url:k.z.string().optional(),baseURL:k.z.string().optional(),final_feedback:k.z.string().optional(),completed:k.z.boolean().optional(),success:k.z.boolean().optional(),statements:k.z.array(de).optional(),teardown:k.z.array(de).optional(),last_modified_at:k.z.string().optional(),testGroup:Ah.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"}),$k=1024*1024});async function ql(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,a=`
|
|
4302
4302
|
return await (${t});
|
|
4303
4303
|
`;return await new i("page",a)(e)}async function ki(e,t,i){let a=[],n=[];for(let o of t){let r=!1;try{let s=`page.${o}`;w.log(`Checking element existence: ${s}`),a.push(`Checking element existence: ${s}`);try{await ql(e,`${s}.waitFor({ state: 'attached', timeout: ${Oh} })`),w.log(`Element is attached: ${s}`),a.push(`Element is attached: ${s}`),r=!0}catch{await ql(e,`${s}.count()`)>0?(w.log(`Element found (snapshot): ${s}`),a.push(`Element found (snapshot): ${s}`),r=!0):(w.log(`Element not found: ${s}`),a.push(`Element not found: ${s}`),r=!1)}}catch(s){w.log(`Error checking element: ${s.message}`),a.push(`Error checking element: ${s.message}`),r=!1}if(n.push(r),!r&&i)break}return{successResults:n,logs:a}}async function lo(e,t,i=!0){let{successResults:a,logs:n}=await ki(e,t,i);return{success:a.length===t.length&&a.every(o=>o),logs:n}}async function Si(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:a}=await lo(e,t,!0);return i?w.log("All validation expressions passed"):w.log(`Validation failed: ${a.join(", ")}`),i}async function co(e,t){let i=e.context().browser();if(!i)throw new Error("Cannot create unsigned-in context: browser not available");let a=await i.newContext(),n=await a.newPage();return await n.goto(t),await Pe(n,Lh),{context:a,page:n,close:async()=>{await n.close(),await a.close()}}}async function uo(e,t,i,a,n,o){let r=`
|
|
4304
4304
|
Based on the current page status, generate ${n} Playwright locators in JavaScript code that can
|
|
@@ -4356,8 +4356,8 @@ ${m.join(`
|
|
|
4356
4356
|
|
|
4357
4357
|
`,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:
|
|
4358
4358
|
${m.join(`
|
|
4359
|
-
`)}`);continue}}return w.log("Generated validation locators passed dual validation"),d}catch(d){w.log(`Failed to generate validation expressions (attempt ${c+1}/${s}): ${d.message}`)}return w.log("Failed to generate valid locators after max retries"),null}finally{o&&await o.close()}}var Oh,Lh,Kn=v(()=>{"use strict";ae();Ce();Oh=5e3,Lh=1e4});var oc={};ze(oc,{LoginType:()=>Gn,checkLocators:()=>ki,createUnsignedInContext:()=>co,generateAndValidateLoginLocators:()=>jn,generateValidationLocators:()=>uo,validateLogin:()=>Si,validateLoginLocators:()=>lo});var rc=v(()=>{"use strict";Kn();ae();ft();Ce();gt();R();ne();ot();ge()});var Uh={};ze(Uh,{VariableStore:()=>ro,WebAgent:()=>mo,configureSdk:()=>pa,createAgentContext:()=>go,defineConfig:()=>hr,shiplightConfig:()=>ur});module.exports=hc(Uh);var cr=X(require("dotenv"),1),dr=require("@playwright/test");var Re=require("fs"),qe=require("path"),Zo=require("glob");var pc=require("uuid");var _=require("zod"),yo=_.z.enum(["JS_CODE","AI_MODE"]),Vn=_.z.object({type:yo,expression:_.z.string()}),xo=_.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Ve=_.z.object({uid:_.z.string(),type:xo,comment:_.z.string().optional()}),vo=_.z.object({action_data:_.z.object({action_name:_.z.string(),kwargs:_.z.record(_.z.any()).optional(),args:_.z.array(_.z.any()).optional()}),action_description:_.z.string().optional(),url:_.z.string().optional(),xpath:_.z.string().nullable().optional(),locator:_.z.string().nullable().optional(),css_selector:_.z.string().nullable().optional(),unique_selector:_.z.string().nullable().optional(),element_index:_.z.number().nullable().optional(),frame_path:_.z.array(_.z.any()).optional(),artifacts:_.z.record(_.z.any()).optional(),feedback:_.z.string().optional(),original_browser_use_action:_.z.any().optional()}).passthrough(),_o=Ve.extend({type:_.z.literal("DRAFT"),description:_.z.string()}),ko=Ve.extend({type:_.z.literal("ACTION"),description:_.z.string(),action_entity:vo.optional(),locator:_.z.string().optional(),use_pure_vision:_.z.boolean().optional()}),oe=_.z.lazy(()=>_.z.union([_o,ko,Ve.extend({type:_.z.literal("STEP"),description:_.z.string().optional().default(""),statements:_.z.array(oe),reference_id:_.z.number().optional(),template_path:_.z.string().optional(),template_params:_.z.record(_.z.string()).optional()}),Ve.extend({type:_.z.literal("IF_ELSE"),description:_.z.string().optional(),condition:Vn,then:_.z.array(oe),else:_.z.array(oe).optional()}),Ve.extend({type:_.z.literal("WHILE_LOOP"),description:_.z.string().optional(),condition:Vn,body:_.z.array(oe),timeout_ms:_.z.number().optional()})])),So=_.z.object({name:_.z.string(),statements:_.z.array(oe),teardown:_.z.array(oe).optional(),skip:_.z.union([_.z.boolean(),_.z.string()]).optional(),timeout:_.z.number().optional(),fail:_.z.union([_.z.boolean(),_.z.string()]).optional(),only:_.z.boolean().optional(),slow:_.z.boolean().optional()}),Ai=_.z.object({tests:_.z.array(So).min(1),beforeAll:_.z.array(oe).optional(),afterAll:_.z.array(oe).optional(),beforeEach:_.z.array(oe).optional(),afterEach:_.z.array(oe).optional()}),Xn=_.z.object({comment:_.z.string().optional(),version:_.z.string().optional(),goal:_.z.string().optional(),url:_.z.string().optional(),baseURL:_.z.string().optional(),final_feedback:_.z.string().optional(),completed:_.z.boolean().optional(),success:_.z.boolean().optional(),statements:_.z.array(oe).optional(),teardown:_.z.array(oe).optional(),last_modified_at:_.z.string().optional(),testGroup:Ai.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"});var B=require("yaml"),se=require("uuid");function Yn(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(Yn);let t=e,i=Object.keys(t);if(i.length===1){let n=i[0];if(n.startsWith("{ ")&&n.endsWith(" }")&&t[n]===null)return`{{${n.slice(2,-2)}}}`}let a={};for(let[n,o]of Object.entries(t))a[n]=Yn(o);return a}var Eo=1024*1024;function ke(e){if(e.length>Eo)throw new Error(`YAML input too large (${e.length} bytes, max ${Eo})`);let t=Yn((0,B.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return mc(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:le(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=le(t.teardown));let a=Xn.safeParse(i);if(!a.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(a.error.errors)}`);let n=a.data;return $o(e,n),n}function mc(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 n={tests:i.map(s=>{if(!s.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(s.statements)||s.statements.length===0)throw new Error(`Suite test "${s.name}" must have a non-empty "statements" array`);let l={name:s.name,statements:le(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=le(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(n.beforeAll=le(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(n.afterAll=le(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(n.beforeEach=le(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(n.afterEach=le(t.afterEach));let o=Ai.safeParse(n);if(!o.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(o.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:o.data}}function le(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(gc)}function gc(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 fc(t);if("WHILE"in t)return wc(t);if("STEP"in t)return bc(t);if("VERIFY"in t){let i=t.VERIFY,a={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(a.code=t.js),{uid:(0,se.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:a}}}}if("URL"in t){let i=t.URL,a=t.new_tab===!0?!0:void 0,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,o={url:typeof i=="string"?i:String(i)};return a&&(o.new_tab=!0),n!==void 0&&(o.timeout_seconds=n),{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:o}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,a=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:a}}}}}if("WAIT"in t){let i=t.WAIT,a=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,se.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${a}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${a}s`,action_data:{action_name:"wait",kwargs:{seconds:a}}}}}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 a=typeof t.description=="string"?t.description:"Code block";return{uid:(0,se.v4)(),type:"ACTION",description:a,action_entity:{action_description:a,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",a=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 a=="string"?a:String(a)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...a}=t;return To({...a,action:"function",functionName:i})}if("action"in t)return To(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 Ao(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 fc(e){let t=Ao(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let a={uid:(0,se.v4)(),type:"IF_ELSE",condition:t,then:le(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(a.else=le(e.ELSE)),a}function wc(e){let t=Ao(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let a={uid:(0,se.v4)(),type:"WHILE_LOOP",condition:t,body:le(i)};return typeof e.timeout_ms=="number"&&(a.timeout_ms=e.timeout_ms),a}function bc(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:le(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 a=e.template_params,n={};for(let[o,r]of Object.entries(a))n[o]=String(r);i.template_params=n}return i}var yc=new Set(["action","intent","desc","locator","xpath","use_pure_vision"]);function To(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:"",a=typeof e.locator=="string"?e.locator:void 0,n=typeof e.xpath=="string"?e.xpath:void 0,o=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[c,d]of Object.entries(e))yc.has(c)||(r[c]=d);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:{}}};a&&(s.locator=a),n&&(s.xpath=n);let l={uid:(0,se.v4)(),type:"ACTION",description:i,action_entity:s};return o&&(l.use_pure_vision=!0),l}function $o(e,t){let i;try{i=(0,B.parseDocument)(e)}catch{return}let a=i.contents;if(!a||!(0,B.isMap)(a))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=a.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let n=a,o=n.get("statements",!0);(0,B.isSeq)(o)&&t.statements&&Xe(o,t.statements);let r=n.get("teardown",!0);(0,B.isSeq)(r)&&t.teardown&&Xe(r,t.teardown)}function Xe(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 a=e.items[i];a.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=a.commentBefore);let n=t[i];if(n.type==="STEP"&&(0,B.isMap)(a)){let o=a.get("statements",!0);(0,B.isSeq)(o)&&Xe(o,n.statements)}else if(n.type==="IF_ELSE"&&(0,B.isMap)(a)){let o=a.get("THEN",!0);(0,B.isSeq)(o)&&Xe(o,n.then);let r=a.get("ELSE",!0);(0,B.isSeq)(r)&&n.else&&Xe(r,n.else)}else if(n.type==="WHILE_LOOP"&&(0,B.isMap)(a)){let o=a.get("DO",!0);(0,B.isSeq)(o)&&Xe(o,n.body)}}}var Mo=require("yaml");var Jn=e=>{let t=[];switch(e.type){case"STEP":e.statements&&t.push({key:"statements",statements:e.statements});break;case"IF_ELSE":e.then&&t.push({key:"then",statements:e.then}),e.else&&t.push({key:"else",statements:e.else});break;case"WHILE_LOOP":e.body&&t.push({key:"body",statements:e.body});break}return t};var $i=e=>{let t=[],i=a=>{for(let n of a){t.push(n);let o=Jn(n);for(let r of o)i(r.statements)}};return i(e),t};var xc=.5,Io=5,Po=3,Oo=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"]);function Lo(e){let t=0,i=0;for(let a of e)if(a.type==="DRAFT")i++;else if(a.type==="ACTION"){let n=a.action_entity?.action_data?.action_name??"";Oo.has(n)||t++}return{action:t,draft:i}}function vc(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function Co(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function _c(e){let t=e.split(/\r?\n/).map(o=>o.trim()).filter(o=>o.length>0&&!o.startsWith("//")),i=t.length,a=t.join(`
|
|
4360
|
-
`).match(/\bawait\b/g),n=a?a.length:0;return i<=Io&&n<=Po?null:`${i} non-blank line(s), ${n} await(s) \u2014 limits are ${Io} lines and ${Po} 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 qn(e,t){let i=t?.coverageThreshold??xc,a=[],n=[],o;try{o=ke(e)}catch(m){return{valid:!1,errors:[`Invalid YAML: ${m.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}o.goal||a.push('Missing required field: "goal"'),o.statements?.length||a.push('Missing required field: "statements"');let r=[...$i(o.statements??[]),...o.teardown?$i(o.teardown):[]],{action:s,draft:l}=Lo(r),c="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 f=g.description||m.uid;a.push(`Unresolved cloud template reference on statement "${f}" (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 f=m,y=f.action_entity?.action_data?.action_name??"";if(y==="js_code"||y==="js_action"||y==="verify"||y==="ai_assert"){let b=f.action_entity?.action_data?.kwargs?.code;if(typeof b=="string"){let p=vc(b);if(p){let x=f.description||y;a.push(`Invalid JS in "${x}": ${p}. ${c}`)}else if(y==="verify"){let x=_c(b);if(x){let S=f.description||y;a.push(`JS cache for "${S}" is too complex: ${x}`)}}}}}if(m.type==="IF_ELSE"){let f=m;if(f.condition.type==="JS_CODE"){let y=Co(f.condition.expression);y&&a.push(`Invalid JS in IF condition "${f.condition.expression}": ${y}. ${c}`)}}if(m.type==="WHILE_LOOP"){let f=m;if(f.condition.type==="JS_CODE"){let y=Co(f.condition.expression);y&&a.push(`Invalid JS in WHILE condition "${f.condition.expression}": ${y}. ${c}`)}}}let d=s+l,h=d>0?Math.round(s/d*100):0;return d>0&&h/100<i&&n.push(`Low action coverage: ${s}/${d} statements (${h}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:a.length===0,errors:a,warnings:n,stats:{total:d,action:s,draft:l,coverage:h}}}var No=112;var Sc=1080-No;var Do={"Blackberry PlayBook":{name:"Blackberry PlayBook",userAgent:"Mozilla/5.0 (PlayBook; U; RIM Tablet OS 2.1.0; en-US) AppleWebKit/536.2+ (KHTML like Gecko) Version/26.0 Safari/536.2+",screen:{width:600,height:1024},viewport:{width:600,height:1024},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"BlackBerry Z30":{name:"BlackBerry Z30",userAgent:"Mozilla/5.0 (BB10; Touch) AppleWebKit/537.10+ (KHTML, like Gecko) Version/26.0 Mobile Safari/537.10+",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note 3":{name:"Galaxy Note 3",userAgent:"Mozilla/5.0 (Linux; U; Android 4.3; en-us; SM-N900T Build/JSS15J) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note II":{name:"Galaxy Note II",userAgent:"Mozilla/5.0 (Linux; U; Android 4.1; en-us; GT-N7100 Build/JRO03C) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S III":{name:"Galaxy S III",userAgent:"Mozilla/5.0 (Linux; U; Android 4.0; en-us; GT-I9300 Build/IMM76D) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S5":{name:"Galaxy S5",userAgent:"Mozilla/5.0 (Linux; Android 5.0; SM-G900P Build/LRX21T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S8":{name:"Galaxy S8",userAgent:"Mozilla/5.0 (Linux; Android 7.0; SM-G950U Build/NRD90M) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:740},viewport:{width:360,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S9+":{name:"Galaxy S9+",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; SM-G965U Build/R16NW) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:320,height:658},viewport:{width:320,height:658},deviceScaleFactor:4.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S24":{name:"Galaxy S24",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-S921U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:780},viewport:{width:360,height:780},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy A55":{name:"Galaxy A55",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-A556B) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:480,height:1040},viewport:{width:480,height:1040},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S4":{name:"Galaxy Tab S4",userAgent:"Mozilla/5.0 (Linux; Android 8.1.0; SM-T837A) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:712,height:1138},viewport:{width:712,height:1138},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S9":{name:"Galaxy Tab S9",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-X710) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:640,height:1024},viewport:{width:640,height:1024},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"iPad (gen 5)":{name:"iPad (gen 5)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 6)":{name:"iPad (gen 6)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 7)":{name:"iPad (gen 7)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:810,height:1080},viewport:{width:810,height:1080},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 11)":{name:"iPad (gen 11)",userAgent:"Mozilla/5.0 (iPad; CPU OS 18_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/604.1",screen:{width:656,height:944},viewport:{width:656,height:944},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Mini":{name:"iPad Mini",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Pro 11":{name:"iPad Pro 11",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:834,height:1194},viewport:{width:834,height:1194},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6":{name:"iPhone 6",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6 Plus":{name:"iPhone 6 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7":{name:"iPhone 7",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7 Plus":{name:"iPhone 7 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8":{name:"iPhone 8",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8 Plus":{name:"iPhone 8 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE":{name:"iPhone SE",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_1 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/14E304 Safari/602.1",screen:{width:320,height:568},viewport:{width:320,height:568},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE (3rd gen)":{name:"iPhone SE (3rd gen)",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 18_5 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/602.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone X":{name:"iPhone X",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:812},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone XR":{name:"iPhone XR",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:896},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11":{name:"iPhone 11",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro":{name:"iPhone 11 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:635},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro Max":{name:"iPhone 11 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12":{name:"iPhone 12",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro":{name:"iPhone 12 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro Max":{name:"iPhone 12 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Mini":{name:"iPhone 12 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13":{name:"iPhone 13",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro":{name:"iPhone 13 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro Max":{name:"iPhone 13 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Mini":{name:"iPhone 13 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14":{name:"iPhone 14",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Plus":{name:"iPhone 14 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro":{name:"iPhone 14 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:660},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro Max":{name:"iPhone 14 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15":{name:"iPhone 15",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Plus":{name:"iPhone 15 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro":{name:"iPhone 15 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro Max":{name:"iPhone 15 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Kindle Fire HDX":{name:"Kindle Fire HDX",userAgent:"Mozilla/5.0 (Linux; U; en-us; KFAPWI Build/JDQ39) AppleWebKit/535.19 (KHTML, like Gecko) Silk/3.13 Safari/535.19 Silk-Accelerated=true",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"LG Optimus L70":{name:"LG Optimus L70",userAgent:"Mozilla/5.0 (Linux; U; Android 4.4.2; en-us; LGMS323 Build/KOT49I.MS32310c) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:1.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 550":{name:"Microsoft Lumia 550",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 550) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 950":{name:"Microsoft Lumia 950",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 950) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:4,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 10":{name:"Nexus 10",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 10 Build/MOB31T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 4":{name:"Nexus 4",userAgent:"Mozilla/5.0 (Linux; Android 4.4.2; Nexus 4 Build/KOT49H) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5":{name:"Nexus 5",userAgent:"Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5X":{name:"Nexus 5X",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 5X Build/OPR4.170623.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6":{name:"Nexus 6",userAgent:"Mozilla/5.0 (Linux; Android 7.1.1; Nexus 6 Build/N6F26U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6P":{name:"Nexus 6P",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 6P Build/OPP3.170518.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 7":{name:"Nexus 7",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 7 Build/MOB30X) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:600,height:960},viewport:{width:600,height:960},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia Lumia 520":{name:"Nokia Lumia 520",userAgent:"Mozilla/5.0 (compatible; MSIE 10.0; Windows Phone 8.0; Trident/6.0; IEMobile/10.0; ARM; Touch; NOKIA; Lumia 520)",screen:{width:320,height:533},viewport:{width:320,height:533},deviceScaleFactor:1.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia N9":{name:"Nokia N9",userAgent:"Mozilla/5.0 (MeeGo; NokiaN9) AppleWebKit/534.13 (KHTML, like Gecko) NokiaBrowser/8.5.0 Mobile Safari/534.13",screen:{width:480,height:854},viewport:{width:480,height:854},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Pixel 2":{name:"Pixel 2",userAgent:"Mozilla/5.0 (Linux; Android 8.0; Pixel 2 Build/OPD3.170816.012) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:731},viewport:{width:411,height:731},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 2 XL":{name:"Pixel 2 XL",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Pixel 2 XL Build/OPD1.170816.004) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:823},viewport:{width:411,height:823},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 3":{name:"Pixel 3",userAgent:"Mozilla/5.0 (Linux; Android 9; Pixel 3 Build/PQ1A.181105.017.A1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:786},viewport:{width:393,height:786},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4":{name:"Pixel 4",userAgent:"Mozilla/5.0 (Linux; Android 10; Pixel 4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:353,height:745},viewport:{width:353,height:745},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4a (5G)":{name:"Pixel 4a (5G)",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 4a (5G)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:892},viewport:{width:412,height:765},deviceScaleFactor:2.63,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 5":{name:"Pixel 5",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:851},viewport:{width:393,height:727},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 7":{name:"Pixel 7",userAgent:"Mozilla/5.0 (Linux; Android 14; Pixel 7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:915},viewport:{width:412,height:839},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Moto G4":{name:"Moto G4",userAgent:"Mozilla/5.0 (Linux; Android 7.0; Moto G (4)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Desktop Chrome HiDPI":{name:"Desktop Chrome HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge HiDPI":{name:"Desktop Edge HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Firefox HiDPI":{name:"Desktop Firefox HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"},"Desktop Safari":{name:"Desktop Safari",userAgent:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Safari/605.1.15",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"webkit"},"Desktop Chrome":{name:"Desktop Chrome",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome Medium Resolution":{name:"Desktop Chrome Medium Resolution",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome (Branded)":{name:"Desktop Chrome (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Chrome Medium Resolution (Branded)":{name:"Desktop Chrome Medium Resolution (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Edge":{name:"Desktop Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge (Branded)":{name:"Desktop Edge (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Edge Medium Resolution (Branded)":{name:"Desktop Edge Medium Resolution (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Firefox":{name:"Desktop Firefox",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"}};var Ro={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"]},bt=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Ro[e].map(a=>Do[a]).filter(a=>a.defaultBrowserType&&i.includes(a.defaultBrowserType))};var Ec={desktop:{label:"Desktop",type:"desktop",devices:bt("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:bt("mobile")}},Tc={desktop:{label:"Desktop",type:"desktop",devices:bt("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:bt("mobile",!0)}};function Zn(){return{version:"1.0",entries:{}}}var he=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(he||{});var Qn=18e4;var Bo=require("yaml");var zo=require("crypto"),xt=require("yaml");var Oi=require("fs"),Je=require("path"),yt=require("yaml"),vt=require("fs"),Yo=require("path");var ta=5e3;function pe(e){return e.replace(/\\/g,"\\\\").replace(/'/g,"\\'").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/\t/g,"\\t")}function G(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function $c(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Mc(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 Ii(e){let t=$c(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let a=Mc(e);if(a){let n=JSON.stringify(a);return`${t}.locator(${n}).first()`}return null}var Ic=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Pc=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"];function Fo(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:Ic.includes(t)}function Cc(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!Pc.includes(t)}var ee=new Map;function $(e,t){ee.set(e,t)}function Oc(e){return ee.get(e)}function Ue(e,t,i=[]){let a=[...i];return t.locator?a.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&a.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&a.push(`frame_path: ${JSON.stringify(t.frame_path)}`),a.length===0?[`await agent.execAction("${e}", page, {});`]:[`await agent.execAction("${e}", page, {`,...a.map(n=>` ${n},`),"});"]}$("click",e=>{let t=Ii(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??ta;return[`await ${t}.click({ timeout: ${i} });`]});$("click_element",ee.get("click"));$("click_element_by_index",ee.get("click"));$("double_click",e=>Ue("double_click",e));$("double_click_on_element",ee.get("double_click"));$("right_click",e=>Ue("right_click",e));$("right_click_on_element",ee.get("right_click"));$("hover",e=>Ue("hover",e));$("hover_element_by_index",ee.get("hover"));$("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return Ue("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("fill",ee.get("input_text"));$("clear_input",e=>Ue("clear_input",e));$("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});$("send_keys",ee.get("press"));$("send_keys_on_element",e=>{let t=Ii(e),i=e.action_data?.kwargs?.keys||"";if(!t)return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(i)} } },`,"});"];let a=e.action_data?.kwargs?.timeout_ms??ta;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${a} });`]});$("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return Ue("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("scroll",e=>{let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]});$("scroll_down",ee.get("scroll"));$("scroll_up",ee.get("scroll"));$("scroll_element",ee.get("scroll"));$("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});$("scroll_on_element",e=>Ue("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));$("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});$("open_tab",ee.get("go_to_url"));$("go_back",()=>['await agent.execAction("go_back", page, {});']);$("reload_page",()=>['await agent.execAction("reload_page", page, {});']);$("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);$("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);$("verify",(e,t)=>{let i=e.action_data?.kwargs,a=typeof i?.code=="string",n=a?i?.statement||e.action_description:e.action_description||i?.statement;if(a&&n){let r=i.code.split(`
|
|
4359
|
+
`)}`);continue}}return w.log("Generated validation locators passed dual validation"),d}catch(d){w.log(`Failed to generate validation expressions (attempt ${c+1}/${s}): ${d.message}`)}return w.log("Failed to generate valid locators after max retries"),null}finally{o&&await o.close()}}var Oh,Lh,Kn=v(()=>{"use strict";ae();Ce();Oh=5e3,Lh=1e4});var oc={};ze(oc,{LoginType:()=>Gn,checkLocators:()=>ki,createUnsignedInContext:()=>co,generateAndValidateLoginLocators:()=>jn,generateValidationLocators:()=>uo,validateLogin:()=>Si,validateLoginLocators:()=>lo});var rc=v(()=>{"use strict";Kn();ae();ft();Ce();gt();R();ne();ot();ge()});var Uh={};ze(Uh,{VariableStore:()=>ro,WebAgent:()=>mo,configureSdk:()=>pa,createAgentContext:()=>go,defineConfig:()=>hr,shiplightConfig:()=>ur});module.exports=hc(Uh);var cr=X(require("dotenv"),1),dr=require("@playwright/test");var Re=require("fs"),qe=require("path"),Zo=require("glob");var _=require("zod"),yo=_.z.enum(["JS_CODE","AI_MODE"]),Vn=_.z.object({type:yo,expression:_.z.string()}),xo=_.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Ve=_.z.object({uid:_.z.string(),type:xo,comment:_.z.string().optional()}),vo=_.z.object({action_data:_.z.object({action_name:_.z.string(),kwargs:_.z.record(_.z.any()).optional(),args:_.z.array(_.z.any()).optional()}),action_description:_.z.string().optional(),url:_.z.string().optional(),xpath:_.z.string().nullable().optional(),locator:_.z.string().nullable().optional(),css_selector:_.z.string().nullable().optional(),unique_selector:_.z.string().nullable().optional(),element_index:_.z.number().nullable().optional(),frame_path:_.z.array(_.z.any()).optional(),artifacts:_.z.record(_.z.any()).optional(),feedback:_.z.string().optional(),original_browser_use_action:_.z.any().optional()}).passthrough(),_o=Ve.extend({type:_.z.literal("DRAFT"),description:_.z.string()}),ko=Ve.extend({type:_.z.literal("ACTION"),description:_.z.string(),action_entity:vo.optional(),locator:_.z.string().optional(),use_pure_vision:_.z.boolean().optional()}),oe=_.z.lazy(()=>_.z.union([_o,ko,Ve.extend({type:_.z.literal("STEP"),description:_.z.string().optional().default(""),statements:_.z.array(oe),reference_id:_.z.number().optional(),template_path:_.z.string().optional(),template_params:_.z.record(_.z.string()).optional()}),Ve.extend({type:_.z.literal("IF_ELSE"),description:_.z.string().optional(),condition:Vn,then:_.z.array(oe),else:_.z.array(oe).optional()}),Ve.extend({type:_.z.literal("WHILE_LOOP"),description:_.z.string().optional(),condition:Vn,body:_.z.array(oe),timeout_ms:_.z.number().optional()})])),So=_.z.object({name:_.z.string(),statements:_.z.array(oe),teardown:_.z.array(oe).optional(),skip:_.z.union([_.z.boolean(),_.z.string()]).optional(),timeout:_.z.number().optional(),fail:_.z.union([_.z.boolean(),_.z.string()]).optional(),only:_.z.boolean().optional(),slow:_.z.boolean().optional()}),Ai=_.z.object({tests:_.z.array(So).min(1),beforeAll:_.z.array(oe).optional(),afterAll:_.z.array(oe).optional(),beforeEach:_.z.array(oe).optional(),afterEach:_.z.array(oe).optional()}),Xn=_.z.object({comment:_.z.string().optional(),version:_.z.string().optional(),goal:_.z.string().optional(),url:_.z.string().optional(),baseURL:_.z.string().optional(),final_feedback:_.z.string().optional(),completed:_.z.boolean().optional(),success:_.z.boolean().optional(),statements:_.z.array(oe).optional(),teardown:_.z.array(oe).optional(),last_modified_at:_.z.string().optional(),testGroup:Ai.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"});var B=require("yaml"),se=require("uuid");function Yn(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(Yn);let t=e,i=Object.keys(t);if(i.length===1){let n=i[0];if(n.startsWith("{ ")&&n.endsWith(" }")&&t[n]===null)return`{{${n.slice(2,-2)}}}`}let a={};for(let[n,o]of Object.entries(t))a[n]=Yn(o);return a}var Eo=1024*1024;function ke(e){if(e.length>Eo)throw new Error(`YAML input too large (${e.length} bytes, max ${Eo})`);let t=Yn((0,B.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return pc(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:le(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=le(t.teardown));let a=Xn.safeParse(i);if(!a.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(a.error.errors)}`);let n=a.data;return $o(e,n),n}function pc(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 n={tests:i.map(s=>{if(!s.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(s.statements)||s.statements.length===0)throw new Error(`Suite test "${s.name}" must have a non-empty "statements" array`);let l={name:s.name,statements:le(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=le(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(n.beforeAll=le(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(n.afterAll=le(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(n.beforeEach=le(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(n.afterEach=le(t.afterEach));let o=Ai.safeParse(n);if(!o.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(o.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:o.data}}function le(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(mc)}function mc(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 gc(t);if("WHILE"in t)return fc(t);if("STEP"in t)return wc(t);if("VERIFY"in t){let i=t.VERIFY,a={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(a.code=t.js),{uid:(0,se.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:a}}}}if("URL"in t){let i=t.URL,a=t.new_tab===!0?!0:void 0,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,o={url:typeof i=="string"?i:String(i)};return a&&(o.new_tab=!0),n!==void 0&&(o.timeout_seconds=n),{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:o}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,a=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:a}}}}}if("WAIT"in t){let i=t.WAIT,a=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,se.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${a}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${a}s`,action_data:{action_name:"wait",kwargs:{seconds:a}}}}}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 a=typeof t.description=="string"?t.description:"Code block";return{uid:(0,se.v4)(),type:"ACTION",description:a,action_entity:{action_description:a,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",a=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 a=="string"?a:String(a)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...a}=t;return To({...a,action:"function",functionName:i})}if("action"in t)return To(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 Ao(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 gc(e){let t=Ao(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let a={uid:(0,se.v4)(),type:"IF_ELSE",condition:t,then:le(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(a.else=le(e.ELSE)),a}function fc(e){let t=Ao(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let a={uid:(0,se.v4)(),type:"WHILE_LOOP",condition:t,body:le(i)};return typeof e.timeout_ms=="number"&&(a.timeout_ms=e.timeout_ms),a}function wc(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:le(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 a=e.template_params,n={};for(let[o,r]of Object.entries(a))n[o]=String(r);i.template_params=n}return i}var bc=new Set(["action","intent","desc","locator","xpath","use_pure_vision"]);function To(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:"",a=typeof e.locator=="string"?e.locator:void 0,n=typeof e.xpath=="string"?e.xpath:void 0,o=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[c,d]of Object.entries(e))bc.has(c)||(r[c]=d);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:{}}};a&&(s.locator=a),n&&(s.xpath=n);let l={uid:(0,se.v4)(),type:"ACTION",description:i,action_entity:s};return o&&(l.use_pure_vision=!0),l}function $o(e,t){let i;try{i=(0,B.parseDocument)(e)}catch{return}let a=i.contents;if(!a||!(0,B.isMap)(a))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=a.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let n=a,o=n.get("statements",!0);(0,B.isSeq)(o)&&t.statements&&Xe(o,t.statements);let r=n.get("teardown",!0);(0,B.isSeq)(r)&&t.teardown&&Xe(r,t.teardown)}function Xe(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 a=e.items[i];a.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=a.commentBefore);let n=t[i];if(n.type==="STEP"&&(0,B.isMap)(a)){let o=a.get("statements",!0);(0,B.isSeq)(o)&&Xe(o,n.statements)}else if(n.type==="IF_ELSE"&&(0,B.isMap)(a)){let o=a.get("THEN",!0);(0,B.isSeq)(o)&&Xe(o,n.then);let r=a.get("ELSE",!0);(0,B.isSeq)(r)&&n.else&&Xe(r,n.else)}else if(n.type==="WHILE_LOOP"&&(0,B.isMap)(a)){let o=a.get("DO",!0);(0,B.isSeq)(o)&&Xe(o,n.body)}}}var Mo=require("yaml");var Jn=e=>{let t=[];switch(e.type){case"STEP":e.statements&&t.push({key:"statements",statements:e.statements});break;case"IF_ELSE":e.then&&t.push({key:"then",statements:e.then}),e.else&&t.push({key:"else",statements:e.else});break;case"WHILE_LOOP":e.body&&t.push({key:"body",statements:e.body});break}return t};var $i=e=>{let t=[],i=a=>{for(let n of a){t.push(n);let o=Jn(n);for(let r of o)i(r.statements)}};return i(e),t};var yc=.5,Io=5,Po=3,Oo=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"]);function Lo(e){let t=0,i=0;for(let a of e)if(a.type==="DRAFT")i++;else if(a.type==="ACTION"){let n=a.action_entity?.action_data?.action_name??"";Oo.has(n)||t++}return{action:t,draft:i}}function xc(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function Co(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function vc(e){let t=e.split(/\r?\n/).map(o=>o.trim()).filter(o=>o.length>0&&!o.startsWith("//")),i=t.length,a=t.join(`
|
|
4360
|
+
`).match(/\bawait\b/g),n=a?a.length:0;return i<=Io&&n<=Po?null:`${i} non-blank line(s), ${n} await(s) \u2014 limits are ${Io} lines and ${Po} 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 qn(e,t){let i=t?.coverageThreshold??yc,a=[],n=[],o;try{o=ke(e)}catch(m){return{valid:!1,errors:[`Invalid YAML: ${m.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}o.goal||a.push('Missing required field: "goal"'),o.statements?.length||a.push('Missing required field: "statements"');let r=[...$i(o.statements??[]),...o.teardown?$i(o.teardown):[]],{action:s,draft:l}=Lo(r),c="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 f=g.description||m.uid;a.push(`Unresolved cloud template reference on statement "${f}" (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 f=m,y=f.action_entity?.action_data?.action_name??"";if(y==="js_code"||y==="js_action"||y==="verify"||y==="ai_assert"){let b=f.action_entity?.action_data?.kwargs?.code;if(typeof b=="string"){let p=xc(b);if(p){let x=f.description||y;a.push(`Invalid JS in "${x}": ${p}. ${c}`)}else if(y==="verify"){let x=vc(b);if(x){let S=f.description||y;a.push(`JS cache for "${S}" is too complex: ${x}`)}}}}}if(m.type==="IF_ELSE"){let f=m;if(f.condition.type==="JS_CODE"){let y=Co(f.condition.expression);y&&a.push(`Invalid JS in IF condition "${f.condition.expression}": ${y}. ${c}`)}}if(m.type==="WHILE_LOOP"){let f=m;if(f.condition.type==="JS_CODE"){let y=Co(f.condition.expression);y&&a.push(`Invalid JS in WHILE condition "${f.condition.expression}": ${y}. ${c}`)}}}let d=s+l,h=d>0?Math.round(s/d*100):0;return d>0&&h/100<i&&n.push(`Low action coverage: ${s}/${d} statements (${h}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:a.length===0,errors:a,warnings:n,stats:{total:d,action:s,draft:l,coverage:h}}}function Zn(){return{version:"1.0",entries:{}}}var _c=require("uuid");var he=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(he||{});var Qn=18e4;var No=112;var Sc=1080-No;var Do={"Blackberry PlayBook":{name:"Blackberry PlayBook",userAgent:"Mozilla/5.0 (PlayBook; U; RIM Tablet OS 2.1.0; en-US) AppleWebKit/536.2+ (KHTML like Gecko) Version/26.0 Safari/536.2+",screen:{width:600,height:1024},viewport:{width:600,height:1024},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"BlackBerry Z30":{name:"BlackBerry Z30",userAgent:"Mozilla/5.0 (BB10; Touch) AppleWebKit/537.10+ (KHTML, like Gecko) Version/26.0 Mobile Safari/537.10+",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note 3":{name:"Galaxy Note 3",userAgent:"Mozilla/5.0 (Linux; U; Android 4.3; en-us; SM-N900T Build/JSS15J) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note II":{name:"Galaxy Note II",userAgent:"Mozilla/5.0 (Linux; U; Android 4.1; en-us; GT-N7100 Build/JRO03C) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S III":{name:"Galaxy S III",userAgent:"Mozilla/5.0 (Linux; U; Android 4.0; en-us; GT-I9300 Build/IMM76D) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S5":{name:"Galaxy S5",userAgent:"Mozilla/5.0 (Linux; Android 5.0; SM-G900P Build/LRX21T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S8":{name:"Galaxy S8",userAgent:"Mozilla/5.0 (Linux; Android 7.0; SM-G950U Build/NRD90M) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:740},viewport:{width:360,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S9+":{name:"Galaxy S9+",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; SM-G965U Build/R16NW) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:320,height:658},viewport:{width:320,height:658},deviceScaleFactor:4.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S24":{name:"Galaxy S24",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-S921U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:780},viewport:{width:360,height:780},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy A55":{name:"Galaxy A55",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-A556B) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:480,height:1040},viewport:{width:480,height:1040},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S4":{name:"Galaxy Tab S4",userAgent:"Mozilla/5.0 (Linux; Android 8.1.0; SM-T837A) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:712,height:1138},viewport:{width:712,height:1138},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S9":{name:"Galaxy Tab S9",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-X710) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:640,height:1024},viewport:{width:640,height:1024},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"iPad (gen 5)":{name:"iPad (gen 5)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 6)":{name:"iPad (gen 6)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 7)":{name:"iPad (gen 7)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:810,height:1080},viewport:{width:810,height:1080},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 11)":{name:"iPad (gen 11)",userAgent:"Mozilla/5.0 (iPad; CPU OS 18_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/604.1",screen:{width:656,height:944},viewport:{width:656,height:944},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Mini":{name:"iPad Mini",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Pro 11":{name:"iPad Pro 11",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:834,height:1194},viewport:{width:834,height:1194},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6":{name:"iPhone 6",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6 Plus":{name:"iPhone 6 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7":{name:"iPhone 7",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7 Plus":{name:"iPhone 7 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8":{name:"iPhone 8",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8 Plus":{name:"iPhone 8 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE":{name:"iPhone SE",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_1 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/14E304 Safari/602.1",screen:{width:320,height:568},viewport:{width:320,height:568},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE (3rd gen)":{name:"iPhone SE (3rd gen)",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 18_5 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/602.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone X":{name:"iPhone X",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:812},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone XR":{name:"iPhone XR",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:896},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11":{name:"iPhone 11",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro":{name:"iPhone 11 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:635},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro Max":{name:"iPhone 11 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12":{name:"iPhone 12",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro":{name:"iPhone 12 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro Max":{name:"iPhone 12 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Mini":{name:"iPhone 12 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13":{name:"iPhone 13",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro":{name:"iPhone 13 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro Max":{name:"iPhone 13 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Mini":{name:"iPhone 13 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14":{name:"iPhone 14",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Plus":{name:"iPhone 14 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro":{name:"iPhone 14 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:660},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro Max":{name:"iPhone 14 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15":{name:"iPhone 15",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Plus":{name:"iPhone 15 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro":{name:"iPhone 15 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro Max":{name:"iPhone 15 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Kindle Fire HDX":{name:"Kindle Fire HDX",userAgent:"Mozilla/5.0 (Linux; U; en-us; KFAPWI Build/JDQ39) AppleWebKit/535.19 (KHTML, like Gecko) Silk/3.13 Safari/535.19 Silk-Accelerated=true",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"LG Optimus L70":{name:"LG Optimus L70",userAgent:"Mozilla/5.0 (Linux; U; Android 4.4.2; en-us; LGMS323 Build/KOT49I.MS32310c) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:1.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 550":{name:"Microsoft Lumia 550",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 550) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 950":{name:"Microsoft Lumia 950",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 950) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:4,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 10":{name:"Nexus 10",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 10 Build/MOB31T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 4":{name:"Nexus 4",userAgent:"Mozilla/5.0 (Linux; Android 4.4.2; Nexus 4 Build/KOT49H) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5":{name:"Nexus 5",userAgent:"Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5X":{name:"Nexus 5X",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 5X Build/OPR4.170623.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6":{name:"Nexus 6",userAgent:"Mozilla/5.0 (Linux; Android 7.1.1; Nexus 6 Build/N6F26U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6P":{name:"Nexus 6P",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 6P Build/OPP3.170518.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 7":{name:"Nexus 7",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 7 Build/MOB30X) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:600,height:960},viewport:{width:600,height:960},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia Lumia 520":{name:"Nokia Lumia 520",userAgent:"Mozilla/5.0 (compatible; MSIE 10.0; Windows Phone 8.0; Trident/6.0; IEMobile/10.0; ARM; Touch; NOKIA; Lumia 520)",screen:{width:320,height:533},viewport:{width:320,height:533},deviceScaleFactor:1.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia N9":{name:"Nokia N9",userAgent:"Mozilla/5.0 (MeeGo; NokiaN9) AppleWebKit/534.13 (KHTML, like Gecko) NokiaBrowser/8.5.0 Mobile Safari/534.13",screen:{width:480,height:854},viewport:{width:480,height:854},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Pixel 2":{name:"Pixel 2",userAgent:"Mozilla/5.0 (Linux; Android 8.0; Pixel 2 Build/OPD3.170816.012) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:731},viewport:{width:411,height:731},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 2 XL":{name:"Pixel 2 XL",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Pixel 2 XL Build/OPD1.170816.004) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:823},viewport:{width:411,height:823},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 3":{name:"Pixel 3",userAgent:"Mozilla/5.0 (Linux; Android 9; Pixel 3 Build/PQ1A.181105.017.A1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:786},viewport:{width:393,height:786},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4":{name:"Pixel 4",userAgent:"Mozilla/5.0 (Linux; Android 10; Pixel 4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:353,height:745},viewport:{width:353,height:745},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4a (5G)":{name:"Pixel 4a (5G)",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 4a (5G)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:892},viewport:{width:412,height:765},deviceScaleFactor:2.63,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 5":{name:"Pixel 5",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:851},viewport:{width:393,height:727},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 7":{name:"Pixel 7",userAgent:"Mozilla/5.0 (Linux; Android 14; Pixel 7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:915},viewport:{width:412,height:839},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Moto G4":{name:"Moto G4",userAgent:"Mozilla/5.0 (Linux; Android 7.0; Moto G (4)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Desktop Chrome HiDPI":{name:"Desktop Chrome HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge HiDPI":{name:"Desktop Edge HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Firefox HiDPI":{name:"Desktop Firefox HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"},"Desktop Safari":{name:"Desktop Safari",userAgent:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Safari/605.1.15",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"webkit"},"Desktop Chrome":{name:"Desktop Chrome",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome Medium Resolution":{name:"Desktop Chrome Medium Resolution",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome (Branded)":{name:"Desktop Chrome (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Chrome Medium Resolution (Branded)":{name:"Desktop Chrome Medium Resolution (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Edge":{name:"Desktop Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge (Branded)":{name:"Desktop Edge (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Edge Medium Resolution (Branded)":{name:"Desktop Edge Medium Resolution (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Firefox":{name:"Desktop Firefox",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"}};var Ro={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"]},bt=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Ro[e].map(a=>Do[a]).filter(a=>a.defaultBrowserType&&i.includes(a.defaultBrowserType))};var Ec={desktop:{label:"Desktop",type:"desktop",devices:bt("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:bt("mobile")}},Tc={desktop:{label:"Desktop",type:"desktop",devices:bt("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:bt("mobile",!0)}};var Bo=require("yaml");var zo=require("crypto"),xt=require("yaml");var Oi=require("fs"),Je=require("path"),yt=require("yaml"),vt=require("fs"),Yo=require("path");var ta=5e3;function pe(e){return e.replace(/\\/g,"\\\\").replace(/'/g,"\\'").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/\t/g,"\\t")}function G(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function $c(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Mc(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 Ii(e){let t=$c(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let a=Mc(e);if(a){let n=JSON.stringify(a);return`${t}.locator(${n}).first()`}return null}var Ic=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Pc=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"];function Fo(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:Ic.includes(t)}function Cc(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!Pc.includes(t)}var ee=new Map;function $(e,t){ee.set(e,t)}function Oc(e){return ee.get(e)}function Ue(e,t,i=[]){let a=[...i];return t.locator?a.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&a.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&a.push(`frame_path: ${JSON.stringify(t.frame_path)}`),a.length===0?[`await agent.execAction("${e}", page, {});`]:[`await agent.execAction("${e}", page, {`,...a.map(n=>` ${n},`),"});"]}$("click",e=>{let t=Ii(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??ta;return[`await ${t}.click({ timeout: ${i} });`]});$("click_element",ee.get("click"));$("click_element_by_index",ee.get("click"));$("double_click",e=>Ue("double_click",e));$("double_click_on_element",ee.get("double_click"));$("right_click",e=>Ue("right_click",e));$("right_click_on_element",ee.get("right_click"));$("hover",e=>Ue("hover",e));$("hover_element_by_index",ee.get("hover"));$("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return Ue("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("fill",ee.get("input_text"));$("clear_input",e=>Ue("clear_input",e));$("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});$("send_keys",ee.get("press"));$("send_keys_on_element",e=>{let t=Ii(e),i=e.action_data?.kwargs?.keys||"";if(!t)return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(i)} } },`,"});"];let a=e.action_data?.kwargs?.timeout_ms??ta;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${a} });`]});$("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return Ue("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("scroll",e=>{let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]});$("scroll_down",ee.get("scroll"));$("scroll_up",ee.get("scroll"));$("scroll_element",ee.get("scroll"));$("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});$("scroll_on_element",e=>Ue("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));$("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});$("open_tab",ee.get("go_to_url"));$("go_back",()=>['await agent.execAction("go_back", page, {});']);$("reload_page",()=>['await agent.execAction("reload_page", page, {});']);$("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);$("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);$("verify",(e,t)=>{let i=e.action_data?.kwargs,a=typeof i?.code=="string",n=a?i?.statement||e.action_description:e.action_description||i?.statement;if(a&&n){let r=i.code.split(`
|
|
4361
4361
|
`),s=JSON.stringify(n);return["{ const _t = Date.now(); try {",...r.map(l=>` ${l}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${s}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${s}\`);`,` await agent.assert(page, ${s}, ${JSON.stringify(t||"")});`,"} }"]}return a?i.code.split(`
|
|
4362
4362
|
`):n?[`await agent.assert(page, ${JSON.stringify(n)}, ${JSON.stringify(t||"")});`]:["// Skipping verify: missing statement or code"]});$("ai_assert",ee.get("verify"));$("assert",ee.get("verify"));$("ai_action",(e,t)=>{let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let a=JSON.stringify(i),n=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${a}, '${t||""}', ${n});`]});$("ai_step",(e,t)=>{let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]});$("ai_extract",(e,t)=>{let i=e.action_data?.kwargs?.element_description,a=e.action_data?.kwargs?.variable_name;if(!i||!a)return["// Skipping ai_extract: missing element_description or variable_name"];let n=JSON.stringify(i),o=JSON.stringify(a);return[`await agent.extract(page, ${n}, ${o}, '${t||""}');`]});$("ai_wait_until",(e,t)=>{let i=e.action_data?.kwargs?.condition,a=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${a}, '${t||""}');`]:["// Skipping ai_wait_until: missing condition"]});$("save_variable",e=>{let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]});$("js_code",e=>{let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],a=t.split(`
|
|
4363
4363
|
`);for(let n of a)i.push(` ${n}`);return i.push("}"),i});$("function",(e,t,i)=>{let a=e.action_data?.kwargs||{},n=a.functionName;if(n&&n.includes("#")){let[r,s]=n.split("#");if(r&&s){let l=r.replace(/\.(ts|js|mjs)$/,""),c=`import { ${s} } from '${l}';`;i?.imports?.add(c);let d={...a,functionName:s},h=Ho(d);return h?[h.endsWith(";")?h:`${h};`]:["// Skipping function: invalid export pattern"]}}let o=Ho(a);return o?[o.endsWith(";")?o:`${o};`]:["// Skipping function: missing functionName"]});$("generate_2fa_code",e=>{let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]});$("upload_file",e=>{let t=e.action_data?.kwargs||{},i=[],a={};return t.paths?a.paths=t.paths:t.path&&(a.path=t.path),t.use_file_input&&(a.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(a)} }`),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(n=>` ${n},`),"});"]});$("wait_for_download_complete",e=>['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]);$("switch_tab",e=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]);$("close_tab",e=>{let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]});$("set_date_for_native_date_picker",e=>{let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(a=>` ${a},`),"});"]});$("done",()=>["// Done - no action needed"]);function ia(e,t){let i=t.action_data?.kwargs||{},a=[];return typeof i.relative_x=="number"&&typeof i.relative_y=="number"?(a.push(`action_data: { kwargs: { relative_x: ${i.relative_x}, relative_y: ${i.relative_y} } }`),t.locator?a.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&a.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&a.push(`frame_path: ${JSON.stringify(t.frame_path)}`)):typeof i.x=="number"&&typeof i.y=="number"&&a.push(`action_data: { kwargs: { x: ${i.x}, y: ${i.y} } }`),[`await agent.execAction("${e}", page, {`,...a.map(n=>` ${n},`),"});"]}$("click_by_coordinates",e=>ia("click_by_coordinates",e));$("right_click_by_coordinates",e=>ia("right_click_by_coordinates",e));$("double_click_by_coordinates",e=>ia("double_click_by_coordinates",e));$("drag_drop",e=>{let t=e.action_data?.kwargs||{},i={};typeof t.relative_x=="number"&&(i.relative_x=t.relative_x),typeof t.relative_y=="number"&&(i.relative_y=t.relative_y),typeof t.delta_x=="number"&&(i.delta_x=t.delta_x),typeof t.delta_y=="number"&&(i.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(i.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(i.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(i.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(i.coord_target_y=t.coord_target_y);let a=[`action_data: { kwargs: ${JSON.stringify(i)} }`];return e.locator?a.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&a.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&a.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...a.map(n=>` ${n},`),"});"]});$("get_dropdown_options",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},`),"});"]});$("extract_email_content",e=>{let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]});$("js_action",e=>{let t=e.action_data?.kwargs?.code;return t?t.split(`
|
|
@@ -4365,7 +4365,7 @@ ${m.join(`
|
|
|
4365
4365
|
`)}function Bc(e,t){let i=[],a=t?.version||"unknown";i.push(`// @generated by shiplightai v${a}`),i.push(...jo()),i.push(""),t?.use&&Object.keys(t.use).length>0&&(i.push(`test.use(${JSON.stringify(t.use,null,2)});`),i.push(""));let n=new Set,o={imports:n,actionEntityStore:t?.actionEntityStore},r=t?.testName||"Test Suite",s=ea(t?.tags);i.push(`test.describe.serial('${s}${pe(r)}', () => {`),e.beforeAll&&e.beforeAll.length>0&&(i.push(...Mi("beforeAll",e.beforeAll,o,1)),i.push("")),e.beforeEach&&e.beforeEach.length>0&&(i.push(...Mi("beforeEach",e.beforeEach,o,1)),i.push(""));for(let c=0;c<e.tests.length;c++){let d=e.tests[c],h=d.timeout||d.skip!==void 0||d.fail!==void 0||d.only||d.slow?{timeout:d.timeout,skip:d.skip,fail:d.fail,only:d.only,slow:d.slow}:void 0;if(d.parameters&&d.parameters.length>0)for(let m of d.parameters)i.push(...Ci(d.testFlow,`${pe(d.name)} [${pe(m.name)}]`,o,1,h,m.name,m.values)),i.push("");else i.push(...Ci(d.testFlow,pe(d.name),o,1,h)),(c<e.tests.length-1||e.afterEach||e.afterAll)&&i.push("")}return e.afterEach&&e.afterEach.length>0&&(i.push(...Mi("afterEach",e.afterEach,o,1)),i.push("")),e.afterAll&&e.afterAll.length>0&&i.push(...Mi("afterAll",e.afterAll,o,1)),i.push("});"),Ko(i,n),i.join(`
|
|
4366
4366
|
`)}function ea(e){return e&&e.length>0?e.map(t=>`@${t}`).join(" ")+" ":""}var Gc=["testContext","request"];function Pi(e){let t=new Set;function i(a){for(let n of a)switch(n.type){case he.ACTION:{let r=n.action_entity?.action_data?.kwargs;if(r?.args&&Array.isArray(r.args))for(let s of r.args)typeof s=="string"&&Gc.includes(s)&&t.add(s);break}case he.STEP:i(n.statements);break;case he.IF_ELSE:{let o=n;i(o.then),o.else&&i(o.else);break}case he.WHILE_LOOP:i(n.body);break}}return i(e),t}function jc(e){let t=Pi(e.statements??[]);if(e.teardown)for(let i of Pi(e.teardown))t.add(i);return t}function na(e){return`{ ${["page","agent",...Array.from(e).sort()].join(", ")} }`}function Ci(e,t,i,a=0,n,o,r){let s=" ".repeat(a),l=[],c=jc(e),d=na(c),h=n?.only?"test.only":"test",m=o?`, { tag: '@${pe(o)}' }`:"";if(l.push(`${s}${h}('${t}'${m}, async (${d}) => {`),n?.skip===!0?l.push(`${s} test.skip();`):typeof n?.skip=="string"&&l.push(`${s} test.skip(true, '${pe(n.skip)}');`),n?.fail===!0?l.push(`${s} test.fail();`):typeof n?.fail=="string"&&l.push(`${s} test.fail(true, '${pe(n.fail)}');`),n?.slow&&l.push(`${s} test.slow();`),n?.timeout&&l.push(`${s} test.setTimeout(${n.timeout});`),r){for(let[y,b]of Object.entries(r))l.push(`${s} agent.agentServices.saveVariable(${JSON.stringify(y)}, ${JSON.stringify(b)});`);l.push("")}let g=e.teardown&&e.teardown.length>0,f=a+1;if(g){if(l.push(`${s} try {`),e.statements&&e.statements.length>0){l.push(`${s} // Test steps`);let b=me(e.statements,f+1,i);l.push(...b)}l.push(`${s} } finally {`),l.push(`${s} // Teardown`);let y=me(e.teardown,f+1,i,"teardown");l.push(...y),l.push(`${s} }`)}else if(e.statements&&e.statements.length>0){l.push(`${s} // Test steps`);let y=me(e.statements,f,i);l.push(...y)}return l.push(`${s}});`),l}function Wo(e,t,i){let a=[],n=Go(t),o=Pi(n),r=na(o);return a.push(`test.${e}(async (${r}) => {`),a.push(...me(n,1,i,e)),a.push("});"),a}function Mi(e,t,i,a){let n=" ".repeat(a),o=[],r=Go(t);if(e==="beforeAll"||e==="afterAll"){let l={...i,noAgent:!0};o.push(`${n}test.${e}(async ({ browser }, workerInfo) => {`),o.push(`${n} const page = await browser.newPage({ baseURL: workerInfo.project.use.baseURL });`),o.push(...me(r,a+1,l,e)),o.push(`${n} await page.close();`),o.push(`${n}});`)}else{let l=Pi(r),c=na(l);o.push(`${n}test.${e}(async (${c}) => {`),o.push(...me(r,a+1,i,e)),o.push(`${n}});`)}return o}function Go(e){let i=(0,Bo.stringify)({goal:"_hook",statements:e});return ke(i).statements??[]}function jo(){return["import { test, expect } from 'shiplightai/fixture';"]}function Ko(e,t){if(t.size>0){let i=0;for(let n=0;n<e.length;n++)e[n].startsWith("import ")&&(i=n+1);let a=Array.from(t);e.splice(i,0,...a)}}var Uo=5;function Vo(e,t,i){let a={expandingPaths:new Set([(0,Je.resolve)(t)]),depth:0,referencedPaths:new Set,basePath:i},n={...e};Array.isArray(n.statements)&&(n.statements=De(n.statements,t,a)),Array.isArray(n.teardown)&&(n.teardown=De(n.teardown,t,a));for(let o of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(n[o])&&(n[o]=De(n[o],t,a));return{doc:n,referencedTemplatePaths:Array.from(a.referencedPaths)}}function De(e,t,i){let a=[];for(let n of e)if(Kc(n)){let o=zc(n,t,i);a.push(o)}else a.push(Vc(n,t,i));return a}function Kc(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function zc(e,t,i){if(i.depth>=Uo)throw new Error(`Template expansion exceeded maximum depth of ${Uo}. Check for deeply nested or circular template references.`);let a=(0,Je.resolve)((0,Je.dirname)(t),e.template),n=!(0,Oi.existsSync)(a)&&i.basePath?(0,Je.resolve)(i.basePath,e.template):a;if(i.expandingPaths.has(n))throw new Error(`Circular template reference detected: ${n} is already being expanded. Stack: ${Array.from(i.expandingPaths).join(" \u2192 ")} \u2192 ${n}`);i.referencedPaths.add(n);let o;try{o=(0,Oi.readFileSync)(n,"utf-8")}catch(f){throw new Error(`Failed to read template file: ${n} (referenced from ${t}): ${f.message}`)}let r=(0,yt.parse)(o);if(!r||typeof r!="object")throw new Error(`Invalid template file: ${n} \u2014 expected a YAML object`);let s=r.params||[],l=e.params||{};for(let f of s)if(!(f in l))throw new Error(`Template ${e.template} requires param "${f}" but it was not provided. Required params: [${s.join(", ")}]`);let c=r.statements;if(!Array.isArray(c))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(l).length>0){let y=(0,yt.stringify)(c);for(let[b,p]of Object.entries(l))y=y.split(`<<${b}>>`).join(String(p));c=(0,yt.parse)(y)}let d={expandingPaths:new Set([...i.expandingPaths,n]),depth:i.depth+1,referencedPaths:i.referencedPaths},h=De(c,n,d),g={STEP:r.name||e.template.replace(/\.yaml$/,"").split("/").pop()||e.template,template_path:e.template,statements:h};return Object.keys(l).length>0&&(g.template_params=l),g}function Vc(e,t,i){if(typeof e!="object"||e===null)return e;let a={...e};return Array.isArray(a.statements)&&(a.statements=De(a.statements,t,i)),Array.isArray(a.THEN)&&(a.THEN=De(a.THEN,t,i)),Array.isArray(a.ELSE)&&(a.ELSE=De(a.ELSE,t,i)),Array.isArray(a.DO)&&(a.DO=De(a.DO,t,i)),a}var aa=class extends Error{constructor(e){super(e),this.name="YamlValidationError"}};function oa(e,t,i){let a=(0,xt.parse)(e),n=a?.name,o=a?.tags,r=a?.use;if(a&&(a.name!==void 0||a.tags!==void 0||a.use!==void 0)&&(delete a.name,delete a.tags,delete a.use),a?.suite){if(a.goal||a.statements)throw new aa('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return Yc(a,n,o,r,t,i)}return Xc(a,n,o,r,t,i)}function Xc(e,t,i,a,n,o){let r=e?.beforeEach,s=e?.afterEach,l=Xo(e?.parameters),c=e?.timeout,d=e?.skip,h=e?.fail,m=e?.only,g=e?.slow;if(e&&(delete e.beforeEach,delete e.afterEach,delete e.parameters,delete e.timeout,delete e.skip,delete e.fail,delete e.only,delete e.slow),e?.url)throw new aa(`The "url" field is not supported in local YAML tests. Use "base_url: ${e.url}" and add "- URL: /" as the first statement instead.`);e&&!e.goal&&t&&(e.goal=t);let f=[];if(n&&e&&typeof e=="object"){let p=Vo(e,n,o);e=p.doc,f=p.referencedTemplatePaths}let y=(0,xt.stringify)(e),b=ke(y);return n&&(Ye(b.statements??[],n,"main"),b.teardown&&Ye(b.teardown,n,"teardown")),{testFlow:b,name:t,tags:i,use:a,beforeEach:r,afterEach:s,parameters:l,timeout:c,skip:d,fail:h,only:m,slow:g,referencedTemplatePaths:f}}function Yc(e,t,i,a,n,o){let r=e.suite;if(!Array.isArray(r.tests)||r.tests.length===0)throw new Error('Suite must have a non-empty "tests" array.');let s=r.beforeAll,l=r.afterAll,c=r.beforeEach,d=r.afterEach,h=[],m=r.tests.map(y=>{if(!y.name)throw new Error('Each test in a suite must have a "name" field.');if(!Array.isArray(y.statements)||y.statements.length===0)throw new Error(`Suite test "${y.name}" must have a non-empty "statements" array.`);let b={goal:y.name,statements:y.statements};y.teardown&&(b.teardown=y.teardown);let p=[],x=b;if(n&&typeof b=="object"){let M=Vo(b,n,o);x=M.doc,p=M.referencedTemplatePaths,h.push(...p)}let S=(0,xt.stringify)(x),E=ke(S),A=Xo(y.parameters);return{testFlow:E,name:y.name,tags:Array.isArray(y.tags)?y.tags:void 0,parameters:A,timeout:y.timeout,skip:y.skip,fail:y.fail,only:y.only,slow:y.slow}}),g=r.base_url,f=g?{...a,baseURL:g}:a;return{suite:{beforeAll:s,afterAll:l,beforeEach:c,afterEach:d,tests:m},name:t,tags:i,use:f,referencedTemplatePaths:h}}function Xo(e){if(!(!Array.isArray(e)||e.length===0))return e.map((t,i)=>{if(!t.name)throw new Error(`Parameter set at index ${i} must have a "name" field.`);if(!t.values||typeof t.values!="object")throw new Error(`Parameter set "${t.name}" must have a "values" object.`);return{name:t.name,values:t.values}})}function Ye(e,t,i){for(let a=0;a<e.length;a++){let n=e[a],o=`${i}.${a}`,r=n.description||"";if(n.uid=Jc(t,o,r),n.type===he.STEP)Ye(n.statements,t,o);else if(n.type===he.IF_ELSE){let s=n;Ye(s.then,t,`${o}.then`),s.else&&Ye(s.else,t,`${o}.else`)}else n.type===he.WHILE_LOOP&&Ye(n.body,t,`${o}.body`)}}function Jc(e,t,i){let a=(0,zo.createHash)("sha256").update(`${e}:${t}:${i}`).digest("hex");return`${a.slice(0,8)}-${a.slice(8,12)}-${a.slice(12,16)}-${a.slice(16,20)}-${a.slice(20,32)}`}function Jo(e,t,i){let a=/\btemplate:\s/.test(e),n=/^suite:/m.test(e),o=a||n?null:qn(e);if(o&&!o.valid)return{valid:!1,errors:o.errors,warnings:[],stats:o.stats};let r,s,l=[];try{let c=i?.parsed??oa(e,t,i?.basePath);l=c.referencedTemplatePaths;let d={version:i?.version,actionEntityStore:i?.actionEntityStore},h=c.testFlow?.baseURL?{...c.use,baseURL:c.testFlow.baseURL}:c.use;c.suite?r=Bc(c.suite,{...d,testName:c.name,tags:c.tags,use:c.use}):r=Uc(c.testFlow,{...d,testName:c.name,tags:c.tags,use:h,beforeEach:c.beforeEach,afterEach:c.afterEach,parameters:c.parameters,timeout:c.timeout,skip:c.skip,fail:c.fail,only:c.only,slow:c.slow});let m=r.split(`
|
|
4367
4367
|
`).filter(g=>!g.startsWith("import ")).join(`
|
|
4368
|
-
`);new Function(m),s=t.replace(/\.test\.yaml$/,".yaml.spec.ts"),(0,vt.mkdirSync)((0,Yo.dirname)(s),{recursive:!0}),(0,vt.writeFileSync)(s,r)}catch(c){let d=c instanceof aa?"":c.message.includes("Unexpected token")?" This usually means a YAML escaping issue \u2014 in double-quoted strings, use \\\\/ instead of \\/ for regex patterns, or use single quotes / block scalars.":" This may indicate a transpiler bug \u2014 please report it.";return{valid:!1,errors:[`Transpilation failed: ${c.message}.${d}`],warnings:[],stats:o?.stats??{total:0,action:0,draft:0,coverage:0},referencedTemplatePaths:l}}return{valid:!0,errors:[],warnings:o?.warnings??[],stats:o?.stats??{total:0,action:0,draft:0,coverage:0},specFile:s,referencedTemplatePaths:l}}var ra="0.1.
|
|
4368
|
+
`);new Function(m),s=t.replace(/\.test\.yaml$/,".yaml.spec.ts"),(0,vt.mkdirSync)((0,Yo.dirname)(s),{recursive:!0}),(0,vt.writeFileSync)(s,r)}catch(c){let d=c instanceof aa?"":c.message.includes("Unexpected token")?" This usually means a YAML escaping issue \u2014 in double-quoted strings, use \\\\/ instead of \\/ for regex patterns, or use single quotes / block scalars.":" This may indicate a transpiler bug \u2014 please report it.";return{valid:!1,errors:[`Transpilation failed: ${c.message}.${d}`],warnings:[],stats:o?.stats??{total:0,action:0,draft:0,coverage:0},referencedTemplatePaths:l}}return{valid:!0,errors:[],warnings:o?.warnings??[],stats:o?.stats??{total:0,action:0,draft:0,coverage:0},specFile:s,referencedTemplatePaths:l}}var ra="0.1.77";function qo(e){try{return(0,Re.statSync)(e).mtimeMs}catch{return 0}}var qc=`// @generated by shiplightai v${ra}`;function Zc(e,t){if(!(0,Re.existsSync)(e)||(0,Re.readFileSync)(e,"utf-8").split(`
|
|
4369
4369
|
`,1)[0]!==qc)return!1;let a=qo(e);for(let n of t)if(qo(n)>a)return!1;return!0}function Qc(e){let t=process.argv.slice(2),i=[],a=(0,qe.resolve)(e);for(let n of t){if(n.startsWith("-"))continue;let o=n.endsWith(".yaml.spec.ts")?n.replace(/\.yaml\.spec\.ts$/,".test.yaml"):n;if(!o.endsWith(".test.yaml"))continue;let r=(0,qe.resolve)(e,o);(0,Re.existsSync)(r)&&i.push(r.startsWith(a)?r.slice(a.length+1):o)}return i.length>0?i:null}function Qo(e){let t=Qc(e.cwd),i=t??(0,Zo.globSync)("**/*.test.yaml",{cwd:e.cwd,ignore:["**/node_modules/**"]}),a=[];for(let n of i){let o=(0,qe.resolve)(e.cwd,n),r=o.replace(/\.test\.yaml$/,".yaml.spec.ts"),s=(0,Re.readFileSync)(o,"utf-8");try{let l=oa(s,o,e.projectRoot??e.cwd),c=(0,qe.relative)(e.cwd,o),d=e.actionEntityStores?.get(c)??e.actionEntityStores?.get("*");if(!(d&&Object.keys(d.entries).length>0)&&Zc(r,[o,...l.referencedTemplatePaths]))continue;let m=Jo(s,o,{version:ra,actionEntityStore:d,parsed:l});if(!m.valid)throw new Error(m.errors.join("; "))}catch(l){console.error(`[shiplight] Failed to transpile ${n}:`,l),a.push({file:n,error:l})}}if(a.length>0){let n=`[shiplight] Transpilation failed for ${a.length} file(s):
|
|
4370
4370
|
`+a.map(o=>` - ${o.file}`).join(`
|
|
4371
4371
|
`);if(t)throw new Error(n);console.warn(n+" (skipped)")}}var re=X(require("fs"),1),_t=X(require("path"),1),sr=require("glob");Di();function lr(e){let t=Ni().SHIPLIGHT_API_TOKEN;return process.env.CI&&t?new ua:new da(e)}var cd=".shiplight/action-cache";function rr(e){return e.replace(/\//g,"__")+".json"}function dd(e){return e.replace(/\.json$/,"").replace(/__/g,"/")}var da=class{constructor(t){this.cwd=t;this.cacheDir=_t.join(t,cd)}isCloud=!1;cacheDir;async lookup(t){let i=new Map;if(t.length===0||!re.existsSync(this.cacheDir))return i;for(let a of t){let n=_t.join(this.cacheDir,rr(a));try{if(re.existsSync(n)){let o=re.readFileSync(n,"utf-8");i.set(a,JSON.parse(o))}}catch{}}return i}async update(t){if(t.size===0)return 0;re.mkdirSync(this.cacheDir,{recursive:!0});let i=0;for(let[a,n]of t)try{let o=_t.join(this.cacheDir,rr(a)),r=Zn();if(re.existsSync(o))try{r=JSON.parse(re.readFileSync(o,"utf-8"))}catch{}let s={...r,entries:{...r.entries,...n.entries}};re.writeFileSync(o,JSON.stringify(s,null,2)),i++}catch{}return i}loadAll(){if(!re.existsSync(this.cacheDir))return;let t=(0,sr.globSync)("*.json",{cwd:this.cacheDir});if(t.length===0)return;let i=new Map,a=0;for(let n of t)try{let o=re.readFileSync(_t.join(this.cacheDir,n),"utf-8"),r=JSON.parse(o),s=dd(n);i.set(s,r),a+=Object.keys(r.entries??{}).length}catch{}if(i.size!==0)return console.log(`[shiplight] Cache: loaded ${a} cached action entit${a===1?"y":"ies"} for ${i.size} test file${i.size!==1?"s":""}`),i}},ua=class{isCloud=!0;async lookup(t){let{lookupActionStores:i}=await Promise.resolve().then(()=>(ca(),la));return i(t)}async update(t){let{updateActionStores:i}=await Promise.resolve().then(()=>(ca(),la));return i(t)}loadAll(){}};Di();function ur(e={}){e.dotenv!==!1&&hd(e.scanDir||process.cwd());let t=e.scanDir||process.cwd(),a=lr(t).loadAll();Qo({cwd:t,projectRoot:process.cwd(),actionEntityStores:a});let n=process.env.SHIPLIGHT_REPORT_DIR,o=process.env.SHIPLIGHT_RUN_ID??ud();return process.env.SHIPLIGHT_RUN_ID=o,n?{outputDir:`test-results/${o}`,reporter:[["list"],["shiplightai/reporter",{outputFolder:n,open:"never"}]]}:{outputDir:`test-results/${o}`,reporter:[["list"],["shiplightai/reporter",{outputFolder:`shiplight-report/${o}`,latestSymlinkDir:"shiplight-report",open:"never"}]]}}function ud(){let e=new Date,t=(i,a=2)=>String(i).padStart(a,"0");return`${e.getFullYear()}-${t(e.getMonth()+1)}-${t(e.getDate())}T${t(e.getHours())}-${t(e.getMinutes())}-${t(e.getSeconds())}-${t(e.getMilliseconds(),3)}`}function hr(e,...t){return(0,dr.defineConfig)(e,...t)}function hd(e){ir(e);for(let t of sa(e))cr.default.config({path:t})}R();R();Bt();it();var ao=require("zod"),ph=ao.z.object({instruction:ao.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!""')});function Ml(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:ph,usesElementIndex:!1,async execute(t,i){let{instruction:a}=t,n={page:i.page,agentServices:i.agentServices,domService:i.domService},o=await tt(a,n,{});if(o.status==="error"||!o.actionEntity)return{success:!1,actionEntity:{action_description:a,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:a}}},error:o.error||"Failed to generate action"};let{actionEntity:r}=o,s=await Wt(r,n);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}Ae();R();var Il=require("ai"),Pl=require("html-to-text");async function mh(e,t,i){let{apiKey:a,domain:n}=e;if(!a||!n)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let o=[];try{let r=`https://api.mailgun.net/v3/${n}/events`,s={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(s.from=i.from_email),i.since)s.begin=Math.floor(i.since/1e3).toString();else{let d=new Date(Date.now()-6e5);s.begin=Math.floor(d.getTime()/1e3).toString()}u.info(`Mailgun params: ${JSON.stringify(s)}`);let l=await fetch(r+"?"+new URLSearchParams(s),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${a}`).toString("base64")}`}});if(!l.ok){let d=await l.text();throw new Error(`Mailgun events API error: ${d}`)}let c=(await l.json()).items||[];for(let d of c.slice(0,10)){if(d.event!=="accepted")continue;let h=(d.storage||{}).url;if(u.info(`message_url: ${h}`),!h){let f=(d.message||{}).headers||{},y=f.subject||"",b=f.from||"",p=f.to||"";if(i.from_email&&!b.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!p.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!y.toLowerCase().includes(i.subject.toLowerCase()))continue;o.push({subject:y,from:b,to:p,date:new Date(d.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:f["message-id"]||""});continue}let m=h.split("/"),g=m[m.length-1];if(u.info(`Storage key: ${g}`),g){let f=`https://api.mailgun.net/v3/domains/${n}/messages/${g}`;try{let y=await fetch(f,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${a}`).toString("base64")}`,Accept:"application/json"}});if(y.ok){let b=await y.json(),p=b.Subject||"",x=b.From||"",S=b.To||"",E=b.Date||"",A=b["Message-Id"]||"";u.info(`subject: ${p}`),u.info(`from_addr: ${x}`),u.info(`to_addr: ${S}`),u.info(`date: ${E}`),u.info(`message_id: ${A}`);let M=b["body-html"]||b["body-plain"]||"";if(M&&M.includes("<")&&(M=(0,Pl.convert)(M)),u.info(`Body: ${M.substring(0,200)}...`),i.subject&&!p.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!M.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:p,from:x,to:S,date:E,body:M,message_id:A});continue}else u.warn(`Messages API returned ${y.status}`)}catch(y){u.warn(`Failed to parse JSON response: ${y}`)}}try{let f=await fetch(h,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${a}`).toString("base64")}`}});if(!f.ok){u.warn(`Could not fetch stored message: ${f.status}`);continue}let y=await f.text();u.info(`Fallback: Raw email length: ${y.length}`);let b=y.split(`
|
|
@@ -4444,7 +4444,7 @@ To: ${m.to}
|
|
|
4444
4444
|
Date: ${m.date}
|
|
4445
4445
|
|
|
4446
4446
|
Body:
|
|
4447
|
-
${m.body}`,f=await fh(g,n,t.model);u.info(`Extracted content: ${f}`),f&&f!=="NOT_FOUND"&&h.push({content:f,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 f=(new Date().getTime()-o.getTime())/1e3;return u.info(`Successfully extracted content after ${s} attempts in ${f.toFixed(1)} seconds`),{data:m.content,result_variable:g,status:"success",message:`Successfully extracted content from email: ${m.email_subject.substring(0,50)}... (attempts: ${s})`}}else u.info(`Found emails but no extractable content in attempt ${s}`)}else u.info(`No emails found in attempt ${s}`)}catch(c){u.warn(`Error in polling attempt ${s}: ${c.message}`)}if(new Date(Date.now()+a*1e3)>=r){u.info("Not enough time for another polling attempt");break}u.info(`Waiting ${a} seconds before next attempt...`),await new Promise(c=>setTimeout(c,a*1e3))}let l=(new Date().getTime()-o.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${s} attempts over ${l.toFixed(1)} seconds`}}catch(n){return u.error(`Error extracting email content: ${n.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${n.message}`}}}R();ne();var ye=require("zod");function Ol(e){switch(e){case"verification_code":return"email_otp_code";case"activation_link":return"email_magic_link";case"custom":return"email_extracted_content";default:return"email_content"}}var Ll=class{getMailgunConfig(){let e=j().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=this.getMailgunConfig();if(!n)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let o=a.kwargs,r=i.getModel?.()||"gemini-2.5-pro",s=await Cl(n,{model:r,forward_email:o.forward_email,extraction_type:o.extraction_type,prompt:o.prompt,filters:{from_email:o.filter_from_email,to_email:o.filter_to_email,subject:o.filter_subject,body_contains:o.filter_body_contains},timeout:o.timeout});if(s.status==="success"&&s.data){let l=s.result_variable?.replace(/^\$/,"")||Ol(o.extraction_type);i.variableStore.set(l,s.data),u.info(`[extract_email_content] Extracted and saved to ${l}`)}else throw new Error(s.message||"Failed to extract email content")}transpile(e){let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]}},wh=ye.z.object({forward_email:ye.z.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:ye.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:ye.z.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:ye.z.string().optional().describe("Filter emails by sender address"),filter_to_email:ye.z.string().optional().describe("Filter emails by recipient address"),filter_subject:ye.z.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:ye.z.string().optional().describe("Filter emails by body content (partial match)"),timeout:ye.z.number().optional().describe("Timeout in seconds for polling (default: 60)")});function Nl(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:wh,async execute(i,a){let{forward_email:n,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}=i,{page:m,agentServices:g}=a;u.info(`[extract_email_content] Extracting ${o} from ${n}`);try{let f={action_description:`Extract ${o} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:n,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}}};await t.execute(m,f,g);let y=Ol(o);return{success:!0,actionEntity:f,message:`Extracted ${o} and saved to $${y}`}}catch(f){return{success:!1,error:f.message,actionEntity:{action_description:`Extract ${o} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:n,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}},feedback:f.message}}}}})}Gt();jt();Kt();zt();Xt();Jt();qt();Qt();ei();ti();ii();ni();ai();ri();si();li();ci();ui();hi();mi();gi();fi();wi();bi();yi();xi();vi();var Un=null;async function xe(){if(Un)return Un;let e=(await Promise.resolve().then(()=>(pt(),ht))).default;return Un=new e,Un}async function Dl(e){let t=await xe(),i=t.getAction("click"),a=t.getAction("hover"),n=t.getAction("right_click"),o=t.getAction("double_click");return cl(e,i),il(e,a),Bs(e,n),gl(e,o),"Click, hover, double-click, right-click, or drag elements"}async function Rl(e){let t=await xe(),i=t.getAction("go_to_url"),a=t.getAction("go_back"),n=t.getAction("reload_page");return el(e,i),Qs(e,a),Ws(e,n),"Navigate to URLs, go back, or reload the page"}async function Fl(e){let t=await xe(),i=t.getAction("clear_input"),a=t.getAction("input_text"),n=t.getAction("press");return sl(e,i),al(e,a),Rs(e,n),"Type text into inputs, clear input values, or press keyboard keys"}async function Hl(e){let t=await xe(),i=t.getAction("scroll_on_element"),a=t.getAction("scroll_to_text"),n=t.getAction("scroll");return ys(e,i),vs(e,a),Ks(e,n),"Scroll the page or scroll to specific text/elements"}async function Wl(e){let t=await xe(),i=t.getAction("close_tab"),a=t.getAction("switch_tab");return ul(e,i),$s(e,a),"Switch between browser tabs or close tabs"}async function Ul(e){let t=await xe(),i=t.getAction("upload_file"),a=t.getAction("wait_for_download_complete");return Ls(e,i),ms(e,a),"Upload files or wait for downloads to complete"}async function Bl(e){let t=await xe(),i=t.getAction("get_dropdown_options"),a=t.getAction("select_dropdown_option"),n=t.getAction("set_date_for_native_date_picker");return Js(e,i),Ss(e,a),Ts(e,n),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function Gl(e){let t=await xe(),i=t.getAction("wait"),a=t.getAction("save_variable"),n=t.getAction("done");return Ds(e,i),js(e,a),pl(e,n),Ml(e),"Wait for conditions, save variables, or complete tasks"}async function jl(e){let t=(await xe()).getAction("generate_2fa_code");Vs(e,t);let i=new Ll;return(await Promise.resolve().then(()=>(pt(),ht))).default.registerAction("extract_email_content",i),Nl(e,i),"Generate 2FA codes or extract email/activation codes"}async function Kl(e){let t=await xe(),i=t.getAction("verify"),a=t.getAction("ai_extract"),n=t.getAction("ai_wait_until");return bl(e,i),xl(e,a),fs(e,n),"Perform AI-powered assertions, extractions, or wait conditions"}$e();var bh=[Dl(H),Rl(H),Fl(H),Hl(H),Wl(H),Ul(H),Bl(H),Gl(H),Kl(H),jl(H)],ak=Promise.all(bh);St();ft();Ce();gt();R();var so=require("playwright");ft();var Ch=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Ch||{});Bt();je();Kn();ae();var Zl=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(a=>!a.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}};ft();Ce();R();async function Ql(e,t=3e3,i=1e3){try{await Pe(e,t,i)}catch{}}async function ec(e,t,i){let a=i*1e3,n=100,o=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-o>a){let r;throw t.downloadStatus?r=`Timed out after ${a}ms waiting for download to complete`:r="No download in progress or completed",u.error(r),new Error(r)}await e.waitForTimeout(n)}if(t.downloadStatus.status==="failed"){let r=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw u.error(r),new Error(r)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function tc(e,t,i,a=60,n){let o=Math.min(a,300),r=Math.max(10,o/10)*1e3,s=Date.now()+o*1e3;for(u.info(`Waiting for condition: "${t}" (timeout: ${o}s)`);;){let l=Date.now();try{if(await i(e,t,n))return u.info(`Condition met: "${t}"`),!0}catch(d){u.warn(`Error evaluating condition: ${d.message}`)}if(Date.now()>s)return u.warn(`Timeout waiting for condition: "${t}"`),!1;let c=r-(Date.now()-l);c>0&&await e.waitForTimeout(c)}}Ce();R();var ic=X(require("fs"),1),Ei=X(require("path"),1),zn=require("otplib"),Nh=(0,zn.createGuardrails)({MIN_SECRET_BYTES:1});function nc(e){return e.url()===":"}var ho=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 Zl(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(a=>!a.isClosed());if(i.length>0){let a=i[i.length-1];return u.info(`[validatePage] Page closed, switching to ${a.url()}`),a}u.error("[validatePage] No valid pages found")}return e}replaceVariables(e){return oo(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return Ei.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(a=>{let n=Ei.basename(a),o=Ei.join(t,n),r=ic.existsSync(o);return r&&u.debug(`[AgentServices] File already exists locally: ${n}`),!r});if(i.length===0){u.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){u.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}u.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,t)}async waitForDownloadComplete(e,t){return ec(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+=`
|
|
4447
|
+
${m.body}`,f=await fh(g,n,t.model);u.info(`Extracted content: ${f}`),f&&f!=="NOT_FOUND"&&h.push({content:f,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 f=(new Date().getTime()-o.getTime())/1e3;return u.info(`Successfully extracted content after ${s} attempts in ${f.toFixed(1)} seconds`),{data:m.content,result_variable:g,status:"success",message:`Successfully extracted content from email: ${m.email_subject.substring(0,50)}... (attempts: ${s})`}}else u.info(`Found emails but no extractable content in attempt ${s}`)}else u.info(`No emails found in attempt ${s}`)}catch(c){u.warn(`Error in polling attempt ${s}: ${c.message}`)}if(new Date(Date.now()+a*1e3)>=r){u.info("Not enough time for another polling attempt");break}u.info(`Waiting ${a} seconds before next attempt...`),await new Promise(c=>setTimeout(c,a*1e3))}let l=(new Date().getTime()-o.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${s} attempts over ${l.toFixed(1)} seconds`}}catch(n){return u.error(`Error extracting email content: ${n.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${n.message}`}}}R();ne();var ye=require("zod");function Ol(e){switch(e){case"verification_code":return"email_otp_code";case"activation_link":return"email_magic_link";case"custom":return"email_extracted_content";default:return"email_content"}}var Ll=class{getMailgunConfig(){let e=j().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=this.getMailgunConfig();if(!n)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let o=a.kwargs,r=i.getModel?.()||"gemini-2.5-pro",s=await Cl(n,{model:r,forward_email:o.forward_email,extraction_type:o.extraction_type,prompt:o.prompt,filters:{from_email:o.filter_from_email,to_email:o.filter_to_email,subject:o.filter_subject,body_contains:o.filter_body_contains},timeout:o.timeout});if(s.status==="success"&&s.data){let l=s.result_variable?.replace(/^\$/,"")||Ol(o.extraction_type);i.variableStore.set(l,s.data),u.info(`[extract_email_content] Extracted and saved to ${l}`)}else throw new Error(s.message||"Failed to extract email content")}transpile(e){let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]}},wh=ye.z.object({forward_email:ye.z.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:ye.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:ye.z.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:ye.z.string().optional().describe("Filter emails by sender address"),filter_to_email:ye.z.string().optional().describe("Filter emails by recipient address"),filter_subject:ye.z.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:ye.z.string().optional().describe("Filter emails by body content (partial match)"),timeout:ye.z.number().optional().describe("Timeout in seconds for polling (default: 60)")});function Nl(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:wh,async execute(i,a){let{forward_email:n,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}=i,{page:m,agentServices:g}=a;u.info(`[extract_email_content] Extracting ${o} from ${n}`);try{let f={action_description:`Extract ${o} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:n,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}}};await t.execute(m,f,g);let y=Ol(o);return{success:!0,actionEntity:f,message:`Extracted ${o} and saved to $${y}`}}catch(f){return{success:!1,error:f.message,actionEntity:{action_description:`Extract ${o} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:n,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}},feedback:f.message}}}}})}Gt();jt();Kt();zt();Xt();Jt();qt();Qt();ei();ti();ii();ni();ai();ri();si();li();ci();ui();hi();mi();gi();fi();wi();bi();yi();xi();vi();var Un=null;async function xe(){if(Un)return Un;let e=(await Promise.resolve().then(()=>(pt(),ht))).default;return Un=new e,Un}async function Dl(e){let t=await xe(),i=t.getAction("click"),a=t.getAction("hover"),n=t.getAction("right_click"),o=t.getAction("double_click");return cl(e,i),il(e,a),Bs(e,n),gl(e,o),"Click, hover, double-click, right-click, or drag elements"}async function Rl(e){let t=await xe(),i=t.getAction("go_to_url"),a=t.getAction("go_back"),n=t.getAction("reload_page");return el(e,i),Qs(e,a),Ws(e,n),"Navigate to URLs, go back, or reload the page"}async function Fl(e){let t=await xe(),i=t.getAction("clear_input"),a=t.getAction("input_text"),n=t.getAction("press");return sl(e,i),al(e,a),Rs(e,n),"Type text into inputs, clear input values, or press keyboard keys"}async function Hl(e){let t=await xe(),i=t.getAction("scroll_on_element"),a=t.getAction("scroll_to_text"),n=t.getAction("scroll");return ys(e,i),vs(e,a),Ks(e,n),"Scroll the page or scroll to specific text/elements"}async function Wl(e){let t=await xe(),i=t.getAction("close_tab"),a=t.getAction("switch_tab");return ul(e,i),$s(e,a),"Switch between browser tabs or close tabs"}async function Ul(e){let t=await xe(),i=t.getAction("upload_file"),a=t.getAction("wait_for_download_complete");return Ls(e,i),ms(e,a),"Upload files or wait for downloads to complete"}async function Bl(e){let t=await xe(),i=t.getAction("get_dropdown_options"),a=t.getAction("select_dropdown_option"),n=t.getAction("set_date_for_native_date_picker");return Js(e,i),Ss(e,a),Ts(e,n),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function Gl(e){let t=await xe(),i=t.getAction("wait"),a=t.getAction("save_variable"),n=t.getAction("done");return Ds(e,i),js(e,a),pl(e,n),Ml(e),"Wait for conditions, save variables, or complete tasks"}async function jl(e){let t=(await xe()).getAction("generate_2fa_code");Vs(e,t);let i=new Ll;return(await Promise.resolve().then(()=>(pt(),ht))).default.registerAction("extract_email_content",i),Nl(e,i),"Generate 2FA codes or extract email/activation codes"}async function Kl(e){let t=await xe(),i=t.getAction("verify"),a=t.getAction("ai_extract"),n=t.getAction("ai_wait_until");return bl(e,i),xl(e,a),fs(e,n),"Perform AI-powered assertions, extractions, or wait conditions"}$e();var bh=[Dl(H),Rl(H),Fl(H),Hl(H),Wl(H),Ul(H),Bl(H),Gl(H),Kl(H),jl(H)],ak=Promise.all(bh);$t();ft();Ce();gt();R();var so=require("playwright");ft();var Ch=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Ch||{});Bt();je();Kn();ae();var Zl=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(a=>!a.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}};ft();Ce();R();async function Ql(e,t=3e3,i=1e3){try{await Pe(e,t,i)}catch{}}async function ec(e,t,i){let a=i*1e3,n=100,o=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-o>a){let r;throw t.downloadStatus?r=`Timed out after ${a}ms waiting for download to complete`:r="No download in progress or completed",u.error(r),new Error(r)}await e.waitForTimeout(n)}if(t.downloadStatus.status==="failed"){let r=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw u.error(r),new Error(r)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function tc(e,t,i,a=60,n){let o=Math.min(a,300),r=Math.max(10,o/10)*1e3,s=Date.now()+o*1e3;for(u.info(`Waiting for condition: "${t}" (timeout: ${o}s)`);;){let l=Date.now();try{if(await i(e,t,n))return u.info(`Condition met: "${t}"`),!0}catch(d){u.warn(`Error evaluating condition: ${d.message}`)}if(Date.now()>s)return u.warn(`Timeout waiting for condition: "${t}"`),!1;let c=r-(Date.now()-l);c>0&&await e.waitForTimeout(c)}}Ce();R();var ic=X(require("fs"),1),Ei=X(require("path"),1),zn=require("otplib"),Nh=(0,zn.createGuardrails)({MIN_SECRET_BYTES:1});function nc(e){return e.url()===":"}var ho=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 Zl(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(a=>!a.isClosed());if(i.length>0){let a=i[i.length-1];return u.info(`[validatePage] Page closed, switching to ${a.url()}`),a}u.error("[validatePage] No valid pages found")}return e}replaceVariables(e){return oo(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return Ei.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(a=>{let n=Ei.basename(a),o=Ei.join(t,n),r=ic.existsSync(o);return r&&u.debug(`[AgentServices] File already exists locally: ${n}`),!r});if(i.length===0){u.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){u.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}u.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,t)}async waitForDownloadComplete(e,t){return ec(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+=`
|
|
4448
4448
|
${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,zn.generateSync)({secret:e,guardrails:Nh});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 Pe(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,a){if(!this.knowledgeRetriever)return u.debug("[AgentServices] No knowledge retriever configured"),[];try{let n=await this.knowledgeRetriever(e,t,i,a);return u.debug(`[AgentServices] Retrieved ${n.length} knowledges for statement`),n}catch(n){return u.warn(`[AgentServices] Failed to retrieve knowledges: ${n.message}`),[]}}};var ac=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(ac||{}),po=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}};Zt();R();var z=X(require("fs"),1),te=X(require("path"),1),Dh=1;function Rh(e){try{let t=e.toString(),i,a=t.indexOf("=>");if(a!==-1){let s=t.slice(a+2).trim();if(s.startsWith("{")){let l=s.lastIndexOf("}");i=s.slice(1,l)}else return s.trim()}else{let s=t.indexOf("{"),l=t.lastIndexOf("}");s!==-1&&l>s&&(i=t.slice(s+1,l))}if(!i)return;let n=i.split(`
|
|
4449
4449
|
`),o=n.filter(s=>s.trim().length>0);if(o.length===0)return;let r=Math.min(...o.map(s=>s.match(/^(\s*)/)?.[1].length??0));return n.map(s=>s.slice(r)).join(`
|
|
4450
4450
|
`).trim()}catch{return}}var Fh=3,Hh=40;function wt(e,t){let i={};for(let[a,n]of Object.entries(e))i[a]=t.has(a)?"*****":n;return i}var mo=class{constructor(e){this.context=e,this._newActionEntities=new Map,this.agentServices=new ho(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(()=>(pt(),ht));this._actionHandler=new e}return this._actionHandler}async execAction(e,t,i){let a=(await this.getActionHandler()).getAction(e);if(!a)throw new Error(`Unknown action: ${e}`);await a.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.
|
|
@@ -4481,4 +4481,4 @@ If the page is not signed in, sign in with the OAuth provider "${l.provider_name
|
|
|
4481
4481
|
`}t.additional_prompt&&(s+=`
|
|
4482
4482
|
Additional instructions: ${t.additional_prompt}
|
|
4483
4483
|
`);try{w.log("Level 3: Attempting agent-based login"),w.log(`Login prompt:
|
|
4484
|
-
${s}`);let l=this.agentServices.knowledgeRetriever,c=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(w.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(y,b,p,x)=>await l(y,b,p,"login")),c=!0,w.log("Login knowledge retriever configured"));let d;try{if(d=await this.run(e,s,"login"),!d.success)return w.log("Level 3 FAILED: Agent login failed"),u.info("Login: Failed"),{success:!1,page:e}}finally{c&&l&&(this.agentServices.setKnowledgeRetriever(l),w.log("Restored original knowledge retriever"))}let h=await e.context().storageState(),m;if(n)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 y=await jn(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(b,p)=>this.run(b,p),async b=>this.getDOMText(b));y?(m=y,w.log(`Generated ${m.length} validation locator(s): ${JSON.stringify(m)}`)):w.log("Failed to generate validation locators, login will still succeed")}catch(y){w.log(`Error generating validation locators: ${y.message}`)}else w.log("Skipping validation locator generation (num_verification_exprs=0)");w.log("Level 3 SUCCESS: Agent login succeeded"),u.info("Login: Agent login succeeded");let g=d.actions||[],f=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:h,cached_actions:f,validation_exprs: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 a=(await Promise.resolve().then(()=>(pt(),ht))).default,n=new a;for(let o=0;o<t.length;o++){let r=t[o];w.log(`Executing cached action ${o+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){w.log(`Action ${o+1} missing action_data, skipping`);continue}await n.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return w.error(`Cached action ${o+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(w.log("Verifying cached login result with AI verification statement"),await this.evaluate(e,i.aiVerificationStatement)?{success:!0}:{success:!1}):i?.validationExprs&&i.validationExprs.length>0?await Si(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,a){if(this.context.stepTracking&&!this.context.stepTracking.results[t]){this.context.stepTracking.currentStepId=t,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(t);try{e=this.agentServices.validatePage(e),await this.waitUntilStable(e);let n={description:i,startTime:Date.now(),artifacts:[],type:a,code:i};if(this.context.stepTracking.artifactsDir){let o=te.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));z.mkdirSync(o,{recursive:!0});let r=te.join(o,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:r}),n.screenshot=r}n.contextBefore=this.snapshotVariables(),this.context.stepTracking.results[t]=n}catch(n){u.warn(`createStepResult failed for step ${t}: ${n}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[],contextBefore:this.snapshotVariables()}}}}snapshotVariables(){return wt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys())}saveDebugInfoToFiles(e,t,i,a=0){let n={};if(!this.context.stepTracking?.artifactsDir)return u.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),n;let o=te.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(z.mkdirSync(o,{recursive:!0}),t.systemPrompt){let r=te.join(o,`system_prompt_${a}.txt`);z.writeFileSync(r,t.systemPrompt),n.system_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=te.join(o,`user_prompt_${a}.txt`);z.writeFileSync(r,t.userPrompt),n.user_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(c=>Array.isArray(c.content)?{...c,content:c.content.map(d=>d.type==="image"&&d.file?.startsWith("data:")?{...d,file:"[base64 image data stripped]"}:d)}:c),s=te.join(o,`messages_${a}.json`),l={system:t.systemPrompt,messages:r};z.writeFileSync(s,JSON.stringify(l,null,2)),n.messages_path=s,u.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=te.join(o,`${r}_response_${a}.txt`);z.writeFileSync(s,t.rawLlmResponse),n.response_path=s,u.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=te.join(o,`screenshot_${a}.png`);z.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),n.screenshot_path=r,u.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=te.join(o,`reasoning_${a}.txt`);z.writeFileSync(r,t.reasoningContent),n.reasoning_path=r,u.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}u.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(n).length} artifacts for step ${e}`)}catch(r){u.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return n}async updateStepResult(e,t,i,a,n){if(!this.context.stepTracking)return;let o=this.context.stepTracking.results[e];if(o){if(t&&(o.status=t,o.contextAfter=this.snapshotVariables(),this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(o.message=i),a&&o.artifacts.push(a),n){let r=n.tokenUsages?.[0]?.model,s=o.artifacts.length,l=this.saveDebugInfoToFiles(e,n,r,s);Object.keys(l).length>0&&o.artifacts.push(l)}o.duration=Date.now()-o.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,o)}}async writeExecutionResults(e,t){try{if(await z.promises.mkdir(e,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=te.join(e,"test-results.json");await z.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=te.join(e,"token-usages.json");await z.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=te.join(e,"ai-actions.json");await z.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}}};Bt();rn();an();
|
|
4484
|
+
${s}`);let l=this.agentServices.knowledgeRetriever,c=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(w.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(y,b,p,x)=>await l(y,b,p,"login")),c=!0,w.log("Login knowledge retriever configured"));let d;try{if(d=await this.run(e,s,"login"),!d.success)return w.log("Level 3 FAILED: Agent login failed"),u.info("Login: Failed"),{success:!1,page:e}}finally{c&&l&&(this.agentServices.setKnowledgeRetriever(l),w.log("Restored original knowledge retriever"))}let h=await e.context().storageState(),m;if(n)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 y=await jn(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(b,p)=>this.run(b,p),async b=>this.getDOMText(b));y?(m=y,w.log(`Generated ${m.length} validation locator(s): ${JSON.stringify(m)}`)):w.log("Failed to generate validation locators, login will still succeed")}catch(y){w.log(`Error generating validation locators: ${y.message}`)}else w.log("Skipping validation locator generation (num_verification_exprs=0)");w.log("Level 3 SUCCESS: Agent login succeeded"),u.info("Login: Agent login succeeded");let g=d.actions||[],f=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:h,cached_actions:f,validation_exprs: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 a=(await Promise.resolve().then(()=>(pt(),ht))).default,n=new a;for(let o=0;o<t.length;o++){let r=t[o];w.log(`Executing cached action ${o+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){w.log(`Action ${o+1} missing action_data, skipping`);continue}await n.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return w.error(`Cached action ${o+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(w.log("Verifying cached login result with AI verification statement"),await this.evaluate(e,i.aiVerificationStatement)?{success:!0}:{success:!1}):i?.validationExprs&&i.validationExprs.length>0?await Si(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,a){if(this.context.stepTracking&&!this.context.stepTracking.results[t]){this.context.stepTracking.currentStepId=t,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(t);try{e=this.agentServices.validatePage(e),await this.waitUntilStable(e);let n={description:i,startTime:Date.now(),artifacts:[],type:a,code:i};if(this.context.stepTracking.artifactsDir){let o=te.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));z.mkdirSync(o,{recursive:!0});let r=te.join(o,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:r}),n.screenshot=r}n.contextBefore=this.snapshotVariables(),this.context.stepTracking.results[t]=n}catch(n){u.warn(`createStepResult failed for step ${t}: ${n}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[],contextBefore:this.snapshotVariables()}}}}snapshotVariables(){return wt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys())}saveDebugInfoToFiles(e,t,i,a=0){let n={};if(!this.context.stepTracking?.artifactsDir)return u.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),n;let o=te.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(z.mkdirSync(o,{recursive:!0}),t.systemPrompt){let r=te.join(o,`system_prompt_${a}.txt`);z.writeFileSync(r,t.systemPrompt),n.system_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=te.join(o,`user_prompt_${a}.txt`);z.writeFileSync(r,t.userPrompt),n.user_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(c=>Array.isArray(c.content)?{...c,content:c.content.map(d=>d.type==="image"&&d.file?.startsWith("data:")?{...d,file:"[base64 image data stripped]"}:d)}:c),s=te.join(o,`messages_${a}.json`),l={system:t.systemPrompt,messages:r};z.writeFileSync(s,JSON.stringify(l,null,2)),n.messages_path=s,u.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=te.join(o,`${r}_response_${a}.txt`);z.writeFileSync(s,t.rawLlmResponse),n.response_path=s,u.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=te.join(o,`screenshot_${a}.png`);z.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),n.screenshot_path=r,u.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=te.join(o,`reasoning_${a}.txt`);z.writeFileSync(r,t.reasoningContent),n.reasoning_path=r,u.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}u.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(n).length} artifacts for step ${e}`)}catch(r){u.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return n}async updateStepResult(e,t,i,a,n){if(!this.context.stepTracking)return;let o=this.context.stepTracking.results[e];if(o){if(t&&(o.status=t,o.contextAfter=this.snapshotVariables(),this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(o.message=i),a&&o.artifacts.push(a),n){let r=n.tokenUsages?.[0]?.model,s=o.artifacts.length,l=this.saveDebugInfoToFiles(e,n,r,s);Object.keys(l).length>0&&o.artifacts.push(l)}o.duration=Date.now()-o.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,o)}}async writeExecutionResults(e,t){try{if(await z.promises.mkdir(e,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=te.join(e,"test-results.json");await z.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=te.join(e,"token-usages.json");await z.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=te.join(e,"ai-actions.json");await z.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}}};Bt();rn();an();it();zi();Xi();Ze();Vi();qi();Qi();It();Pt();$e();$t();Mt();wn();je();Lt();Nt();nt();Dt();Rt();Kn();ae();ft();Ce();gt();Ae();Qe();Et();Tt();He();io();ln();cn();dn();un();hn();pn();mn();gn();fn();bn();yn();Gt();jt();Kt();zt();Xt();Jt();qt();Qt();ei();ti();ii();ni();ai();ri();si();li();ci();ui();hi();mi();gi();fi();wi();bi();yi();xi();Ht();vi();Pn();Zt();K();Ge();R();ne();ot();Nn();F();function Wh(){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,a=t.find(p=>p.type==="month").value,n=t.find(p=>p.type==="day").value,o=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"),c=`${i}-${a}-${n}T${o}:${r}:${s}.${l}`,d=e.toISOString().slice(0,-1),h=Date.parse(c+"Z"),m=Date.parse(d+"Z"),g=Math.round((m-h)/(1e3*60)),f=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),y=String(Math.abs(g)%60).padStart(2,"0"),b=g<=0?"+":"-";return`${i}-${a}-${n}T${o}:${r}:${s}.${l}${b}${f}:${y}`}function go(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",Wh()),{model:e.model,computer_use_model:e.computer_use_model,variableStore:t,organizationId:e.organizationId,organizationSettings:e.organizationSettings,executionHistory:e.executionHistory||[],testDataDir:e.testDataDir,downloadDir:e.downloadDir,useNativeGenerator:e.useNativeGenerator,autoDismissModal:e.autoDismissModal,tokenUsages:[],aiActionDetails:[]}}ge();0&&(module.exports={VariableStore,WebAgent,configureSdk,createAgentContext,defineConfig,shiplightConfig});
|