agent-device 0.15.1 → 0.15.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/android-snapshot-helper/dist/{agent-device-android-snapshot-helper-0.15.1.apk → agent-device-android-snapshot-helper-0.15.2.apk} +0 -0
- package/android-snapshot-helper/dist/agent-device-android-snapshot-helper-0.15.2.apk.sha256 +1 -0
- package/android-snapshot-helper/dist/{agent-device-android-snapshot-helper-0.15.1.manifest.json → agent-device-android-snapshot-helper-0.15.2.manifest.json} +6 -6
- package/dist/src/2151.js +12 -8
- package/dist/src/9542.js +2 -2
- package/dist/src/cli.js +20 -20
- package/dist/src/index.d.ts +1 -0
- package/dist/src/internal/daemon.js +42 -41
- package/ios-runner/AgentDeviceRunner/AgentDeviceRunnerUITests/RunnerTests+Interaction.swift +5 -0
- package/package.json +1 -1
- package/server.json +2 -2
- package/android-snapshot-helper/dist/agent-device-android-snapshot-helper-0.15.1.apk.sha256 +0 -1
package/dist/src/9542.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import e from"node:net";import t from"node:http";import a from"node:https";import r from"node:fs";import o from"node:path";import{pipeline as n}from"node:stream/promises";import i from"node:os";import{createHash as s,randomUUID as l}from"node:crypto";import{Writable as c}from"node:stream";import{toAppErrorCode as d,AppError as p}from"./9152.js";import{runCmdSync as u,runCmd as m,runCmdDetached as f}from"./9818.js";import{readVersion as h,findProjectRoot as y}from"./9671.js";import{createRequestId as w,withDiagnosticTimer as I,emitDiagnostic as v}from"./7599.js";import{isAgentDeviceDaemonProcess as g,stopProcessForTakeover as b}from"./8656.js";import{readRect as A,settingsCommandCodec as k,PUBLIC_COMMANDS as P,elementTargetCodec as S,asRecord as _,longPressCommandCodec as M,buildAppIdentifiers as E,buildDeviceIdentifiers as D,computeDaemonCodeSignature as T,resolveDaemonTransportPreference as N,readRequiredNumber as U,readPoint as C,parsing_stripUndefined as L,readOptionalString as R,readRequiredPlatform as O,readRequiredDeviceKind as x,findCommandCodec as F,INTERNAL_COMMANDS as B,fillCommandCodec as q,typeCommandCodec as z,isRecord as j,readRequiredString as $,readNullableString as H,readDeviceTarget as K,isCommandCodec as V,screenshotFlagsFromOptions as G,resolveDaemonPaths as J,resolveDaemonServerMode as W,waitCommandCodec as Y,interactionTargetCodec as Q}from"./3572.js";import{sleep as X}from"./4829.js";import{reloadMetro as Z,prepareMetroRuntime as ee}from"./1974.js";function et(e){return new Promise((t,a)=>{let r="";e.setEncoding("utf8"),e.on("data",e=>{r+=e}),e.on("end",()=>t(r)),e.on("error",a)})}let ea="sha256";async function er(e){let t=await eo(e.localPath,e.platform),a=e.baseUrl.endsWith("/")?e.baseUrl:`${e.baseUrl}/`;try{let r=await el({normalizedBase:a,token:e.token,artifact:t});if(r?.kind==="cache-hit")return r.uploadId;if(r?.kind==="direct-upload")try{return await ec(t.payloadPath,r),await ep({normalizedBase:a,token:e.token,uploadId:r.uploadId})}catch{}return await es({normalizedBase:a,token:e.token,artifact:t})}finally{t.cleanup()}}async function eo(e,t){var a,n,i;let s,l=r.statSync(e),c=o.basename(e),d=l.isDirectory(),p=("ios"===(a=t)||"android"===a?a:void 0)??(n=e,i=l,s=n.toLowerCase(),i.isDirectory()&&s.endsWith(".app")||s.endsWith(".ipa")?"ios":s.endsWith(".apk")||s.endsWith(".aab")?"android":void 0),u=[];try{let t=d?await en(e,u):e,a=r.statSync(t);return{payloadPath:t,fileName:c,artifactType:d?"app-bundle":"file",platform:p,contentType:d?"application/gzip":"application/octet-stream",sha256:await eu(t),sizeBytes:a.size,cleanup:()=>ei(u)}}catch(e){throw ei(u),e}}async function en(e,t){let a=r.mkdtempSync(o.join(i.tmpdir(),`agent-device-upload-${l()}-`));t.push(a);let n=o.join(a,`${o.basename(e)}.tar.gz`);return await m("tar",["czf",n,"-C",o.dirname(e),o.basename(e)],{env:{...process.env,COPYFILE_DISABLE:"1"}}),n}function ei(e){for(let t of e)r.rmSync(t,{recursive:!0,force:!0})}async function es(e){let{normalizedBase:t,token:a,artifact:r}=e,o=new URL("upload",t),n={"content-type":r.contentType,"x-artifact-type":r.artifactType,"x-artifact-filename":r.fileName,"x-artifact-hash":r.sha256,"x-artifact-hash-algorithm":ea,"transfer-encoding":"chunked"};a&&(n.authorization=`Bearer ${a}`,n["x-agent-device-token"]=a);let i=await ed({url:o,method:"POST",headers:n,payloadPath:r.payloadPath,timeoutMessage:"Artifact upload timed out",timeoutHint:"The upload to the remote daemon exceeded the 5-minute timeout.",errorMessage:"Failed to upload artifact to remote daemon",errorHint:"Verify the remote daemon is reachable and supports artifact uploads."});try{let e=JSON.parse(i.body);if(!e.ok||!e.uploadId)throw new p("COMMAND_FAILED",`Upload failed: ${i.body}`);return e.uploadId}catch(e){if(e instanceof p)throw e;throw new p("COMMAND_FAILED",`Invalid upload response: ${i.body}`)}}async function el(e){let t=new URL("upload/preflight",e.normalizedBase),a={"content-type":"application/json"};e.token&&(a.authorization=`Bearer ${e.token}`,a["x-agent-device-token"]=e.token);let r=await fetch(t,{method:"POST",headers:a,signal:AbortSignal.timeout(3e4),body:JSON.stringify({sha256:e.artifact.sha256,fileName:e.artifact.fileName,sizeBytes:e.artifact.sizeBytes,artifactType:e.artifact.artifactType,...e.artifact.platform?{platform:e.artifact.platform}:{},contentType:e.artifact.contentType})}).catch(()=>void 0);if(r?.ok)return function(e){var t;if(!e||"object"!=typeof e||!0!==e.ok||"string"!=typeof e.uploadId)return;if(!0===e.cacheHit)return{kind:"cache-hit",uploadId:e.uploadId};let a=e.upload;if(!a||"string"!=typeof a.url)return;let r=a.headers??{};if(!(!(t=r)||"object"!=typeof t||Array.isArray(t))&&Object.values(t).every(e=>"string"==typeof e))return{kind:"direct-upload",uploadId:e.uploadId,url:a.url,headers:r}}(await r.json().catch(()=>void 0))}async function ec(e,t){let a=await ed({url:new URL(t.url),method:"PUT",headers:t.headers,payloadPath:e,timeoutMessage:"Direct artifact upload timed out",timeoutHint:"The direct upload ticket did not accept the artifact within the timeout.",errorMessage:"Failed to upload artifact with direct upload ticket"});if(a.statusCode<200||a.statusCode>=300)throw new p("COMMAND_FAILED","Direct artifact upload failed",{statusCode:a.statusCode,statusMessage:a.statusMessage})}async function ed(e){let o="https:"===e.url.protocol?a:t;return await new Promise((t,a)=>{let i=o.request({protocol:e.url.protocol,host:e.url.hostname,port:e.url.port,method:e.method,path:e.url.pathname+e.url.search,headers:e.headers},e=>{et(e).then(a=>{clearTimeout(s),t({statusCode:e.statusCode??500,statusMessage:e.statusMessage,body:a})}).catch(a)}),s=setTimeout(()=>{i.destroy(),a(new p("COMMAND_FAILED",e.timeoutMessage,{timeoutMs:3e5,...e.timeoutHint?{hint:e.timeoutHint}:{}}))},3e5);i.on("error",t=>{clearTimeout(s),a(new p("COMMAND_FAILED",e.errorMessage,e.errorHint?{hint:e.errorHint}:{},t))}),i.on("close",()=>clearTimeout(s)),n(r.createReadStream(e.payloadPath),i).catch(e=>{i.destroy(),a(new p("COMMAND_FAILED","Failed to read local artifact",{},e instanceof Error?e:Error(String(e))))})})}async function ep(e){let t=new URL("upload/finalize",e.normalizedBase),a={"content-type":"application/json"};e.token&&(a.authorization=`Bearer ${e.token}`,a["x-agent-device-token"]=e.token);let r=await fetch(t,{method:"POST",headers:a,signal:AbortSignal.timeout(3e4),body:JSON.stringify({uploadId:e.uploadId})}).catch(e=>{throw new p("COMMAND_FAILED","Failed to finalize direct artifact upload",{},e)});if(!r.ok)throw new p("COMMAND_FAILED","Direct artifact upload finalize failed",{status:r.status,statusText:r.statusText});let o=await r.json().catch(()=>void 0);if(!o?.ok||!o.uploadId)throw new p("COMMAND_FAILED","Invalid upload finalize response");return o.uploadId}async function eu(e){let t=s(ea),a=new c({write(e,a,r){t.update(e),r()}});return await n(r.createReadStream(e),a).catch(e=>{throw new p("COMMAND_FAILED","Failed to read local artifact",{},e instanceof Error?e:void 0)}),t.digest("hex")}let em=["xcodebuild .*AgentDeviceRunnerUITests/RunnerTests/testCommand","xcodebuild .*AgentDeviceRunner\\.env\\.session-","xcodebuild build-for-testing .*ios-runner/AgentDeviceRunner/AgentDeviceRunner\\.xcodeproj"],ef=new e.BlockList;async function eh(t){let a=t.meta?.requestId??w(),r=!!(t.meta?.debug||t.flags?.verbose),o=function(t){let a,r=t.flags?.stateDir??process.env.AGENT_DEVICE_STATE_DIR,o=function(e){let t;if(e){try{t=new URL(e)}catch(t){throw new p("INVALID_ARGS","Invalid daemon base URL",{daemonBaseUrl:e},t instanceof Error?t:void 0)}if("http:"!==t.protocol&&"https:"!==t.protocol)throw new p("INVALID_ARGS","Daemon base URL must use http or https",{daemonBaseUrl:e});return t.toString().replace(/\/+$/,"")}}(t.flags?.daemonBaseUrl??process.env.AGENT_DEVICE_DAEMON_BASE_URL),n=t.flags?.daemonAuthToken??process.env.AGENT_DEVICE_DAEMON_AUTH_TOKEN;var i=o,s=n;if(!(!i||"localhost"===(a=new URL(i).hostname.trim().toLowerCase().replace(/^\[(.*)\]$/,"$1"))||(e.isIPv4(a)?ef.check(a,"ipv4"):!!e.isIPv6(a)&&ef.check(a,"ipv6")))&&("string"!=typeof s||!(s.trim().length>0)))throw new p("INVALID_ARGS","Remote daemon base URL for non-loopback hosts requires daemon authentication",{daemonBaseUrl:i,hint:"Provide --daemon-auth-token or AGENT_DEVICE_DAEMON_AUTH_TOKEN when using a non-loopback remote daemon URL."});let l=t.flags?.daemonTransport??process.env.AGENT_DEVICE_DAEMON_TRANSPORT,c=N(l);if(o&&"socket"===c)throw new p("INVALID_ARGS","Remote daemon base URL only supports HTTP transport. Remove --daemon-transport socket.",{daemonBaseUrl:o});let d=W(t.flags?.daemonServerMode??process.env.AGENT_DEVICE_DAEMON_SERVER_MODE??("dual"===l?"dual":void 0));return{paths:J(r),transportPreference:c,serverMode:d,remoteBaseUrl:o,remoteAuthToken:n}}(t),n="test"===t.command?void 0:9e4,i=await I("daemon_startup",async()=>await eb(o),{requestId:a,session:t.session}),s=await ey(t,i),l={...t,positionals:s.positionals,flags:s.flags,token:i.token,meta:{...t.meta??{},requestId:a,debug:r,cwd:t.meta?.cwd,tenantId:t.meta?.tenantId??t.flags?.tenant,runId:t.meta?.runId??t.flags?.runId,leaseId:t.meta?.leaseId??t.flags?.leaseId,sessionIsolation:t.meta?.sessionIsolation??t.flags?.sessionIsolation,lockPolicy:t.meta?.lockPolicy,lockPlatform:t.meta?.lockPlatform,...s.uploadedArtifactId?{uploadedArtifactId:s.uploadedArtifactId}:{},...s.clientArtifactPaths?{clientArtifactPaths:s.clientArtifactPaths}:{},...s.installSource?{installSource:s.installSource}:{}}};return v({level:"info",phase:"daemon_request_prepare",data:{requestId:a,command:t.command,session:t.session}}),await I("daemon_request",async()=>await eL(i,l,o.transportPreference,n),{requestId:a,command:t.command})}async function ey(e,t){let a,n=[...e.positionals??[]],i=e.flags?{...e.flags}:void 0,s=e.meta?.installSource,l={};if(ez(t)){let r=function(e,t){if("screenshot"===e.command){let a=ev(e,"path",".png");return t[0]?{field:"path",localPath:a,positionalIndex:0,positionalPath:eg("screenshot",".png")}:{field:"path",localPath:a,positionalIndex:0,flagPath:eg("screenshot",".png")}}if("record"===e.command&&"start"===(t[0]??"").toLowerCase()){let t=ev(e,"outPath",".mp4",1);return{field:"outPath",localPath:t,positionalIndex:1,positionalPath:eg("recording",o.extname(t)||".mp4")}}return null}(e,n);r&&(void 0!==r.positionalPath&&(n[r.positionalIndex]=r.positionalPath),void 0!==r.flagPath&&((i??={}).out=r.flagPath),l[r.field]=r.localPath);let c=await eI(e,t);c&&(s=c.installSource,a=c.uploadedArtifactId??a)}let c=()=>ew({positionals:n,flags:i,installSource:s,uploadedArtifactId:a,clientArtifactPaths:l});if(!ez(t)||"install"!==e.command&&"reinstall"!==e.command||n.length<2)return c();let d=n[1];if(d.startsWith("remote:"))return n[1]=d.slice(7),ew({positionals:n,flags:i,clientArtifactPaths:l});let p=o.isAbsolute(d)?d:o.resolve(e.meta?.cwd??process.cwd(),d);return r.existsSync(p)?(a=await er({localPath:p,baseUrl:t.baseUrl,token:t.token,platform:e.flags?.platform}),c()):ew({positionals:n,flags:i,clientArtifactPaths:l})}function ew(e){return{positionals:e.positionals,flags:e.flags,installSource:e.installSource,uploadedArtifactId:e.uploadedArtifactId,...Object.keys(e.clientArtifactPaths).length>0?{clientArtifactPaths:e.clientArtifactPaths}:{}}}async function eI(e,t){let a=e.meta?.installSource;if("install_source"!==e.command||!a||"path"!==a.kind)return null;let n=a.path.trim();if(!n)return{installSource:a};if(n.startsWith("remote:"))return{installSource:{...a,path:n.slice(7)}};let i=o.isAbsolute(n)?n:o.resolve(e.meta?.cwd??process.cwd(),n);if(!r.existsSync(i))return{installSource:{...a,path:i}};let s=await er({localPath:i,baseUrl:t.baseUrl,token:t.token,platform:e.flags?.platform});return{installSource:{...a,path:i},uploadedArtifactId:s}}function ev(e,t,a,r=0){let n=e.positionals?.[r]??e.flags?.out,i=`${"path"===t?"screenshot":"recording"}-${Date.now()}${a}`,s=n&&n.trim().length>0?n:i;return o.isAbsolute(s)?s:o.resolve(e.meta?.cwd??process.cwd(),s)}function eg(e,t){let a=t.startsWith(".")?t:`.${t}`;return o.posix.join("/tmp",`agent-device-${e}-${Date.now()}-${Math.random().toString(36).slice(2,8)}${a}`)}async function eb(e){let t,a;if(e.remoteBaseUrl){let t={transport:"http",token:e.remoteAuthToken??"",pid:0,baseUrl:e.remoteBaseUrl};if(await eN(t,"http"))return t;throw new p("COMMAND_FAILED","Remote daemon is unavailable",{daemonBaseUrl:e.remoteBaseUrl,hint:"Verify AGENT_DEVICE_DAEMON_BASE_URL points to a reachable daemon with GET /health and POST /rpc."})}let r=eS(e.paths.infoPath),o=h(),n=T((a=eC()).useSrc?a.srcPath:a.distPath,a.root),i=!!r&&await eN(r,e.transportPreference);if(r&&r.version===o&&r.codeSignature===n&&i)return r;r&&(r.version!==o||r.codeSignature!==n||!i)&&(await eP(r),eT(e.paths.infoPath)),function(e){let t=eE(e);if(!t.hasLock||t.hasInfo)return;let a=e_(e.lockPath);if(!a)return eT(e.lockPath);g(a.pid,a.processStartTime)||eT(e.lockPath)}(e.paths);let s=0,l=[];for(let a=1;a<=2;a+=1){try{await eU(e)}catch(r){if(t=r instanceof Error?r.message:String(r),l.push(await eM(e.paths,"start_error")),a<2){await X(150);continue}break}let r=await eA(15e3,e);if(r)return r;if(await ek(e.paths)){s+=1;continue}let o=eE(e.paths),n=a<2,i=await eM(e.paths,"startup_timeout",{stopLiveProcesses:!1});if(l.push(i),i.retainedInfoProcess||i.retainedLockProcess){let t=await eA(15e3,e);if(t)return t;break}if(!n)break;o.hasInfo||o.hasLock||await X(150)}let c=eE(e.paths);throw new p("COMMAND_FAILED","Failed to start daemon",{kind:"daemon_startup_failed",infoPath:e.paths.infoPath,lockPath:e.paths.lockPath,startupTimeoutMs:15e3,startupAttempts:2,lockRecoveryCount:s,cleanupResults:l,startError:t,metadataState:c,hint:function(e,t=J(process.env.AGENT_DEVICE_STATE_DIR)){return e.hasLock&&!e.hasInfo?`agent-device attempted to clean stale daemon metadata automatically, but ${t.lockPath} still exists without ${t.infoPath}. Retry with --debug; if this persists, remove ${t.lockPath} after confirming no agent-device daemon process is running.`:e.hasLock&&e.hasInfo?`agent-device attempted to clean stale daemon metadata automatically, but ${t.infoPath} and ${t.lockPath} still remain. Retry with --debug; if this persists, remove both files after confirming no agent-device daemon process is running.`:"agent-device did not observe reachable daemon metadata after retrying. Stale metadata was cleaned automatically when safe; retry with --debug and check daemon diagnostics logs."}(c,e.paths)})}async function eA(e,t){let a=Date.now();for(;Date.now()-a<e;){let e=eS(t.paths.infoPath);if(e&&await eN(e,t.transportPreference))return e;await X(100)}return null}async function ek(e){let t=eE(e);if(!t.hasLock||t.hasInfo)return!1;let a=e_(e.lockPath);return!(a&&g(a.pid,a.processStartTime))&&(eT(e.lockPath),!0)}async function eP(e){await b(e.pid,{termTimeoutMs:3e3,killTimeoutMs:1e3,expectedStartTime:e.processStartTime})}function eS(e){let t=eD(e);if(!t||"object"!=typeof t)return null;let a="string"==typeof t.token&&t.token.length>0?t.token:null;if(!a)return null;let r=Number.isInteger(t.port)&&Number(t.port)>0,o=Number.isInteger(t.httpPort)&&Number(t.httpPort)>0;if(!r&&!o)return null;let n=t.transport,i="string"==typeof t.version?t.version:void 0,s="string"==typeof t.codeSignature?t.codeSignature:void 0,l="string"==typeof t.processStartTime?t.processStartTime:void 0,c=Number.isInteger(t.pid)&&Number(t.pid)>0;return{token:a,port:r?Number(t.port):void 0,httpPort:o?Number(t.httpPort):void 0,transport:"socket"===n||"http"===n||"dual"===n?n:void 0,pid:c?Number(t.pid):0,version:i,codeSignature:s,processStartTime:l}}function e_(e){let t=eD(e);return t&&"object"==typeof t&&Number.isInteger(t.pid)&&Number(t.pid)>0?{pid:Number(t.pid),processStartTime:"string"==typeof t.processStartTime?t.processStartTime:void 0,startedAt:"number"==typeof t.startedAt?t.startedAt:void 0}:null}ef.addSubnet("127.0.0.0",8,"ipv4"),ef.addAddress("::1","ipv6"),ef.addSubnet("::ffff:127.0.0.0",104,"ipv6");async function eM(e,t,a={}){let o=a.stopLiveProcesses??!0,n={reason:t,removedInfo:!1,removedLock:!1,stoppedInfoProcess:!1,stoppedLockProcess:!1};try{var i,s,l,c;let t=r.existsSync(e.infoPath),a=eS(e.infoPath);if(a){let t=g(a.pid,a.processStartTime);t&&!o?n.retainedInfoProcess=!0:(t&&(await eP(a),n.stoppedInfoProcess=!0),i=e.infoPath,eT(i),n.removedInfo=!0)}else t&&(s=e.infoPath,eT(s),n.removedInfo=!0);let d=r.existsSync(e.lockPath),p=e_(e.lockPath);if(p){let t=g(p.pid,p.processStartTime);t&&!o?n.retainedLockProcess=!0:(t&&(await b(p.pid,{termTimeoutMs:3e3,killTimeoutMs:1e3,expectedStartTime:p.processStartTime}),n.stoppedLockProcess=!0),l=e.lockPath,eT(l),n.removedLock=!0)}else d&&(c=e.lockPath,eT(c),n.removedLock=!0)}catch(e){n.error=e instanceof Error?e.message:String(e)}return v({level:n.error?"warn":"info",phase:"daemon_startup_metadata_cleanup",data:n}),n}function eE(e){return{hasInfo:r.existsSync(e.infoPath),hasLock:r.existsSync(e.lockPath)}}function eD(e){if(!r.existsSync(e))return null;try{return JSON.parse(r.readFileSync(e,"utf8"))}catch{return null}}function eT(e){try{r.existsSync(e)&&r.unlinkSync(e)}catch{}}async function eN(r,o){var n;return"http"===eR(r,o)?await function(e){let r=e.baseUrl?ej(e.baseUrl,"health"):e.httpPort?`http://127.0.0.1:${e.httpPort}/health`:null;if(!r)return Promise.resolve(!1);let o=new URL(r),n="https:"===o.protocol?a:t,i=e.baseUrl?3e3:500;return new Promise(e=>{let t=n.request({protocol:o.protocol,host:o.hostname,port:o.port,path:o.pathname+o.search,method:"GET",timeout:i},t=>{t.resume(),e((t.statusCode??500)<500)});t.on("timeout",()=>{t.destroy(),e(!1)}),t.on("error",()=>{e(!1)}),t.end()})}(r):await ((n=r.port)?new Promise(t=>{let a=e.createConnection({host:"127.0.0.1",port:n},()=>{a.destroy(),t(!0)});a.on("error",()=>{t(!1)})}):Promise.resolve(!1))}async function eU(e){let t=eC(),a=t.useSrc?["--experimental-strip-types",t.srcPath]:[t.distPath],r={...process.env,AGENT_DEVICE_STATE_DIR:e.paths.baseDir,AGENT_DEVICE_DAEMON_SERVER_MODE:e.serverMode};f(process.execPath,a,{env:r})}function eC(){let e=y(),t=[o.join(e,"dist","src","internal","daemon.js"),o.join(e,"dist","src","daemon.js")],a=t.find(e=>r.existsSync(e))??t[0],n=o.join(e,"src","daemon.ts"),i=t.some(e=>r.existsSync(e)),s=r.existsSync(n);if(!i&&!s)throw new p("COMMAND_FAILED","Daemon entry not found",{distPaths:t,srcPath:n});return{root:e,distPath:a,distPaths:t,srcPath:n,useSrc:process.execArgv.includes("--experimental-strip-types")?s:!i&&s}}async function eL(e,t,a,r){return"http"===eR(e,a)?await eq(e,t,r):await eB(e,t,r)}function eR(e,t){if(e.baseUrl){if("socket"===t)throw new p("COMMAND_FAILED","Remote daemon endpoint only supports HTTP transport",{daemonBaseUrl:e.baseUrl});return"http"}if("http"===t||"socket"===t){var a=e,r=t;if(eO(a,r))return r;throw new p("COMMAND_FAILED","http"===r?"Daemon HTTP endpoint is unavailable":"Daemon socket endpoint is unavailable")}let o=("socket"===e.transport||"dual"===e.transport?["socket","http"]:["http","socket"]).find(t=>eO(e,t));if(o)return o;throw new p("COMMAND_FAILED","Daemon metadata has no reachable transport")}function eO(e,t){return"http"===t?!!e.httpPort:!!e.port}function ex(e,t,a,r,o,n){let i=o?{terminated:0}:function(){let e=0;try{for(let t of em){let a=u("pkill",["-f",t],{allowFailure:!0});0===a.exitCode&&(e+=1)}return{terminated:e}}catch(t){return{terminated:e,error:t instanceof Error?t.message:String(t)}}}(),s=o?{forcedKill:!1}:function(e,t){let a=!1;try{g(e.pid,e.processStartTime)&&(process.kill(e.pid,"SIGKILL"),a=!0)}catch{b(e.pid,{termTimeoutMs:3e3,killTimeoutMs:1e3,expectedStartTime:e.processStartTime})}finally{eT(t.infoPath),eT(t.lockPath)}return{forcedKill:a}}(e,t);return v({level:"error",phase:"daemon_request_timeout",data:{timeoutMs:n,requestId:a,command:r,timedOutRunnerPidsTerminated:i.terminated,timedOutRunnerCleanupError:i.error,daemonPidReset:o?void 0:e.pid,daemonPidForceKilled:o?void 0:s.forcedKill,daemonBaseUrl:e.baseUrl}}),new p("COMMAND_FAILED","Daemon request timed out",{timeoutMs:n,requestId:a,hint:o?"Retry with --debug and verify the remote daemon URL, auth token, and remote host logs.":"Retry with --debug and check daemon diagnostics logs. Timed-out iOS runner xcodebuild processes were terminated when detected."})}function eF(e,t,a){return v({level:"error",phase:"daemon_request_socket_error",data:{requestId:t,message:e instanceof Error?e.message:String(e)}}),new p("COMMAND_FAILED","Failed to communicate with daemon",{requestId:t,hint:a?"Retry command. If this persists, verify the remote daemon URL, auth token, and remote host reachability.":"Retry command. If this persists, clean stale daemon metadata and start a fresh session."},e instanceof Error?e:void 0)}async function eB(t,a,r){let o=t.port;if(!o)throw new p("COMMAND_FAILED","Daemon socket endpoint is unavailable");return new Promise((n,i)=>{let s=e.createConnection({host:"127.0.0.1",port:o},()=>{s.write(`${JSON.stringify(a)}
|
|
2
|
-
`)}),l=J(a.flags?.stateDir??process.env.AGENT_DEVICE_STATE_DIR),c="number"==typeof r?setTimeout(()=>{s.destroy(),i(ex(t,l,a.meta?.requestId,a.command,!1,r))},r):void 0,d="";s.setEncoding("utf8"),s.on("data",e=>{let t=(d+=e).indexOf("\n");if(-1===t)return;let r=d.slice(0,t).trim();if(r)try{let e=JSON.parse(r);s.end(),c&&clearTimeout(c),n(e)}catch(e){c&&clearTimeout(c),i(new p("COMMAND_FAILED","Invalid daemon response",{requestId:a.meta?.requestId,line:r},e instanceof Error?e:void 0))}}),s.on("error",e=>{c&&clearTimeout(c),i(eF(e,a.meta?.requestId,!1))})})}async function eq(e,r,o){var n,i,s;let l,c=e.baseUrl?new URL(ej(e.baseUrl,"rpc")):e.httpPort?new URL(`http://127.0.0.1:${e.httpPort}/rpc`):null;if(!c)throw new p("COMMAND_FAILED","Daemon HTTP endpoint is unavailable");let u=JSON.stringify((n=r,i={includeTokenParam:!e.baseUrl},l=n.meta?.requestId??w(),"lease_allocate"!==(s=n.command)&&"lease_heartbeat"!==s&&"lease_release"!==s?{jsonrpc:"2.0",id:l,method:"agent_device.command",params:n}:{jsonrpc:"2.0",id:l,method:function(e){switch(e){case"lease_allocate":return"agent_device.lease.allocate";case"lease_heartbeat":return"agent_device.lease.heartbeat";case"lease_release":return"agent_device.lease.release"}}(n.command),params:function(e,t,a){let r={...a.includeTokenParam?{token:e.token}:{},session:e.session,tenantId:e.meta?.tenantId,runId:e.meta?.runId};switch(t){case"lease_allocate":return{...r,ttlMs:e.meta?.leaseTtlMs,backend:e.meta?.leaseBackend};case"lease_heartbeat":return{...r,leaseId:e.meta?.leaseId,ttlMs:e.meta?.leaseTtlMs};case"lease_release":return{...r,leaseId:e.meta?.leaseId}}}(n,n.command,i)})),m={"content-type":"application/json","content-length":Buffer.byteLength(u)};return e.baseUrl&&e.token&&(m.authorization=`Bearer ${e.token}`,m["x-agent-device-token"]=e.token),await new Promise((n,i)=>{let s=J(r.flags?.stateDir??process.env.AGENT_DEVICE_STATE_DIR),l=("https:"===c.protocol?a:t).request({protocol:c.protocol,host:c.hostname,port:c.port,method:"POST",path:c.pathname+c.search,headers:m},t=>{et(t).then(t=>{h&&clearTimeout(h),function(e,t){let{info:a,req:r,resolve:o,reject:n}=t;try{let t=JSON.parse(e);if(t.error){let e=t.error.data??{};n(new p(d(null!=e.code?String(e.code):void 0,"COMMAND_FAILED"),String(e.message??t.error.message??"Daemon RPC request failed"),{..."object"==typeof e.details&&e.details?e.details:{},hint:"string"==typeof e.hint?e.hint:void 0,diagnosticId:"string"==typeof e.diagnosticId?e.diagnosticId:void 0,logPath:"string"==typeof e.logPath?e.logPath:void 0,requestId:r.meta?.requestId}));return}if(!t.result||"object"!=typeof t.result)return void n(new p("COMMAND_FAILED","Invalid daemon RPC response",{requestId:r.meta?.requestId}));if(a.baseUrl&&t.result.ok)return void e$(a,r,t.result).then(o).catch(n);o(t.result)}catch(t){n(new p("COMMAND_FAILED","Invalid daemon response",{requestId:r.meta?.requestId,line:e},t instanceof Error?t:void 0))}}(t,{info:e,req:r,resolve:n,reject:i})}).catch(e=>{h&&clearTimeout(h),i(new p("COMMAND_FAILED","Failed to read daemon response",{requestId:r.meta?.requestId},e instanceof Error?e:void 0))})}),f=ez(e),h="number"==typeof o?setTimeout(()=>{l.destroy(),i(ex(e,s,r.meta?.requestId,r.command,f,o))},o):void 0;l.on("error",e=>{h&&clearTimeout(h),i(eF(e,r.meta?.requestId,f))}),l.write(u),l.end()})}function ez(e){return"string"==typeof e.baseUrl&&e.baseUrl.length>0}function ej(e,t){return new URL(t,e.endsWith("/")?e:`${e}/`).toString()}async function e$(e,t,a){let r=Array.isArray(a.data?.artifacts)?a.data.artifacts:[];if(0===r.length||!e.baseUrl)return a;let n=a.data?{...a.data}:{},i=[];for(let a of r){if(!a||"object"!=typeof a||"string"!=typeof a.artifactId){i.push(a);continue}let r=function(e,t){if(e.localPath&&e.localPath.trim().length>0)return e.localPath;let a=t.meta?.clientArtifactPaths?.[e.field];if(a&&a.trim().length>0)return a;let r=e.fileName?.trim()||`${e.field}-${Date.now()}`;return o.resolve(t.meta?.cwd??process.cwd(),r)}(a,t);await eH({baseUrl:e.baseUrl,token:e.token,artifactId:a.artifactId,destinationPath:r,requestId:t.meta?.requestId}),n[a.field]=r,i.push({...a,localPath:r})}return n.artifacts=i,{ok:!0,data:n}}async function eH(e){var i,s;let l,c=new URL((i=e.baseUrl,s=e.artifactId,l=i.endsWith("/")?i:`${i}/`,new URL(`artifacts/${encodeURIComponent(s)}`,l).toString())),d="https:"===c.protocol?a:t;await r.promises.mkdir(o.dirname(e.destinationPath),{recursive:!0}),await new Promise((t,a)=>{let o=!1,i=e.timeoutMs??9e4,s=n=>{if(!o){if(o=!0,clearTimeout(u),n)return void r.promises.rm(e.destinationPath,{force:!0}).finally(()=>a(n));t()}},l=d.request({protocol:c.protocol,host:c.hostname,port:c.port,method:"GET",path:c.pathname+c.search,headers:e.token?{authorization:`Bearer ${e.token}`,"x-agent-device-token":e.token}:void 0},t=>{if((t.statusCode??500)>=400){let a="";t.setEncoding("utf8"),t.on("data",e=>{a+=e}),t.on("end",()=>{s(new p("COMMAND_FAILED","Failed to download remote artifact",{artifactId:e.artifactId,statusCode:t.statusCode,requestId:e.requestId,body:a}))});return}t.on("aborted",()=>{s(new p("COMMAND_FAILED","Remote artifact download was interrupted",{artifactId:e.artifactId,requestId:e.requestId}))}),n(t,r.createWriteStream(e.destinationPath)).then(()=>s(),e=>s(e instanceof Error?e:Error(String(e))))}),u=setTimeout(()=>{l.destroy(new p("COMMAND_FAILED","Remote artifact download timed out",{artifactId:e.artifactId,requestId:e.requestId,timeoutMs:i}))},i);l.on("error",t=>{t instanceof p?s(t):s(new p("COMMAND_FAILED","Failed to download remote artifact",{artifactId:e.artifactId,requestId:e.requestId,timeoutMs:i},t instanceof Error?t:void 0))}),l.end()})}function eK(e,t){let a=R(e,"bundleId"),r=R(e,"package");return{app:$(e,"app"),appPath:$(e,"appPath"),platform:O(e,"platform"),appId:a??r,bundleId:a,package:r,identifiers:E({session:t,bundleId:a,packageName:r})}}function eV(e){let{record:t,platform:a,id:r,name:o,target:n}=eJ(e,"name");return{platform:a,target:n,kind:x(t,"kind"),id:r,name:o,booted:"boolean"==typeof t.booted?t.booted:void 0,identifiers:D(a,r,o),...eW(a,r)}}function eG(e){let{record:t,platform:a,id:r,name:o,target:n}=eJ(e,"name"),i=$(t,"device"),s={session:o,...D(a,r,i)};return{name:o,createdAt:U(t,"createdAt"),device:{platform:a,target:n,id:r,name:i,identifiers:s,...eW(a,r,H(t,"ios_simulator_device_set"))},identifiers:s}}function eJ(e,t){let a=_(e);return{record:a,platform:O(a,"platform"),id:$(a,"id"),name:$(a,t),target:K(a,"target")}}function eW(e,t,a){return{ios:"ios"===e?{udid:t,...void 0!==a?{simulatorSetPath:a}:{}}:void 0,android:"android"===e?{serial:t}:void 0}}function eY(e){return e??"default"}function eQ(e={},t={}){var a;let r,o=t.transport??eh,n=async(t,a=[],r={})=>{var n,i;let s=(n=e,i=r,{...n,...i}),l=await o({session:eY(s.session),command:t,positionals:a,flags:L({stateDir:s.stateDir,daemonBaseUrl:s.daemonBaseUrl,daemonAuthToken:s.daemonAuthToken,daemonTransport:s.daemonTransport,daemonServerMode:s.daemonServerMode,tenant:s.tenant,sessionIsolation:s.sessionIsolation,runId:s.runId,leaseId:s.leaseId,leaseBackend:s.leaseBackend,platform:s.platform,target:s.target,device:s.device,udid:s.udid,serial:s.serial,iosSimulatorDeviceSet:s.iosSimulatorDeviceSet,androidDeviceAllowlist:s.androidDeviceAllowlist,surface:s.surface,activity:s.activity,relaunch:s.relaunch,shutdown:s.shutdown,saveScript:s.saveScript,noRecord:s.noRecord,backMode:s.backMode,metroHost:s.metroHost,metroPort:s.metroPort,bundleUrl:s.bundleUrl,launchUrl:s.launchUrl,snapshotInteractiveOnly:s.interactiveOnly,snapshotCompact:s.compact,snapshotDepth:s.depth,snapshotScope:s.scope,snapshotRaw:s.raw,snapshotForceFull:s.forceFull,...G(s),appsFilter:s.appsFilter,out:s.out,count:s.count,fps:s.fps,quality:s.quality,hideTouches:s.hideTouches,intervalMs:s.intervalMs,delayMs:s.delayMs,holdMs:s.holdMs,jitterPx:s.jitterPx,pixels:s.pixels,doubleTap:s.doubleTap,clickButton:s.clickButton,pauseMs:s.pauseMs,pattern:s.pattern,headless:s.headless,restart:s.restart,replayUpdate:s.replayUpdate,replayBackend:s.replayBackend,replayEnv:s.replayEnv,replayShellEnv:s.replayShellEnv,failFast:s.failFast,timeoutMs:s.timeoutMs,retries:s.retries,artifactsDir:s.artifactsDir,reportJunit:s.reportJunit,findFirst:s.findFirst,findLast:s.findLast,networkInclude:s.networkInclude,batchOnError:s.batchOnError,batchMaxSteps:s.batchMaxSteps,batchSteps:s.batchSteps,verbose:s.debug}),runtime:s.runtime,meta:L({requestId:s.requestId,cwd:s.cwd,debug:s.debug,lockPolicy:s.lockPolicy,lockPlatform:s.lockPlatform,tenantId:s.tenant,runId:s.runId,leaseId:s.leaseId,leaseBackend:s.leaseBackend,leaseTtlMs:s.leaseTtlMs,sessionIsolation:s.sessionIsolation,installSource:s.installSource,retainMaterializedPaths:s.retainMaterializedPaths,materializedPathRetentionMs:s.materializedPathRetentionMs,materializationId:s.materializationId})});return l.ok||function(e){throw new p(d(e.code),e.message,{...e.details??{},hint:e.hint,diagnosticId:e.diagnosticId,logPath:e.logPath})}(l.error),l.data??{}},i=async(e={})=>{let t=await n(B.sessionList,[],e);return(Array.isArray(t.sessions)?t.sessions:[]).map(eG)},s=async(e,t=[],a={})=>await n(e,t,a),l=(t={})=>{var a,r;return eY((a=e,r=t,{...a,...r}).session)};return{command:(a=async e=>await n(e.command,e.positionals,e.options),r=async e=>await a(e),{wait:async e=>{var t;return await r((t=e,{command:P.wait,positionals:Y.encode(t),options:t}))},alert:async(e={})=>{var t;let a;return await r((a=(t=e).action??"get",{command:P.alert,positionals:[a,...void 0!==t.timeoutMs?[String(t.timeoutMs)]:[]],options:t}))},appState:async(e={})=>await r({command:P.appState,positionals:[],options:e}),back:async(e={})=>await r({command:P.back,positionals:[],options:{...e,backMode:e.mode}}),home:async(e={})=>await r({command:P.home,positionals:[],options:e}),rotate:async e=>await r({command:P.rotate,positionals:[e.orientation],options:e}),appSwitcher:async(e={})=>await r({command:P.appSwitcher,positionals:[],options:e}),keyboard:async(e={})=>await r({command:P.keyboard,positionals:e.action?[e.action]:[],options:e}),clipboard:async e=>{var t;return await r("read"===(t=e).action?{command:P.clipboard,positionals:["read"],options:t}:{command:P.clipboard,positionals:["write",t.text],options:t})},reactNative:async e=>await r({command:P.reactNative,positionals:[e.action],options:e})}),devices:{list:async(e={})=>{let t=await n(P.devices,[],e);return(Array.isArray(t.devices)?t.devices:[]).map(eV)},boot:async(e={})=>await s(P.boot,[],e)},sessions:{list:async(e={})=>await i(e),close:async(e={})=>{let t=l(e),a=(await n(P.close,[],e)).shutdown;return{session:t,shutdown:"object"==typeof a&&null!==a?a:void 0,identifiers:{session:t}}}},apps:{install:async e=>eK(await n(P.install,[e.app,e.appPath],e),l(e)),reinstall:async e=>eK(await n(P.reinstall,[e.app,e.appPath],e),l(e)),installFromSource:async e=>(function(e,t){let a=R(e,"bundleId"),r=R(e,"packageName"),o=a??r??R(e,"appId"),n=R(e,"launchTarget")??r??a??o;if(!n)throw new p("COMMAND_FAILED",'Daemon response is missing "launchTarget".',{response:e});return{appName:R(e,"appName"),appId:o,bundleId:a,packageName:r,launchTarget:n,installablePath:R(e,"installablePath"),archivePath:R(e,"archivePath"),materializationId:R(e,"materializationId"),materializationExpiresAt:R(e,"materializationExpiresAt"),identifiers:E({session:t,bundleId:a,packageName:r,appId:o})}})(await n(B.installSource,[],{...e,installSource:e.source,retainMaterializedPaths:e.retainPaths,materializedPathRetentionMs:e.retentionMs}),l(e)),list:async(e={})=>{let t=await n(P.apps,[],e);return Array.isArray(t.apps)?t.apps.filter(e=>"string"==typeof e):[]},open:async e=>{let t=l(e),a=e.app?e.url?[e.app,e.url]:[e.app]:[],r=await n(P.open,a,e),o=function(e){let t=e.platform,a=R(e,"id"),r=R(e,"device");if("ios"!==t&&"macos"!==t&&"android"!==t&&"linux"!==t||!a||!r)return;let o=K(e,"target"),n=D(t,a,r);return{platform:t,target:o,id:a,name:r,identifiers:n,ios:"ios"===t?{udid:R(e,"device_udid")??a,simulatorSetPath:H(e,"ios_simulator_device_set")}:void 0,android:"android"===t?{serial:R(e,"serial")??a}:void 0}}(r),i=R(r,"appBundleId");return{session:t,appName:R(r,"appName"),appBundleId:i,appId:i,startup:function(e){if(j(e)&&"number"==typeof e.durationMs&&"string"==typeof e.measuredAt&&"string"==typeof e.method)return{durationMs:e.durationMs,measuredAt:e.measuredAt,method:e.method,appTarget:R(e,"appTarget"),appBundleId:R(e,"appBundleId")}}(r.startup),runtime:function(e){if(!j(e))return;let t=e.platform,a=R(e,"metroHost"),r="number"==typeof e.metroPort?e.metroPort:void 0;return{platform:"ios"===t||"android"===t?t:void 0,metroHost:a,metroPort:r,bundleUrl:R(e,"bundleUrl"),launchUrl:R(e,"launchUrl")}}(r.runtime),device:o,identifiers:{session:t,deviceId:o?.id,deviceName:o?.name,udid:o?.ios?.udid,serial:o?.android?.serial,appId:i,appBundleId:i}}},close:async(e={})=>{let t=l(e),a=(await n(P.close,e.app?[e.app]:[],e)).shutdown;return{session:t,closedApp:e.app,shutdown:"object"==typeof a&&null!==a?a:void 0,identifiers:{session:t}}},push:async e=>{var t;return await s(P.push,[e.app,"string"==typeof(t=e.payload)?t:JSON.stringify(t)],e)},triggerEvent:async e=>{var t;return await s(P.triggerAppEvent,[(t=e).event,...t.payload?[JSON.stringify(t.payload)]:[]],e)}},materializations:{release:async e=>{var t;return{released:!0===(t=await n(B.releaseMaterializedPaths,[],{...e,materializationId:e.materializationId})).released,materializationId:$(t,"materializationId"),identifiers:{}}}},leases:{allocate:async e=>e2(await n(B.leaseAllocate,[],{...e,leaseId:void 0,leaseTtlMs:e.ttlMs})),heartbeat:async e=>e2(await n(B.leaseHeartbeat,[],{...e,leaseTtlMs:e.ttlMs})),release:async e=>({released:!0===(await n(B.leaseRelease,[],e)).released})},metro:{prepare:async t=>await ee({projectRoot:t.projectRoot??e.cwd,kind:t.kind,publicBaseUrl:t.publicBaseUrl,proxyBaseUrl:t.proxyBaseUrl,proxyBearerToken:t.bearerToken,bridgeScope:t.bridgeScope,launchUrl:t.launchUrl,companionProfileKey:t.companionProfileKey,companionConsumerKey:t.companionConsumerKey,metroPort:t.port,listenHost:t.listenHost,statusHost:t.statusHost,startupTimeoutMs:t.startupTimeoutMs,probeTimeoutMs:t.probeTimeoutMs,reuseExisting:t.reuseExisting,installDependenciesIfNeeded:t.installDependenciesIfNeeded,runtimeFilePath:t.runtimeFilePath,logPath:t.logPath}),reload:async(t={})=>await Z({metroHost:t.metroHost,metroPort:t.metroPort,bundleUrl:t.bundleUrl,runtime:e.runtime,timeoutMs:t.timeoutMs})},capture:{snapshot:async(e={})=>{var t,a,r,o;let i,s,c,d,p,u=l(e);return t=await n(P.snapshot,[],e),a=u,i=R(t,"appBundleId"),{nodes:Array.isArray(r=t.nodes)?r:[],truncated:!0===t.truncated,appName:R(t,"appName"),appBundleId:i,...(s=eX((o=t).visibility),c=eX(o.androidSnapshot),d=eX(o.unchanged),p=Array.isArray(o.warnings)?o.warnings.filter(e=>"string"==typeof e):void 0,{...s?{visibility:s}:{},...c?{androidSnapshot:c}:{},...d?{unchanged:d}:{},...p?{warnings:p}:{}}),identifiers:{session:a,appId:i,appBundleId:i}}},screenshot:async(e={})=>{let t=l(e),a=await n(P.screenshot,e.path?[e.path]:[],{...e,...G(e)});return{path:$(a,"path"),overlayRefs:function(e){let t=e.overlayRefs;if(!Array.isArray(t))return;let a=[];for(let e of t){if(!j(e))continue;let t=R(e,"ref"),r=A(e,"rect"),o=A(e,"overlayRect"),n=C(e,"center");t&&r&&o&&n&&a.push({ref:t,label:R(e,"label"),rect:r,overlayRect:o,center:n})}return a}(a),identifiers:{session:t}}},diff:async e=>await s(P.diff,[e.kind],{...e,interactiveOnly:e.interactiveOnly,compact:e.compact,depth:e.depth,scope:e.scope,raw:e.raw})},interactions:{click:async e=>await s(P.click,Q.encode(e),{...e,clickButton:e.button}),press:async e=>await s(P.press,Q.encode(e),e),longPress:async e=>await s(P.longPress,M.encode(e),e),swipe:async e=>await s(P.swipe,[String(e.from.x),String(e.from.y),String(e.to.x),String(e.to.y),...e0(e.durationMs)],e),focus:async e=>await s(P.focus,[String(e.x),String(e.y)],e),type:async e=>await s(P.type,z.encode(e),e),fill:async e=>await s(P.fill,q.encode(e),e),scroll:async e=>await s(P.scroll,[e.direction,...e0(e.amount)],e),pinch:async e=>await s(P.pinch,[String(e.scale),...e0(e.x),...e0(e.y)],e),get:async e=>await s(P.get,[e.format,...S.encode(e)],e),is:async e=>await s(P.is,V.encode(e),e),find:async e=>await s(P.find,F.encode(e),{...e,findFirst:e.first,findLast:e.last})},replay:{run:async e=>await s(P.replay,[e.path],{...e,replayUpdate:e.update,replayBackend:e.backend??(!0===e.maestro?"maestro":void 0),replayEnv:e.env,replayShellEnv:e1(process.env)}),test:async e=>await s(P.test,e.paths,{...e,replayUpdate:e.update,replayEnv:e.env,replayShellEnv:e1(process.env)})},batch:{run:async e=>await s(P.batch,[],{...e,batchSteps:e.steps,batchOnError:e.onError,batchMaxSteps:e.maxSteps})},observability:{perf:async(e={})=>await s(P.perf,[],e),logs:async(e={})=>{var t;return await s(P.logs,[(t=e).action??"path",...eZ(t.message)],e)},network:async(e={})=>{var t;return await s(P.network,[...(t=e).action?[t.action]:[],...e0(t.limit)],{...e,networkInclude:e.include})}},recording:{record:async e=>await s(P.record,[e.action,...eZ(e.path)],e),trace:async e=>await s(P.trace,[e.action,...eZ(e.path)],e)},settings:{update:async e=>await s(P.settings,k.encode(e),e)}}}function eX(e){return"object"==typeof e&&null!==e?e:void 0}function eZ(e){return void 0===e?[]:[e]}function e0(e){return void 0===e?[]:[String(e)]}function e1(e){let t={};for(let[a,r]of Object.entries(e))"string"==typeof r&&a.startsWith("AD_VAR_")&&(t[a]=r);return t}function e2(e){let t=e.lease;if(!t||"object"!=typeof t||Array.isArray(t))throw Error("Invalid lease response from daemon");return{leaseId:$(t,"leaseId"),tenantId:$(t,"tenantId"),runId:$(t,"runId"),backend:$(t,"backend"),createdAt:"number"==typeof t.createdAt?t.createdAt:void 0,heartbeatAt:"number"==typeof t.heartbeatAt?t.heartbeatAt:void 0,expiresAt:"number"==typeof t.expiresAt?t.expiresAt:void 0}}export{eQ as createAgentDeviceClient,eh as sendToDaemon};
|
|
1
|
+
import e from"node:net";import t from"node:http";import a from"node:https";import r from"node:fs";import o from"node:path";import{pipeline as n}from"node:stream/promises";import i from"node:os";import{createHash as s,randomUUID as l}from"node:crypto";import{Writable as c}from"node:stream";import{toAppErrorCode as d,AppError as p}from"./9152.js";import{runCmdSync as u,runCmd as m,runCmdDetached as f}from"./9818.js";import{readVersion as h,findProjectRoot as y}from"./9671.js";import{createRequestId as w,withDiagnosticTimer as v,emitDiagnostic as I}from"./7599.js";import{isAgentDeviceDaemonProcess as g,stopProcessForTakeover as b}from"./8656.js";import{readRect as A,settingsCommandCodec as k,PUBLIC_COMMANDS as P,elementTargetCodec as S,asRecord as _,longPressCommandCodec as M,buildAppIdentifiers as E,buildDeviceIdentifiers as D,computeDaemonCodeSignature as T,resolveDaemonTransportPreference as N,readRequiredNumber as U,readPoint as C,parsing_stripUndefined as R,readOptionalString as L,readRequiredPlatform as O,readRequiredDeviceKind as x,findCommandCodec as F,INTERNAL_COMMANDS as B,fillCommandCodec as q,typeCommandCodec as z,isRecord as $,readRequiredString as j,readNullableString as H,readDeviceTarget as K,isCommandCodec as V,screenshotFlagsFromOptions as G,resolveDaemonPaths as J,resolveDaemonServerMode as W,waitCommandCodec as Y,interactionTargetCodec as Q}from"./3572.js";import{sleep as X}from"./4829.js";import{reloadMetro as Z,prepareMetroRuntime as ee}from"./1974.js";function et(e){return new Promise((t,a)=>{let r="";e.setEncoding("utf8"),e.on("data",e=>{r+=e}),e.on("end",()=>t(r)),e.on("error",a)})}let ea="sha256";async function er(e){let t=await eo(e.localPath,e.platform),a=e.baseUrl.endsWith("/")?e.baseUrl:`${e.baseUrl}/`;try{let r=await el({normalizedBase:a,token:e.token,artifact:t});if(r?.kind==="cache-hit")return r.uploadId;if(r?.kind==="direct-upload")try{return await ec(t.payloadPath,r),await ep({normalizedBase:a,token:e.token,uploadId:r.uploadId})}catch{}return await es({normalizedBase:a,token:e.token,artifact:t})}finally{t.cleanup()}}async function eo(e,t){var a,n,i;let s,l=r.statSync(e),c=o.basename(e),d=l.isDirectory(),p=("ios"===(a=t)||"android"===a?a:void 0)??(n=e,i=l,s=n.toLowerCase(),i.isDirectory()&&s.endsWith(".app")||s.endsWith(".ipa")?"ios":s.endsWith(".apk")||s.endsWith(".aab")?"android":void 0),u=[];try{let t=d?await en(e,u):e,a=r.statSync(t);return{payloadPath:t,fileName:c,artifactType:d?"app-bundle":"file",platform:p,contentType:d?"application/gzip":"application/octet-stream",sha256:await eu(t),sizeBytes:a.size,cleanup:()=>ei(u)}}catch(e){throw ei(u),e}}async function en(e,t){let a=r.mkdtempSync(o.join(i.tmpdir(),`agent-device-upload-${l()}-`));t.push(a);let n=o.join(a,`${o.basename(e)}.tar.gz`);return await m("tar",["czf",n,"-C",o.dirname(e),o.basename(e)],{env:{...process.env,COPYFILE_DISABLE:"1"}}),n}function ei(e){for(let t of e)r.rmSync(t,{recursive:!0,force:!0})}async function es(e){let{normalizedBase:t,token:a,artifact:r}=e,o=new URL("upload",t),n={"content-type":r.contentType,"x-artifact-type":r.artifactType,"x-artifact-filename":r.fileName,"x-artifact-hash":r.sha256,"x-artifact-hash-algorithm":ea,"transfer-encoding":"chunked"};a&&(n.authorization=`Bearer ${a}`,n["x-agent-device-token"]=a);let i=await ed({url:o,method:"POST",headers:n,payloadPath:r.payloadPath,timeoutMessage:"Artifact upload timed out",timeoutHint:"The upload to the remote daemon exceeded the 5-minute timeout.",errorMessage:"Failed to upload artifact to remote daemon",errorHint:"Verify the remote daemon is reachable and supports artifact uploads."});try{let e=JSON.parse(i.body);if(!e.ok||!e.uploadId)throw new p("COMMAND_FAILED",`Upload failed: ${i.body}`);return e.uploadId}catch(e){if(e instanceof p)throw e;throw new p("COMMAND_FAILED",`Invalid upload response: ${i.body}`)}}async function el(e){let t=new URL("upload/preflight",e.normalizedBase),a={"content-type":"application/json"};e.token&&(a.authorization=`Bearer ${e.token}`,a["x-agent-device-token"]=e.token);let r=await fetch(t,{method:"POST",headers:a,signal:AbortSignal.timeout(3e4),body:JSON.stringify({sha256:e.artifact.sha256,fileName:e.artifact.fileName,sizeBytes:e.artifact.sizeBytes,artifactType:e.artifact.artifactType,...e.artifact.platform?{platform:e.artifact.platform}:{},contentType:e.artifact.contentType})}).catch(()=>void 0);if(r?.ok)return function(e){var t;if(!e||"object"!=typeof e||!0!==e.ok||"string"!=typeof e.uploadId)return;if(!0===e.cacheHit)return{kind:"cache-hit",uploadId:e.uploadId};let a=e.upload;if(!a||"string"!=typeof a.url)return;let r=a.headers??{};if(!(!(t=r)||"object"!=typeof t||Array.isArray(t))&&Object.values(t).every(e=>"string"==typeof e))return{kind:"direct-upload",uploadId:e.uploadId,url:a.url,headers:r}}(await r.json().catch(()=>void 0))}async function ec(e,t){let a=await ed({url:new URL(t.url),method:"PUT",headers:t.headers,payloadPath:e,timeoutMessage:"Direct artifact upload timed out",timeoutHint:"The direct upload ticket did not accept the artifact within the timeout.",errorMessage:"Failed to upload artifact with direct upload ticket"});if(a.statusCode<200||a.statusCode>=300)throw new p("COMMAND_FAILED","Direct artifact upload failed",{statusCode:a.statusCode,statusMessage:a.statusMessage})}async function ed(e){let o="https:"===e.url.protocol?a:t;return await new Promise((t,a)=>{let i=o.request({protocol:e.url.protocol,host:e.url.hostname,port:e.url.port,method:e.method,path:e.url.pathname+e.url.search,headers:e.headers},e=>{et(e).then(a=>{clearTimeout(s),t({statusCode:e.statusCode??500,statusMessage:e.statusMessage,body:a})}).catch(a)}),s=setTimeout(()=>{i.destroy(),a(new p("COMMAND_FAILED",e.timeoutMessage,{timeoutMs:3e5,...e.timeoutHint?{hint:e.timeoutHint}:{}}))},3e5);i.on("error",t=>{clearTimeout(s),a(new p("COMMAND_FAILED",e.errorMessage,e.errorHint?{hint:e.errorHint}:{},t))}),i.on("close",()=>clearTimeout(s)),n(r.createReadStream(e.payloadPath),i).catch(e=>{i.destroy(),a(new p("COMMAND_FAILED","Failed to read local artifact",{},e instanceof Error?e:Error(String(e))))})})}async function ep(e){let t=new URL("upload/finalize",e.normalizedBase),a={"content-type":"application/json"};e.token&&(a.authorization=`Bearer ${e.token}`,a["x-agent-device-token"]=e.token);let r=await fetch(t,{method:"POST",headers:a,signal:AbortSignal.timeout(3e4),body:JSON.stringify({uploadId:e.uploadId})}).catch(e=>{throw new p("COMMAND_FAILED","Failed to finalize direct artifact upload",{},e)});if(!r.ok)throw new p("COMMAND_FAILED","Direct artifact upload finalize failed",{status:r.status,statusText:r.statusText});let o=await r.json().catch(()=>void 0);if(!o?.ok||!o.uploadId)throw new p("COMMAND_FAILED","Invalid upload finalize response");return o.uploadId}async function eu(e){let t=s(ea),a=new c({write(e,a,r){t.update(e),r()}});return await n(r.createReadStream(e),a).catch(e=>{throw new p("COMMAND_FAILED","Failed to read local artifact",{},e instanceof Error?e:void 0)}),t.digest("hex")}let em=["xcodebuild .*AgentDeviceRunnerUITests/RunnerTests/testCommand","xcodebuild .*AgentDeviceRunner\\.env\\.session-","xcodebuild build-for-testing .*ios-runner/AgentDeviceRunner/AgentDeviceRunner\\.xcodeproj"],ef=new e.BlockList;async function eh(t){let a=t.meta?.requestId??w(),r=!!(t.meta?.debug||t.flags?.verbose),o=function(t){let a,r=t.flags?.stateDir??process.env.AGENT_DEVICE_STATE_DIR,o=function(e){let t;if(e){try{t=new URL(e)}catch(t){throw new p("INVALID_ARGS","Invalid daemon base URL",{daemonBaseUrl:e},t instanceof Error?t:void 0)}if("http:"!==t.protocol&&"https:"!==t.protocol)throw new p("INVALID_ARGS","Daemon base URL must use http or https",{daemonBaseUrl:e});return t.toString().replace(/\/+$/,"")}}(t.flags?.daemonBaseUrl??process.env.AGENT_DEVICE_DAEMON_BASE_URL),n=t.flags?.daemonAuthToken??process.env.AGENT_DEVICE_DAEMON_AUTH_TOKEN;var i=o,s=n;if(!(!i||"localhost"===(a=new URL(i).hostname.trim().toLowerCase().replace(/^\[(.*)\]$/,"$1"))||(e.isIPv4(a)?ef.check(a,"ipv4"):!!e.isIPv6(a)&&ef.check(a,"ipv6")))&&("string"!=typeof s||!(s.trim().length>0)))throw new p("INVALID_ARGS","Remote daemon base URL for non-loopback hosts requires daemon authentication",{daemonBaseUrl:i,hint:"Provide --daemon-auth-token or AGENT_DEVICE_DAEMON_AUTH_TOKEN when using a non-loopback remote daemon URL."});let l=t.flags?.daemonTransport??process.env.AGENT_DEVICE_DAEMON_TRANSPORT,c=N(l);if(o&&"socket"===c)throw new p("INVALID_ARGS","Remote daemon base URL only supports HTTP transport. Remove --daemon-transport socket.",{daemonBaseUrl:o});let d=W(t.flags?.daemonServerMode??process.env.AGENT_DEVICE_DAEMON_SERVER_MODE??("dual"===l?"dual":void 0));return{paths:J(r),transportPreference:c,serverMode:d,remoteBaseUrl:o,remoteAuthToken:n}}(t),n="test"===t.command?void 0:9e4,i=await v("daemon_startup",async()=>await eb(o),{requestId:a,session:t.session}),s=await ey(t,i),l={...t,positionals:s.positionals,flags:s.flags,token:i.token,meta:{...t.meta??{},requestId:a,debug:r,cwd:t.meta?.cwd,tenantId:t.meta?.tenantId??t.flags?.tenant,runId:t.meta?.runId??t.flags?.runId,leaseId:t.meta?.leaseId??t.flags?.leaseId,sessionIsolation:t.meta?.sessionIsolation??t.flags?.sessionIsolation,lockPolicy:t.meta?.lockPolicy,lockPlatform:t.meta?.lockPlatform,...s.uploadedArtifactId?{uploadedArtifactId:s.uploadedArtifactId}:{},...s.clientArtifactPaths?{clientArtifactPaths:s.clientArtifactPaths}:{},...s.installSource?{installSource:s.installSource}:{}}};return I({level:"info",phase:"daemon_request_prepare",data:{requestId:a,command:t.command,session:t.session}}),await v("daemon_request",async()=>await eR(i,l,o.transportPreference,n),{requestId:a,command:t.command})}async function ey(e,t){let a,n=[...e.positionals??[]],i=e.flags?{...e.flags}:void 0,s=e.meta?.installSource,l={};if(ez(t)){let r=function(e,t){if("screenshot"===e.command){let a=eI(e,"path",".png");return t[0]?{field:"path",localPath:a,positionalIndex:0,positionalPath:eg("screenshot",".png")}:{field:"path",localPath:a,positionalIndex:0,flagPath:eg("screenshot",".png")}}if("record"===e.command&&"start"===(t[0]??"").toLowerCase()){let t=eI(e,"outPath",".mp4",1);return{field:"outPath",localPath:t,positionalIndex:1,positionalPath:eg("recording",o.extname(t)||".mp4")}}return null}(e,n);r&&(void 0!==r.positionalPath&&(n[r.positionalIndex]=r.positionalPath),void 0!==r.flagPath&&((i??={}).out=r.flagPath),l[r.field]=r.localPath);let c=await ev(e,t);c&&(s=c.installSource,a=c.uploadedArtifactId??a)}let c=()=>ew({positionals:n,flags:i,installSource:s,uploadedArtifactId:a,clientArtifactPaths:l});if(!ez(t)||"install"!==e.command&&"reinstall"!==e.command||n.length<2)return c();let d=n[1];if(d.startsWith("remote:"))return n[1]=d.slice(7),ew({positionals:n,flags:i,clientArtifactPaths:l});let p=o.isAbsolute(d)?d:o.resolve(e.meta?.cwd??process.cwd(),d);return r.existsSync(p)?(a=await er({localPath:p,baseUrl:t.baseUrl,token:t.token,platform:e.flags?.platform}),c()):ew({positionals:n,flags:i,clientArtifactPaths:l})}function ew(e){return{positionals:e.positionals,flags:e.flags,installSource:e.installSource,uploadedArtifactId:e.uploadedArtifactId,...Object.keys(e.clientArtifactPaths).length>0?{clientArtifactPaths:e.clientArtifactPaths}:{}}}async function ev(e,t){let a=e.meta?.installSource;if("install_source"!==e.command||!a||"path"!==a.kind)return null;let n=a.path.trim();if(!n)return{installSource:a};if(n.startsWith("remote:"))return{installSource:{...a,path:n.slice(7)}};let i=o.isAbsolute(n)?n:o.resolve(e.meta?.cwd??process.cwd(),n);if(!r.existsSync(i))return{installSource:{...a,path:i}};let s=await er({localPath:i,baseUrl:t.baseUrl,token:t.token,platform:e.flags?.platform});return{installSource:{...a,path:i},uploadedArtifactId:s}}function eI(e,t,a,r=0){let n=e.positionals?.[r]??e.flags?.out,i=`${"path"===t?"screenshot":"recording"}-${Date.now()}${a}`,s=n&&n.trim().length>0?n:i;return o.isAbsolute(s)?s:o.resolve(e.meta?.cwd??process.cwd(),s)}function eg(e,t){let a=t.startsWith(".")?t:`.${t}`;return o.posix.join("/tmp",`agent-device-${e}-${Date.now()}-${Math.random().toString(36).slice(2,8)}${a}`)}async function eb(e){let t,a;if(e.remoteBaseUrl){let t={transport:"http",token:e.remoteAuthToken??"",pid:0,baseUrl:e.remoteBaseUrl};if(await eN(t,"http"))return t;throw new p("COMMAND_FAILED","Remote daemon is unavailable",{daemonBaseUrl:e.remoteBaseUrl,hint:"Verify AGENT_DEVICE_DAEMON_BASE_URL points to a reachable daemon with GET /health and POST /rpc."})}let r=eS(e.paths.infoPath),o=h(),n=T((a=eC()).useSrc?a.srcPath:a.distPath,a.root),i=!!r&&await eN(r,e.transportPreference);if(r&&r.version===o&&r.codeSignature===n&&i)return r;r&&(r.version!==o||r.codeSignature!==n||!i)&&(await eP(r),eT(e.paths.infoPath)),function(e){let t=eE(e);if(!t.hasLock||t.hasInfo)return;let a=e_(e.lockPath);if(!a)return eT(e.lockPath);g(a.pid,a.processStartTime)||eT(e.lockPath)}(e.paths);let s=0,l=[];for(let a=1;a<=2;a+=1){try{await eU(e)}catch(r){if(t=r instanceof Error?r.message:String(r),l.push(await eM(e.paths,"start_error")),a<2){await X(150);continue}break}let r=await eA(15e3,e);if(r)return r;if(await ek(e.paths)){s+=1;continue}let o=eE(e.paths),n=a<2,i=await eM(e.paths,"startup_timeout",{stopLiveProcesses:!1});if(l.push(i),i.retainedInfoProcess||i.retainedLockProcess){let t=await eA(15e3,e);if(t)return t;break}if(!n)break;o.hasInfo||o.hasLock||await X(150)}let c=eE(e.paths);throw new p("COMMAND_FAILED","Failed to start daemon",{kind:"daemon_startup_failed",infoPath:e.paths.infoPath,lockPath:e.paths.lockPath,startupTimeoutMs:15e3,startupAttempts:2,lockRecoveryCount:s,cleanupResults:l,startError:t,metadataState:c,hint:function(e,t=J(process.env.AGENT_DEVICE_STATE_DIR)){return e.hasLock&&!e.hasInfo?`agent-device attempted to clean stale daemon metadata automatically, but ${t.lockPath} still exists without ${t.infoPath}. Retry with --debug; if this persists, remove ${t.lockPath} after confirming no agent-device daemon process is running.`:e.hasLock&&e.hasInfo?`agent-device attempted to clean stale daemon metadata automatically, but ${t.infoPath} and ${t.lockPath} still remain. Retry with --debug; if this persists, remove both files after confirming no agent-device daemon process is running.`:"agent-device did not observe reachable daemon metadata after retrying. Stale metadata was cleaned automatically when safe; retry with --debug and check daemon diagnostics logs."}(c,e.paths)})}async function eA(e,t){let a=Date.now();for(;Date.now()-a<e;){let e=eS(t.paths.infoPath);if(e&&await eN(e,t.transportPreference))return e;await X(100)}return null}async function ek(e){let t=eE(e);if(!t.hasLock||t.hasInfo)return!1;let a=e_(e.lockPath);return!(a&&g(a.pid,a.processStartTime))&&(eT(e.lockPath),!0)}async function eP(e){await b(e.pid,{termTimeoutMs:3e3,killTimeoutMs:1e3,expectedStartTime:e.processStartTime})}function eS(e){let t=eD(e);if(!t||"object"!=typeof t)return null;let a="string"==typeof t.token&&t.token.length>0?t.token:null;if(!a)return null;let r=Number.isInteger(t.port)&&Number(t.port)>0,o=Number.isInteger(t.httpPort)&&Number(t.httpPort)>0;if(!r&&!o)return null;let n=t.transport,i="string"==typeof t.version?t.version:void 0,s="string"==typeof t.codeSignature?t.codeSignature:void 0,l="string"==typeof t.processStartTime?t.processStartTime:void 0,c=Number.isInteger(t.pid)&&Number(t.pid)>0;return{token:a,port:r?Number(t.port):void 0,httpPort:o?Number(t.httpPort):void 0,transport:"socket"===n||"http"===n||"dual"===n?n:void 0,pid:c?Number(t.pid):0,version:i,codeSignature:s,processStartTime:l}}function e_(e){let t=eD(e);return t&&"object"==typeof t&&Number.isInteger(t.pid)&&Number(t.pid)>0?{pid:Number(t.pid),processStartTime:"string"==typeof t.processStartTime?t.processStartTime:void 0,startedAt:"number"==typeof t.startedAt?t.startedAt:void 0}:null}ef.addSubnet("127.0.0.0",8,"ipv4"),ef.addAddress("::1","ipv6"),ef.addSubnet("::ffff:127.0.0.0",104,"ipv6");async function eM(e,t,a={}){let o=a.stopLiveProcesses??!0,n={reason:t,removedInfo:!1,removedLock:!1,stoppedInfoProcess:!1,stoppedLockProcess:!1};try{var i,s,l,c;let t=r.existsSync(e.infoPath),a=eS(e.infoPath);if(a){let t=g(a.pid,a.processStartTime);t&&!o?n.retainedInfoProcess=!0:(t&&(await eP(a),n.stoppedInfoProcess=!0),i=e.infoPath,eT(i),n.removedInfo=!0)}else t&&(s=e.infoPath,eT(s),n.removedInfo=!0);let d=r.existsSync(e.lockPath),p=e_(e.lockPath);if(p){let t=g(p.pid,p.processStartTime);t&&!o?n.retainedLockProcess=!0:(t&&(await b(p.pid,{termTimeoutMs:3e3,killTimeoutMs:1e3,expectedStartTime:p.processStartTime}),n.stoppedLockProcess=!0),l=e.lockPath,eT(l),n.removedLock=!0)}else d&&(c=e.lockPath,eT(c),n.removedLock=!0)}catch(e){n.error=e instanceof Error?e.message:String(e)}return I({level:n.error?"warn":"info",phase:"daemon_startup_metadata_cleanup",data:n}),n}function eE(e){return{hasInfo:r.existsSync(e.infoPath),hasLock:r.existsSync(e.lockPath)}}function eD(e){if(!r.existsSync(e))return null;try{return JSON.parse(r.readFileSync(e,"utf8"))}catch{return null}}function eT(e){try{r.existsSync(e)&&r.unlinkSync(e)}catch{}}async function eN(r,o){var n;return"http"===eL(r,o)?await function(e){let r=e.baseUrl?e$(e.baseUrl,"health"):e.httpPort?`http://127.0.0.1:${e.httpPort}/health`:null;if(!r)return Promise.resolve(!1);let o=new URL(r),n="https:"===o.protocol?a:t,i=e.baseUrl?3e3:500;return new Promise(e=>{let t=n.request({protocol:o.protocol,host:o.hostname,port:o.port,path:o.pathname+o.search,method:"GET",timeout:i},t=>{t.resume(),e((t.statusCode??500)<500)});t.on("timeout",()=>{t.destroy(),e(!1)}),t.on("error",()=>{e(!1)}),t.end()})}(r):await ((n=r.port)?new Promise(t=>{let a=e.createConnection({host:"127.0.0.1",port:n},()=>{a.destroy(),t(!0)});a.on("error",()=>{t(!1)})}):Promise.resolve(!1))}async function eU(e){let t=eC(),a=t.useSrc?["--experimental-strip-types",t.srcPath]:[t.distPath],r={...process.env,AGENT_DEVICE_STATE_DIR:e.paths.baseDir,AGENT_DEVICE_DAEMON_SERVER_MODE:e.serverMode};f(process.execPath,a,{env:r})}function eC(){let e=y(),t=[o.join(e,"dist","src","internal","daemon.js"),o.join(e,"dist","src","daemon.js")],a=t.find(e=>r.existsSync(e))??t[0],n=o.join(e,"src","daemon.ts"),i=t.some(e=>r.existsSync(e)),s=r.existsSync(n);if(!i&&!s)throw new p("COMMAND_FAILED","Daemon entry not found",{distPaths:t,srcPath:n});return{root:e,distPath:a,distPaths:t,srcPath:n,useSrc:process.execArgv.includes("--experimental-strip-types")?s:!i&&s}}async function eR(e,t,a,r){return"http"===eL(e,a)?await eq(e,t,r):await eB(e,t,r)}function eL(e,t){if(e.baseUrl){if("socket"===t)throw new p("COMMAND_FAILED","Remote daemon endpoint only supports HTTP transport",{daemonBaseUrl:e.baseUrl});return"http"}if("http"===t||"socket"===t){var a=e,r=t;if(eO(a,r))return r;throw new p("COMMAND_FAILED","http"===r?"Daemon HTTP endpoint is unavailable":"Daemon socket endpoint is unavailable")}let o=("socket"===e.transport||"dual"===e.transport?["socket","http"]:["http","socket"]).find(t=>eO(e,t));if(o)return o;throw new p("COMMAND_FAILED","Daemon metadata has no reachable transport")}function eO(e,t){return"http"===t?!!e.httpPort:!!e.port}function ex(e,t,a,r,o,n){let i=o?{terminated:0}:function(){let e=0;try{for(let t of em){let a=u("pkill",["-f",t],{allowFailure:!0});0===a.exitCode&&(e+=1)}return{terminated:e}}catch(t){return{terminated:e,error:t instanceof Error?t.message:String(t)}}}(),s=!o&&"snapshot"!==r,l=s?function(e,t){let a=!1;try{g(e.pid,e.processStartTime)&&(process.kill(e.pid,"SIGKILL"),a=!0)}catch{b(e.pid,{termTimeoutMs:3e3,killTimeoutMs:1e3,expectedStartTime:e.processStartTime})}finally{eT(t.infoPath),eT(t.lockPath)}return{forcedKill:a}}(e,t):{forcedKill:!1};return I({level:"error",phase:"daemon_request_timeout",data:{timeoutMs:n,requestId:a,command:r,timedOutRunnerPidsTerminated:i.terminated,timedOutRunnerCleanupError:i.error,daemonPidReset:s?e.pid:void 0,daemonPidForceKilled:s?l.forcedKill:void 0,daemonPreservedAfterTimeout:!o&&!s,daemonBaseUrl:e.baseUrl}}),new p("COMMAND_FAILED","Daemon request timed out",{timeoutMs:n,requestId:a,hint:function(e){let{remote:t,resetDaemon:a,command:r}=e;return t?"Retry with --debug and verify the remote daemon URL, auth token, and remote host logs.":a?"Retry with --debug and check daemon diagnostics logs. Timed-out iOS runner xcodebuild processes were terminated when detected.":`Retry with --debug and check daemon diagnostics logs. The timed-out ${r??"request"} request was canceled and iOS runner work was aborted when detected; the daemon was kept alive so the session can still be closed or inspected.`}({remote:o,resetDaemon:s,command:r})})}function eF(e,t,a){return I({level:"error",phase:"daemon_request_socket_error",data:{requestId:t,message:e instanceof Error?e.message:String(e)}}),new p("COMMAND_FAILED","Failed to communicate with daemon",{requestId:t,hint:a?"Retry command. If this persists, verify the remote daemon URL, auth token, and remote host reachability.":"Retry command. If this persists, clean stale daemon metadata and start a fresh session."},e instanceof Error?e:void 0)}async function eB(t,a,r){let o=t.port;if(!o)throw new p("COMMAND_FAILED","Daemon socket endpoint is unavailable");return new Promise((n,i)=>{let s=e.createConnection({host:"127.0.0.1",port:o},()=>{s.write(`${JSON.stringify(a)}
|
|
2
|
+
`)}),l=J(a.flags?.stateDir??process.env.AGENT_DEVICE_STATE_DIR),c="number"==typeof r?setTimeout(()=>{s.destroy(),i(ex(t,l,a.meta?.requestId,a.command,!1,r))},r):void 0,d="";s.setEncoding("utf8"),s.on("data",e=>{let t=(d+=e).indexOf("\n");if(-1===t)return;let r=d.slice(0,t).trim();if(r)try{let e=JSON.parse(r);s.end(),c&&clearTimeout(c),n(e)}catch(e){c&&clearTimeout(c),i(new p("COMMAND_FAILED","Invalid daemon response",{requestId:a.meta?.requestId,line:r},e instanceof Error?e:void 0))}}),s.on("error",e=>{c&&clearTimeout(c),i(eF(e,a.meta?.requestId,!1))})})}async function eq(e,r,o){var n,i,s;let l,c=e.baseUrl?new URL(e$(e.baseUrl,"rpc")):e.httpPort?new URL(`http://127.0.0.1:${e.httpPort}/rpc`):null;if(!c)throw new p("COMMAND_FAILED","Daemon HTTP endpoint is unavailable");let u=JSON.stringify((n=r,i={includeTokenParam:!e.baseUrl},l=n.meta?.requestId??w(),"lease_allocate"!==(s=n.command)&&"lease_heartbeat"!==s&&"lease_release"!==s?{jsonrpc:"2.0",id:l,method:"agent_device.command",params:n}:{jsonrpc:"2.0",id:l,method:function(e){switch(e){case"lease_allocate":return"agent_device.lease.allocate";case"lease_heartbeat":return"agent_device.lease.heartbeat";case"lease_release":return"agent_device.lease.release"}}(n.command),params:function(e,t,a){let r={...a.includeTokenParam?{token:e.token}:{},session:e.session,tenantId:e.meta?.tenantId,runId:e.meta?.runId};switch(t){case"lease_allocate":return{...r,ttlMs:e.meta?.leaseTtlMs,backend:e.meta?.leaseBackend};case"lease_heartbeat":return{...r,leaseId:e.meta?.leaseId,ttlMs:e.meta?.leaseTtlMs};case"lease_release":return{...r,leaseId:e.meta?.leaseId}}}(n,n.command,i)})),m={"content-type":"application/json","content-length":Buffer.byteLength(u)};return e.baseUrl&&e.token&&(m.authorization=`Bearer ${e.token}`,m["x-agent-device-token"]=e.token),await new Promise((n,i)=>{let s=J(r.flags?.stateDir??process.env.AGENT_DEVICE_STATE_DIR),l=("https:"===c.protocol?a:t).request({protocol:c.protocol,host:c.hostname,port:c.port,method:"POST",path:c.pathname+c.search,headers:m},t=>{et(t).then(t=>{h&&clearTimeout(h),function(e,t){let{info:a,req:r,resolve:o,reject:n}=t;try{let t=JSON.parse(e);if(t.error){let e=t.error.data??{};n(new p(d(null!=e.code?String(e.code):void 0,"COMMAND_FAILED"),String(e.message??t.error.message??"Daemon RPC request failed"),{..."object"==typeof e.details&&e.details?e.details:{},hint:"string"==typeof e.hint?e.hint:void 0,diagnosticId:"string"==typeof e.diagnosticId?e.diagnosticId:void 0,logPath:"string"==typeof e.logPath?e.logPath:void 0,requestId:r.meta?.requestId}));return}if(!t.result||"object"!=typeof t.result)return void n(new p("COMMAND_FAILED","Invalid daemon RPC response",{requestId:r.meta?.requestId}));if(a.baseUrl&&t.result.ok)return void ej(a,r,t.result).then(o).catch(n);o(t.result)}catch(t){n(new p("COMMAND_FAILED","Invalid daemon response",{requestId:r.meta?.requestId,line:e},t instanceof Error?t:void 0))}}(t,{info:e,req:r,resolve:n,reject:i})}).catch(e=>{h&&clearTimeout(h),i(new p("COMMAND_FAILED","Failed to read daemon response",{requestId:r.meta?.requestId},e instanceof Error?e:void 0))})}),f=ez(e),h="number"==typeof o?setTimeout(()=>{l.destroy(),i(ex(e,s,r.meta?.requestId,r.command,f,o))},o):void 0;l.on("error",e=>{h&&clearTimeout(h),i(eF(e,r.meta?.requestId,f))}),l.write(u),l.end()})}function ez(e){return"string"==typeof e.baseUrl&&e.baseUrl.length>0}function e$(e,t){return new URL(t,e.endsWith("/")?e:`${e}/`).toString()}async function ej(e,t,a){let r=Array.isArray(a.data?.artifacts)?a.data.artifacts:[];if(0===r.length||!e.baseUrl)return a;let n=a.data?{...a.data}:{},i=[];for(let a of r){if(!a||"object"!=typeof a||"string"!=typeof a.artifactId){i.push(a);continue}let r=function(e,t){if(e.localPath&&e.localPath.trim().length>0)return e.localPath;let a=t.meta?.clientArtifactPaths?.[e.field];if(a&&a.trim().length>0)return a;let r=e.fileName?.trim()||`${e.field}-${Date.now()}`;return o.resolve(t.meta?.cwd??process.cwd(),r)}(a,t);await eH({baseUrl:e.baseUrl,token:e.token,artifactId:a.artifactId,destinationPath:r,requestId:t.meta?.requestId}),n[a.field]=r,i.push({...a,localPath:r})}return n.artifacts=i,{ok:!0,data:n}}async function eH(e){var i,s;let l,c=new URL((i=e.baseUrl,s=e.artifactId,l=i.endsWith("/")?i:`${i}/`,new URL(`artifacts/${encodeURIComponent(s)}`,l).toString())),d="https:"===c.protocol?a:t;await r.promises.mkdir(o.dirname(e.destinationPath),{recursive:!0}),await new Promise((t,a)=>{let o=!1,i=e.timeoutMs??9e4,s=n=>{if(!o){if(o=!0,clearTimeout(u),n)return void r.promises.rm(e.destinationPath,{force:!0}).finally(()=>a(n));t()}},l=d.request({protocol:c.protocol,host:c.hostname,port:c.port,method:"GET",path:c.pathname+c.search,headers:e.token?{authorization:`Bearer ${e.token}`,"x-agent-device-token":e.token}:void 0},t=>{if((t.statusCode??500)>=400){let a="";t.setEncoding("utf8"),t.on("data",e=>{a+=e}),t.on("end",()=>{s(new p("COMMAND_FAILED","Failed to download remote artifact",{artifactId:e.artifactId,statusCode:t.statusCode,requestId:e.requestId,body:a}))});return}t.on("aborted",()=>{s(new p("COMMAND_FAILED","Remote artifact download was interrupted",{artifactId:e.artifactId,requestId:e.requestId}))}),n(t,r.createWriteStream(e.destinationPath)).then(()=>s(),e=>s(e instanceof Error?e:Error(String(e))))}),u=setTimeout(()=>{l.destroy(new p("COMMAND_FAILED","Remote artifact download timed out",{artifactId:e.artifactId,requestId:e.requestId,timeoutMs:i}))},i);l.on("error",t=>{t instanceof p?s(t):s(new p("COMMAND_FAILED","Failed to download remote artifact",{artifactId:e.artifactId,requestId:e.requestId,timeoutMs:i},t instanceof Error?t:void 0))}),l.end()})}function eK(e,t){let a=L(e,"bundleId"),r=L(e,"package");return{app:j(e,"app"),appPath:j(e,"appPath"),platform:O(e,"platform"),appId:a??r,bundleId:a,package:r,identifiers:E({session:t,bundleId:a,packageName:r})}}function eV(e){let{record:t,platform:a,id:r,name:o,target:n}=eJ(e,"name");return{platform:a,target:n,kind:x(t,"kind"),id:r,name:o,booted:"boolean"==typeof t.booted?t.booted:void 0,identifiers:D(a,r,o),...eW(a,r)}}function eG(e){let{record:t,platform:a,id:r,name:o,target:n}=eJ(e,"name"),i=j(t,"device"),s={session:o,...D(a,r,i)};return{name:o,createdAt:U(t,"createdAt"),device:{platform:a,target:n,id:r,name:i,identifiers:s,...eW(a,r,H(t,"ios_simulator_device_set"))},identifiers:s}}function eJ(e,t){let a=_(e);return{record:a,platform:O(a,"platform"),id:j(a,"id"),name:j(a,t),target:K(a,"target")}}function eW(e,t,a){return{ios:"ios"===e?{udid:t,...void 0!==a?{simulatorSetPath:a}:{}}:void 0,android:"android"===e?{serial:t}:void 0}}function eY(e){return e??"default"}function eQ(e={},t={}){var a;let r,o=t.transport??eh,n=async(t,a=[],r={})=>{var n,i;let s=(n=e,i=r,{...n,...i}),l=await o({session:eY(s.session),command:t,positionals:a,flags:R({stateDir:s.stateDir,daemonBaseUrl:s.daemonBaseUrl,daemonAuthToken:s.daemonAuthToken,daemonTransport:s.daemonTransport,daemonServerMode:s.daemonServerMode,tenant:s.tenant,sessionIsolation:s.sessionIsolation,runId:s.runId,leaseId:s.leaseId,leaseBackend:s.leaseBackend,platform:s.platform,target:s.target,device:s.device,udid:s.udid,serial:s.serial,iosSimulatorDeviceSet:s.iosSimulatorDeviceSet,androidDeviceAllowlist:s.androidDeviceAllowlist,surface:s.surface,activity:s.activity,launchConsole:s.launchConsole,relaunch:s.relaunch,shutdown:s.shutdown,saveScript:s.saveScript,noRecord:s.noRecord,backMode:s.backMode,metroHost:s.metroHost,metroPort:s.metroPort,bundleUrl:s.bundleUrl,launchUrl:s.launchUrl,snapshotInteractiveOnly:s.interactiveOnly,snapshotCompact:s.compact,snapshotDepth:s.depth,snapshotScope:s.scope,snapshotRaw:s.raw,snapshotForceFull:s.forceFull,...G(s),appsFilter:s.appsFilter,out:s.out,count:s.count,fps:s.fps,quality:s.quality,hideTouches:s.hideTouches,intervalMs:s.intervalMs,delayMs:s.delayMs,holdMs:s.holdMs,jitterPx:s.jitterPx,pixels:s.pixels,doubleTap:s.doubleTap,clickButton:s.clickButton,pauseMs:s.pauseMs,pattern:s.pattern,headless:s.headless,restart:s.restart,replayUpdate:s.replayUpdate,replayBackend:s.replayBackend,replayEnv:s.replayEnv,replayShellEnv:s.replayShellEnv,failFast:s.failFast,timeoutMs:s.timeoutMs,retries:s.retries,artifactsDir:s.artifactsDir,reportJunit:s.reportJunit,findFirst:s.findFirst,findLast:s.findLast,networkInclude:s.networkInclude,batchOnError:s.batchOnError,batchMaxSteps:s.batchMaxSteps,batchSteps:s.batchSteps,verbose:s.debug}),runtime:s.runtime,meta:R({requestId:s.requestId,cwd:s.cwd,debug:s.debug,lockPolicy:s.lockPolicy,lockPlatform:s.lockPlatform,tenantId:s.tenant,runId:s.runId,leaseId:s.leaseId,leaseBackend:s.leaseBackend,leaseTtlMs:s.leaseTtlMs,sessionIsolation:s.sessionIsolation,installSource:s.installSource,retainMaterializedPaths:s.retainMaterializedPaths,materializedPathRetentionMs:s.materializedPathRetentionMs,materializationId:s.materializationId})});return l.ok||function(e){throw new p(d(e.code),e.message,{...e.details??{},hint:e.hint,diagnosticId:e.diagnosticId,logPath:e.logPath})}(l.error),l.data??{}},i=async(e={})=>{let t=await n(B.sessionList,[],e);return(Array.isArray(t.sessions)?t.sessions:[]).map(eG)},s=async(e,t=[],a={})=>await n(e,t,a),l=(t={})=>{var a,r;return eY((a=e,r=t,{...a,...r}).session)};return{command:(a=async e=>await n(e.command,e.positionals,e.options),r=async e=>await a(e),{wait:async e=>{var t;return await r((t=e,{command:P.wait,positionals:Y.encode(t),options:t}))},alert:async(e={})=>{var t;let a;return await r((a=(t=e).action??"get",{command:P.alert,positionals:[a,...void 0!==t.timeoutMs?[String(t.timeoutMs)]:[]],options:t}))},appState:async(e={})=>await r({command:P.appState,positionals:[],options:e}),back:async(e={})=>await r({command:P.back,positionals:[],options:{...e,backMode:e.mode}}),home:async(e={})=>await r({command:P.home,positionals:[],options:e}),rotate:async e=>await r({command:P.rotate,positionals:[e.orientation],options:e}),appSwitcher:async(e={})=>await r({command:P.appSwitcher,positionals:[],options:e}),keyboard:async(e={})=>await r({command:P.keyboard,positionals:e.action?[e.action]:[],options:e}),clipboard:async e=>{var t;return await r("read"===(t=e).action?{command:P.clipboard,positionals:["read"],options:t}:{command:P.clipboard,positionals:["write",t.text],options:t})},reactNative:async e=>await r({command:P.reactNative,positionals:[e.action],options:e})}),devices:{list:async(e={})=>{let t=await n(P.devices,[],e);return(Array.isArray(t.devices)?t.devices:[]).map(eV)},boot:async(e={})=>await s(P.boot,[],e)},sessions:{list:async(e={})=>await i(e),close:async(e={})=>{let t=l(e),a=(await n(P.close,[],e)).shutdown;return{session:t,shutdown:"object"==typeof a&&null!==a?a:void 0,identifiers:{session:t}}}},apps:{install:async e=>eK(await n(P.install,[e.app,e.appPath],e),l(e)),reinstall:async e=>eK(await n(P.reinstall,[e.app,e.appPath],e),l(e)),installFromSource:async e=>(function(e,t){let a=L(e,"bundleId"),r=L(e,"packageName"),o=a??r??L(e,"appId"),n=L(e,"launchTarget")??r??a??o;if(!n)throw new p("COMMAND_FAILED",'Daemon response is missing "launchTarget".',{response:e});return{appName:L(e,"appName"),appId:o,bundleId:a,packageName:r,launchTarget:n,installablePath:L(e,"installablePath"),archivePath:L(e,"archivePath"),materializationId:L(e,"materializationId"),materializationExpiresAt:L(e,"materializationExpiresAt"),identifiers:E({session:t,bundleId:a,packageName:r,appId:o})}})(await n(B.installSource,[],{...e,installSource:e.source,retainMaterializedPaths:e.retainPaths,materializedPathRetentionMs:e.retentionMs}),l(e)),list:async(e={})=>{let t=await n(P.apps,[],e);return Array.isArray(t.apps)?t.apps.filter(e=>"string"==typeof e):[]},open:async e=>{let t=l(e),a=e.app?e.url?[e.app,e.url]:[e.app]:[],r=await n(P.open,a,e),o=function(e){let t=e.platform,a=L(e,"id"),r=L(e,"device");if("ios"!==t&&"macos"!==t&&"android"!==t&&"linux"!==t||!a||!r)return;let o=K(e,"target"),n=D(t,a,r);return{platform:t,target:o,id:a,name:r,identifiers:n,ios:"ios"===t?{udid:L(e,"device_udid")??a,simulatorSetPath:H(e,"ios_simulator_device_set")}:void 0,android:"android"===t?{serial:L(e,"serial")??a}:void 0}}(r),i=L(r,"appBundleId");return{session:t,appName:L(r,"appName"),appBundleId:i,appId:i,startup:function(e){if($(e)&&"number"==typeof e.durationMs&&"string"==typeof e.measuredAt&&"string"==typeof e.method)return{durationMs:e.durationMs,measuredAt:e.measuredAt,method:e.method,appTarget:L(e,"appTarget"),appBundleId:L(e,"appBundleId")}}(r.startup),runtime:function(e){if(!$(e))return;let t=e.platform,a=L(e,"metroHost"),r="number"==typeof e.metroPort?e.metroPort:void 0;return{platform:"ios"===t||"android"===t?t:void 0,metroHost:a,metroPort:r,bundleUrl:L(e,"bundleUrl"),launchUrl:L(e,"launchUrl")}}(r.runtime),device:o,identifiers:{session:t,deviceId:o?.id,deviceName:o?.name,udid:o?.ios?.udid,serial:o?.android?.serial,appId:i,appBundleId:i}}},close:async(e={})=>{let t=l(e),a=(await n(P.close,e.app?[e.app]:[],e)).shutdown;return{session:t,closedApp:e.app,shutdown:"object"==typeof a&&null!==a?a:void 0,identifiers:{session:t}}},push:async e=>{var t;return await s(P.push,[e.app,"string"==typeof(t=e.payload)?t:JSON.stringify(t)],e)},triggerEvent:async e=>{var t;return await s(P.triggerAppEvent,[(t=e).event,...t.payload?[JSON.stringify(t.payload)]:[]],e)}},materializations:{release:async e=>{var t;return{released:!0===(t=await n(B.releaseMaterializedPaths,[],{...e,materializationId:e.materializationId})).released,materializationId:j(t,"materializationId"),identifiers:{}}}},leases:{allocate:async e=>e2(await n(B.leaseAllocate,[],{...e,leaseId:void 0,leaseTtlMs:e.ttlMs})),heartbeat:async e=>e2(await n(B.leaseHeartbeat,[],{...e,leaseTtlMs:e.ttlMs})),release:async e=>({released:!0===(await n(B.leaseRelease,[],e)).released})},metro:{prepare:async t=>await ee({projectRoot:t.projectRoot??e.cwd,kind:t.kind,publicBaseUrl:t.publicBaseUrl,proxyBaseUrl:t.proxyBaseUrl,proxyBearerToken:t.bearerToken,bridgeScope:t.bridgeScope,launchUrl:t.launchUrl,companionProfileKey:t.companionProfileKey,companionConsumerKey:t.companionConsumerKey,metroPort:t.port,listenHost:t.listenHost,statusHost:t.statusHost,startupTimeoutMs:t.startupTimeoutMs,probeTimeoutMs:t.probeTimeoutMs,reuseExisting:t.reuseExisting,installDependenciesIfNeeded:t.installDependenciesIfNeeded,runtimeFilePath:t.runtimeFilePath,logPath:t.logPath}),reload:async(t={})=>await Z({metroHost:t.metroHost,metroPort:t.metroPort,bundleUrl:t.bundleUrl,runtime:e.runtime,timeoutMs:t.timeoutMs})},capture:{snapshot:async(e={})=>{var t,a,r,o;let i,s,c,d,p,u=l(e);return t=await n(P.snapshot,[],e),a=u,i=L(t,"appBundleId"),{nodes:Array.isArray(r=t.nodes)?r:[],truncated:!0===t.truncated,appName:L(t,"appName"),appBundleId:i,...(s=eX((o=t).visibility),c=eX(o.androidSnapshot),d=eX(o.unchanged),p=Array.isArray(o.warnings)?o.warnings.filter(e=>"string"==typeof e):void 0,{...s?{visibility:s}:{},...c?{androidSnapshot:c}:{},...d?{unchanged:d}:{},...p?{warnings:p}:{}}),identifiers:{session:a,appId:i,appBundleId:i}}},screenshot:async(e={})=>{let t=l(e),a=await n(P.screenshot,e.path?[e.path]:[],{...e,...G(e)});return{path:j(a,"path"),overlayRefs:function(e){let t=e.overlayRefs;if(!Array.isArray(t))return;let a=[];for(let e of t){if(!$(e))continue;let t=L(e,"ref"),r=A(e,"rect"),o=A(e,"overlayRect"),n=C(e,"center");t&&r&&o&&n&&a.push({ref:t,label:L(e,"label"),rect:r,overlayRect:o,center:n})}return a}(a),identifiers:{session:t}}},diff:async e=>await s(P.diff,[e.kind],{...e,interactiveOnly:e.interactiveOnly,compact:e.compact,depth:e.depth,scope:e.scope,raw:e.raw})},interactions:{click:async e=>await s(P.click,Q.encode(e),{...e,clickButton:e.button}),press:async e=>await s(P.press,Q.encode(e),e),longPress:async e=>await s(P.longPress,M.encode(e),e),swipe:async e=>await s(P.swipe,[String(e.from.x),String(e.from.y),String(e.to.x),String(e.to.y),...e0(e.durationMs)],e),focus:async e=>await s(P.focus,[String(e.x),String(e.y)],e),type:async e=>await s(P.type,z.encode(e),e),fill:async e=>await s(P.fill,q.encode(e),e),scroll:async e=>await s(P.scroll,[e.direction,...e0(e.amount)],e),pinch:async e=>await s(P.pinch,[String(e.scale),...e0(e.x),...e0(e.y)],e),get:async e=>await s(P.get,[e.format,...S.encode(e)],e),is:async e=>await s(P.is,V.encode(e),e),find:async e=>await s(P.find,F.encode(e),{...e,findFirst:e.first,findLast:e.last})},replay:{run:async e=>await s(P.replay,[e.path],{...e,replayUpdate:e.update,replayBackend:e.backend??(!0===e.maestro?"maestro":void 0),replayEnv:e.env,replayShellEnv:e1(process.env)}),test:async e=>await s(P.test,e.paths,{...e,replayUpdate:e.update,replayEnv:e.env,replayShellEnv:e1(process.env)})},batch:{run:async e=>await s(P.batch,[],{...e,batchSteps:e.steps,batchOnError:e.onError,batchMaxSteps:e.maxSteps})},observability:{perf:async(e={})=>await s(P.perf,[],e),logs:async(e={})=>{var t;return await s(P.logs,[(t=e).action??"path",...eZ(t.message)],e)},network:async(e={})=>{var t;return await s(P.network,[...(t=e).action?[t.action]:[],...e0(t.limit)],{...e,networkInclude:e.include})}},recording:{record:async e=>await s(P.record,[e.action,...eZ(e.path)],e),trace:async e=>await s(P.trace,[e.action,...eZ(e.path)],e)},settings:{update:async e=>await s(P.settings,k.encode(e),e)}}}function eX(e){return"object"==typeof e&&null!==e?e:void 0}function eZ(e){return void 0===e?[]:[e]}function e0(e){return void 0===e?[]:[String(e)]}function e1(e){let t={};for(let[a,r]of Object.entries(e))"string"==typeof r&&a.startsWith("AD_VAR_")&&(t[a]=r);return t}function e2(e){let t=e.lease;if(!t||"object"!=typeof t||Array.isArray(t))throw Error("Invalid lease response from daemon");return{leaseId:j(t,"leaseId"),tenantId:j(t,"tenantId"),runId:j(t,"runId"),backend:j(t,"backend"),createdAt:"number"==typeof t.createdAt?t.createdAt:void 0,heartbeatAt:"number"==typeof t.heartbeatAt?t.heartbeatAt:void 0,expiresAt:"number"==typeof t.expiresAt?t.expiresAt:void 0}}export{eQ as createAgentDeviceClient,eh as sendToDaemon};
|