conductor-oss 0.58.39 → 0.58.41
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +5 -5
- package/web/.next/standalone/packages/web/.next/BUILD_ID +1 -1
- package/web/.next/standalone/packages/web/.next/app-path-routes-manifest.json +4 -4
- package/web/.next/standalone/packages/web/.next/build-manifest.json +3 -3
- package/web/.next/standalone/packages/web/.next/prerender-manifest.json +3 -3
- package/web/.next/standalone/packages/web/.next/react-loadable-manifest.json +5 -5
- package/web/.next/standalone/packages/web/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/_global-error.html +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/_global-error.rsc +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/_not-found/page.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/_not-found/page.js.nft.json +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/api/sessions/[id]/preview/route.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/bridge/connect/page.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/bridge/connect/page.js.nft.json +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/bridge/connect/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/embed/terminal/[id]/page.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/embed/terminal/[id]/page.js.nft.json +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/embed/terminal/[id]/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/page.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/page.js.nft.json +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/sessions/[id]/page.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/sessions/[id]/page.js.nft.json +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/sessions/[id]/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/settings/bridge/page.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/settings/bridge/page.js.nft.json +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/settings/bridge/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/sign-in/[[...sign-in]]/page.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/sign-in/[[...sign-in]]/page.js.nft.json +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/sign-in/[[...sign-in]]/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/sign-in/hosted/page.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/sign-in/hosted/page.js.nft.json +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/sign-in/hosted/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/sign-in/sso-callback/page.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/sign-in/sso-callback/page.js.nft.json +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/sign-in/sso-callback/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/unlock/page.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/unlock/page.js.nft.json +1 -1
- package/web/.next/standalone/packages/web/.next/server/app/unlock/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/app-paths-manifest.json +4 -4
- package/web/.next/standalone/packages/web/.next/server/chunks/107.js +1 -0
- package/web/.next/standalone/packages/web/.next/server/chunks/1564.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/chunks/177.js +1 -0
- package/web/.next/standalone/packages/web/.next/server/chunks/2089.js +3 -3
- package/web/.next/standalone/packages/web/.next/server/chunks/3990.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/chunks/6054.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/chunks/9455.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/middleware-build-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/middleware-react-loadable-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/next-font-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/next-font-manifest.json +1 -1
- package/web/.next/standalone/packages/web/.next/server/pages/500.html +1 -1
- package/web/.next/standalone/packages/web/.next/server/server-reference-manifest.js +1 -1
- package/web/.next/standalone/packages/web/.next/server/server-reference-manifest.json +1 -1
- package/web/.next/standalone/packages/web/.next/static/chunks/2799.1e0f8bbd84a63128.js +1 -0
- package/web/.next/standalone/packages/web/.next/static/chunks/{4443.611b659fd26e567b.js → 4443.21500483f2024d8e.js} +1 -1
- package/web/.next/standalone/packages/web/.next/static/chunks/474.0468442a7b5947e9.js +1 -0
- package/web/.next/standalone/packages/web/.next/static/chunks/8462.f878c844419c1a0c.js +1 -0
- package/web/.next/{static/chunks/8510-eb40f26ac825fca3.js → standalone/packages/web/.next/static/chunks/8510-5c551d5a3d4b390c.js} +1 -1
- package/web/.next/standalone/packages/web/.next/static/chunks/app/layout-b196fb7d7e558466.js +1 -0
- package/web/.next/standalone/packages/web/.next/static/chunks/app/page-970687afb211d9f8.js +1 -0
- package/web/.next/standalone/packages/web/.next/static/chunks/{webpack-b8e6b1ccb85a3faa.js → webpack-59e3530274e2a5a1.js} +1 -1
- package/web/.next/static/chunks/2799.1e0f8bbd84a63128.js +1 -0
- package/web/.next/static/chunks/{4443.611b659fd26e567b.js → 4443.21500483f2024d8e.js} +1 -1
- package/web/.next/static/chunks/474.0468442a7b5947e9.js +1 -0
- package/web/.next/static/chunks/8462.f878c844419c1a0c.js +1 -0
- package/web/.next/{standalone/packages/web/.next/static/chunks/8510-eb40f26ac825fca3.js → static/chunks/8510-5c551d5a3d4b390c.js} +1 -1
- package/web/.next/static/chunks/app/layout-b196fb7d7e558466.js +1 -0
- package/web/.next/static/chunks/app/page-970687afb211d9f8.js +1 -0
- package/web/.next/static/chunks/{webpack-b8e6b1ccb85a3faa.js → webpack-59e3530274e2a5a1.js} +1 -1
- package/web/.next/standalone/packages/web/.next/server/chunks/2553.js +0 -1
- package/web/.next/standalone/packages/web/.next/server/chunks/60.js +0 -1
- package/web/.next/standalone/packages/web/.next/static/chunks/2799.d54bac0b61a6c631.js +0 -1
- package/web/.next/standalone/packages/web/.next/static/chunks/474.d51d3c524fefdcc2.js +0 -1
- package/web/.next/standalone/packages/web/.next/static/chunks/7649.96df81c61d4eeaaa.js +0 -1
- package/web/.next/standalone/packages/web/.next/static/chunks/app/layout-40d6d4ccf615ee62.js +0 -1
- package/web/.next/standalone/packages/web/.next/static/chunks/app/page-b6a5c403840a5555.js +0 -1
- package/web/.next/static/chunks/2799.d54bac0b61a6c631.js +0 -1
- package/web/.next/static/chunks/474.d51d3c524fefdcc2.js +0 -1
- package/web/.next/static/chunks/7649.96df81c61d4eeaaa.js +0 -1
- package/web/.next/static/chunks/app/layout-40d6d4ccf615ee62.js +0 -1
- package/web/.next/static/chunks/app/page-b6a5c403840a5555.js +0 -1
- /package/web/.next/standalone/packages/web/.next/static/{W7Ix_gUgmq_cKa_iZEKIf → BoRHND7Qzg9aFwUgEoPWa}/_buildManifest.js +0 -0
- /package/web/.next/standalone/packages/web/.next/static/{W7Ix_gUgmq_cKa_iZEKIf → BoRHND7Qzg9aFwUgEoPWa}/_ssgManifest.js +0 -0
- /package/web/.next/static/{W7Ix_gUgmq_cKa_iZEKIf → BoRHND7Qzg9aFwUgEoPWa}/_buildManifest.js +0 -0
- /package/web/.next/static/{W7Ix_gUgmq_cKa_iZEKIf → BoRHND7Qzg9aFwUgEoPWa}/_ssgManifest.js +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";exports.id=3990,exports.ids=[3990],exports.modules={25985:(a,b,c)=>{c.d(b,{FM:()=>g,JZ:()=>f,N7:()=>h});var d=c(32679),e=c(70209);async function f(a){let b=await (0,d.ny)(a),c=new Headers({"x-conductor-proxy-authorized":"true","x-conductor-access-authenticated":b.authenticated||"local"===b.provider?"true":"false"});b.role&&c.set("x-conductor-access-role",b.role),b.email&&c.set("x-conductor-access-email",b.email),b.provider&&c.set("x-conductor-access-provider",b.provider);let e=process.env.CONDUCTOR_PROXY_AUTH_SECRET?.trim()||null;return e&&c.set("x-conductor-proxy-secret",e),c}async function g(a,b,c={}){let h=await (0,d.sB)(a,c.role??"viewer");if(h)return h;if(c.requireActionGuard){let b=(0,d.G1)(a);if(b)return b}return(0,e.zP)(a,b,{headers:await f(a)})}async function h(a,b,c={}){let g=await (0,d.sB)(a,c.role??"viewer");if(g)return g;if(c.requireActionGuard){let b=(0,d.G1)(a);if(b)return b}return(0,e.X_)(a,b,{headers:await f(a)})}},28480:(a,b,c)=>{c.a(a,async(a,d)=>{try{c.d(b,{Ob:()=>A});var e=c(71553),f=c(31421),g=c(4573),h=c(73024),i=c(77030),j=c(76760),k=c(8856),l=c(34140),m=c(36026),n=c(94842),o=c(59506),p=a([k,l]);[k,l]=p.then?(await p)():p;let B={width:1440,height:960},C=["127.0.0.1","localhost","::1","0.0.0.0"],D=/^[a-z][a-z\d+.-]*:\/\//i,E=/^(?:localhost|127\.0\.0\.1|0\.0\.0\.0|\[::1\]|::1)(?::\d+)?(?:\/.*)?$/i;function q(a){return a.replace(/^\[(.*)\]$/,"$1").toLowerCase()}function r(a){let b=q(a);return C.includes(b)}function s(a){let b=a.split(".").map(a=>Number.parseInt(a,10));if(4!==b.length||b.some(a=>!Number.isInteger(a)||a<0||a>255))return!0;let[c,d]=b;return 0===c||10===c||127===c||100===c&&d>=64&&d<=127||169===c&&254===d||172===c&&d>=16&&d<=31||192===c&&168===d||198===c&&(18===d||19===d)||c>=224}function t(a){let b=q(a),c=(0,i.isIP)(b);if(4===c)return s(b);if(6===c){let a,c;return c=(a=q(b).toLowerCase()).startsWith("::ffff:")?a.slice(7):null,"::"===a||"::1"===a||a.startsWith("fe8")||a.startsWith("fe9")||a.startsWith("fea")||a.startsWith("feb")||a.startsWith("fc")||a.startsWith("fd")||!!c&&s(c)}return!1}async function u(a){if(process.env.CONDUCTOR_ALLOW_UNSAFE_PREVIEW_HOSTS?.trim().toLowerCase()==="true")return;let b=new URL(a);if(!r(b.hostname)){if(t(b.hostname))throw Error("Preview navigation to private network hosts is blocked. Use loopback URLs for local dev servers or set CONDUCTOR_ALLOW_UNSAFE_PREVIEW_HOSTS=true to override.");if((await (0,e.lookup)(b.hostname,{all:!0,verbatim:!0}).catch(()=>[])).some(a=>t(a.address)))throw Error("Preview navigation resolved to a private network address and was blocked. Set CONDUCTOR_ALLOW_UNSAFE_PREVIEW_HOSTS=true only if you intentionally trust that target.")}}function v(a,b){if(!b)return"direct";try{let c=new URL(a),d=r(q(c.hostname));if(b.allowedOrigins.includes(c.origin))return"bridge";return d?"blocked":"direct"}catch{return"direct"}}function w(a,b){try{let c=new URL(a),d=new URL(b);return c.origin===d.origin}catch{return a===b}}let F=globalThis;function x(a,b){a.push(b),a.length>150&&a.splice(0,a.length-150)}function y(a){return`${a}-${Date.now()}-${Math.random().toString(36).slice(2,8)}`}function z(a){return(a??"").replace(/\s+/g," ").trim()}class G{async getBrowser(){return this.browserPromise||(this.browserPromise=k.default.launch({headless:!0,executablePath:function(){let a=process.env.PUPPETEER_EXECUTABLE_PATH?.trim();if(a)return a;for(let a of[l.ChromeReleaseChannel.STABLE,l.ChromeReleaseChannel.CANARY,l.ChromeReleaseChannel.BETA,l.ChromeReleaseChannel.DEV])try{return(0,l.computeSystemExecutablePath)({browser:l.Browser.CHROME,channel:a})}catch{}let b=function(){for(let a of"darwin"===process.platform?["/Applications/Google Chrome.app/Contents/MacOS/Google Chrome","/Applications/Google Chrome Canary.app/Contents/MacOS/Google Chrome Canary","/Applications/Chromium.app/Contents/MacOS/Chromium","/Applications/Microsoft Edge.app/Contents/MacOS/Microsoft Edge","/Applications/Brave Browser.app/Contents/MacOS/Brave Browser"]:"win32"===process.platform?[process.env.PROGRAMFILES,process.env["PROGRAMFILES(X86)"],process.env.LOCALAPPDATA].filter(a=>!!a?.trim()).flatMap(a=>[(0,j.join)(a,"Google","Chrome","Application","chrome.exe"),(0,j.join)(a,"Chromium","Application","chrome.exe"),(0,j.join)(a,"Microsoft","Edge","Application","msedge.exe"),(0,j.join)(a,"BraveSoftware","Brave-Browser","Application","brave.exe")]):["google-chrome-stable","google-chrome","chromium-browser","chromium","microsoft-edge","brave-browser"]){if(a.includes("/")||a.includes("\\")){if((0,h.existsSync)(a))return a;continue}let b=function(a){let b="win32"===process.platform?"where":"which";try{return(0,f.execFileSync)(b,[a],{encoding:"utf8",stdio:["ignore","pipe","ignore"]}).trim().split(/\r?\n/).map(a=>a.trim()).find(Boolean)||null}catch{return null}}(a);if(b)return b}return null}();if(b)return b;throw Error("Chrome/Chromium not found. Install a supported browser or set PUPPETEER_EXECUTABLE_PATH.")}(),defaultViewport:B,args:["--disable-dev-shm-usage","--disable-background-networking","--no-first-run","--no-default-browser-check"]})),this.browserPromise}getState(a){let b=this.states.get(a);return b||(b={sessionId:a,context:null,page:null,destroying:!1,activeFrameId:null,selectedElement:null,consoleLogs:[],networkLogs:[],lastError:null,frameIds:new WeakMap,requestStarts:new WeakMap,frameSequence:0,bridgePreview:null,requestInterceptionEnabled:!1},this.states.set(a,b)),b}async ensureContext(a,b){return a.context&&!a.context.closed||(a.context=await b.createBrowserContext()),a.context}async destroySession(a,b={}){let c=this.states.get(a);if(!c||c.destroying)return;c.destroying=!0;let d=c.page,e=c.context;try{!1!==b.closePage&&d&&!d.isClosed()&&await d.close().catch(()=>{}),e&&!e.closed&&await e.close().catch(()=>{})}finally{this.states.delete(a)}}ensureFrameId(a,b){let c=a.frameIds.get(b);if(c)return c;let d=`frame-${++a.frameSequence}`;return a.frameIds.set(b,d),d}async configureBridgePreview(a,b,c){let d=this.getState(a);d.bridgePreview=b&&c?{...b,forwardedHeaders:Object.fromEntries(new Headers(c).entries())}:null,d.page&&!d.page.isClosed()&&await this.syncRequestInterception(d,d.page)}async syncRequestInterception(a,b,c){let d="bridge"===v(c??b.url(),a.bridgePreview);a.requestInterceptionEnabled!==d&&(await b.setRequestInterception(d),a.requestInterceptionEnabled=d)}async handleBridgePreviewRequest(a,b){let c,d=a.bridgePreview;if(!d)return void await b.continue();try{c=new URL(b.url())}catch{await b.abort("blockedbyclient");return}if("http:"!==c.protocol&&"https:"!==c.protocol||!d.allowedOrigins.includes(c.origin))return void await b.abort("blockedbyclient");let e="GET"===b.method()||"HEAD"===b.method()?null:b.postData()??null,f=await (0,n.LN)(d.bridgeId,d.forwardedHeaders,{sessionId:d.sessionId,method:b.method(),url:c.toString(),headers:function(a){let b={};for(let[c,d]of Object.entries(a)){let a=c.trim().toLowerCase();a&&"host"!==a&&"connection"!==a&&"proxy-connection"!==a&&"keep-alive"!==a&&"transfer-encoding"!==a&&"content-length"!==a&&"accept-encoding"!==a&&(b[a]=d)}return b}(b.headers()),bodyBase64:e?g.Buffer.from(e).toString("base64"):null});await b.respond({status:f.status,headers:f.headers,body:f.bodyBase64?g.Buffer.from(f.bodyBase64,"base64"):g.Buffer.alloc(0)})}attachListeners(a,b){b.on("console",b=>{this.captureConsole(a,b)}),b.on("pageerror",b=>{let c=b instanceof Error?b.message:String(b);x(a.consoleLogs,{id:y("pageerror"),kind:"pageerror",level:"error",message:c,timestamp:new Date().toISOString()}),a.lastError=c}),b.on("request",b=>{a.requestStarts.set(b,Date.now()),a.requestInterceptionEnabled&&this.handleBridgePreviewRequest(a,b).catch(async c=>{a.lastError=c instanceof Error?c.message:"Bridge preview request failed",x(a.networkLogs,{id:y("preview-request"),kind:"network",level:"error",message:a.lastError,timestamp:new Date().toISOString(),url:b.url(),method:b.method(),status:null,resourceType:b.resourceType()});try{await b.abort("failed")}catch{}})}),b.on("response",b=>{this.captureResponse(a,b)}),b.on("requestfailed",b=>{x(a.networkLogs,{id:y("requestfailed"),kind:"network",level:"error",message:b.failure()?.errorText??"Request failed",timestamp:new Date().toISOString(),url:b.url(),method:b.method(),status:null,resourceType:b.resourceType()})}),b.on("framenavigated",c=>{let d=this.ensureFrameId(a,c);c===b.mainFrame()&&(a.activeFrameId??=d),a.selectedElement?.frameId===d&&(a.selectedElement=null)}),b.on("close",()=>{this.destroySession(a.sessionId,{closePage:!1})})}captureConsole(a,b){let c=b.location();x(a.consoleLogs,{id:y("console"),kind:"console",level:b.type(),message:z(b.text()),timestamp:new Date().toISOString(),url:c.url??null})}captureResponse(a,b){let c=b.request();x(a.networkLogs,{id:y("network"),kind:"network",level:b.ok()?"info":"error",message:`${c.method()} ${b.status()} ${z(b.statusText())}`.trim(),timestamp:new Date().toISOString(),url:b.url(),method:c.method(),status:b.status(),resourceType:c.resourceType()})}async ensurePage(a){let b=await this.getBrowser(),c=this.getState(a);if(c.page&&!c.page.isClosed())return await this.syncRequestInterception(c,c.page),{state:c,page:c.page};let d=await this.ensureContext(c,b),e=await d.newPage();return await e.setViewport(B),e.setDefaultNavigationTimeout(3e4),e.setDefaultTimeout(15e3),this.attachListeners(c,e),await this.syncRequestInterception(c,e),c.page=e,c.activeFrameId=this.ensureFrameId(c,e.mainFrame()),c.selectedElement=null,c.lastError=null,{state:c,page:e}}collectFrames(a,b){let c=b.frames().map(c=>{let d=this.ensureFrameId(a,c),e=c.parentFrame();return{id:d,name:c.name()||(c===b.mainFrame()?"Main frame":"Untitled frame"),url:c.url(),parentId:e?this.ensureFrameId(a,e):null,isMain:c===b.mainFrame()}});return c.some(b=>b.id===a.activeFrameId)||(a.activeFrameId=c.find(a=>a.isMain)?.id??c[0]?.id??null),a.selectedElement&&!c.some(b=>b.id===a.selectedElement?.frameId)&&(a.selectedElement=null),c}resolveFrame(a,b,c){let d=c??a.activeFrameId,e=b.frames();return d?e.find(b=>this.ensureFrameId(a,b)===d)??b.mainFrame():b.mainFrame()}async navigationProducedUsablePage(a,b,c,d){if(!(d instanceof Error?d.message:String(d)).toLowerCase().includes("net::err_aborted"))return!1;let e=a.url();if("about:blank"===e||e===c&&!w(e,b)||!w(e,b))return!1;try{let b=await a.evaluate(()=>document.readyState);return"interactive"===b||"complete"===b}catch{return!1}}async snapshotElement(a,b,c){return a.evaluate(({selector:a,point:b})=>{var c,d;let e,f,g,h;function i(a){return(a??"").replace(/\s+/g," ").trim()}let j=null;return("string"==typeof a&&a.trim()?j=document.querySelector(a):b&&(j=document.elementFromPoint(b.x,b.y)),j)?(c=j,e=i(c.outerHTML).slice(0,400),f=i(c.textContent),g=c.getBoundingClientRect(),h=[...c.attributes].reduce((a,b)=>(a&&Object.keys(a).length>=12||(a[b.name]=b.value),a),{}),{selector:function(a){let b=[],c=a;for(;c&&b.length<5;){let a=function(a){let b=a.tagName.toLowerCase(),c=i(a.getAttribute("id"));if(c)return`#${CSS.escape(c)}`;let d=[...a.classList].slice(0,2).map(a=>`.${CSS.escape(a)}`).join(""),e="",f=a.parentElement;if(f){let b=[...f.children].filter(b=>b.tagName===a.tagName);b.length>1&&(e=`:nth-of-type(${b.indexOf(a)+1})`)}return`${b}${d}${e}`}(c);if(b.unshift(a),a.startsWith("#"))break;c=c.parentElement}return b.join(" > ")}(c),tag:c.tagName.toLowerCase(),text:f.slice(0,220),role:function(a){let b=i(a.getAttribute("role"));if(b)return b;let c=a.tagName.toLowerCase();return"button"===c?"button":"a"===c&&a.hasAttribute("href")?"link":"input"===c?(a.getAttribute("type")??"textbox").toLowerCase():null}(c),name:(d=f.slice(0,220),i(c.getAttribute("aria-label")??c.getAttribute("title")??c.getAttribute("placeholder")??c.getAttribute("alt")??d)||null),interactive:function(a){if(!(a instanceof HTMLElement))return!1;let b=a.tagName.toLowerCase();return!!(["button","input","select","textarea","summary"].includes(b)||"a"===b&&a.hasAttribute("href")||a.hasAttribute("contenteditable")||a.hasAttribute("onclick")||(a.getAttribute("role")??"").match(/button|link|tab|checkbox|radio|switch|textbox|menuitem/i))||a.tabIndex>=0}(c),id:i(c.getAttribute("id"))||null,classes:[...c.classList].slice(0,6),htmlPreview:e,bounds:{x:g.x,y:g.y,width:g.width,height:g.height},attributes:h}):null},{selector:b,point:c})}async connect(a,b){let{state:c,page:d}=await this.ensurePage(a),e=function(a){let b,c=!(b=a.trim())||D.test(b)?b:E.test(b)?`http://${b}`:b;try{let a=new URL(c),b=a.toString(),d=q(a.hostname),e=a.protocol.toLowerCase();if("http:"!==e&&"https:"!==e)throw Error(`Navigation blocked: only http and https URLs are allowed. Got protocol "${a.protocol}".`);if(r(d)){let a=new Set([b]);for(let c of C){let d=new URL(b);d.hostname=c,a.add(d.toString())}return[...a]}return[b]}catch(a){if(a instanceof Error&&a.message.startsWith("Navigation blocked:"))throw a;throw Error(`Navigation blocked: could not parse "${c}" as a valid URL.`)}}(b),f=null;for(let a of e){let b=v(a,c.bridgePreview);if("blocked"===b){f=Error("Bridge preview only allows navigation to the session's reported local dev server origin.");continue}let e=d.url();try{"direct"===b&&await u(a),await this.syncRequestInterception(c,d,a),await d.goto(a,{waitUntil:"domcontentloaded"}),await this.syncRequestInterception(c,d),c.selectedElement=null,c.lastError=null,c.activeFrameId=this.ensureFrameId(c,d.mainFrame());return}catch(b){if(await this.navigationProducedUsablePage(d,a,e,b)){await this.syncRequestInterception(c,d),c.selectedElement=null,c.lastError=null,c.activeFrameId=this.ensureFrameId(c,d.mainFrame());return}f=b}}throw c.lastError=f instanceof Error?f.message:"Failed to connect preview",f??Error("Failed to connect preview")}async runCommand(a,b){switch(b.command){case"connect":case"navigate":await this.connect(a,b.url);return;case"reload":{let{state:b,page:c}=await this.ensurePage(a);try{await c.reload({waitUntil:"domcontentloaded"}),b.lastError=null}catch(a){throw b.lastError=a instanceof Error?a.message:"Failed to reload preview",a}return}case"goBack":{let{state:b,page:c}=await this.ensurePage(a);try{await this.syncRequestInterception(b,c),await c.goBack({waitUntil:"domcontentloaded",timeout:1500}),await this.syncRequestInterception(b,c),b.selectedElement=null,b.lastError=null,b.activeFrameId=this.ensureFrameId(b,c.mainFrame())}catch(a){throw b.lastError=a instanceof Error?a.message:"Failed to go back",a}return}case"goForward":{let{state:b,page:c}=await this.ensurePage(a);try{await this.syncRequestInterception(b,c),await c.goForward({waitUntil:"domcontentloaded",timeout:1500}),await this.syncRequestInterception(b,c),b.selectedElement=null,b.lastError=null,b.activeFrameId=this.ensureFrameId(b,c.mainFrame())}catch(a){throw b.lastError=a instanceof Error?a.message:"Failed to go forward",a}return}case"selectFrame":{let{state:c,page:d}=await this.ensurePage(a),e=this.resolveFrame(c,d,b.frameId);c.activeFrameId=this.ensureFrameId(c,e),c.selectedElement=null,c.lastError=null;return}case"clickAtPoint":{let{state:c,page:d}=await this.ensurePage(a);c.selectedElement=null,c.lastError=null;let e=d.waitForNavigation({waitUntil:"domcontentloaded",timeout:1500}).catch(()=>null);await d.mouse.click(b.x,b.y),await e,await d.waitForNetworkIdle({idleTime:250,timeout:1e3}).catch(()=>null);return}case"typeText":{let{state:c,page:d}=await this.ensurePage(a);if(!b.text)return;await d.keyboard.type(b.text),c.lastError=null;return}case"pressKey":{let{state:c,page:d}=await this.ensurePage(a);c.lastError=null;let e=d.waitForNavigation({waitUntil:"domcontentloaded",timeout:1500}).catch(()=>null);await d.keyboard.press(b.key),await e,await d.waitForNetworkIdle({idleTime:250,timeout:1e3}).catch(()=>null);return}case"selectAtPoint":{let{state:c,page:d}=await this.ensurePage(a),e=this.resolveFrame(c,d,c.activeFrameId);if(e!==d.mainFrame())throw Error("Point selection is only available for the main frame. Pick nested frame elements from the DOM list.");let f=await this.snapshotElement(e,void 0,{x:b.x,y:b.y});if(!f)throw Error("No element found at the selected point");c.selectedElement={...f,frameId:this.ensureFrameId(c,e),frameName:e.name()||"Main frame",frameUrl:e.url()},c.lastError=null;return}case"selectBySelector":{let{state:c,page:d}=await this.ensurePage(a),e=this.resolveFrame(c,d,b.frameId),f=await this.snapshotElement(e,b.selector);if(!f)throw Error(`Element not found for selector: ${b.selector}`);c.selectedElement={...f,frameId:this.ensureFrameId(c,e),frameName:e.name()||(e===d.mainFrame()?"Main frame":"Frame"),frameUrl:e.url()},c.activeFrameId=this.ensureFrameId(c,e),c.lastError=null;return}default:return}}async inspectDom(a,b,c=!1){let{state:d,page:e}=await this.ensurePage(a),f=this.resolveFrame(d,e,b),g=await f.evaluate(({interactiveOnly:a,limit:b})=>{function c(a){return(a??"").replace(/\s+/g," ").trim()}let d=document.body??document.documentElement,e=document.createTreeWalker(d,NodeFilter.SHOW_ELEMENT),f=[],g=0;for(;e.nextNode();){g+=1;let d=e.currentNode;if(!(d instanceof Element))continue;let h=function(a){if(!(a instanceof HTMLElement))return!1;let b=a.tagName.toLowerCase();return!!(["button","input","select","textarea","summary"].includes(b)||"a"===b&&a.hasAttribute("href")||a.hasAttribute("contenteditable")||(a.getAttribute("role")??"").match(/button|link|tab|checkbox|radio|switch|textbox|menuitem/i))||a.tabIndex>=0}(d);if(a&&!h)continue;let i=c(d.textContent).slice(0,220),j=d.getBoundingClientRect();if(f.push({selector:function(a){let b=[],d=a;for(;d&&b.length<5;){let a=function(a){let b=a.tagName.toLowerCase(),d=c(a.getAttribute("id"));if(d)return`#${CSS.escape(d)}`;let e=[...a.classList].slice(0,2).map(a=>`.${CSS.escape(a)}`).join(""),f="",g=a.parentElement;if(g){let b=[...g.children].filter(b=>b.tagName===a.tagName);b.length>1&&(f=`:nth-of-type(${b.indexOf(a)+1})`)}return`${b}${e}${f}`}(d);if(b.unshift(a),a.startsWith("#"))break;d=d.parentElement}return b.join(" > ")}(d),tag:d.tagName.toLowerCase(),text:i,role:function(a){let b=c(a.getAttribute("role"));if(b)return b;let d=a.tagName.toLowerCase();return"button"===d?"button":"a"===d&&a.hasAttribute("href")?"link":"input"===d?(a.getAttribute("type")??"textbox").toLowerCase():null}(d),name:c(d.getAttribute("aria-label")??d.getAttribute("title")??d.getAttribute("placeholder")??d.getAttribute("alt")??i)||null,interactive:h,id:c(d.getAttribute("id"))||null,classes:[...d.classList].slice(0,6),htmlPreview:c(d.outerHTML).slice(0,320),bounds:{x:j.x,y:j.y,width:j.width,height:j.height}}),f.length>=b)break}return{nodes:f,truncated:f.length>=b||g>f.length}},{interactiveOnly:c,limit:250});return{frameId:this.ensureFrameId(d,f),nodes:g.nodes,truncated:g.truncated}}async takeScreenshot(a){let{page:b}=await this.ensurePage(a);return"about:blank"===b.url()?null:b.screenshot({type:"png"})}async getNavigationCapabilities(a){if(!a||a.isClosed()||"about:blank"===a.url())return{canGoBack:!1,canGoForward:!1};let b=null;try{b=await a.createCDPSession();let c=await b.send("Page.getNavigationHistory");return{canGoBack:c.currentIndex>0,canGoForward:c.currentIndex<c.entries.length-1}}catch{return{canGoBack:!1,canGoForward:!1}}finally{await b?.detach().catch(()=>null)}}async getStatus(a,b){let c=this.states.get(a)??null,d=c?.page&&!c.page.isClosed()?c.page:null,e=c&&d?this.collectFrames(c,d):[],{canGoBack:f,canGoForward:g}=await this.getNavigationCapabilities(d),h=null;if(d&&"about:blank"!==d.url())try{h=await d.title()}catch{h=null}return{connected:!!(d&&"about:blank"!==d.url()),candidateUrls:b,currentUrl:d&&"about:blank"!==d.url()?d.url():null,title:h,tunnelUrl:null,tunnelLocalOrigin:null,canGoBack:f,canGoForward:g,frames:e,activeFrameId:c?.activeFrameId??null,selectedElement:c?.selectedElement??null,consoleLogs:c?.consoleLogs??[],networkLogs:c?.networkLogs??[],lastError:c?.lastError??null,screenshotKey:`${Date.now()}`}}constructor(){this.browserPromise=null,this.states=new Map}}function A(){return!function(){let a=(0,m._)();if(!a)return!1;try{let b=new URL(a).hostname.toLowerCase();return"localhost"===b||"127.0.0.1"===b||"0.0.0.0"===b||"::1"===b||"[::1]"===b}catch{return!1}}()?(0,o.k)():(F._conductorPreviewBrowserManager||(F._conductorPreviewBrowserManager=new G),F._conductorPreviewBrowserManager)}d()}catch(a){d(a)}})},36026:(a,b,c)=>{function d(a){let b=a?.trim();if(!b)return null;try{let a=new URL(b);if("http:"!==a.protocol&&"https:"!==a.protocol)return null;return a.toString()}catch{return null}}function e(a){let b=a?.trim();if(!b)return null;let c=Number.parseInt(b,10);return!Number.isInteger(c)||c<1||c>65535?null:c}function f(){let a=d(process.env.CONDUCTOR_BACKEND_URL);if(a)return a;let b=d(process.env.NEXT_PUBLIC_CONDUCTOR_BACKEND_URL);if(b)return b;let c=e(process.env.CONDUCTOR_BACKEND_PORT);if(null!==c)return`http://127.0.0.1:${c}`;let f=e(process.env.NEXT_PUBLIC_CONDUCTOR_BACKEND_PORT);return null!==f?`http://127.0.0.1:${f}`:null}function g(){let a=f();if(!a)throw Error("Rust backend URL is not configured");return a}c.d(b,{B:()=>g,_:()=>f})},42599:(a,b,c)=>{c.d(b,{Ix:()=>q});var d=c(51455),e=c(94842),f=c(36026),g=c(91752);let h=/(?:127\.0\.0\.1|0\.0\.0\.0|localhost|::1|\[::1\])/i,i=/\bhttps?:\/\/[^\s"'<>`]+/gi,j=/^[a-z][a-z\d+.-]*:\/\//i,k=/(?<!:\/\/)(?:localhost|127\.0\.0\.1|0\.0\.0\.0|\[::1\]|::1)(?::\d+)?(?:\/[^\s"'<>`]*)?/gi,l=new Set(["previewUrl","devServerUrl","devServerURL","localUrl"]),m={devServerUrl:0,devServerURL:0,localUrl:10,previewUrl:50};function n(a,b=""){let c=(0,g.DW)(a),d=c?.sessionId??a;return`/api/sessions/${encodeURIComponent(d)}${b}`}async function o(a,b,c={}){let d=(0,g.DW)(a);if(d){if(!c.request)throw Error("Bridge preview lookup requires the incoming request context");return(0,e.nl)(c.request,d.bridgeId,b,{pathOverride:b})}return fetch(new URL(b,(0,f.B)()),{cache:"no-store",headers:c.headers})}async function p(a,b={}){let c=(0,g.DW)(a),d=await o(a,n(a),b);if(404===d.status)return null;if(!d.ok)throw Error(`Failed to fetch session ${a}: ${d.status}`);let e=await d.json();return c?(0,g.Vk)(e,c.bridgeId):e}async function q(a,b={}){try{var c,d;let e=await p(a,b);if(!e)return{session:null,candidateUrls:[],error:null,bridgePreview:null};let f=await x(e,b);return{session:e,candidateUrls:f,error:(c=e,d=f,!c.bridgeId?.trim()||d.length>0?null:[c.pr?.previewUrl??null,c.metadata.previewUrl??null,c.metadata.devServerUrl??null,c.metadata.devServerURL??null,c.metadata.localUrl??null,c.metadata.url??null,c.summary].some(a=>t(a).some(a=>u(a)))?"Bridge preview could not find a paired-device local dev server URL for this session.":"Bridge preview uses the paired device's local dev server, but this session did not report one."),bridgePreview:function(a,b){let c=a.bridgeId?.trim();if(!c)return null;let d=[...new Set(b.filter(a=>u(a)).map(a=>{try{return new URL(a).origin}catch{return null}}).filter(a=>!!a))];if(0===d.length)return null;let e=(0,g.DW)(a.id);return{bridgeId:c,sessionId:e?.sessionId??a.id,allowedOrigins:d}}(e,f)}}catch(a){return{session:null,candidateUrls:[],error:a instanceof Error?a.message:"Failed to load preview session",bridgePreview:null}}}function r(a){let b=a.trim().replace(/[),.;]+$/,""),c=j.test(b)?b:k.test(b)?`http://${b}`:b;k.lastIndex=0;try{let a=new URL(c);return"0.0.0.0"===a.hostname&&(a.hostname="127.0.0.1"),a.toString()}catch{return c}}async function s(a){try{let b=await (0,d.readFile)(a,"utf8");return t(b)}catch{return[]}}function t(a){return[...a?.match(i)??[],...a?.match(k)??[]].map(r)}function u(a){try{let b=new URL(a);return h.test(b.hostname)}catch{return!1}}function v(a,b,c,d,e=!1){if(!b?.trim())return;let f=r(b);if(!f||function(a,b){try{let c=new URL(a);if(b){let a=new URL(b);if(c.origin===a.origin)return!0}return c.pathname.startsWith("/api/")}catch{return!1}}(f,d))return;try{let a=new URL(f);if("http:"!==a.protocol&&"https:"!==a.protocol||!e&&!u(f))return}catch{return}let g=a.get(f);(void 0===g||c<g)&&a.set(f,c)}async function w(a,b={}){try{let c=await o(a,n(a,"/output?lines=400"),b);if(!c.ok)return"";let d=await c.json().catch(()=>null);return"string"==typeof d?.output?d.output:""}catch{return""}}async function x(a,b={}){let c=(0,f._)()??"",d=new Map;for(let[b,e]of(a.pr?.previewUrl?.trim()&&v(d,a.pr.previewUrl,50,c,!0),a.metadata.devServerUrl?.trim()&&v(d,a.metadata.devServerUrl,0,c,!0),Object.entries(a.metadata)))for(let a of(l.has(b)&&e.trim()&&v(d,e,m[b]??30,c,!0),t(e)))v(d,a,60,c);for(let b of t(a.summary))v(d,b,70,c);let e=a.metadata.devServerLog?.trim();if(e)for(let a of(await s(e)))v(d,a,40,c);for(let e of t(await w(a.id,b)))v(d,e,80,c);return[...d.entries()].sort(([a,b],[c,d])=>{if(b!==d)return b-d;let e=+!u(a),f=+!u(c);return e!==f?e-f:a.localeCompare(c)}).map(([a])=>a)}},59506:(a,b,c)=>{c.d(b,{k:()=>i});var d=c(4573),e=c(46224);function f(a,b=null){return{connected:!1,candidateUrls:a,currentUrl:null,title:null,tunnelUrl:null,tunnelLocalOrigin:null,canGoBack:!1,canGoForward:!1,frames:[],activeFrameId:null,selectedElement:null,consoleLogs:[],networkLogs:[],lastError:b,screenshotKey:`${Date.now()}`}}class g{async configureBridgePreview(a,b,c){let d=(0,e.y)(),f=b&&c&&d?{...b,relayUrl:d,forwardedHeaders:Object.fromEntries(new Headers(c).entries())}:null;if(JSON.stringify(this.bridgePreviewConfigs.get(a)??null)===JSON.stringify(f))return;this.bridgePreviewConfigs.set(a,f);let g=this.remoteSessionIds.get(a);if(g&&this.isConfigured()){this.remoteSessionIds.delete(a);try{await fetch(`${this.workerUrl}/sessions/${encodeURIComponent(g)}`,{method:"DELETE",headers:this.buildHeaders(),cache:"no-store"})}catch{}}}async destroySession(a){let b=this.remoteSessionIds.get(a);if(this.remoteSessionIds.delete(a),this.bridgePreviewConfigs.delete(a),b&&this.isConfigured())try{await fetch(`${this.workerUrl}/sessions/${encodeURIComponent(b)}`,{method:"DELETE",headers:this.buildHeaders(),cache:"no-store"})}catch{}}async runCommand(a,b){let c=await this.sendCommand(a,b,{createIfMissing:!0});if("error"===c.kind)throw Error(c.message)}async inspectDom(a,b,c=!1){let d=await this.sendCommand(a,{command:"dom",frameId:b,interactiveOnly:c},{createIfMissing:!0});if("dom"!==d.kind)throw Error("error"===d.kind?d.message:"Unexpected preview worker DOM response");return d}async takeScreenshot(a){if(!this.remoteSessionIds.has(a))return null;let b=await this.sendCommand(a,{command:"screenshot"},{createIfMissing:!1});if("error"===b.kind){if(b.message.includes("not connected"))return null;throw Error(b.message)}if("screenshot"!==b.kind)throw Error("Unexpected preview worker screenshot response");return d.Buffer.from(b.imageBase64,"base64")}async getStatus(a,b){if(!this.remoteSessionIds.has(a))return f(b,this.configurationError());try{let c=await this.sendCommand(a,{command:"status",candidateUrls:b},{createIfMissing:!1});if("status"===c.kind)return c;return f(b,"error"===c.kind?c.message:"Preview service is unavailable")}catch(a){return f(b,a instanceof Error?a.message:"Preview service is unavailable")}}async sendCommand(a,b,c){let d=this.configurationError();if(d)return{kind:"error",message:d};let e=this.remoteSessionIds.get(a)??null;if(!e){if(!c.createIfMissing)return{kind:"error",message:"Preview is not connected"};e=await this.createRemoteSession(a)}try{let d=await fetch(`${this.workerUrl}/sessions/${encodeURIComponent(e)}/command`,{method:"POST",headers:this.buildHeaders(),body:JSON.stringify(b),cache:"no-store"}),f=await d.json();if(404===d.status&&!1!==c.retry)return this.remoteSessionIds.delete(a),await this.sendCommand(a,b,{createIfMissing:c.createIfMissing,retry:!1});if(!d.ok||"error"===f.kind)return"error"===f.kind?f:{kind:"error",message:"Preview worker request failed"};return f}catch(a){throw Error(this.networkErrorMessage(a))}}async createRemoteSession(a){let b=this.configurationError();if(b)throw Error(b);let c={bridgePreview:this.bridgePreviewConfigs.get(a)??null};try{let b=await fetch(`${this.workerUrl}/sessions`,{method:"POST",headers:this.buildHeaders(),body:JSON.stringify(c),cache:"no-store"}),d=await b.json();if(!b.ok||!d.sessionId)throw Error(d.error||"Preview worker session creation failed");return this.remoteSessionIds.set(a,d.sessionId),d.sessionId}catch(a){throw Error(this.networkErrorMessage(a))}}buildHeaders(){return{Authorization:`Bearer ${this.workerApiKey}`,"Content-Type":"application/json"}}configurationError(){return this.workerUrl&&this.workerApiKey?null:"Preview worker is not configured"}isConfigured(){return null===this.configurationError()}networkErrorMessage(a){let b=a instanceof Error?a.message:"Preview service is unavailable";return"Preview worker is not configured"===b?b:"Preview service is unavailable"}constructor(){this.workerUrl=function(a){let b=a?.trim();if(!b)return null;try{let a=new URL(b);if("http:"!==a.protocol&&"https:"!==a.protocol)return null;return a.toString().replace(/\/$/,"")}catch{return null}}(process.env.CONDUCTOR_PREVIEW_WORKER_URL),this.workerApiKey=process.env.CONDUCTOR_PREVIEW_WORKER_KEY?.trim()||null,this.remoteSessionIds=new Map,this.bridgePreviewConfigs=new Map}}let h=globalThis;function i(){return h._conductorPreviewWorkerClient||(h._conductorPreviewWorkerClient=new g),h._conductorPreviewWorkerClient}},70209:(a,b,c)=>{c.d(b,{X_:()=>m,Z$:()=>h,zP:()=>l});var d=c(77873),e=c(36026);let f=new Set(["connection","host","content-length","expect","upgrade","proxy-authorization","proxy-authenticate","te","trailers","transfer-encoding","accept-encoding","x-conductor-proxy-authorized","x-conductor-access-authenticated","x-conductor-access-role","x-conductor-access-email","x-conductor-access-provider","x-conductor-proxy-secret"]),g=new Set(["connection","content-length","content-encoding","keep-alive","transfer-encoding"]);function h(){return null!==(0,e._)()}function i(a){let b=new Headers;return a.headers.forEach((a,c)=>{g.has(c.toLowerCase())||b.set(c,a)}),b}async function j(a,b,c={}){let d=(0,e.B)(),g=new URL(a.url),h=new URL(b,d);h.search=g.search;let k=new Headers;a.headers.forEach((a,b)=>{f.has(b.toLowerCase())||k.set(b,a)}),c.headers&&new Headers(c.headers).forEach((a,b)=>{k.set(b,a)}),k.set("x-forwarded-proto",g.protocol.replace(":","")),k.set("x-forwarded-host",g.host);let l={method:a.method,headers:k,redirect:"manual",cache:"no-store"};if("GET"!==a.method&&"HEAD"!==a.method){let b=await a.arrayBuffer();b.byteLength>0&&(l.body=b)}let m=await fetch(h,l),n=i(m);return new Response(m.body,{status:m.status,statusText:m.statusText,headers:n})}async function k(a,b,c={}){let d,g=(0,e.B)(),h=new URL(a.url),j=new URL(b,g);j.search=h.search;let l=new Headers;a.headers.forEach((a,b)=>{f.has(b.toLowerCase())||l.set(b,a)}),c.headers&&new Headers(c.headers).forEach((a,b)=>{l.set(b,a)}),l.set("Accept","text/event-stream"),l.set("Cache-Control","no-cache"),l.set("x-forwarded-proto",h.protocol.replace(":","")),l.set("x-forwarded-host",h.host);let m=await fetch(j,{method:"GET",headers:l,redirect:"manual",cache:"no-store",signal:a.signal});return m.ok&&m.body?new Response(m.body,{status:m.status,statusText:m.statusText,headers:((d=i(m)).set("Content-Type","text/event-stream"),d.set("Cache-Control","no-cache, no-transform"),d.set("Connection","keep-alive"),d.set("X-Accel-Buffering","no"),d)}):new Response(m.body,{status:m.status,statusText:m.statusText,headers:i(m)})}async function l(a,b,c={}){if(!h())return d.NextResponse.json({error:"Rust backend URL is not configured"},{status:503});try{return await j(a,b,c)}catch(a){return d.NextResponse.json({error:a instanceof Error?a.message:"Failed to reach Rust backend"},{status:502})}}async function m(a,b,c={}){if(!h())return d.NextResponse.json({error:"Rust backend URL is not configured"},{status:503});try{return await k(a,b,c)}catch(a){return d.NextResponse.json({error:a instanceof Error?a.message:"Failed to reach Rust backend"},{status:502})}}}};
|
|
1
|
+
"use strict";exports.id=3990,exports.ids=[3990],exports.modules={25985:(a,b,c)=>{c.d(b,{FM:()=>g,JZ:()=>f,N7:()=>h});var d=c(32679),e=c(70209);async function f(a){let b=await (0,d.ny)(a),c=new Headers({"x-conductor-proxy-authorized":"true","x-conductor-access-authenticated":b.authenticated||"local"===b.provider?"true":"false"});b.role&&c.set("x-conductor-access-role",b.role),b.email&&c.set("x-conductor-access-email",b.email),b.provider&&c.set("x-conductor-access-provider",b.provider);let e=process.env.CONDUCTOR_PROXY_AUTH_SECRET?.trim()||null;return e&&c.set("x-conductor-proxy-secret",e),c}async function g(a,b,c={}){let h=await (0,d.sB)(a,c.role??"viewer");if(h)return h;if(c.requireActionGuard){let b=(0,d.G1)(a);if(b)return b}return(0,e.zP)(a,b,{headers:await f(a)})}async function h(a,b,c={}){let g=await (0,d.sB)(a,c.role??"viewer");if(g)return g;if(c.requireActionGuard){let b=(0,d.G1)(a);if(b)return b}return(0,e.X_)(a,b,{headers:await f(a)})}},28480:(a,b,c)=>{c.a(a,async(a,d)=>{try{c.d(b,{Ob:()=>A});var e=c(71553),f=c(31421),g=c(4573),h=c(73024),i=c(77030),j=c(76760),k=c(8856),l=c(34140),m=c(36026),n=c(94842),o=c(59506),p=a([k,l]);[k,l]=p.then?(await p)():p;let B={width:1440,height:960},C=["127.0.0.1","localhost","::1","0.0.0.0"],D=/^[a-z][a-z\d+.-]*:\/\//i,E=/^(?:localhost|127\.0\.0\.1|0\.0\.0\.0|\[::1\]|::1)(?::\d+)?(?:\/.*)?$/i;function q(a){return a.replace(/^\[(.*)\]$/,"$1").toLowerCase()}function r(a){let b=q(a);return C.includes(b)}function s(a){let b=a.split(".").map(a=>Number.parseInt(a,10));if(4!==b.length||b.some(a=>!Number.isInteger(a)||a<0||a>255))return!0;let[c,d]=b;return 0===c||10===c||127===c||100===c&&d>=64&&d<=127||169===c&&254===d||172===c&&d>=16&&d<=31||192===c&&168===d||198===c&&(18===d||19===d)||c>=224}function t(a){let b=q(a),c=(0,i.isIP)(b);if(4===c)return s(b);if(6===c){let a,c;return c=(a=q(b).toLowerCase()).startsWith("::ffff:")?a.slice(7):null,"::"===a||"::1"===a||a.startsWith("fe8")||a.startsWith("fe9")||a.startsWith("fea")||a.startsWith("feb")||a.startsWith("fc")||a.startsWith("fd")||!!c&&s(c)}return!1}async function u(a){if(process.env.CONDUCTOR_ALLOW_UNSAFE_PREVIEW_HOSTS?.trim().toLowerCase()==="true")return;let b=new URL(a);if(!r(b.hostname)){if(t(b.hostname))throw Error("Preview navigation to private network hosts is blocked. Use loopback URLs for local dev servers or set CONDUCTOR_ALLOW_UNSAFE_PREVIEW_HOSTS=true to override.");if((await (0,e.lookup)(b.hostname,{all:!0,verbatim:!0}).catch(()=>[])).some(a=>t(a.address)))throw Error("Preview navigation resolved to a private network address and was blocked. Set CONDUCTOR_ALLOW_UNSAFE_PREVIEW_HOSTS=true only if you intentionally trust that target.")}}function v(a,b){if(!b)return"direct";try{let c=new URL(a),d=r(q(c.hostname));if(b.allowedOrigins.includes(c.origin))return"bridge";return d?"blocked":"direct"}catch{return"direct"}}function w(a,b){try{let c=new URL(a),d=new URL(b);return c.origin===d.origin}catch{return a===b}}let F=globalThis;function x(a,b){a.push(b),a.length>150&&a.splice(0,a.length-150)}function y(a){return`${a}-${Date.now()}-${Math.random().toString(36).slice(2,8)}`}function z(a){return(a??"").replace(/\s+/g," ").trim()}class G{async getBrowser(){return this.browserPromise||(this.browserPromise=k.default.launch({headless:!0,executablePath:function(){let a=process.env.PUPPETEER_EXECUTABLE_PATH?.trim();if(a)return a;for(let a of[l.ChromeReleaseChannel.STABLE,l.ChromeReleaseChannel.CANARY,l.ChromeReleaseChannel.BETA,l.ChromeReleaseChannel.DEV])try{return(0,l.computeSystemExecutablePath)({browser:l.Browser.CHROME,channel:a})}catch{}let b=function(){for(let a of"darwin"===process.platform?["/Applications/Google Chrome.app/Contents/MacOS/Google Chrome","/Applications/Google Chrome Canary.app/Contents/MacOS/Google Chrome Canary","/Applications/Chromium.app/Contents/MacOS/Chromium","/Applications/Microsoft Edge.app/Contents/MacOS/Microsoft Edge","/Applications/Brave Browser.app/Contents/MacOS/Brave Browser"]:"win32"===process.platform?[process.env.PROGRAMFILES,process.env["PROGRAMFILES(X86)"],process.env.LOCALAPPDATA].filter(a=>!!a?.trim()).flatMap(a=>[(0,j.join)(a,"Google","Chrome","Application","chrome.exe"),(0,j.join)(a,"Chromium","Application","chrome.exe"),(0,j.join)(a,"Microsoft","Edge","Application","msedge.exe"),(0,j.join)(a,"BraveSoftware","Brave-Browser","Application","brave.exe")]):["google-chrome-stable","google-chrome","chromium-browser","chromium","microsoft-edge","brave-browser"]){if(a.includes("/")||a.includes("\\")){if((0,h.existsSync)(a))return a;continue}let b=function(a){let b="win32"===process.platform?"where":"which";try{return(0,f.execFileSync)(b,[a],{encoding:"utf8",stdio:["ignore","pipe","ignore"]}).trim().split(/\r?\n/).map(a=>a.trim()).find(Boolean)||null}catch{return null}}(a);if(b)return b}return null}();if(b)return b;throw Error("Chrome/Chromium not found. Install a supported browser or set PUPPETEER_EXECUTABLE_PATH.")}(),defaultViewport:B,args:["--disable-dev-shm-usage","--disable-background-networking","--no-first-run","--no-default-browser-check"]})),this.browserPromise}getState(a){let b=this.states.get(a);return b||(b={sessionId:a,context:null,page:null,destroying:!1,activeFrameId:null,selectedElement:null,consoleLogs:[],networkLogs:[],lastError:null,frameIds:new WeakMap,requestStarts:new WeakMap,frameSequence:0,bridgePreview:null,requestInterceptionEnabled:!1},this.states.set(a,b)),b}async ensureContext(a,b){return a.context&&!a.context.closed||(a.context=await b.createBrowserContext()),a.context}async destroySession(a,b={}){let c=this.states.get(a);if(!c||c.destroying)return;c.destroying=!0;let d=c.page,e=c.context;try{!1!==b.closePage&&d&&!d.isClosed()&&await d.close().catch(()=>{}),e&&!e.closed&&await e.close().catch(()=>{})}finally{this.states.delete(a)}}ensureFrameId(a,b){let c=a.frameIds.get(b);if(c)return c;let d=`frame-${++a.frameSequence}`;return a.frameIds.set(b,d),d}async configureBridgePreview(a,b,c){let d=this.getState(a);d.bridgePreview=b&&c?{...b,forwardedHeaders:Object.fromEntries(new Headers(c).entries())}:null,d.page&&!d.page.isClosed()&&await this.syncRequestInterception(d,d.page)}async syncRequestInterception(a,b,c){let d="bridge"===v(c??b.url(),a.bridgePreview);a.requestInterceptionEnabled!==d&&(await b.setRequestInterception(d),a.requestInterceptionEnabled=d)}async handleBridgePreviewRequest(a,b){let c,d=a.bridgePreview;if(!d)return void await b.continue();try{c=new URL(b.url())}catch{await b.abort("blockedbyclient");return}if("http:"!==c.protocol&&"https:"!==c.protocol||!d.allowedOrigins.includes(c.origin))return void await b.abort("blockedbyclient");let e="GET"===b.method()||"HEAD"===b.method()?null:b.postData()??null,f=await (0,n.LN)(d.bridgeId,d.forwardedHeaders,{sessionId:d.sessionId,method:b.method(),url:c.toString(),headers:function(a){let b={};for(let[c,d]of Object.entries(a)){let a=c.trim().toLowerCase();a&&"host"!==a&&"connection"!==a&&"proxy-connection"!==a&&"keep-alive"!==a&&"transfer-encoding"!==a&&"content-length"!==a&&"accept-encoding"!==a&&(b[a]=d)}return b}(b.headers()),bodyBase64:e?g.Buffer.from(e).toString("base64"):null});await b.respond({status:f.status,headers:f.headers,body:f.bodyBase64?g.Buffer.from(f.bodyBase64,"base64"):g.Buffer.alloc(0)})}attachListeners(a,b){b.on("console",b=>{this.captureConsole(a,b)}),b.on("pageerror",b=>{let c=b instanceof Error?b.message:String(b);x(a.consoleLogs,{id:y("pageerror"),kind:"pageerror",level:"error",message:c,timestamp:new Date().toISOString()}),a.lastError=c}),b.on("request",b=>{a.requestStarts.set(b,Date.now()),a.requestInterceptionEnabled&&this.handleBridgePreviewRequest(a,b).catch(async c=>{a.lastError=c instanceof Error?c.message:"Bridge preview request failed",x(a.networkLogs,{id:y("preview-request"),kind:"network",level:"error",message:a.lastError,timestamp:new Date().toISOString(),url:b.url(),method:b.method(),status:null,resourceType:b.resourceType()});try{await b.abort("failed")}catch{}})}),b.on("response",b=>{this.captureResponse(a,b)}),b.on("requestfailed",b=>{x(a.networkLogs,{id:y("requestfailed"),kind:"network",level:"error",message:b.failure()?.errorText??"Request failed",timestamp:new Date().toISOString(),url:b.url(),method:b.method(),status:null,resourceType:b.resourceType()})}),b.on("framenavigated",c=>{let d=this.ensureFrameId(a,c);c===b.mainFrame()&&(a.activeFrameId??=d),a.selectedElement?.frameId===d&&(a.selectedElement=null)}),b.on("close",()=>{this.destroySession(a.sessionId,{closePage:!1})})}captureConsole(a,b){let c=b.location();x(a.consoleLogs,{id:y("console"),kind:"console",level:b.type(),message:z(b.text()),timestamp:new Date().toISOString(),url:c.url??null})}captureResponse(a,b){let c=b.request();x(a.networkLogs,{id:y("network"),kind:"network",level:b.ok()?"info":"error",message:`${c.method()} ${b.status()} ${z(b.statusText())}`.trim(),timestamp:new Date().toISOString(),url:b.url(),method:c.method(),status:b.status(),resourceType:c.resourceType()})}async ensurePage(a){let b=await this.getBrowser(),c=this.getState(a);if(c.page&&!c.page.isClosed())return await this.syncRequestInterception(c,c.page),{state:c,page:c.page};let d=await this.ensureContext(c,b),e=await d.newPage();return await e.setViewport(B),e.setDefaultNavigationTimeout(3e4),e.setDefaultTimeout(15e3),this.attachListeners(c,e),await this.syncRequestInterception(c,e),c.page=e,c.activeFrameId=this.ensureFrameId(c,e.mainFrame()),c.selectedElement=null,c.lastError=null,{state:c,page:e}}collectFrames(a,b){let c=b.frames().map(c=>{let d=this.ensureFrameId(a,c),e=c.parentFrame();return{id:d,name:c.name()||(c===b.mainFrame()?"Main frame":"Untitled frame"),url:c.url(),parentId:e?this.ensureFrameId(a,e):null,isMain:c===b.mainFrame()}});return c.some(b=>b.id===a.activeFrameId)||(a.activeFrameId=c.find(a=>a.isMain)?.id??c[0]?.id??null),a.selectedElement&&!c.some(b=>b.id===a.selectedElement?.frameId)&&(a.selectedElement=null),c}resolveFrame(a,b,c){let d=c??a.activeFrameId,e=b.frames();return d?e.find(b=>this.ensureFrameId(a,b)===d)??b.mainFrame():b.mainFrame()}async navigationProducedUsablePage(a,b,c,d){if(!(d instanceof Error?d.message:String(d)).toLowerCase().includes("net::err_aborted"))return!1;let e=a.url();if("about:blank"===e||e===c&&!w(e,b)||!w(e,b))return!1;try{let b=await a.evaluate(()=>document.readyState);return"interactive"===b||"complete"===b}catch{return!1}}async snapshotElement(a,b,c){return a.evaluate(({selector:a,point:b})=>{var c,d;let e,f,g,h;function i(a){return(a??"").replace(/\s+/g," ").trim()}let j=null;return("string"==typeof a&&a.trim()?j=document.querySelector(a):b&&(j=document.elementFromPoint(b.x,b.y)),j)?(c=j,e=i(c.outerHTML).slice(0,400),f=i(c.textContent),g=c.getBoundingClientRect(),h=[...c.attributes].reduce((a,b)=>(a&&Object.keys(a).length>=12||(a[b.name]=b.value),a),{}),{selector:function(a){let b=[],c=a;for(;c&&b.length<5;){let a=function(a){let b=a.tagName.toLowerCase(),c=i(a.getAttribute("id"));if(c)return`#${CSS.escape(c)}`;let d=[...a.classList].slice(0,2).map(a=>`.${CSS.escape(a)}`).join(""),e="",f=a.parentElement;if(f){let b=[...f.children].filter(b=>b.tagName===a.tagName);b.length>1&&(e=`:nth-of-type(${b.indexOf(a)+1})`)}return`${b}${d}${e}`}(c);if(b.unshift(a),a.startsWith("#"))break;c=c.parentElement}return b.join(" > ")}(c),tag:c.tagName.toLowerCase(),text:f.slice(0,220),role:function(a){let b=i(a.getAttribute("role"));if(b)return b;let c=a.tagName.toLowerCase();return"button"===c?"button":"a"===c&&a.hasAttribute("href")?"link":"input"===c?(a.getAttribute("type")??"textbox").toLowerCase():null}(c),name:(d=f.slice(0,220),i(c.getAttribute("aria-label")??c.getAttribute("title")??c.getAttribute("placeholder")??c.getAttribute("alt")??d)||null),interactive:function(a){if(!(a instanceof HTMLElement))return!1;let b=a.tagName.toLowerCase();return!!(["button","input","select","textarea","summary"].includes(b)||"a"===b&&a.hasAttribute("href")||a.hasAttribute("contenteditable")||a.hasAttribute("onclick")||(a.getAttribute("role")??"").match(/button|link|tab|checkbox|radio|switch|textbox|menuitem/i))||a.tabIndex>=0}(c),id:i(c.getAttribute("id"))||null,classes:[...c.classList].slice(0,6),htmlPreview:e,bounds:{x:g.x,y:g.y,width:g.width,height:g.height},attributes:h}):null},{selector:b,point:c})}async connect(a,b){let{state:c,page:d}=await this.ensurePage(a),e=function(a){let b,c=!(b=a.trim())||D.test(b)?b:E.test(b)?`http://${b}`:b;try{let a=new URL(c),b=a.toString(),d=q(a.hostname),e=a.protocol.toLowerCase();if("http:"!==e&&"https:"!==e)throw Error(`Navigation blocked: only http and https URLs are allowed. Got protocol "${a.protocol}".`);if(r(d)){let a=new Set([b]);for(let c of C){let d=new URL(b);d.hostname=c,a.add(d.toString())}return[...a]}return[b]}catch(a){if(a instanceof Error&&a.message.startsWith("Navigation blocked:"))throw a;throw Error(`Navigation blocked: could not parse "${c}" as a valid URL.`)}}(b),f=null;for(let a of e){let b=v(a,c.bridgePreview);if("blocked"===b){f=Error("Bridge preview only allows navigation to the session's reported local dev server origin.");continue}let e=d.url();try{"direct"===b&&await u(a),await this.syncRequestInterception(c,d,a),await d.goto(a,{waitUntil:"domcontentloaded"}),await this.syncRequestInterception(c,d),c.selectedElement=null,c.lastError=null,c.activeFrameId=this.ensureFrameId(c,d.mainFrame());return}catch(b){if(await this.navigationProducedUsablePage(d,a,e,b)){await this.syncRequestInterception(c,d),c.selectedElement=null,c.lastError=null,c.activeFrameId=this.ensureFrameId(c,d.mainFrame());return}f=b}}throw c.lastError=f instanceof Error?f.message:"Failed to connect preview",f??Error("Failed to connect preview")}async runCommand(a,b){switch(b.command){case"connect":case"navigate":await this.connect(a,b.url);return;case"reload":{let{state:b,page:c}=await this.ensurePage(a);try{await c.reload({waitUntil:"domcontentloaded"}),b.lastError=null}catch(a){throw b.lastError=a instanceof Error?a.message:"Failed to reload preview",a}return}case"goBack":{let{state:b,page:c}=await this.ensurePage(a);try{await this.syncRequestInterception(b,c),await c.goBack({waitUntil:"domcontentloaded",timeout:1500}),await this.syncRequestInterception(b,c),b.selectedElement=null,b.lastError=null,b.activeFrameId=this.ensureFrameId(b,c.mainFrame())}catch(a){throw b.lastError=a instanceof Error?a.message:"Failed to go back",a}return}case"goForward":{let{state:b,page:c}=await this.ensurePage(a);try{await this.syncRequestInterception(b,c),await c.goForward({waitUntil:"domcontentloaded",timeout:1500}),await this.syncRequestInterception(b,c),b.selectedElement=null,b.lastError=null,b.activeFrameId=this.ensureFrameId(b,c.mainFrame())}catch(a){throw b.lastError=a instanceof Error?a.message:"Failed to go forward",a}return}case"selectFrame":{let{state:c,page:d}=await this.ensurePage(a),e=this.resolveFrame(c,d,b.frameId);c.activeFrameId=this.ensureFrameId(c,e),c.selectedElement=null,c.lastError=null;return}case"clickAtPoint":{let{state:c,page:d}=await this.ensurePage(a);c.selectedElement=null,c.lastError=null;let e=d.waitForNavigation({waitUntil:"domcontentloaded",timeout:1500}).catch(()=>null);await d.mouse.click(b.x,b.y),await e,await d.waitForNetworkIdle({idleTime:250,timeout:1e3}).catch(()=>null);return}case"typeText":{let{state:c,page:d}=await this.ensurePage(a);if(!b.text)return;await d.keyboard.type(b.text),c.lastError=null;return}case"pressKey":{let{state:c,page:d}=await this.ensurePage(a);c.lastError=null;let e=d.waitForNavigation({waitUntil:"domcontentloaded",timeout:1500}).catch(()=>null);await d.keyboard.press(b.key),await e,await d.waitForNetworkIdle({idleTime:250,timeout:1e3}).catch(()=>null);return}case"selectAtPoint":{let{state:c,page:d}=await this.ensurePage(a),e=this.resolveFrame(c,d,c.activeFrameId);if(e!==d.mainFrame())throw Error("Point selection is only available for the main frame. Pick nested frame elements from the DOM list.");let f=await this.snapshotElement(e,void 0,{x:b.x,y:b.y});if(!f)throw Error("No element found at the selected point");c.selectedElement={...f,frameId:this.ensureFrameId(c,e),frameName:e.name()||"Main frame",frameUrl:e.url()},c.lastError=null;return}case"selectBySelector":{let{state:c,page:d}=await this.ensurePage(a),e=this.resolveFrame(c,d,b.frameId),f=await this.snapshotElement(e,b.selector);if(!f)throw Error(`Element not found for selector: ${b.selector}`);c.selectedElement={...f,frameId:this.ensureFrameId(c,e),frameName:e.name()||(e===d.mainFrame()?"Main frame":"Frame"),frameUrl:e.url()},c.activeFrameId=this.ensureFrameId(c,e),c.lastError=null;return}default:return}}async inspectDom(a,b,c=!1){let{state:d,page:e}=await this.ensurePage(a),f=this.resolveFrame(d,e,b),g=await f.evaluate(({interactiveOnly:a,limit:b})=>{function c(a){return(a??"").replace(/\s+/g," ").trim()}let d=document.body??document.documentElement,e=document.createTreeWalker(d,NodeFilter.SHOW_ELEMENT),f=[],g=0;for(;e.nextNode();){g+=1;let d=e.currentNode;if(!(d instanceof Element))continue;let h=function(a){if(!(a instanceof HTMLElement))return!1;let b=a.tagName.toLowerCase();return!!(["button","input","select","textarea","summary"].includes(b)||"a"===b&&a.hasAttribute("href")||a.hasAttribute("contenteditable")||(a.getAttribute("role")??"").match(/button|link|tab|checkbox|radio|switch|textbox|menuitem/i))||a.tabIndex>=0}(d);if(a&&!h)continue;let i=c(d.textContent).slice(0,220),j=d.getBoundingClientRect();if(f.push({selector:function(a){let b=[],d=a;for(;d&&b.length<5;){let a=function(a){let b=a.tagName.toLowerCase(),d=c(a.getAttribute("id"));if(d)return`#${CSS.escape(d)}`;let e=[...a.classList].slice(0,2).map(a=>`.${CSS.escape(a)}`).join(""),f="",g=a.parentElement;if(g){let b=[...g.children].filter(b=>b.tagName===a.tagName);b.length>1&&(f=`:nth-of-type(${b.indexOf(a)+1})`)}return`${b}${e}${f}`}(d);if(b.unshift(a),a.startsWith("#"))break;d=d.parentElement}return b.join(" > ")}(d),tag:d.tagName.toLowerCase(),text:i,role:function(a){let b=c(a.getAttribute("role"));if(b)return b;let d=a.tagName.toLowerCase();return"button"===d?"button":"a"===d&&a.hasAttribute("href")?"link":"input"===d?(a.getAttribute("type")??"textbox").toLowerCase():null}(d),name:c(d.getAttribute("aria-label")??d.getAttribute("title")??d.getAttribute("placeholder")??d.getAttribute("alt")??i)||null,interactive:h,id:c(d.getAttribute("id"))||null,classes:[...d.classList].slice(0,6),htmlPreview:c(d.outerHTML).slice(0,320),bounds:{x:j.x,y:j.y,width:j.width,height:j.height}}),f.length>=b)break}return{nodes:f,truncated:f.length>=b||g>f.length}},{interactiveOnly:c,limit:250});return{frameId:this.ensureFrameId(d,f),nodes:g.nodes,truncated:g.truncated}}async takeScreenshot(a){let{page:b}=await this.ensurePage(a);return"about:blank"===b.url()?null:b.screenshot({type:"png"})}async getNavigationCapabilities(a){if(!a||a.isClosed()||"about:blank"===a.url())return{canGoBack:!1,canGoForward:!1};let b=null;try{b=await a.createCDPSession();let c=await b.send("Page.getNavigationHistory");return{canGoBack:c.currentIndex>0,canGoForward:c.currentIndex<c.entries.length-1}}catch{return{canGoBack:!1,canGoForward:!1}}finally{await b?.detach().catch(()=>null)}}async getStatus(a,b){let c=this.states.get(a)??null,d=c?.page&&!c.page.isClosed()?c.page:null,e=c&&d?this.collectFrames(c,d):[],{canGoBack:f,canGoForward:g}=await this.getNavigationCapabilities(d),h=null;if(d&&"about:blank"!==d.url())try{h=await d.title()}catch{h=null}return{connected:!!(d&&"about:blank"!==d.url()),candidateUrls:b,currentUrl:d&&"about:blank"!==d.url()?d.url():null,title:h,tunnelUrl:null,tunnelLocalOrigin:null,canGoBack:f,canGoForward:g,frames:e,activeFrameId:c?.activeFrameId??null,selectedElement:c?.selectedElement??null,consoleLogs:c?.consoleLogs??[],networkLogs:c?.networkLogs??[],lastError:c?.lastError??null,screenshotKey:`${Date.now()}`}}constructor(){this.browserPromise=null,this.states=new Map}}function A(){return!function(){let a=(0,m._)();if(!a)return!1;try{let b=new URL(a).hostname.toLowerCase();return"localhost"===b||"127.0.0.1"===b||"0.0.0.0"===b||"::1"===b||"[::1]"===b}catch{return!1}}()?(0,o.k)():(F._conductorPreviewBrowserManager||(F._conductorPreviewBrowserManager=new G),F._conductorPreviewBrowserManager)}d()}catch(a){d(a)}})},36026:(a,b,c)=>{function d(a){let b=a?.trim();if(!b)return null;try{let a=new URL(b);if("http:"!==a.protocol&&"https:"!==a.protocol)return null;return a.toString()}catch{return null}}function e(a){let b=a?.trim();if(!b)return null;let c=Number.parseInt(b,10);return!Number.isInteger(c)||c<1||c>65535?null:c}function f(){let a=d(process.env.CONDUCTOR_BACKEND_URL);if(a)return a;let b=d(process.env.NEXT_PUBLIC_CONDUCTOR_BACKEND_URL);if(b)return b;let c=e(process.env.CONDUCTOR_BACKEND_PORT);if(null!==c)return`http://127.0.0.1:${c}`;let f=e(process.env.NEXT_PUBLIC_CONDUCTOR_BACKEND_PORT);return null!==f?`http://127.0.0.1:${f}`:null}function g(){let a=f();if(!a)throw Error("Rust backend URL is not configured");return a}c.d(b,{B:()=>g,_:()=>f})},42599:(a,b,c)=>{c.d(b,{Ix:()=>s});var d=c(51455),e=c(94842),f=c(36026),g=c(91752);let h=/(?:127\.0\.0\.1|0\.0\.0\.0|localhost|::1|\[::1\])/i,i=/\bhttps?:\/\/[^\s"'<>`]+/gi,j=/^[a-z][a-z\d+.-]*:\/\//i,k=/(?<!:\/\/)(?:localhost|127\.0\.0\.1|0\.0\.0\.0|\[::1\]|::1)(?::\d+)?(?:\/[^\s"'<>`]*)?/gi,l=new Set(["previewUrl","devServerUrl","devServerURL","localUrl"]),m={devServerUrl:0,devServerURL:0,localUrl:10,previewUrl:50};function n(a,b){let c=a[b];return"string"==typeof c?c:null}async function o(a,b={}){let c,d=a.bridgeId?.trim()||(0,g.DW)(a.id)?.bridgeId||null;try{if(d){if(!b.request)return[];c=await (0,e.nl)(b.request,d,"/api/repositories",{pathOverride:"/api/repositories"})}else{let a=(0,f.B)();c=await fetch(new URL("/api/repositories",a),{cache:"no-store",headers:b.headers})}}catch{return[]}if(!c.ok)return[];let h=await c.json().catch(()=>null),i=(Array.isArray(h?.repositories)?h.repositories:[]).find(b=>b&&"object"==typeof b&&n(b,"id")===a.projectId);if(!i||"object"!=typeof i)return[];let j=function(a){var b,c;let d,e,f=n(a,"devServerUrl")?.trim();if(f)return f;let g=n(a,"devServerPort")?.trim();if(!g)return null;let h=!0===a.devServerHttps?"https":"http",i=(b=n(a,"devServerHost"),(d=b?.trim())?"0.0.0.0"===d?"127.0.0.1":d:"127.0.0.1"),j=(c=n(a,"devServerPath"),(e=c?.trim())&&"/"!==e?e.startsWith("/")?e:`/${e}`:"");return`${h}://${i}:${g}${j}`}(i);return j?[j]:[]}function p(a,b=""){let c=(0,g.DW)(a),d=c?.sessionId??a;return`/api/sessions/${encodeURIComponent(d)}${b}`}async function q(a,b,c={}){let d=(0,g.DW)(a);if(d){if(!c.request)throw Error("Bridge preview lookup requires the incoming request context");return(0,e.nl)(c.request,d.bridgeId,b,{pathOverride:b})}return fetch(new URL(b,(0,f.B)()),{cache:"no-store",headers:c.headers})}async function r(a,b={}){let c=(0,g.DW)(a),d=await q(a,p(a),b);if(404===d.status)return null;if(!d.ok)throw Error(`Failed to fetch session ${a}: ${d.status}`);let e=await d.json();return c?(0,g.Vk)(e,c.bridgeId):e}async function s(a,b={}){try{var c,d;let e=await r(a,b);if(!e)return{session:null,candidateUrls:[],error:null,bridgePreview:null};let f=await z(e,b);return{session:e,candidateUrls:f,error:(c=e,d=f,!c.bridgeId?.trim()||d.length>0?null:[c.pr?.previewUrl??null,c.metadata.previewUrl??null,c.metadata.devServerUrl??null,c.metadata.devServerURL??null,c.metadata.localUrl??null,c.metadata.url??null,c.summary].some(a=>v(a).some(a=>w(a)))?"Bridge preview could not find a paired-device local dev server URL for this session.":"Bridge preview uses the paired device's local dev server, but this session did not report one."),bridgePreview:function(a,b){let c=a.bridgeId?.trim();if(!c)return null;let d=[...new Set(b.filter(a=>w(a)).map(a=>{try{return new URL(a).origin}catch{return null}}).filter(a=>!!a))];if(0===d.length)return null;let e=(0,g.DW)(a.id);return{bridgeId:c,sessionId:e?.sessionId??a.id,allowedOrigins:d}}(e,f)}}catch(a){return{session:null,candidateUrls:[],error:a instanceof Error?a.message:"Failed to load preview session",bridgePreview:null}}}function t(a){let b=a.trim().replace(/[),.;]+$/,""),c=j.test(b)?b:k.test(b)?`http://${b}`:b;k.lastIndex=0;try{let a=new URL(c);return"0.0.0.0"===a.hostname&&(a.hostname="127.0.0.1"),a.toString()}catch{return c}}async function u(a){try{let b=await (0,d.readFile)(a,"utf8");return v(b)}catch{return[]}}function v(a){return[...a?.match(i)??[],...a?.match(k)??[]].map(t)}function w(a){try{let b=new URL(a);return h.test(b.hostname)}catch{return!1}}function x(a,b,c,d,e=!1){if(!b?.trim())return;let f=t(b);if(!f||function(a,b){try{let c=new URL(a);if(b){let a=new URL(b);if(c.origin===a.origin)return!0}return c.pathname.startsWith("/api/")}catch{return!1}}(f,d))return;try{let a=new URL(f);if("http:"!==a.protocol&&"https:"!==a.protocol||!e&&!w(f))return}catch{return}let g=a.get(f);(void 0===g||c<g)&&a.set(f,c)}async function y(a,b={}){try{let c=await q(a,p(a,"/output?lines=400"),b);if(!c.ok)return"";let d=await c.json().catch(()=>null);return"string"==typeof d?.output?d.output:""}catch{return""}}async function z(a,b={}){let c=(0,f._)()??"",d=new Map;for(let[e,f]of(b.previewUrlHint?.trim()&&x(d,b.previewUrlHint,-10,c,!0),a.pr?.previewUrl?.trim()&&x(d,a.pr.previewUrl,50,c,!0),a.metadata.devServerUrl?.trim()&&x(d,a.metadata.devServerUrl,0,c,!0),Object.entries(a.metadata)))if("string"==typeof f)for(let a of(l.has(e)&&f.trim()&&x(d,f,m[e]??30,c,!0),v(f)))x(d,a,60,c);for(let b of v(a.summary))x(d,b,70,c);let e=a.metadata.devServerLog?.trim();if(e)for(let a of(await u(e)))x(d,a,40,c);for(let e of v(await y(a.id,b)))x(d,e,80,c);if(![...d.keys()].some(a=>w(a)))for(let e of(await o(a,b)))x(d,e,20,c,!0);return[...d.entries()].sort(([a,b],[c,d])=>{if(b!==d)return b-d;let e=+!w(a),f=+!w(c);return e!==f?e-f:a.localeCompare(c)}).map(([a])=>a)}},59506:(a,b,c)=>{c.d(b,{k:()=>i});var d=c(4573),e=c(46224);function f(a,b=null){return{connected:!1,candidateUrls:a,currentUrl:null,title:null,tunnelUrl:null,tunnelLocalOrigin:null,canGoBack:!1,canGoForward:!1,frames:[],activeFrameId:null,selectedElement:null,consoleLogs:[],networkLogs:[],lastError:b,screenshotKey:`${Date.now()}`}}class g{async configureBridgePreview(a,b,c){let d=(0,e.y)(),f=b&&c&&d?{...b,relayUrl:d,forwardedHeaders:Object.fromEntries(new Headers(c).entries())}:null;if(JSON.stringify(this.bridgePreviewConfigs.get(a)??null)===JSON.stringify(f))return;this.bridgePreviewConfigs.set(a,f);let g=this.remoteSessionIds.get(a);if(g&&this.isConfigured()){this.remoteSessionIds.delete(a);try{await fetch(`${this.workerUrl}/sessions/${encodeURIComponent(g)}`,{method:"DELETE",headers:this.buildHeaders(),cache:"no-store"})}catch{}}}async destroySession(a){let b=this.remoteSessionIds.get(a);if(this.remoteSessionIds.delete(a),this.bridgePreviewConfigs.delete(a),b&&this.isConfigured())try{await fetch(`${this.workerUrl}/sessions/${encodeURIComponent(b)}`,{method:"DELETE",headers:this.buildHeaders(),cache:"no-store"})}catch{}}async runCommand(a,b){let c=await this.sendCommand(a,b,{createIfMissing:!0});if("error"===c.kind)throw Error(c.message)}async inspectDom(a,b,c=!1){let d=await this.sendCommand(a,{command:"dom",frameId:b,interactiveOnly:c},{createIfMissing:!0});if("dom"!==d.kind)throw Error("error"===d.kind?d.message:"Unexpected preview worker DOM response");return d}async takeScreenshot(a){if(!this.remoteSessionIds.has(a))return null;let b=await this.sendCommand(a,{command:"screenshot"},{createIfMissing:!1});if("error"===b.kind){if(b.message.includes("not connected"))return null;throw Error(b.message)}if("screenshot"!==b.kind)throw Error("Unexpected preview worker screenshot response");return d.Buffer.from(b.imageBase64,"base64")}async getStatus(a,b){if(!this.remoteSessionIds.has(a))return f(b,this.configurationError());try{let c=await this.sendCommand(a,{command:"status",candidateUrls:b},{createIfMissing:!1});if("status"===c.kind)return c;return f(b,"error"===c.kind?c.message:"Preview service is unavailable")}catch(a){return f(b,a instanceof Error?a.message:"Preview service is unavailable")}}async sendCommand(a,b,c){let d=this.configurationError();if(d)return{kind:"error",message:d};let e=this.remoteSessionIds.get(a)??null;if(!e){if(!c.createIfMissing)return{kind:"error",message:"Preview is not connected"};e=await this.createRemoteSession(a)}try{let d=await fetch(`${this.workerUrl}/sessions/${encodeURIComponent(e)}/command`,{method:"POST",headers:this.buildHeaders(),body:JSON.stringify(b),cache:"no-store"}),f=await d.json();if(404===d.status&&!1!==c.retry)return this.remoteSessionIds.delete(a),await this.sendCommand(a,b,{createIfMissing:c.createIfMissing,retry:!1});if(!d.ok||"error"===f.kind)return"error"===f.kind?f:{kind:"error",message:"Preview worker request failed"};return f}catch(a){throw Error(this.networkErrorMessage(a))}}async createRemoteSession(a){let b=this.configurationError();if(b)throw Error(b);let c={bridgePreview:this.bridgePreviewConfigs.get(a)??null};try{let b=await fetch(`${this.workerUrl}/sessions`,{method:"POST",headers:this.buildHeaders(),body:JSON.stringify(c),cache:"no-store"}),d=await b.json();if(!b.ok||!d.sessionId)throw Error(d.error||"Preview worker session creation failed");return this.remoteSessionIds.set(a,d.sessionId),d.sessionId}catch(a){throw Error(this.networkErrorMessage(a))}}buildHeaders(){return{Authorization:`Bearer ${this.workerApiKey}`,"Content-Type":"application/json"}}configurationError(){return this.workerUrl&&this.workerApiKey?null:"Preview worker is not configured"}isConfigured(){return null===this.configurationError()}networkErrorMessage(a){let b,c=a instanceof Error?a.message:"Preview service is unavailable";return(b=c.trim().toLowerCase())&&("preview worker is not configured"===b||!("fetch failed"===b||b.includes("econnrefused")||b.includes("enotfound")||b.includes("eai_again")||b.includes("networkerror")||b.includes("socket hang up")))?c:"Preview service is unavailable"}constructor(){this.workerUrl=function(a){let b=a?.trim();if(!b)return null;try{let a=new URL(b);if("http:"!==a.protocol&&"https:"!==a.protocol)return null;return a.toString().replace(/\/$/,"")}catch{return null}}(process.env.CONDUCTOR_PREVIEW_WORKER_URL),this.workerApiKey=process.env.CONDUCTOR_PREVIEW_WORKER_KEY?.trim()||null,this.remoteSessionIds=new Map,this.bridgePreviewConfigs=new Map}}let h=globalThis;function i(){return h._conductorPreviewWorkerClient||(h._conductorPreviewWorkerClient=new g),h._conductorPreviewWorkerClient}},70209:(a,b,c)=>{c.d(b,{X_:()=>m,Z$:()=>h,zP:()=>l});var d=c(77873),e=c(36026);let f=new Set(["connection","host","content-length","expect","upgrade","proxy-authorization","proxy-authenticate","te","trailers","transfer-encoding","accept-encoding","x-conductor-proxy-authorized","x-conductor-access-authenticated","x-conductor-access-role","x-conductor-access-email","x-conductor-access-provider","x-conductor-proxy-secret"]),g=new Set(["connection","content-length","content-encoding","keep-alive","transfer-encoding"]);function h(){return null!==(0,e._)()}function i(a){let b=new Headers;return a.headers.forEach((a,c)=>{g.has(c.toLowerCase())||b.set(c,a)}),b}async function j(a,b,c={}){let d=(0,e.B)(),g=new URL(a.url),h=new URL(b,d);h.search=g.search;let k=new Headers;a.headers.forEach((a,b)=>{f.has(b.toLowerCase())||k.set(b,a)}),c.headers&&new Headers(c.headers).forEach((a,b)=>{k.set(b,a)}),k.set("x-forwarded-proto",g.protocol.replace(":","")),k.set("x-forwarded-host",g.host);let l={method:a.method,headers:k,redirect:"manual",cache:"no-store"};if("GET"!==a.method&&"HEAD"!==a.method){let b=await a.arrayBuffer();b.byteLength>0&&(l.body=b)}let m=await fetch(h,l),n=i(m);return new Response(m.body,{status:m.status,statusText:m.statusText,headers:n})}async function k(a,b,c={}){let d,g=(0,e.B)(),h=new URL(a.url),j=new URL(b,g);j.search=h.search;let l=new Headers;a.headers.forEach((a,b)=>{f.has(b.toLowerCase())||l.set(b,a)}),c.headers&&new Headers(c.headers).forEach((a,b)=>{l.set(b,a)}),l.set("Accept","text/event-stream"),l.set("Cache-Control","no-cache"),l.set("x-forwarded-proto",h.protocol.replace(":","")),l.set("x-forwarded-host",h.host);let m=await fetch(j,{method:"GET",headers:l,redirect:"manual",cache:"no-store",signal:a.signal});return m.ok&&m.body?new Response(m.body,{status:m.status,statusText:m.statusText,headers:((d=i(m)).set("Content-Type","text/event-stream"),d.set("Cache-Control","no-cache, no-transform"),d.set("Connection","keep-alive"),d.set("X-Accel-Buffering","no"),d)}):new Response(m.body,{status:m.status,statusText:m.statusText,headers:i(m)})}async function l(a,b,c={}){if(!h())return d.NextResponse.json({error:"Rust backend URL is not configured"},{status:503});try{return await j(a,b,c)}catch(a){return d.NextResponse.json({error:a instanceof Error?a.message:"Failed to reach Rust backend"},{status:502})}}async function m(a,b,c={}){if(!h())return d.NextResponse.json({error:"Rust backend URL is not configured"},{status:503});try{return await k(a,b,c)}catch(a){return d.NextResponse.json({error:a instanceof Error?a.message:"Failed to reach Rust backend"},{status:502})}}}};
|