@crewx/sdk 0.8.8-rc.23 → 0.8.8-rc.25

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,59 +1,59 @@
1
- 'use strict';var fs$1=require('fs'),F=require('path'),child_process=require('child_process'),sdk=require('@agentclientprotocol/sdk'),jsYaml=require('js-yaml'),zod=require('zod'),module$1=require('module'),ie=require('handlebars'),promises=require('fs/promises'),crypto$1=require('crypto'),events=require('events'),async_hooks=require('async_hooks'),mcp_js=require('@modelcontextprotocol/sdk/server/mcp.js'),webStandardStreamableHttp_js=require('@modelcontextprotocol/sdk/server/webStandardStreamableHttp.js'),perf_hooks=require('perf_hooks'),drizzleOrm=require('drizzle-orm'),Ci=require('os'),sqliteCore=require('drizzle-orm/sqlite-core');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var F__namespace=/*#__PURE__*/_interopNamespace(F);var ie__namespace=/*#__PURE__*/_interopNamespace(ie);var Ci__default=/*#__PURE__*/_interopDefault(Ci);var Ut=Object.defineProperty;var co=Object.getOwnPropertyDescriptor;var uo=Object.getOwnPropertyNames;var po=Object.prototype.hasOwnProperty;var W=(o=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(o,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):o)(function(o){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+o+'" is not supported')});var N=(o,e)=>()=>(o&&(e=o(o=0)),e);var lt=(o,e)=>{for(var t in e)Ut(o,t,{get:e[t],enumerable:true});},go=(o,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of uo(e))!po.call(o,n)&&n!==t&&Ut(o,n,{get:()=>e[n],enumerable:!(r=co(e,n))||r.enumerable});return o};var Ht=o=>go(Ut({},"__esModule",{value:true}),o);var l=N(()=>{});function mt(o){return typeof o!="string"?void 0:o.trim()||void 0}function ft(o){return mt(o)?.toLowerCase()??""}function De(o){try{return fs$1.statSync(o).isFile()}catch{return false}}function zr(o,e){if(o.includes("/")||o.includes("\\")||F__namespace.default.isAbsolute(o))return o;let r=(e.PATH??e.Path??process.env.PATH??process.env.Path??"").split(";").map(a=>a.trim()).filter(Boolean),n=F__namespace.default.extname(o).length>0,s=e.PATHEXT??e.Pathext??process.env.PATHEXT??process.env.Pathext??".EXE;.CMD;.BAT;.COM",i=n?[""]:s.split(";").map(a=>a.trim()).filter(Boolean).map(a=>a.startsWith(".")?a:`.${a}`);for(let a of r)for(let d of i){let c=ft(d),u=d.toUpperCase();for(let m of [d,c,u]){let g=F__namespace.default.join(a,`${o}${m}`);if(De(g))return g}}return o}function Po(o){if(!De(o))return null;try{let e=fs$1.readFileSync(o,"utf8"),t=F__namespace.default.dirname(o),r=[];for(let a of e.matchAll(/"([^"\r\n]*)"/g)){let u=(a[1]??"").match(/%~?dp0%?\s*[\\/]*(.*)$/i)?.[1]?.trim();if(!u)continue;let m=u.replace(/[\\/]+/g,F__namespace.default.sep).replace(/^[\\/]+/,""),g=F__namespace.default.resolve(t,m);De(g)&&r.push(g);}let n=[],s=new Map;for(let a of e.matchAll(/SET\s+"(\w+)=%~?dp0%?[\\/]?([^"]+)"/gi)){let d=a[1].toUpperCase(),c=a[2].trim().replace(/[\\/]+/g,F__namespace.default.sep).replace(/^[\\/]+/,"");s.set(d,F__namespace.default.resolve(t,c));}for(let a of e.split(/\r?\n/))if(a.includes("%*"))for(let d of a.matchAll(/"%(\w+)%"/g)){let c=s.get(d[1].toUpperCase());c&&De(c)&&n.push(c);}let i=a=>a.find(d=>{let c=ft(F__namespace.default.basename(d));return c!=="node.exe"&&c!=="node"})??null;return i(n)??i(r)}catch{return null}}function Co(o,e){if(typeof e=="string")return mt(e)||null;if(!e||typeof e!="object")return null;if(o){let t=e[o],r=typeof t=="string"?mt(t):void 0;if(r)return r}for(let t of Object.values(e)){let r=typeof t=="string"?mt(t):void 0;if(r)return r}return null}function bo(o,e){if(!e)return null;let t=F__namespace.default.dirname(o),r=[F__namespace.default.resolve(t,"..",e),F__namespace.default.resolve(t,"node_modules",e)];for(let n of r){let s=F__namespace.default.join(n,"package.json");if(De(s))try{let i=JSON.parse(fs$1.readFileSync(s,"utf8")),a=Co(e,i.bin);if(!a)continue;let d=F__namespace.default.resolve(n,a);if(De(d))return d}catch{}}return null}function Eo(o){let e=o.platform??process.platform,t=o.env??process.env,r=o.execPath??process.execPath;if(e!=="win32")return {command:o.command,leadingArgv:[],resolution:"direct"};let n=zr(o.command,t),s=ft(F__namespace.default.extname(n));if(s===".js"||s===".cjs"||s===".mjs")return {command:r,leadingArgv:[n],resolution:"node-entrypoint",windowsHide:true};if(s===".cmd"||s===".bat"){let i=Po(n)??bo(n,o.packageName);return i?ft(F__namespace.default.extname(i))===".exe"?{command:i,leadingArgv:[],resolution:"exe-entrypoint",windowsHide:true}:{command:r,leadingArgv:[i],resolution:"node-entrypoint",windowsHide:true}:{command:n,leadingArgv:[],resolution:"unresolved-wrapper"}}return {command:n,leadingArgv:[],resolution:"direct"}}function To(o){if(o.candidate.resolution!=="unresolved-wrapper")return {command:o.candidate.command,leadingArgv:o.candidate.leadingArgv,resolution:o.candidate.resolution,windowsHide:o.candidate.windowsHide};if(o.allowShellFallback===true)return {command:o.candidate.command,leadingArgv:[],resolution:"shell-fallback",shell:true};throw new Error(`${F__namespace.default.basename(o.candidate.command)} wrapper resolved, but no executable/Node entrypoint could be resolved without shell execution.`)}function Be(o){let e=Eo(o);return To({candidate:e,allowShellFallback:o.allowShellFallback})}function We(o,e){return {command:o.command,argv:[...o.leadingArgv,...e],resolution:o.resolution,shell:o.shell,windowsHide:o.windowsHide}}var yt=N(()=>{l();});function So(o){if(o.type!=="usage"||!("input_tokens"in o))return null;let e=Number(o.input_tokens??0),t=Number(o.output_tokens??0),n="cache_read_input_tokens"in o?Number(o.cache_read_input_tokens):void 0,s="cached_input_tokens"in o?Number(o.cached_input_tokens):void 0,i=n!==void 0?n:s??0;return {inputTokens:n!==void 0?e+n:e,outputTokens:t,cachedInputTokens:i}}function Io(o){let e=o.usage;if(!e||typeof e!="object"||Array.isArray(e))return null;let t=e;if(!("input_tokens"in t))return null;let r=Number(t.input_tokens??0),n=Number(t.output_tokens??0),i="cache_read_input_tokens"in t?Number(t.cache_read_input_tokens):void 0,a="cached_input_tokens"in t?Number(t.cached_input_tokens):void 0,d=i!==void 0?i:a??0;return {inputTokens:i!==void 0?r+i:r,outputTokens:n,cachedInputTokens:d}}function Oo(o){if(o.type!=="step_finish")return null;let t=o.part?.tokens;if(!t)return null;let r=Number(t.input??0),n=Number(t.output??0),s=t.cache,i=s?Number(s.read??0):0;return {inputTokens:r+i,outputTokens:n,cachedInputTokens:i}}function Q(o){if(!o||!o.trim())return;let e=null;for(let t of o.split(`
2
- `))if(t.trim())try{let r=JSON.parse(t),n=So(r)??Io(r)??Oo(r);n&&(e=n);}catch{}return e??void 0}var ve=N(()=>{l();});exports.RateLimitError=void 0;var qt=N(()=>{l();exports.RateLimitError=class extends Error{name="RateLimitError";constructor(e){super(e);}};});function Z(o){return /crewx\s+(x|execute)\s/.test(o)}function ee(o,e){let t=e.match(/@(\S+)/);return {timestamp:o,type:"agent_call",targetAgent:t?.[1]?.replace(/["']/g,""),toolInput:e}}var Le=N(()=>{l();});function te(o){if(typeof o=="string")return o;if(!o||typeof o!="object")return JSON.stringify(o??{});let e=o;return typeof e.command=="string"?e.command:typeof e.file_path=="string"?e.file_path:typeof e.filePath=="string"?e.filePath:typeof e.path=="string"?e.path:typeof e.query=="string"?e.query:typeof e.pattern=="string"?e.pattern:typeof e.url=="string"?e.url:typeof e.prompt=="string"?e.prompt.length>200?e.prompt.slice(0,200)+"\u2026":e.prompt:typeof e.description=="string"?e.description:JSON.stringify(e)}var $e=N(()=>{l();});function Mo(o,e){let t=e.type;if(t==="text"){let r=String(e.text||"");return r?{timestamp:o,type:"text",content:r}:null}if(t==="thinking"){let r=String(e.thinking||"");return {timestamp:o,type:"thinking",content:r||"(thinking)"}}if(t==="tool_use"){let r=String(e.name||""),n=e.id,s=e.input,i=te(s);return r==="Bash"&&Z(i)?ee(o,i):{timestamp:o,type:"tool_use",toolUseId:n,toolName:r,toolInput:i}}if(t==="tool_result"){let r=!!e.is_error,n=e.tool_use_id,s=e.output??e.content??"",i;return typeof s=="string"?i=s:Array.isArray(s)?i=s.filter(a=>a.type==="text"&&typeof a.text=="string").map(a=>a.text).join(`
3
- `):i=JSON.stringify(s),{timestamp:o,type:"tool_result",toolUseId:n,resultPreview:i,isError:r}}return null}exports.claudeAdapter=void 0;var Bt=N(()=>{l();qt();Le();$e();exports.claudeAdapter={command:"claude",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs],s=n.indexOf("-p");return s!==-1?(n.splice(s+1,0,o),e.model&&n.push("--model",e.model),{args:n}):(e.model&&n.push("--model",e.model),{args:n,stdinMessage:o})}let r=["-p",o,"--output-format","stream-json","--verbose"];return e.model&&r.push("--model",e.model),{args:r}},extractText(o){let e=o.split(`
1
+ 'use strict';var fs=require('fs'),W=require('path'),child_process=require('child_process'),sdk=require('@agentclientprotocol/sdk'),jsYaml=require('js-yaml'),zod=require('zod'),module$1=require('module'),de=require('handlebars'),promises=require('fs/promises'),crypto$1=require('crypto'),events=require('events'),async_hooks=require('async_hooks'),mcp_js=require('@modelcontextprotocol/sdk/server/mcp.js'),webStandardStreamableHttp_js=require('@modelcontextprotocol/sdk/server/webStandardStreamableHttp.js'),perf_hooks=require('perf_hooks'),drizzleOrm=require('drizzle-orm'),Si=require('os'),sqliteCore=require('drizzle-orm/sqlite-core');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var W__namespace=/*#__PURE__*/_interopNamespace(W);var de__namespace=/*#__PURE__*/_interopNamespace(de);var Si__default=/*#__PURE__*/_interopDefault(Si);var Ht=Object.defineProperty;var go=Object.getOwnPropertyDescriptor;var mo=Object.getOwnPropertyNames;var fo=Object.prototype.hasOwnProperty;var z=(o=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(o,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):o)(function(o){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+o+'" is not supported')});var N=(o,e)=>()=>(o&&(e=o(o=0)),e);var ct=(o,e)=>{for(var t in e)Ht(o,t,{get:e[t],enumerable:true});},yo=(o,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of mo(e))!fo.call(o,n)&&n!==t&&Ht(o,n,{get:()=>e[n],enumerable:!(r=go(e,n))||r.enumerable});return o};var qt=o=>yo(Ht({},"__esModule",{value:true}),o);var l=N(()=>{});function ft(o){return typeof o!="string"?void 0:o.trim()||void 0}function yt(o){return ft(o)?.toLowerCase()??""}function Le(o){try{return fs.statSync(o).isFile()}catch{return false}}function Jr(o,e){if(o.includes("/")||o.includes("\\")||W__namespace.default.isAbsolute(o))return o;let r=(e.PATH??e.Path??process.env.PATH??process.env.Path??"").split(";").map(a=>a.trim()).filter(Boolean),n=W__namespace.default.extname(o).length>0,s=e.PATHEXT??e.Pathext??process.env.PATHEXT??process.env.Pathext??".EXE;.CMD;.BAT;.COM",i=n?[""]:s.split(";").map(a=>a.trim()).filter(Boolean).map(a=>a.startsWith(".")?a:`.${a}`);for(let a of r)for(let d of i){let c=yt(d),u=d.toUpperCase();for(let g of [d,c,u]){let f=W__namespace.default.join(a,`${o}${g}`);if(Le(f))return f}}return o}function bo(o){if(!Le(o))return null;try{let e=fs.readFileSync(o,"utf8"),t=W__namespace.default.dirname(o),r=[];for(let a of e.matchAll(/"([^"\r\n]*)"/g)){let u=(a[1]??"").match(/%~?dp0%?\s*[\\/]*(.*)$/i)?.[1]?.trim();if(!u)continue;let g=u.replace(/[\\/]+/g,W__namespace.default.sep).replace(/^[\\/]+/,""),f=W__namespace.default.resolve(t,g);Le(f)&&r.push(f);}let n=[],s=new Map;for(let a of e.matchAll(/SET\s+"(\w+)=%~?dp0%?[\\/]?([^"]+)"/gi)){let d=a[1].toUpperCase(),c=a[2].trim().replace(/[\\/]+/g,W__namespace.default.sep).replace(/^[\\/]+/,"");s.set(d,W__namespace.default.resolve(t,c));}for(let a of e.split(/\r?\n/))if(a.includes("%*"))for(let d of a.matchAll(/"%(\w+)%"/g)){let c=s.get(d[1].toUpperCase());c&&Le(c)&&n.push(c);}let i=a=>a.find(d=>{let c=yt(W__namespace.default.basename(d));return c!=="node.exe"&&c!=="node"})??null;return i(n)??i(r)}catch{return null}}function Eo(o,e){if(typeof e=="string")return ft(e)||null;if(!e||typeof e!="object")return null;if(o){let t=e[o],r=typeof t=="string"?ft(t):void 0;if(r)return r}for(let t of Object.values(e)){let r=typeof t=="string"?ft(t):void 0;if(r)return r}return null}function So(o,e){if(!e)return null;let t=W__namespace.default.dirname(o),r=[W__namespace.default.resolve(t,"..",e),W__namespace.default.resolve(t,"node_modules",e)];for(let n of r){let s=W__namespace.default.join(n,"package.json");if(Le(s))try{let i=JSON.parse(fs.readFileSync(s,"utf8")),a=Eo(e,i.bin);if(!a)continue;let d=W__namespace.default.resolve(n,a);if(Le(d))return d}catch{}}return null}function Io(o){let e=o.platform??process.platform,t=o.env??process.env,r=o.execPath??process.execPath;if(e!=="win32")return {command:o.command,leadingArgv:[],resolution:"direct"};let n=Jr(o.command,t),s=yt(W__namespace.default.extname(n));if(s===".js"||s===".cjs"||s===".mjs")return {command:r,leadingArgv:[n],resolution:"node-entrypoint",windowsHide:true};if(s===".cmd"||s===".bat"){let i=bo(n)??So(n,o.packageName);return i?yt(W__namespace.default.extname(i))===".exe"?{command:i,leadingArgv:[],resolution:"exe-entrypoint",windowsHide:true}:{command:r,leadingArgv:[i],resolution:"node-entrypoint",windowsHide:true}:{command:n,leadingArgv:[],resolution:"unresolved-wrapper"}}return {command:n,leadingArgv:[],resolution:"direct"}}function Oo(o){if(o.candidate.resolution!=="unresolved-wrapper")return {command:o.candidate.command,leadingArgv:o.candidate.leadingArgv,resolution:o.candidate.resolution,windowsHide:o.candidate.windowsHide};if(o.allowShellFallback===true)return {command:o.candidate.command,leadingArgv:[],resolution:"shell-fallback",shell:true};throw new Error(`${W__namespace.default.basename(o.candidate.command)} wrapper resolved, but no executable/Node entrypoint could be resolved without shell execution.`)}function We(o){let e=Io(o);return Oo({candidate:e,allowShellFallback:o.allowShellFallback})}function ze(o,e){return {command:o.command,argv:[...o.leadingArgv,...e],resolution:o.resolution,shell:o.shell,windowsHide:o.windowsHide}}var ht=N(()=>{l();});function Mo(o){if(o.type!=="usage"||!("input_tokens"in o))return null;let e=Number(o.input_tokens??0),t=Number(o.output_tokens??0),n="cache_read_input_tokens"in o?Number(o.cache_read_input_tokens):void 0,s="cached_input_tokens"in o?Number(o.cached_input_tokens):void 0,i=n!==void 0?n:s??0;return {inputTokens:n!==void 0?e+n:e,outputTokens:t,cachedInputTokens:i}}function No(o){let e=o.usage;if(!e||typeof e!="object"||Array.isArray(e))return null;let t=e;if(!("input_tokens"in t))return null;let r=Number(t.input_tokens??0),n=Number(t.output_tokens??0),i="cache_read_input_tokens"in t?Number(t.cache_read_input_tokens):void 0,a="cached_input_tokens"in t?Number(t.cached_input_tokens):void 0,d=i!==void 0?i:a??0;return {inputTokens:i!==void 0?r+i:r,outputTokens:n,cachedInputTokens:d}}function Do(o){if(o.type!=="step_finish")return null;let t=o.part?.tokens;if(!t)return null;let r=Number(t.input??0),n=Number(t.output??0),s=t.cache,i=s?Number(s.read??0):0;return {inputTokens:r+i,outputTokens:n,cachedInputTokens:i}}function ee(o){if(!o||!o.trim())return;let e=null;for(let t of o.split(`
2
+ `))if(t.trim())try{let r=JSON.parse(t),n=Mo(r)??No(r)??Do(r);n&&(e=n);}catch{}return e??void 0}var Ae=N(()=>{l();});exports.RateLimitError=void 0;var Wt=N(()=>{l();exports.RateLimitError=class extends Error{name="RateLimitError";constructor(e){super(e);}};});function te(o){return /crewx\s+(x|execute)\s/.test(o)}function re(o,e){let t=e.match(/@(\S+)/);return {timestamp:o,type:"agent_call",targetAgent:t?.[1]?.replace(/["']/g,""),toolInput:e}}var $e=N(()=>{l();});function ne(o){if(typeof o=="string")return o;if(!o||typeof o!="object")return JSON.stringify(o??{});let e=o;return typeof e.command=="string"?e.command:typeof e.file_path=="string"?e.file_path:typeof e.filePath=="string"?e.filePath:typeof e.path=="string"?e.path:typeof e.query=="string"?e.query:typeof e.pattern=="string"?e.pattern:typeof e.url=="string"?e.url:typeof e.prompt=="string"?e.prompt.length>200?e.prompt.slice(0,200)+"\u2026":e.prompt:typeof e.description=="string"?e.description:JSON.stringify(e)}var je=N(()=>{l();});function Lo(o,e){let t=e.type;if(t==="text"){let r=String(e.text||"");return r?{timestamp:o,type:"text",content:r}:null}if(t==="thinking"){let r=String(e.thinking||"");return {timestamp:o,type:"thinking",content:r||"(thinking)"}}if(t==="tool_use"){let r=String(e.name||""),n=e.id,s=e.input,i=ne(s);return r==="Bash"&&te(i)?re(o,i):{timestamp:o,type:"tool_use",toolUseId:n,toolName:r,toolInput:i}}if(t==="tool_result"){let r=!!e.is_error,n=e.tool_use_id,s=e.output??e.content??"",i;return typeof s=="string"?i=s:Array.isArray(s)?i=s.filter(a=>a.type==="text"&&typeof a.text=="string").map(a=>a.text).join(`
3
+ `):i=JSON.stringify(s),{timestamp:o,type:"tool_result",toolUseId:n,resultPreview:i,isError:r}}return null}exports.claudeAdapter=void 0;var zt=N(()=>{l();Wt();$e();je();exports.claudeAdapter={command:"claude",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs],s=n.indexOf("-p");return s!==-1?(n.splice(s+1,0,o),e.model&&n.push("--model",e.model),{args:n}):(e.model&&n.push("--model",e.model),{args:n,stdinMessage:o})}let r=["-p",o,"--output-format","stream-json","--verbose"];return e.model&&r.push("--model",e.model),{args:r}},extractText(o){let e=o.split(`
4
4
  `).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="assistant"&&Array.isArray(s.message?.content))for(let i of s.message.content)i.type==="text"&&typeof i.text=="string"&&i.text.trim()&&t.push(i.text.trim());s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(`
5
5
 
6
6
  `):r||o.trim()},extractFailure(o){if(o.includes('"rate_limit_event"'))try{let e=JSON.parse(o);if(e.type==="rate_limit_event"){let t=e.rate_limit_info??{};if(t.status==="rejected")return new exports.RateLimitError(`Claude rate limit: ${t.rateLimitType??"unknown"} (status: ${t.status})`)}}catch{}return null},parseResultMeta(o){let e=o.split(`
7
- `);for(let t of e)if(t.trim())try{let r=JSON.parse(t);if(r.type==="result"){let n=r.usage,s=n?{inputTokens:Number(n.input_tokens??0)+Number(n.cache_read_input_tokens??0),outputTokens:Number(n.output_tokens??0),cachedInputTokens:Number(n.cache_read_input_tokens??0),costUsd:Number(r.total_cost_usd??0)}:null,i=r.modelUsage,a=i?Object.keys(i)[0]??null:null;return {usage:s,model:a}}}catch{}return {usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(r!=="assistant"&&r!=="user")return [];let s=t.message?.content;if(!Array.isArray(s))return [];let i=e??new Date().toISOString(),a=[];for(let d of s){let c=Mo(i,d);c&&a.push(c);}return a}};});exports.geminiAdapter=void 0;var Wt=N(()=>{l();ve();Le();$e();exports.geminiAdapter={command:"gemini",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs],s=n.indexOf("-p");return s!==-1?(n.splice(s+1,0,o),e.model&&n.push("--model",e.model),{args:n}):(e.model&&n.push("--model",e.model),{args:n,stdinMessage:o})}let r=["-p",o,"--output-format","stream-json","--verbose"];return e.model&&r.push("--model",e.model),{args:r}},extractText(o){let e=o.split(`
8
- `).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);s.type==="message"&&s.role==="assistant"&&s.delta===!0&&typeof s.content=="string"&&t.push(s.content),s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(""):r||o.trim()},parseResultMeta(o){let e=Q(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(r!=="message"&&r!=="tool_use"&&r!=="tool_result")return [];let n=e??new Date().toISOString();if(r==="message"){if(t.role!=="assistant")return [];let i=t.content;return i?[{timestamp:n,type:"text",content:i}]:[]}if(r==="tool_use"){let s=String(t.tool_name||""),i=t.tool_id,a=t.parameters,d=te(a);return /^bash$/i.test(s)&&Z(d)?[ee(n,d)]:[{timestamp:n,type:"tool_use",toolName:s,toolUseId:i,toolInput:d}]}if(r==="tool_result"){let s=t.tool_id,i=String(t.output||""),a=t.status!=="success";return [{timestamp:n,type:"tool_result",toolUseId:s,resultPreview:i,isError:a}]}return []}};});exports.copilotAdapter=void 0;var zt=N(()=>{l();ve();Le();$e();exports.copilotAdapter={command:"copilot",buildArgs(o,e,t){let r=e.additionalArgs?[...e.additionalArgs]:[];return e.model&&r.push("--model",e.model),{args:r,stdinMessage:o}},extractText(o){let e=o.split(`
7
+ `);for(let t of e)if(t.trim())try{let r=JSON.parse(t);if(r.type==="result"){let n=r.usage,s=n?{inputTokens:Number(n.input_tokens??0)+Number(n.cache_read_input_tokens??0),outputTokens:Number(n.output_tokens??0),cachedInputTokens:Number(n.cache_read_input_tokens??0),costUsd:Number(r.total_cost_usd??0)}:null,i=r.modelUsage,a=i?Object.keys(i)[0]??null:null;return {usage:s,model:a}}}catch{}return {usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(r!=="assistant"&&r!=="user")return [];let s=t.message?.content;if(!Array.isArray(s))return [];let i=e??new Date().toISOString(),a=[];for(let d of s){let c=Lo(i,d);c&&a.push(c);}return a}};});exports.geminiAdapter=void 0;var Vt=N(()=>{l();Ae();$e();je();exports.geminiAdapter={command:"gemini",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs],s=n.indexOf("-p");return s!==-1?(n.splice(s+1,0,o),e.model&&n.push("--model",e.model),{args:n}):(e.model&&n.push("--model",e.model),{args:n,stdinMessage:o})}let r=["-p",o,"--output-format","stream-json","--verbose"];return e.model&&r.push("--model",e.model),{args:r}},extractText(o){let e=o.split(`
8
+ `).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);s.type==="message"&&s.role==="assistant"&&s.delta===!0&&typeof s.content=="string"&&t.push(s.content),s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(""):r||o.trim()},parseResultMeta(o){let e=ee(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(r!=="message"&&r!=="tool_use"&&r!=="tool_result")return [];let n=e??new Date().toISOString();if(r==="message"){if(t.role!=="assistant")return [];let i=t.content;return i?[{timestamp:n,type:"text",content:i}]:[]}if(r==="tool_use"){let s=String(t.tool_name||""),i=t.tool_id,a=t.parameters,d=ne(a);return /^bash$/i.test(s)&&te(d)?[re(n,d)]:[{timestamp:n,type:"tool_use",toolName:s,toolUseId:i,toolInput:d}]}if(r==="tool_result"){let s=t.tool_id,i=String(t.output||""),a=t.status!=="success";return [{timestamp:n,type:"tool_result",toolUseId:s,resultPreview:i,isError:a}]}return []}};});exports.copilotAdapter=void 0;var Kt=N(()=>{l();Ae();$e();je();exports.copilotAdapter={command:"copilot",buildArgs(o,e,t){let r=e.additionalArgs?[...e.additionalArgs]:[];return e.model&&r.push("--model",e.model),{args:r,stdinMessage:o}},extractText(o){let e=o.split(`
9
9
  `).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="assistant.message"&&typeof s.data?.content=="string"){let i=s.data.content;i.trim()&&t.push(i.trim());}s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(`
10
10
 
11
- `):r||o.trim()},parseResultMeta(o){let e=Q(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(!r.startsWith("tool.execution")&&!r.startsWith("assistant.")&&r!=="user.message")return [];let n=t.data;if(!n)return [];let s=e??new Date().toISOString(),i=n.toolCallId;if(r==="tool.execution_start"){let a=String(n.toolName||""),d=n.arguments,c=te(d);return (a==="bash"||a==="Bash")&&Z(c)?[ee(s,c)]:[{timestamp:s,type:"tool_use",toolName:a,toolInput:c,...i&&{toolUseId:i}}]}if(r==="tool.execution_complete"){let a=n.error;if(a)return [{timestamp:s,type:"tool_result",isError:true,resultPreview:String(a.message||""),...i&&{toolUseId:i}}];let d=n.result,c=String(d?.content||"");return [{timestamp:s,type:"tool_result",resultPreview:c,isError:false,...i&&{toolUseId:i}}]}if(r==="assistant.message"){let a=String(n.content||"");return a?[{timestamp:s,type:"text",content:a}]:[]}return []}};});function No(o,e){if(e.type==="command_execution"){let r=String(e.command||"");return Z(r)?[ee(o,r)]:[{timestamp:o,type:"tool_use",toolName:"Bash",toolInput:r}]}return []}function Do(o,e){let t=e.type;if(t==="message"||t==="text"){let r=e.content;if(Array.isArray(r))for(let n of r){let s=Lo(o,n);if(s)return s}if(typeof e.text=="string")return {timestamp:o,type:"text",content:e.text}}if(t==="reasoning")return {timestamp:o,type:"text",content:String(e.text||"")};if(t==="command_execution"){let r=String(e.aggregated_output||e.output||""),n=!!e.is_error;return {timestamp:o,type:"tool_result",resultPreview:r,isError:n}}if(t==="tool_use"){let r=String(e.name||e.tool_name||""),n=e.input,s=te(n);return r==="Bash"&&Z(s)?ee(o,s):{timestamp:o,type:"tool_use",toolName:r,toolInput:s}}if(t==="tool_result"){let r=!!e.is_error,n=String(e.output||e.content||"");return {timestamp:o,type:"tool_result",resultPreview:n,isError:r}}return null}function Lo(o,e){let t=e.type;if(t==="text")return {timestamp:o,type:"text",content:String(e.text||"")};if(t==="tool_use"){let r=String(e.name||""),n=e.input,s=te(n);return r==="Bash"&&Z(s)?ee(o,s):{timestamp:o,type:"tool_use",toolName:r,toolInput:s}}return null}exports.codexAdapter=void 0;var Vt=N(()=>{l();ve();Le();$e();exports.codexAdapter={command:"codex",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs];return !n.includes("--json")&&!n.includes("--experimental-json")&&n.push("--json"),e.model&&n.push("--model",e.model),{args:n,stdinMessage:o}}let r=["exec","--json"];return e.model&&r.push("--model",e.model),{args:r,stdinMessage:o}},extractText(o){let e=o.split(`
11
+ `):r||o.trim()},parseResultMeta(o){let e=ee(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(!r.startsWith("tool.execution")&&!r.startsWith("assistant.")&&r!=="user.message")return [];let n=t.data;if(!n)return [];let s=e??new Date().toISOString(),i=n.toolCallId;if(r==="tool.execution_start"){let a=String(n.toolName||""),d=n.arguments,c=ne(d);return (a==="bash"||a==="Bash")&&te(c)?[re(s,c)]:[{timestamp:s,type:"tool_use",toolName:a,toolInput:c,...i&&{toolUseId:i}}]}if(r==="tool.execution_complete"){let a=n.error;if(a)return [{timestamp:s,type:"tool_result",isError:true,resultPreview:String(a.message||""),...i&&{toolUseId:i}}];let d=n.result,c=String(d?.content||"");return [{timestamp:s,type:"tool_result",resultPreview:c,isError:false,...i&&{toolUseId:i}}]}if(r==="assistant.message"){let a=String(n.content||"");return a?[{timestamp:s,type:"text",content:a}]:[]}return []}};});function $o(o,e){if(e.type==="command_execution"){let r=String(e.command||"");return te(r)?[re(o,r)]:[{timestamp:o,type:"tool_use",toolName:"Bash",toolInput:r}]}return []}function jo(o,e){let t=e.type;if(t==="message"||t==="text"){let r=e.content;if(Array.isArray(r))for(let n of r){let s=Uo(o,n);if(s)return s}if(typeof e.text=="string")return {timestamp:o,type:"text",content:e.text}}if(t==="reasoning")return {timestamp:o,type:"text",content:String(e.text||"")};if(t==="command_execution"){let r=String(e.aggregated_output||e.output||""),n=!!e.is_error;return {timestamp:o,type:"tool_result",resultPreview:r,isError:n}}if(t==="tool_use"){let r=String(e.name||e.tool_name||""),n=e.input,s=ne(n);return r==="Bash"&&te(s)?re(o,s):{timestamp:o,type:"tool_use",toolName:r,toolInput:s}}if(t==="tool_result"){let r=!!e.is_error,n=String(e.output||e.content||"");return {timestamp:o,type:"tool_result",resultPreview:n,isError:r}}return null}function Uo(o,e){let t=e.type;if(t==="text")return {timestamp:o,type:"text",content:String(e.text||"")};if(t==="tool_use"){let r=String(e.name||""),n=e.input,s=ne(n);return r==="Bash"&&te(s)?re(o,s):{timestamp:o,type:"tool_use",toolName:r,toolInput:s}}return null}exports.codexAdapter=void 0;var Jt=N(()=>{l();Ae();$e();je();exports.codexAdapter={command:"codex",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs];return !n.includes("--json")&&!n.includes("--experimental-json")&&n.push("--json"),e.model&&n.push("--model",e.model),{args:n,stdinMessage:o}}let r=["exec","--json"];return e.model&&r.push("--model",e.model),{args:r,stdinMessage:o}},extractText(o){let e=o.split(`
12
12
  `).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="item.completed"&&(s.item?.type==="message"||s.item?.type==="agent_message")&&typeof s.item?.text=="string"){let i=s.item.text;i.trim()&&t.push(i.trim());}s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(`
13
13
 
14
- `):r||o.trim()},parseResultMeta(o){let e=Q(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(!r.startsWith("item.")&&!r.startsWith("turn.")&&!r.startsWith("thread."))return [];let n=t.item;if(!n)return [];let s=e??new Date().toISOString();if(r==="item.started")return No(s,n);if(r==="item.completed"){let i=Do(s,n);return i?[i]:[]}return []}};});exports.opencodeAdapter=void 0;var Kt=N(()=>{l();ve();$e();exports.opencodeAdapter={command:"opencode",buildArgs(o,e,t){let r=e.additionalArgs,n=r!==void 0?[...r]:["run"];return n.includes("--format")||n.push("--format","json"),e.model&&n.push("--model",e.model),n.push(o),{args:n}},extractText(o){let e=o.split(`
15
- `).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="text"&&typeof s.part?.text=="string"){let i=s.part.text;i.trim()&&t.push(i.trim());}s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(""):r||o.trim()},parseResultMeta(o){let e=Q(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];let n=e??new Date().toISOString();if(r==="text"){let i=t.part?.text;return i?[{timestamp:n,type:"text",content:i}]:[]}if(r==="tool_use"){let s=t.part;if(!s)return [];let i=String(s.tool||""),a=String(s.callID||""),d=s.state,c=String(d?.status||""),u=d?.input,m=te(u),g=[{timestamp:n,type:"tool_use",toolName:i,toolUseId:a,toolInput:m}];if(c==="completed"&&d?.output!==void 0){let p=d.output,y=typeof p=="string"?p:JSON.stringify(p);g.push({timestamp:n,type:"tool_result",toolUseId:a,resultPreview:y,isError:false});}else c==="error"&&g.push({timestamp:n,type:"tool_result",toolUseId:a,resultPreview:String(d?.error||"tool error"),isError:true});return g}return []}};});var Jt,Xt=N(()=>{l();Jt={command:"agy",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs];return n.includes("--print")||n.unshift("--print",o),e.model&&n.push("--model",e.model),n.push("--dangerously-skip-permissions"),{args:n}}let r=["--print",o,"--dangerously-skip-permissions"];return e.model&&r.push("--model",e.model),{args:r}},extractText(o){return o.trim()},parseResultMeta(o){return {usage:null,model:null}},parseEvent(o,e){return []}};});function Gt(o,e,t){if(t){let r=exports.BUILTIN_ADAPTERS[t];if(r?.parseEvent)return r.parseEvent(e,o)}for(let r of Object.values(exports.BUILTIN_ADAPTERS)){let n=r.parseEvent?.(e,o)??[];if(n.length>0)return n}return []}exports.BUILTIN_ADAPTERS=void 0;var je=N(()=>{l();Bt();Wt();zt();Vt();Kt();Xt();Bt();Wt();zt();Vt();Kt();Xt();Le();exports.BUILTIN_ADAPTERS={claude:exports.claudeAdapter,gemini:exports.geminiAdapter,copilot:exports.copilotAdapter,codex:exports.codexAdapter,opencode:exports.opencodeAdapter,antigravity:Jt};});function jo(o){let e=o.split(`
14
+ `):r||o.trim()},parseResultMeta(o){let e=ee(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(!r.startsWith("item.")&&!r.startsWith("turn.")&&!r.startsWith("thread."))return [];let n=t.item;if(!n)return [];let s=e??new Date().toISOString();if(r==="item.started")return $o(s,n);if(r==="item.completed"){let i=jo(s,n);return i?[i]:[]}return []}};});exports.opencodeAdapter=void 0;var Xt=N(()=>{l();Ae();je();exports.opencodeAdapter={command:"opencode",buildArgs(o,e,t){let r=e.additionalArgs,n=r!==void 0?[...r]:["run"];return n.includes("--format")||n.push("--format","json"),e.model&&n.push("--model",e.model),n.push(o),{args:n}},extractText(o){let e=o.split(`
15
+ `).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="text"&&typeof s.part?.text=="string"){let i=s.part.text;i.trim()&&t.push(i.trim());}s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(""):r||o.trim()},parseResultMeta(o){let e=ee(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];let n=e??new Date().toISOString();if(r==="text"){let i=t.part?.text;return i?[{timestamp:n,type:"text",content:i}]:[]}if(r==="tool_use"){let s=t.part;if(!s)return [];let i=String(s.tool||""),a=String(s.callID||""),d=s.state,c=String(d?.status||""),u=d?.input,g=ne(u),f=[{timestamp:n,type:"tool_use",toolName:i,toolUseId:a,toolInput:g}];if(c==="completed"&&d?.output!==void 0){let p=d.output,m=typeof p=="string"?p:JSON.stringify(p);f.push({timestamp:n,type:"tool_result",toolUseId:a,resultPreview:m,isError:false});}else c==="error"&&f.push({timestamp:n,type:"tool_result",toolUseId:a,resultPreview:String(d?.error||"tool error"),isError:true});return f}return []}};});var Gt,Yt=N(()=>{l();Gt={command:"agy",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs];return n.includes("--print")||n.unshift("--print",o),e.model&&n.push("--model",e.model),n.push("--dangerously-skip-permissions"),{args:n}}let r=["--print",o,"--dangerously-skip-permissions"];return e.model&&r.push("--model",e.model),{args:r}},extractText(o){return o.trim()},parseResultMeta(o){return {usage:null,model:null}},parseEvent(o,e){return []}};});function Qt(o,e,t){if(t){let r=exports.BUILTIN_ADAPTERS[t];if(r?.parseEvent)return r.parseEvent(e,o)}for(let r of Object.values(exports.BUILTIN_ADAPTERS)){let n=r.parseEvent?.(e,o)??[];if(n.length>0)return n}return []}exports.BUILTIN_ADAPTERS=void 0;var Ue=N(()=>{l();zt();Vt();Kt();Jt();Xt();Yt();zt();Vt();Kt();Jt();Xt();Yt();$e();exports.BUILTIN_ADAPTERS={claude:exports.claudeAdapter,gemini:exports.geminiAdapter,copilot:exports.copilotAdapter,codex:exports.codexAdapter,opencode:exports.opencodeAdapter,antigravity:Gt};});function Ho(o){let e=o.split(`
16
16
  `).filter(d=>d.trim()),t=[],r=[],n=[],s=[],i=[],a=null;for(let d of e)try{let c=JSON.parse(d);if(c.type==="assistant"&&Array.isArray(c.message?.content))for(let u of c.message.content)u.type==="text"&&typeof u.text=="string"&&u.text.trim()&&t.push(u.text.trim());if(c.type==="message"&&c.role==="assistant"&&c.delta===!0&&typeof c.content=="string"&&r.push(c.content),c.type==="assistant.message"&&typeof c.data?.content=="string"){let u=c.data.content;u.trim()&&n.push(u.trim());}if(c.type==="item.completed"&&(c.item?.type==="message"||c.item?.type==="agent_message")&&typeof c.item?.text=="string"){let u=c.item.text;u.trim()&&s.push(u.trim());}if(c.type==="text"&&typeof c.part?.text=="string"){let u=c.part.text;u.trim()&&i.push(u.trim());}c.type==="result"&&typeof c.result=="string"&&(a=c.result);}catch{}return t.length>0?t.join(`
17
17
 
18
18
  `):r.length>0?r.join(""):n.length>0?n.join(`
19
19
 
20
20
  `):s.length>0?s.join(`
21
21
 
22
- `):i.length>0?i.join(""):a||o.trim()}function Uo(o){let e=Q(o);return e?{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0}:null}function Ho(o,e,t=process.platform){return o==="copilot"&&t==="win32"&&e instanceof exports.ProviderError&&e.message.includes('CLI command "copilot" not found')}function Kr(o,e,t,r,n,s,i){return new Promise((a,d)=>{let c=n?.timeoutMs??288e5,u=Be({command:o,allowShellFallback:true}),m=We(u,e),g=child_process.spawn(m.command,m.argv,{env:{...process.env,...n?.env??{}},cwd:n?.cwd,stdio:["pipe","pipe","pipe"],shell:m.shell??false,windowsHide:m.windowsHide});s!==void 0&&g.stdin.write(s),g.stdin.end(),g.pid!==void 0&&n?.onPid?.(g.pid);let p=false,y=false,x=()=>{try{g.kill("SIGKILL");}catch{}},_=setTimeout(()=>{if(!p){y=true;try{g.kill("SIGTERM");}catch{}setTimeout(x,Vr).unref();}},c);_.unref();let v="",R="",I="",b="";g.stdout.on("data",U=>{let j=U.toString();v+=j,I+=j;let T=I.split(`
23
- `);I=T.pop()??"";for(let $ of T)if($.trim()&&(n?.onOutput?.($,"stdout"),i?.extractFailure)){let q=i.extractFailure($);if(q){p=true,clearTimeout(_);try{g.kill("SIGTERM");}catch{}setTimeout(x,Vr).unref(),d(q);return}}}),g.stderr.on("data",U=>{let j=U.toString();R+=j,b+=j;let T=b.split(`
24
- `);b=T.pop()??"";for(let $ of T)$.trim()&&n?.onOutput?.($,"stderr");}),g.on("error",U=>{p=true,clearTimeout(_),U.code==="ENOENT"?d(new exports.ProviderError(`CLI command "${o}" not found. Is ${t} installed?`,t)):d(new exports.ProviderError(`Spawn error: ${U.message}`,t));}),g.on("close",U=>{if(p)return;p=true,clearTimeout(_),I.trim()&&n?.onOutput?.(I,"stdout"),b.trim()&&n?.onOutput?.(b,"stderr");let j=U??0;if(n?.onExitCode?.(j),y&&U!==0)return d(new Ve(`Total runtime exceeded ${c}ms; process killed.`,t));if(j!==0){if(i?.interpretExit){let $=i.interpretExit(j,R);if($){d($);return}}d(new exports.ProviderError(`Process exited with code ${j}: ${R.slice(0,500)}`,t));return}let T=i?i.extractText(v):jo(v);a({stdout:v,parsed:T});});})}function le(o,e){Jr.set(o,e);}function ce(o){let e=o.split("/");if(e.length!==2)throw new exports.ProviderError(`Invalid provider format: "${o}". Expected namespace/id (e.g., cli/claude)`,o);let[t,r]=e,n=Jr.get(t);if(n)return n(r,o);if(t==="cli"){let s=exports.BUILTIN_ADAPTERS[r];if(!s)throw new exports.ProviderError(`Unknown CLI provider id: "${r}". Supported: ${Object.keys(exports.BUILTIN_ADAPTERS).join(", ")}`,o);return new Yt(r,s,o)}throw new exports.ProviderError(`Unsupported provider namespace: "${t}". Register a factory with registerProviderFactory('${t}', factory).`,o)}exports.ProviderError=void 0;var Ve,Vr;exports.ClientToolCallRequiredError=void 0;var Jr,Yt,se=N(()=>{l();yt();ve();je();exports.ProviderError=class extends Error{constructor(t,r){super(t);this.providerStr=r;this.name="ProviderError";}providerStr},Ve=class extends exports.ProviderError{constructor(e,t){super(e,t),this.name="TotalTimeoutError";}};Vr=2e3;exports.ClientToolCallRequiredError=class extends Error{constructor(t,r){super(`Client tool call required: ${t.toolName}`);this.toolCall=t;this.continuationState=r;}toolCall;continuationState;name="ClientToolCallRequiredError"},Jr=new Map;Yt=class{constructor(e,t,r){this.providerId=e;this.adapter=t;this.providerStr=r;}providerId;adapter;providerStr;async execute(e,t){let r=this.composeMessage(e,t),{args:n,stdinMessage:s}=this.adapter.buildArgs(r,t??{},true);t?.onCommand?.(`${this.adapter.command} ${n.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(n,t,s);return this.handleResultMeta(i,t),a}async query(e,t){let r=this.composeMessage(e,t),{args:n,stdinMessage:s}=this.adapter.buildArgs(r,t??{},false);t?.onCommand?.(`${this.adapter.command} ${n.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(n,t,s);return this.handleResultMeta(i,t),a}composeMessage(e,t){return t?.systemPrompt?`${t.systemPrompt}
22
+ `):i.length>0?i.join(""):a||o.trim()}function qo(o){let e=ee(o);return e?{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0}:null}function Bo(o,e,t=process.platform){return o==="copilot"&&t==="win32"&&e instanceof exports.ProviderError&&e.message.includes('CLI command "copilot" not found')}function Gr(o,e,t,r,n,s,i){return new Promise((a,d)=>{let c=n?.timeoutMs??288e5,u=We({command:o,allowShellFallback:true}),g=ze(u,e),f=child_process.spawn(g.command,g.argv,{env:{...process.env,...n?.env??{}},cwd:n?.cwd,stdio:["pipe","pipe","pipe"],shell:g.shell??false,windowsHide:g.windowsHide});s!==void 0&&f.stdin.write(s),f.stdin.end(),f.pid!==void 0&&n?.onPid?.(f.pid);let p=false,m=false,w=()=>{try{f.kill("SIGKILL");}catch{}},v=setTimeout(()=>{if(!p){m=true;try{f.kill("SIGTERM");}catch{}setTimeout(w,Xr).unref();}},c);v.unref();let k="",x="",S="",T="";f.stdout.on("data",B=>{let $=B.toString();k+=$,S+=$;let P=S.split(`
23
+ `);S=P.pop()??"";for(let H of P)if(H.trim()&&(n?.onOutput?.(H,"stdout"),i?.extractFailure)){let G=i.extractFailure(H);if(G){p=true,clearTimeout(v);try{f.kill("SIGTERM");}catch{}setTimeout(w,Xr).unref(),d(G);return}}}),f.stderr.on("data",B=>{let $=B.toString();x+=$,T+=$;let P=T.split(`
24
+ `);T=P.pop()??"";for(let H of P)H.trim()&&n?.onOutput?.(H,"stderr");}),f.on("error",B=>{p=true,clearTimeout(v),B.code==="ENOENT"?d(new exports.ProviderError(`CLI command "${o}" not found. Is ${t} installed?`,t)):d(new exports.ProviderError(`Spawn error: ${B.message}`,t));}),f.on("close",B=>{if(p)return;p=true,clearTimeout(v),S.trim()&&n?.onOutput?.(S,"stdout"),T.trim()&&n?.onOutput?.(T,"stderr");let $=B??0;if(n?.onExitCode?.($),m&&B!==0)return d(new Ke(`Total runtime exceeded ${c}ms; process killed.`,t));if($!==0){if(i?.interpretExit){let H=i.interpretExit($,x);if(H){d(H);return}}d(new exports.ProviderError(`Process exited with code ${$}: ${x.slice(0,500)}`,t));return}let P=i?i.extractText(k):Ho(k);a({stdout:k,parsed:P});});})}function ue(o,e){Yr.set(o,e);}function pe(o){let e=o.split("/");if(e.length!==2)throw new exports.ProviderError(`Invalid provider format: "${o}". Expected namespace/id (e.g., cli/claude)`,o);let[t,r]=e,n=Yr.get(t);if(n)return n(r,o);if(t==="cli"){let s=exports.BUILTIN_ADAPTERS[r];if(!s)throw new exports.ProviderError(`Unknown CLI provider id: "${r}". Supported: ${Object.keys(exports.BUILTIN_ADAPTERS).join(", ")}`,o);return new Zt(r,s,o)}throw new exports.ProviderError(`Unsupported provider namespace: "${t}". Register a factory with registerProviderFactory('${t}', factory).`,o)}exports.ProviderError=void 0;var Ke,Xr;exports.ClientToolCallRequiredError=void 0;var Yr,Zt,ae=N(()=>{l();ht();Ae();Ue();exports.ProviderError=class extends Error{constructor(t,r){super(t);this.providerStr=r;this.name="ProviderError";}providerStr},Ke=class extends exports.ProviderError{constructor(e,t){super(e,t),this.name="TotalTimeoutError";}};Xr=2e3;exports.ClientToolCallRequiredError=class extends Error{constructor(t,r){super(`Client tool call required: ${t.toolName}`);this.toolCall=t;this.continuationState=r;}toolCall;continuationState;name="ClientToolCallRequiredError"},Yr=new Map;Zt=class{constructor(e,t,r){this.providerId=e;this.adapter=t;this.providerStr=r;}providerId;adapter;providerStr;async execute(e,t){let r=this.composeMessage(e,t),{args:n,stdinMessage:s}=this.adapter.buildArgs(r,t??{},true);t?.onCommand?.(`${this.adapter.command} ${n.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(n,t,s);return this.handleResultMeta(i,t),a}async query(e,t){let r=this.composeMessage(e,t),{args:n,stdinMessage:s}=this.adapter.buildArgs(r,t??{},false);t?.onCommand?.(`${this.adapter.command} ${n.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(n,t,s);return this.handleResultMeta(i,t),a}composeMessage(e,t){return t?.systemPrompt?`${t.systemPrompt}
25
25
 
26
26
  ---
27
27
 
28
- ${e}`:e}async runProcess(e,t,r){try{return await Kr(this.adapter.command,e,this.providerStr,this.providerId,t,r,this.adapter)}catch(n){if(Ho(this.providerId,n)){let s=e[0]==="copilot"?e:["copilot",...e];return Kr("gh",s,this.providerStr,this.providerId,t,r,this.adapter)}throw n}}handleResultMeta(e,t){if(!this.adapter.parseResultMeta){let i=Uo(e);i&&t?.onUsage&&t.onUsage(i);return}let{usage:r,model:n}=this.adapter.parseResultMeta(e);r&&t?.onUsage&&t.onUsage(r);let s=n??(this.providerId==="opencode"?t?.model??null:null);s&&t?.onModel&&t.onModel(s);}};});var yn,hn;exports.VercelProviderRuntime=void 0;var ur=N(()=>{l();se();yn=10,hn=50,exports.VercelProviderRuntime=class{config;constructor(e){this.config=e;}async query(e,t){return this._run(e,"query",t)}async execute(e,t){return this._run(e,"execute",t)}async _run(e,t,r){let{generateText:n,tool:s}=await import('ai'),i=this.convertTools(r?.tools??[],s),a=this.createModel(r?.model),d=Math.min(r?.maxSteps??this.config.maxSteps??yn,hn);try{let c=0,u=await n({model:a,system:r?.systemPrompt??void 0,prompt:e,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens},onStepFinish:g=>{if(c++,!!r?.onOutput){if(g.toolCalls&&g.toolCalls.length>0)for(let p of g.toolCalls)r.onOutput(JSON.stringify({type:"assistant",message:{content:[{type:"tool_use",id:p.toolCallId,name:p.toolName,input:p.args}]}}),"stdout");if(g.toolResults&&g.toolResults.length>0)for(let p of g.toolResults){let y=typeof p.result=="string"?p.result:JSON.stringify(p.result);r.onOutput(JSON.stringify({type:"user",message:{content:[{type:"tool_result",tool_use_id:p.toolCallId,output:y,is_error:!1}]}}),"stdout");}}}}),m=new Set((r?.tools??[]).filter(g=>!g.execute).map(g=>g.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let g=u.toolCalls.filter(p=>m.has(p.toolName));if(g.length>0){let p=g[0];throw new exports.ClientToolCallRequiredError({toolCallId:p.toolCallId,toolName:p.toolName,args:p.args},{userMessage:e,responseMessages:u.response?.messages??[],toolDefinitions:r?.tools??[],maxSteps:d,systemPrompt:r?.systemPrompt,modelOverride:r?.model})}}if(r?.onUsage&&u.usage){let g={inputTokens:u.usage.promptTokens??0,outputTokens:u.usage.completionTokens??0,cachedInputTokens:0,costUsd:0};r.onUsage(g);}return r?.onModel&&r.onModel(r.model??this.config.model),u.text??""}catch(c){throw c instanceof exports.ClientToolCallRequiredError?c:c.status===401?new exports.ProviderError(`Authentication failed for ${this.config.provider}. Check your API key.`,this.config.provider):c.status===429?new exports.ProviderError(`Rate limit exceeded for ${this.config.provider}.`,this.config.provider):new exports.ProviderError(`Provider error: ${c.message}`,this.config.provider)}}async continueWithToolResults(e,t,r){let{generateText:n,tool:s}=await import('ai'),i=this.convertTools(e.toolDefinitions,s),a=this.createModel(e.modelOverride),d=Math.min(e.maxSteps??this.config.maxSteps??yn,hn),c=[{role:"user",content:e.userMessage},...e.responseMessages,{role:"tool",content:t.map(u=>({type:"tool-result",toolCallId:u.toolCallId,toolName:u.toolName,result:typeof u.result=="string"?u.result:JSON.stringify(u.result)}))}];try{let u=await n({model:a,system:e.systemPrompt??void 0,messages:c,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens}}),m=new Set(e.toolDefinitions.filter(g=>!g.execute).map(g=>g.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let g=u.toolCalls.filter(p=>m.has(p.toolName));if(g.length>0){let p=g[0];throw new exports.ClientToolCallRequiredError({toolCallId:p.toolCallId,toolName:p.toolName,args:p.args},{userMessage:e.userMessage,responseMessages:[...e.responseMessages,{role:"tool",content:t.map(y=>({type:"tool-result",toolCallId:y.toolCallId,toolName:y.toolName,result:typeof y.result=="string"?y.result:JSON.stringify(y.result)}))},...u.response?.messages??[]],toolDefinitions:e.toolDefinitions,maxSteps:e.maxSteps,systemPrompt:e.systemPrompt,modelOverride:e.modelOverride})}}return r?.onUsage&&u.usage&&r.onUsage({inputTokens:u.usage.promptTokens??0,outputTokens:u.usage.completionTokens??0,cachedInputTokens:0,costUsd:0}),r?.onModel&&r.onModel(e.modelOverride??this.config.model),u.text??""}catch(u){throw u instanceof exports.ClientToolCallRequiredError?u:new exports.ProviderError(`Provider error: ${u.message}`,this.config.provider)}}convertTools(e,t){let{z:r}=W("zod"),n={};for(let s of e){let i=this.jsonSchemaToZod(s.parameters??{},r);s.execute?n[s.name]=t({description:s.description,parameters:i,execute:async a=>s.execute(a)}):n[s.name]=t({description:s.description,parameters:i});}return n}jsonSchemaToZod(e,t){if(!e||!e.properties)return t.object({});let r={},n=e.properties,s=e.required??[];for(let[i,a]of Object.entries(n)){let d;switch(a.type){case "string":d=t.string();break;case "number":d=t.number();break;case "integer":d=t.number().int();break;case "boolean":d=t.boolean();break;case "array":d=t.array(t.any());break;default:d=t.any();}a.description&&(d=d.describe(a.description)),s.includes(i)||(d=d.optional()),r[i]=d;}return t.object(r)}createModel(e){let{provider:t,apiKey:r,baseURL:n}=this.config,s=e||this.config.model;switch(t){case "api/openrouter":{let{createOpenAI:i}=W("@ai-sdk/openai");return i({apiKey:r||process.env.OPENROUTER_API_KEY,baseURL:n||"https://openrouter.ai/api/v1"})(s)}case "api/openai":{let{createOpenAI:i}=W("@ai-sdk/openai");return i({apiKey:r||process.env.OPENAI_API_KEY,...n&&{baseURL:n}})(s)}case "api/anthropic":{let{createAnthropic:i}=W("@ai-sdk/anthropic");return i({apiKey:r||process.env.ANTHROPIC_API_KEY,...n&&{baseURL:n}})(s)}case "api/google":{let{createGoogleGenerativeAI:i}=W("@ai-sdk/google");return i({apiKey:r||process.env.GOOGLE_API_KEY})(s)}default:throw new exports.ProviderError(`Unsupported API provider: ${t}`,t)}}};});var xn={};lt(xn,{registerApiProviders:()=>wn});function wn(o){le("api",(e,t)=>{let r=o?.apiKeys?.[e];return new exports.VercelProviderRuntime({provider:t,model:"",apiKey:r,maxSteps:o?.defaults?.maxSteps,temperature:o?.defaults?.temperature})});}var pr=N(()=>{l();se();ur();});function gr(o){let e=o.update;if(e.sessionUpdate==="agent_message_chunk"){let t=e.content;if(t.type==="text"&&typeof t.text=="string")return t.text}return null}function ne(o,e){try{let t=JSON.parse(o);if(t!=null&&typeof t=="object"&&typeof t.type=="string"&&bs.has(t.type)){let r=e??new Date().toISOString();return [{...t,timestamp:t.timestamp||r}]}}catch{}return []}var bs,he=N(()=>{l();bs=new Set(["text","tool_use","tool_result","error","agent_call"]);});exports.AcpProtocolError=void 0;var mr=N(()=>{l();exports.AcpProtocolError=class extends Error{constructor(t,r,n){super(t);this.code=r;this.data=n;}code;data;name="AcpProtocolError"};});var Is,Os,kn,vn,Ms;exports.AcpConnection=void 0;var Rt=N(()=>{l();mr();se();Is=-32e3,Os=2e3,kn=3e4,vn=1e4,Ms=8*36e5,exports.AcpConnection=class{constructor(e){this.options=e;}options;proc=null;sdkConnection=null;disposed=false;stderrBuffer="";collectedStderr="";pendingUpdateCallback=null;authMethods=[];_initResponse=null;get initResponse(){return this._initResponse}async connect(e){if(this.disposed)throw new exports.ProviderError("AcpConnection has been disposed","acp");let t=this.options.spawn,r=process.platform==="win32"&&(t.shellOnWindows??true),n=child_process.spawn(t.command,t.args,{stdio:["pipe","pipe","pipe"],env:{...process.env,...this.options.env??{}},cwd:this.options.cwd,shell:r,windowsHide:true,detached:process.platform!=="win32"});n.pid!==void 0&&this.options.onPid?.(n.pid),n.stderr.on("data",p=>{let y=p.toString();this.collectedStderr+=y,this.stderrBuffer+=y;let x=this.stderrBuffer.split(`
29
- `);this.stderrBuffer=x.pop()??"";for(let w of x)w.trim()&&this.options.onStderr?.(w);}),this.proc=n;let s=new WritableStream({write:p=>new Promise((y,x)=>{n.stdin.write(p,w=>{w?x(w):y();});}),close:()=>{n.stdin.end();}}),i=new ReadableStream({start:p=>{n.stdout.on("data",y=>{p.enqueue(new Uint8Array(y));}),n.stdout.on("end",()=>{p.close();}),n.stdout.on("error",y=>{p.error(y);});}}),a=sdk.ndJsonStream(s,i),d=this,c=new sdk.ClientSideConnection(p=>({requestPermission:async y=>{if(d.options.configOptions?.allow_all!==void 0){let x=y.options;if(Array.isArray(x)&&x.length>0)return {outcome:{outcome:"selected",optionId:(x.find(_=>_.kind==="allow_once")??x.find(_=>_.kind?.startsWith("allow_"))??x[0]).optionId}}}return {outcome:{outcome:"cancelled"}}},sessionUpdate:async y=>{d.pendingUpdateCallback?.(y);}}),a);this.sdkConnection=c;let u=new Promise((p,y)=>{n.on("error",x=>{if(x.code==="ENOENT"){let _=t.command==="npx"&&t.args.length>0?`@agentclientprotocol/${t.args[0]}`:t.command;y(new exports.ProviderError(`ACP command "${t.command}" not found. Is the ACP adapter installed? Try: npm install -g ${_}`,"acp"));}else y(new exports.ProviderError(`ACP spawn error: ${x.message}`,"acp"));});}),m=this.doInitialize(c,e),g=new Promise((p,y)=>{setTimeout(()=>{y(new exports.AcpProtocolError(`ACP connect timeout after ${kn}ms. The ACP adapter may not be installed or may require interactive setup.`));},kn).unref();});await Promise.race([m,g,u]);}async doInitialize(e,t){let r=await e.initialize({protocolVersion:1,clientCapabilities:{auth:{}},clientInfo:{name:t?.name??"crewx-sdk",version:t?.version??"0.8.4"}});this._initResponse=r,this.authMethods=r.authMethods??[];}async newSession(e){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");try{return await this.newSessionWithTimeout(e)}catch(t){if(!this.isAuthError(t))throw t;return await this.tryAuthenticate(),this.newSessionWithTimeout(e)}}async newSessionWithTimeout(e){return (await this.newSessionRawTimeout(e)).sessionId}async newSessionRaw(e){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");try{return await this.newSessionRawTimeout(e)}catch(t){if(!this.isAuthError(t))throw t;return await this.tryAuthenticate(),this.newSessionRawTimeout(e)}}async newSessionRawTimeout(e){let t=this.sdkConnection.newSession(e),r=new Promise((n,s)=>{setTimeout(()=>{s(new exports.AcpProtocolError(`ACP session/new timeout after ${vn}ms`));},vn).unref();});return Promise.race([t,r])}isAuthError(e){return typeof e=="object"&&e!==null&&"code"in e&&e.code===Is}async tryAuthenticate(){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected.","acp");let e=this.authMethods.find(r=>r.type==="env_var"&&this.hasEnvVarsFor(r));if(e){await this.sdkConnection.authenticate({methodId:e.id});return}let t=this.authMethods.map(r=>`${r.id} (${r.type??"agent"})`).join(", ");if(this.authMethods.length>0){let r=this.authMethods.filter(n=>n.type==="env_var");if(r.length>0){let n=r.flatMap(s=>(s.vars??[]).filter(i=>!i.optional&&!process.env[i.name]).map(i=>i.name));throw new exports.AcpProtocolError(`ACP authentication required. Missing environment variables: ${n.join(", ")}. Set them in your shell or crewx.yaml env block.`)}throw new exports.AcpProtocolError(`ACP authentication required but no supported method found. Available methods: ${t}. CrewX currently supports env_var authentication only.`)}throw new exports.AcpProtocolError("ACP agent requires authentication but advertised no auth methods.")}hasEnvVarsFor(e){return !e.vars||e.vars.length===0?true:e.vars.filter(t=>!t.optional).every(t=>!!process.env[t.name])}async setModel(e,t){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.unstable_setSessionModel({sessionId:e,modelId:t});}async setMode(e,t){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.setSessionMode({sessionId:e,modeId:t});}async setConfigOption(e,t,r){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.setSessionConfigOption({sessionId:e,configId:t,value:r});}async prompt(e,t,r,n){if(!this.sdkConnection||!this.proc)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");this.pendingUpdateCallback=r??null;let s=this.sdkConnection,i=this.proc,a=n??Ms,d=false,c=s.prompt({sessionId:e,prompt:t}).finally(()=>{d=true;}),u=new Promise((g,p)=>{setTimeout(()=>{s.cancel({sessionId:e}).catch(()=>{}),p(new Ve(`ACP prompt timeout after ${a}ms`,"acp"));},a).unref();}),m=new Promise((g,p)=>{let y=(v,R,I)=>{if(d)return;let b=R!=null?`signal=${R}`:`code=${String(v)}`;p(new exports.ProviderError(`ACP process terminated unexpectedly (${b}) [${I}]: ${this.collectedStderr.slice(-500)}`,"acp"));},x=(v,R)=>y(v,R,"exit"),w=(v,R)=>y(v,R,"close");i.once("exit",x),i.once("close",w);let _=()=>{i.off("exit",x),i.off("close",w);};c.then(_,_);});try{return await Promise.race([c,u,m])}finally{this.pendingUpdateCallback=null;}}async dispose(){if(this.disposed)return;this.disposed=true,this.pendingUpdateCallback=null,this.sdkConnection=null;let e=this.proc;if(!e)return;this.proc=null,this.stderrBuffer.trim()&&(this.options.onStderr?.(this.stderrBuffer),this.stderrBuffer="");let t=e.pid,r=n=>{if(t!==void 0&&process.platform!=="win32")try{process.kill(-t,n);}catch{}else try{e.kill(n);}catch{}};await new Promise(n=>{let s=()=>{clearTimeout(i),n();};e.once("close",s),e.once("error",s);try{r("SIGTERM");}catch{s();return}let i=setTimeout(()=>{r("SIGKILL");},Os);});}get isConnected(){return !this.disposed&&this.sdkConnection!==null&&this.proc!==null}};});function _n(o,e){if(o!=null&&typeof o=="object"){let t=o;if(typeof t.command=="string")return t.command;if(typeof t.file_path=="string")return t.file_path;if(typeof t.filePath=="string")return t.filePath;if(typeof t.path=="string")return t.path;if(typeof t.query=="string")return t.query;if(typeof t.pattern=="string")return t.pattern;if(typeof t.url=="string")return t.url;if(Object.keys(t).length>0)return JSON.stringify(t)}if(e&&e.length>0)return e.map(t=>t.path).join(", ")}var Ns;exports.AcpProviderRuntime=void 0;var fr=N(()=>{l();he();Rt();Ns={read:"Read",edit:"Edit",delete:"Delete",move:"Move",search:"Search",execute:"Bash",think:"Think",fetch:"WebFetch",switch_mode:"SwitchMode"};exports.AcpProviderRuntime=class{constructor(e,t,r){this.adapter=t;}adapter;async query(e,t){return this.runPrompt(e,t)}async execute(e,t){return this.runPrompt(e,t)}async dispose(){}async runPrompt(e,t){let{command:r,args:n}=this.adapter.spawn;t?.onCommand?.(`${r} ${n.join(" ")}`);let s=this.adapter.buildSpawnEnv?.(t?.model??""),i=s?{...t?.env,...s}:t?.env,a=new exports.AcpConnection({spawn:this.adapter.spawn,env:i,cwd:t?.cwd,timeoutMs:t?.timeoutMs,onPid:t?.onPid,onStderr:d=>t?.onOutput?.(d,"stderr"),configOptions:t?.configOptions});try{await a.connect(this.adapter.clientInfo);let d=this.adapter.buildSessionParams({cwd:t?.cwd,env:t?.env,model:t?.model,systemPrompt:t?.systemPrompt}),c=await a.newSession(d);await this.applySessionOptions(a,c,t);let u=this.composePrompt(e,t),m=[],g=await a.prompt(c,u,p=>this.handleUpdate(p,t,m),t?.timeoutMs);return this.handleUsage(g,t),m.join("")}finally{await a.dispose().catch(()=>{});}}async applySessionOptions(e,t,r){if(r?.model&&r.model!=="default"&&!this.adapter.buildSpawnEnv){let n=this.adapter.buildEffortAction?.(r.effort??"",r.model);try{n?.type==="set_model"?await e.setModel(t,n.modelId):await e.setModel(t,r.model);}catch(s){console.warn(`[acp] setModel(${r.model}) failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.mode){let n=this.adapter.resolveMode?.(r.mode)??r.mode;if(n)try{await e.setMode(t,n);}catch(s){console.warn(`[acp] setMode(${n}) failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.effort){let n=this.adapter.buildEffortAction?.(r.effort,r.model);if(n&&n.type==="set_config_option")try{await e.setConfigOption(t,n.configId,n.value);}catch(s){console.warn(`[acp] setConfigOption(${n.configId}) effort failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.configOptions)for(let[n,s]of Object.entries(r.configOptions))try{await e.setConfigOption(t,n,s);}catch(i){console.warn(`[acp] setConfigOption(${n}) failed, retrying: ${i instanceof Error?i.message:String(i)}`);try{await new Promise(a=>setTimeout(a,500)),await e.setConfigOption(t,n,s);}catch(a){console.warn(`[acp] setConfigOption(${n}) retry failed: ${a instanceof Error?a.message:String(a)}`);}}}composePrompt(e,t){let r=[];return t?.systemPrompt?.trim()&&(r.push(t.systemPrompt),r.push("---")),t?.context&&(r.push(t.context),r.push("---")),r.push(e),[{type:"text",text:r.join(`
28
+ ${e}`:e}async runProcess(e,t,r){try{return await Gr(this.adapter.command,e,this.providerStr,this.providerId,t,r,this.adapter)}catch(n){if(Bo(this.providerId,n)){let s=e[0]==="copilot"?e:["copilot",...e];return Gr("gh",s,this.providerStr,this.providerId,t,r,this.adapter)}throw n}}handleResultMeta(e,t){if(!this.adapter.parseResultMeta){let i=qo(e);i&&t?.onUsage&&t.onUsage(i);return}let{usage:r,model:n}=this.adapter.parseResultMeta(e);r&&t?.onUsage&&t.onUsage(r);let s=n??(this.providerId==="opencode"?t?.model??null:null);s&&t?.onModel&&t.onModel(s);}};});var xn,kn;exports.VercelProviderRuntime=void 0;var mr=N(()=>{l();ae();xn=10,kn=50,exports.VercelProviderRuntime=class{config;constructor(e){this.config=e;}async query(e,t){return this._run(e,"query",t)}async execute(e,t){return this._run(e,"execute",t)}async _run(e,t,r){let{generateText:n,tool:s}=await import('ai'),i=this.convertTools(r?.tools??[],s),a=this.createModel(r?.model),d=Math.min(r?.maxSteps??this.config.maxSteps??xn,kn);try{let c=0,u=await n({model:a,system:r?.systemPrompt??void 0,prompt:e,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens},onStepFinish:f=>{if(c++,!!r?.onOutput){if(f.toolCalls&&f.toolCalls.length>0)for(let p of f.toolCalls)r.onOutput(JSON.stringify({type:"assistant",message:{content:[{type:"tool_use",id:p.toolCallId,name:p.toolName,input:p.args}]}}),"stdout");if(f.toolResults&&f.toolResults.length>0)for(let p of f.toolResults){let m=typeof p.result=="string"?p.result:JSON.stringify(p.result);r.onOutput(JSON.stringify({type:"user",message:{content:[{type:"tool_result",tool_use_id:p.toolCallId,output:m,is_error:!1}]}}),"stdout");}}}}),g=new Set((r?.tools??[]).filter(f=>!f.execute).map(f=>f.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let f=u.toolCalls.filter(p=>g.has(p.toolName));if(f.length>0){let p=f[0];throw new exports.ClientToolCallRequiredError({toolCallId:p.toolCallId,toolName:p.toolName,args:p.args},{userMessage:e,responseMessages:u.response?.messages??[],toolDefinitions:r?.tools??[],maxSteps:d,systemPrompt:r?.systemPrompt,modelOverride:r?.model})}}if(r?.onUsage&&u.usage){let f={inputTokens:u.usage.promptTokens??0,outputTokens:u.usage.completionTokens??0,cachedInputTokens:0,costUsd:0};r.onUsage(f);}return r?.onModel&&r.onModel(r.model??this.config.model),u.text??""}catch(c){throw c instanceof exports.ClientToolCallRequiredError?c:c.status===401?new exports.ProviderError(`Authentication failed for ${this.config.provider}. Check your API key.`,this.config.provider):c.status===429?new exports.ProviderError(`Rate limit exceeded for ${this.config.provider}.`,this.config.provider):new exports.ProviderError(`Provider error: ${c.message}`,this.config.provider)}}async continueWithToolResults(e,t,r){let{generateText:n,tool:s}=await import('ai'),i=this.convertTools(e.toolDefinitions,s),a=this.createModel(e.modelOverride),d=Math.min(e.maxSteps??this.config.maxSteps??xn,kn),c=[{role:"user",content:e.userMessage},...e.responseMessages,{role:"tool",content:t.map(u=>({type:"tool-result",toolCallId:u.toolCallId,toolName:u.toolName,result:typeof u.result=="string"?u.result:JSON.stringify(u.result)}))}];try{let u=await n({model:a,system:e.systemPrompt??void 0,messages:c,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens}}),g=new Set(e.toolDefinitions.filter(f=>!f.execute).map(f=>f.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let f=u.toolCalls.filter(p=>g.has(p.toolName));if(f.length>0){let p=f[0];throw new exports.ClientToolCallRequiredError({toolCallId:p.toolCallId,toolName:p.toolName,args:p.args},{userMessage:e.userMessage,responseMessages:[...e.responseMessages,{role:"tool",content:t.map(m=>({type:"tool-result",toolCallId:m.toolCallId,toolName:m.toolName,result:typeof m.result=="string"?m.result:JSON.stringify(m.result)}))},...u.response?.messages??[]],toolDefinitions:e.toolDefinitions,maxSteps:e.maxSteps,systemPrompt:e.systemPrompt,modelOverride:e.modelOverride})}}return r?.onUsage&&u.usage&&r.onUsage({inputTokens:u.usage.promptTokens??0,outputTokens:u.usage.completionTokens??0,cachedInputTokens:0,costUsd:0}),r?.onModel&&r.onModel(e.modelOverride??this.config.model),u.text??""}catch(u){throw u instanceof exports.ClientToolCallRequiredError?u:new exports.ProviderError(`Provider error: ${u.message}`,this.config.provider)}}convertTools(e,t){let{z:r}=z("zod"),n={};for(let s of e){let i=this.jsonSchemaToZod(s.parameters??{},r);s.execute?n[s.name]=t({description:s.description,parameters:i,execute:async a=>s.execute(a)}):n[s.name]=t({description:s.description,parameters:i});}return n}jsonSchemaToZod(e,t){if(!e||!e.properties)return t.object({});let r={},n=e.properties,s=e.required??[];for(let[i,a]of Object.entries(n)){let d;switch(a.type){case "string":d=t.string();break;case "number":d=t.number();break;case "integer":d=t.number().int();break;case "boolean":d=t.boolean();break;case "array":d=t.array(t.any());break;default:d=t.any();}a.description&&(d=d.describe(a.description)),s.includes(i)||(d=d.optional()),r[i]=d;}return t.object(r)}createModel(e){let{provider:t,apiKey:r,baseURL:n}=this.config,s=e||this.config.model;switch(t){case "api/openrouter":{let{createOpenAI:i}=z("@ai-sdk/openai");return i({apiKey:r||process.env.OPENROUTER_API_KEY,baseURL:n||"https://openrouter.ai/api/v1"})(s)}case "api/openai":{let{createOpenAI:i}=z("@ai-sdk/openai");return i({apiKey:r||process.env.OPENAI_API_KEY,...n&&{baseURL:n}})(s)}case "api/anthropic":{let{createAnthropic:i}=z("@ai-sdk/anthropic");return i({apiKey:r||process.env.ANTHROPIC_API_KEY,...n&&{baseURL:n}})(s)}case "api/google":{let{createGoogleGenerativeAI:i}=z("@ai-sdk/google");return i({apiKey:r||process.env.GOOGLE_API_KEY})(s)}default:throw new exports.ProviderError(`Unsupported API provider: ${t}`,t)}}};});var _n={};ct(_n,{registerApiProviders:()=>vn});function vn(o){ue("api",(e,t)=>{let r=o?.apiKeys?.[e];return new exports.VercelProviderRuntime({provider:t,model:"",apiKey:r,maxSteps:o?.defaults?.maxSteps,temperature:o?.defaults?.temperature})});}var fr=N(()=>{l();ae();mr();});function yr(o){let e=o.update;if(e.sessionUpdate==="agent_message_chunk"){let t=e.content;if(t.type==="text"&&typeof t.text=="string")return t.text}return null}function se(o,e){try{let t=JSON.parse(o);if(t!=null&&typeof t=="object"&&typeof t.type=="string"&&Is.has(t.type)){let r=e??new Date().toISOString();return [{...t,timestamp:t.timestamp||r}]}}catch{}return []}var Is,xe=N(()=>{l();Is=new Set(["text","tool_use","tool_result","error","agent_call"]);});exports.AcpProtocolError=void 0;var hr=N(()=>{l();exports.AcpProtocolError=class extends Error{constructor(t,r,n){super(t);this.code=r;this.data=n;}code;data;name="AcpProtocolError"};});var Ds,Ls,An,Rn,$s;exports.AcpConnection=void 0;var Rt=N(()=>{l();hr();ae();Ds=-32e3,Ls=2e3,An=3e4,Rn=1e4,$s=8*36e5,exports.AcpConnection=class{constructor(e){this.options=e;}options;proc=null;sdkConnection=null;disposed=false;stderrBuffer="";collectedStderr="";pendingUpdateCallback=null;authMethods=[];_initResponse=null;get initResponse(){return this._initResponse}async connect(e){if(this.disposed)throw new exports.ProviderError("AcpConnection has been disposed","acp");let t=this.options.spawn,r=process.platform==="win32"&&(t.shellOnWindows??true),n=child_process.spawn(t.command,t.args,{stdio:["pipe","pipe","pipe"],env:{...process.env,...this.options.env??{}},cwd:this.options.cwd,shell:r,windowsHide:true,detached:process.platform!=="win32"});n.pid!==void 0&&this.options.onPid?.(n.pid),n.stderr.on("data",p=>{let m=p.toString();this.collectedStderr+=m,this.stderrBuffer+=m;let w=this.stderrBuffer.split(`
29
+ `);this.stderrBuffer=w.pop()??"";for(let A of w)A.trim()&&this.options.onStderr?.(A);}),this.proc=n;let s=new WritableStream({write:p=>new Promise((m,w)=>{n.stdin.write(p,A=>{A?w(A):m();});}),close:()=>{n.stdin.end();}}),i=new ReadableStream({start:p=>{n.stdout.on("data",m=>{p.enqueue(new Uint8Array(m));}),n.stdout.on("end",()=>{p.close();}),n.stdout.on("error",m=>{p.error(m);});}}),a=sdk.ndJsonStream(s,i),d=this,c=new sdk.ClientSideConnection(p=>({requestPermission:async m=>{if(d.options.configOptions?.allow_all!==void 0){let w=m.options;if(Array.isArray(w)&&w.length>0)return {outcome:{outcome:"selected",optionId:(w.find(v=>v.kind==="allow_once")??w.find(v=>v.kind?.startsWith("allow_"))??w[0]).optionId}}}return {outcome:{outcome:"cancelled"}}},sessionUpdate:async m=>{d.pendingUpdateCallback?.(m);}}),a);this.sdkConnection=c;let u=new Promise((p,m)=>{n.on("error",w=>{if(w.code==="ENOENT"){let v=t.command==="npx"&&t.args.length>0?`@agentclientprotocol/${t.args[0]}`:t.command;m(new exports.ProviderError(`ACP command "${t.command}" not found. Is the ACP adapter installed? Try: npm install -g ${v}`,"acp"));}else m(new exports.ProviderError(`ACP spawn error: ${w.message}`,"acp"));});}),g=this.doInitialize(c,e),f=new Promise((p,m)=>{setTimeout(()=>{m(new exports.AcpProtocolError(`ACP connect timeout after ${An}ms. The ACP adapter may not be installed or may require interactive setup.`));},An).unref();});await Promise.race([g,f,u]);}async doInitialize(e,t){let r=await e.initialize({protocolVersion:1,clientCapabilities:{auth:{}},clientInfo:{name:t?.name??"crewx-sdk",version:t?.version??"0.8.4"}});this._initResponse=r,this.authMethods=r.authMethods??[];}async newSession(e){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");try{return await this.newSessionWithTimeout(e)}catch(t){if(!this.isAuthError(t))throw t;return await this.tryAuthenticate(),this.newSessionWithTimeout(e)}}async newSessionWithTimeout(e){return (await this.newSessionRawTimeout(e)).sessionId}async newSessionRaw(e){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");try{return await this.newSessionRawTimeout(e)}catch(t){if(!this.isAuthError(t))throw t;return await this.tryAuthenticate(),this.newSessionRawTimeout(e)}}async newSessionRawTimeout(e){let t=this.sdkConnection.newSession(e),r=new Promise((n,s)=>{setTimeout(()=>{s(new exports.AcpProtocolError(`ACP session/new timeout after ${Rn}ms`));},Rn).unref();});return Promise.race([t,r])}isAuthError(e){return typeof e=="object"&&e!==null&&"code"in e&&e.code===Ds}async tryAuthenticate(){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected.","acp");let e=this.authMethods.find(r=>r.type==="env_var"&&this.hasEnvVarsFor(r));if(e){await this.sdkConnection.authenticate({methodId:e.id});return}let t=this.authMethods.map(r=>`${r.id} (${r.type??"agent"})`).join(", ");if(this.authMethods.length>0){let r=this.authMethods.filter(n=>n.type==="env_var");if(r.length>0){let n=r.flatMap(s=>(s.vars??[]).filter(i=>!i.optional&&!process.env[i.name]).map(i=>i.name));throw new exports.AcpProtocolError(`ACP authentication required. Missing environment variables: ${n.join(", ")}. Set them in your shell or crewx.yaml env block.`)}throw new exports.AcpProtocolError(`ACP authentication required but no supported method found. Available methods: ${t}. CrewX currently supports env_var authentication only.`)}throw new exports.AcpProtocolError("ACP agent requires authentication but advertised no auth methods.")}hasEnvVarsFor(e){return !e.vars||e.vars.length===0?true:e.vars.filter(t=>!t.optional).every(t=>!!process.env[t.name])}async setModel(e,t){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.unstable_setSessionModel({sessionId:e,modelId:t});}async setMode(e,t){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.setSessionMode({sessionId:e,modeId:t});}async setConfigOption(e,t,r){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.setSessionConfigOption({sessionId:e,configId:t,value:r});}async prompt(e,t,r,n){if(!this.sdkConnection||!this.proc)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");this.pendingUpdateCallback=r??null;let s=this.sdkConnection,i=this.proc,a=n??$s,d=false,c=s.prompt({sessionId:e,prompt:t}).finally(()=>{d=true;}),u=new Promise((f,p)=>{setTimeout(()=>{s.cancel({sessionId:e}).catch(()=>{}),p(new Ke(`ACP prompt timeout after ${a}ms`,"acp"));},a).unref();}),g=new Promise((f,p)=>{let m=(k,x,S)=>{if(d)return;let T=x!=null?`signal=${x}`:`code=${String(k)}`;p(new exports.ProviderError(`ACP process terminated unexpectedly (${T}) [${S}]: ${this.collectedStderr.slice(-500)}`,"acp"));},w=(k,x)=>m(k,x,"exit"),A=(k,x)=>m(k,x,"close");i.once("exit",w),i.once("close",A);let v=()=>{i.off("exit",w),i.off("close",A);};c.then(v,v);});try{return await Promise.race([c,u,g])}finally{this.pendingUpdateCallback=null;}}async dispose(){if(this.disposed)return;this.disposed=true,this.pendingUpdateCallback=null,this.sdkConnection=null;let e=this.proc;if(!e)return;this.proc=null,this.stderrBuffer.trim()&&(this.options.onStderr?.(this.stderrBuffer),this.stderrBuffer="");let t=e.pid,r=n=>{if(t!==void 0&&process.platform!=="win32")try{process.kill(-t,n);}catch{}else try{e.kill(n);}catch{}};await new Promise(n=>{let s=()=>{clearTimeout(i),n();};e.once("close",s),e.once("error",s);try{r("SIGTERM");}catch{s();return}let i=setTimeout(()=>{r("SIGKILL");},Ls);});}get isConnected(){return !this.disposed&&this.sdkConnection!==null&&this.proc!==null}};});function Pn(o,e){if(o!=null&&typeof o=="object"){let t=o;if(typeof t.command=="string")return t.command;if(typeof t.file_path=="string")return t.file_path;if(typeof t.filePath=="string")return t.filePath;if(typeof t.path=="string")return t.path;if(typeof t.query=="string")return t.query;if(typeof t.pattern=="string")return t.pattern;if(typeof t.url=="string")return t.url;if(Object.keys(t).length>0)return JSON.stringify(t)}if(e&&e.length>0)return e.map(t=>t.path).join(", ")}var js;exports.AcpProviderRuntime=void 0;var wr=N(()=>{l();xe();Rt();js={read:"Read",edit:"Edit",delete:"Delete",move:"Move",search:"Search",execute:"Bash",think:"Think",fetch:"WebFetch",switch_mode:"SwitchMode"};exports.AcpProviderRuntime=class{constructor(e,t,r){this.adapter=t;}adapter;async query(e,t){return this.runPrompt(e,t)}async execute(e,t){return this.runPrompt(e,t)}async dispose(){}async runPrompt(e,t){let{command:r,args:n}=this.adapter.spawn;t?.onCommand?.(`${r} ${n.join(" ")}`);let s=this.adapter.buildSpawnEnv?.(t?.model??""),i=s?{...t?.env,...s}:t?.env,a=new exports.AcpConnection({spawn:this.adapter.spawn,env:i,cwd:t?.cwd,timeoutMs:t?.timeoutMs,onPid:t?.onPid,onStderr:d=>t?.onOutput?.(d,"stderr"),configOptions:t?.configOptions});try{await a.connect(this.adapter.clientInfo);let d=this.adapter.buildSessionParams({cwd:t?.cwd,env:t?.env,model:t?.model,systemPrompt:t?.systemPrompt}),c=await a.newSession(d);await this.applySessionOptions(a,c,t);let u=this.composePrompt(e,t),g=[],f=await a.prompt(c,u,p=>this.handleUpdate(p,t,g),t?.timeoutMs);return this.handleUsage(f,t),g.join("")}finally{await a.dispose().catch(()=>{});}}async applySessionOptions(e,t,r){if(r?.model&&r.model!=="default"&&!this.adapter.buildSpawnEnv){let n=this.adapter.buildEffortAction?.(r.effort??"",r.model);try{n?.type==="set_model"?await e.setModel(t,n.modelId):await e.setModel(t,r.model);}catch(s){console.warn(`[acp] setModel(${r.model}) failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.mode){let n=this.adapter.resolveMode?.(r.mode)??r.mode;if(n)try{await e.setMode(t,n);}catch(s){console.warn(`[acp] setMode(${n}) failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.effort){let n=this.adapter.buildEffortAction?.(r.effort,r.model);if(n&&n.type==="set_config_option")try{await e.setConfigOption(t,n.configId,n.value);}catch(s){console.warn(`[acp] setConfigOption(${n.configId}) effort failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.configOptions)for(let[n,s]of Object.entries(r.configOptions))try{await e.setConfigOption(t,n,s);}catch(i){console.warn(`[acp] setConfigOption(${n}) failed, retrying: ${i instanceof Error?i.message:String(i)}`);try{await new Promise(a=>setTimeout(a,500)),await e.setConfigOption(t,n,s);}catch(a){console.warn(`[acp] setConfigOption(${n}) retry failed: ${a instanceof Error?a.message:String(a)}`);}}}composePrompt(e,t){let r=[];return t?.systemPrompt?.trim()&&(r.push(t.systemPrompt),r.push("---")),t?.context&&(r.push(t.context),r.push("---")),r.push(e),[{type:"text",text:r.join(`
30
30
 
31
- `)}]}handleUpdate(e,t,r){let n=e.update;if(n.sessionUpdate==="agent_message_chunk"){let s=null;this.adapter.extractTextFromUpdate?s=this.adapter.extractTextFromUpdate(e):s=gr(e),s!==null&&(r.push(s),t?.onOutput?.(s,"stdout"));}else if(n.sessionUpdate==="tool_call"){let s=new Date().toISOString(),i=n,a={title:i.title??"",kind:i.kind,rawInput:i.rawInput,rawOutput:i.rawOutput,locations:i.locations,_meta:i._meta},d=this.resolveToolCall(a),c={timestamp:s,type:"tool_use",toolUseId:i.toolCallId,toolName:d.toolName,toolInput:d.toolInput};t?.onTaskLog?.([c]);}else if(n.sessionUpdate==="tool_call_update"){let s=new Date().toISOString(),i=n;if(i.status==="completed"||i.status==="failed"){let d=this.extractResultPreview(i.rawOutput),c={timestamp:s,type:"tool_result",toolUseId:i.toolCallId,resultPreview:d,isError:i.status==="failed"};t?.onTaskLog?.([c]);}else if(i.rawInput!=null&&typeof i.rawInput=="object"&&Object.keys(i.rawInput).length>0){let d={title:i.title??"",kind:i.kind,rawInput:i.rawInput,rawOutput:i.rawOutput,locations:i.locations,_meta:i._meta},c=this.resolveToolCall(d),u={timestamp:s,type:"tool_use",toolUseId:i.toolCallId,toolName:c.toolName,toolInput:c.toolInput};t?.onTaskLog?.([u]);}}else n.sessionUpdate;}resolveToolCall(e){let t=e._meta;if(t?.claudeCode?.toolName)return {toolName:t.claudeCode.toolName,toolInput:_n(e.rawInput,e.locations)??(e.title||void 0)};if(this.adapter.parseToolCall){let s=this.adapter.parseToolCall(e);if(s)return {toolName:s.toolName??e.title??"unknown",toolInput:s.toolInput}}let r=Ns[e.kind??""]??e.title??"unknown",n=_n(e.rawInput,e.locations)??(e.title||void 0);return {toolName:r,toolInput:n}}extractResultPreview(e){if(e!=null){if(typeof e=="string")return e;if(Array.isArray(e)){let t=e.filter(r=>r!=null&&typeof r=="object"&&r.type==="text"&&typeof r.text=="string").map(r=>r.text);if(t.length>0)return t.join(`
32
- `)}if(typeof e=="object"){let t=e;if(typeof t.formatted_output=="string")return t.formatted_output;if(typeof t.content=="string")return t.content;if(Array.isArray(t.content)){let r=this.extractResultPreview(t.content);if(r)return r}if(typeof t.output=="string")return t.output;if(typeof t.text=="string")return t.text;if(typeof t.message=="string")return t.message;if(t.result!=null){let r=this.extractResultPreview(t.result);if(r)return r}if(t.error!=null){let r=this.extractResultPreview(t.error);if(r)return r}}return JSON.stringify(e)}}handleUsage(e,t){if(!t?.onUsage)return;if(this.adapter.extractUsage){let n=this.adapter.extractUsage(e);if(n){t.onUsage(n);return}}let r=e.usage;r&&t.onUsage({inputTokens:r.inputTokens??0,outputTokens:r.outputTokens??0,cachedInputTokens:r.cachedReadTokens??0,costUsd:0});}};});var Rn;exports.claudeAcpAdapter=void 0;var Pt=N(()=>{l();he();Rn=[{id:"claude-opus-4-8[1m]",name:"Claude Opus 4.8 (Extended)"},{id:"claude-opus-4-8",name:"Claude Opus 4.8"},{id:"claude-opus-4-7[1m]",name:"Claude Opus 4.7 (Extended)"},{id:"claude-opus-4-7",name:"Claude Opus 4.7"},{id:"claude-opus-4-6[1m]",name:"Claude Opus 4.6 (Extended)"},{id:"claude-opus-4-6",name:"Claude Opus 4.6"},{id:"claude-sonnet-4-6[1m]",name:"Claude Sonnet 4.6 (Extended)"},{id:"claude-sonnet-4-6",name:"Claude Sonnet 4.6"},{id:"claude-haiku-4-5",name:"Claude Haiku 4.5"}],exports.claudeAcpAdapter={spawn:{command:"npx",args:["-y","@agentclientprotocol/claude-agent-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/claude-agent-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Claude",defaultMode:"default"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},extractUsage(o){let e=o.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"bypassPermissions",buildEffortAction(o){return o?{type:"set_config_option",configId:"effort",value:o}:null},buildSpawnEnv(o){if(!(!o||o==="default"))return {ANTHROPIC_MODEL:o}},resolveMode(o){return {yolo:"bypassPermissions"}[o]??o},parseEvent:ne};});exports.codexAcpAdapter=void 0;var yr=N(()=>{l();he();exports.codexAcpAdapter={spawn:{command:"npx",args:["-y","@agentclientprotocol/codex-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/codex-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Codex",defaultMode:"agent"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},extractUsage(o){let e=o.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"agent-full-access",buildEffortAction(o,e){if(!e)return null;let t=e.match(/^(.+?)\[([^\]]+)\]$/),r=t?t[1]:e,n=t?t[2]:void 0;return {type:"set_model",modelId:`${r}[${o||n||"medium"}]`}},resolveMode(o){return {yolo:"agent-full-access",default:"agent",plan:"read-only"}[o]??o},parseEvent:ne};});exports.geminiAcpAdapter=void 0;var hr=N(()=>{l();he();exports.geminiAcpAdapter={spawn:{command:"gemini",args:["--acp","--skip-trust"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Gemini"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},yoloModeId:"yolo",buildEffortAction(o){return null},resolveMode(o){return {acceptEdits:"autoEdit"}[o]??o},parseEvent:ne};});var Ue;exports.copilotAcpAdapter=void 0;var wr=N(()=>{l();he();Ue="https://agentclientprotocol.com/protocol/session-modes",exports.copilotAcpAdapter={spawn:{command:"copilot",args:["--acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"GitHub Copilot"},buildSessionParams(o){return {cwd:o.cwd?F.resolve(o.cwd):process.cwd(),mcpServers:[]}},yoloModeId:`${Ue}#autopilot`,buildEffortAction(o){return o?{type:"set_config_option",configId:"reasoning_effort",value:o}:null},resolveMode(o){return o.startsWith("https://")?o:{yolo:`${Ue}#autopilot`,default:`${Ue}#agent`,agent:`${Ue}#agent`,plan:`${Ue}#plan`,autopilot:`${Ue}#autopilot`}[o]??null},parseEvent:ne};});exports.opencodeAcpAdapter=void 0;var xr=N(()=>{l();he();exports.opencodeAcpAdapter={spawn:{command:"opencode",args:["acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"OpenCode"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},yoloModeId:void 0,buildEffortAction(o){return null},resolveMode(o){let e={default:"build"};return o==="yolo"?null:e[o]??o},parseEvent:ne};});exports.ACP_ADAPTERS=void 0;var St=N(()=>{l();Pt();yr();hr();wr();xr();Pt();yr();hr();wr();xr();exports.ACP_ADAPTERS={claude:exports.claudeAcpAdapter,codex:exports.codexAcpAdapter,gemini:exports.geminiAcpAdapter,copilot:exports.copilotAcpAdapter,opencode:exports.opencodeAcpAdapter};});var Pn={};lt(Pn,{registerAcpProviders:()=>An});function An(o){if(o){le("acp",o);return}le("acp",(e,t)=>{let r=exports.ACP_ADAPTERS[e];if(!r)throw new exports.ProviderError(`Unknown ACP provider id: "${e}". Supported: ${Object.keys(exports.ACP_ADAPTERS).join(", ")}`,t);return new exports.AcpProviderRuntime(e,r,t)});}var kr=N(()=>{l();se();fr();St();se();});function Ls(o){if(!o)return o;let e=o.trim().replace(/\/+$/,"");return e.toLowerCase().endsWith("/mcp")?e.slice(0,-4):e}exports.McpHttpTransport=void 0;var vr=N(()=>{l();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=Ls(e.url);this.endpoint=`${t}/mcp`,this.headers={"Content-Type":"application/json",...e.headers??{}},e.apiKey&&(this.headers.Authorization=`Bearer ${e.apiKey}`),this.timeoutMs=e.timeoutMs??3e4;}async send(e){let t=new AbortController,r=setTimeout(()=>t.abort(),this.timeoutMs);try{let n=await fetch(this.endpoint,{method:"POST",headers:this.headers,body:JSON.stringify(e),signal:t.signal});if(clearTimeout(r),!n.ok){let a=await n.text();throw new Error(`HTTP ${n.status}: ${n.statusText}${a?` - ${a}`:""}`)}let s=n.headers.get("content-type");if(s?.includes("application/json"))return await n.json();let i=await n.text();return {jsonrpc:"2.0",id:e.id,error:{code:-32600,message:`Unexpected response content-type: ${s}`,data:i}}}catch(n){throw clearTimeout(r),n instanceof Error&&n.name==="AbortError"?new Error(`MCP-HTTP request timeout after ${this.timeoutMs}ms to ${this.endpoint}`):n}}async close(){}};});exports.RemoteAgentManager=void 0;var _r=N(()=>{l();vr();exports.RemoteAgentManager=class{logger;configs=new Map;transports=new Map;constructor(e={}){this.logger=e.logger??(()=>{});}loadConfig(e,t){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,new exports.McpHttpTransport({url:t.url,apiKey:t.apiKey,headers:t.headers,timeoutMs:t.timeoutMs})),this.logger(`Loaded remote agent config for: ${e}`,"debug");}loadConfigWithTransport(e,t,r){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,r),this.logger(`Loaded remote agent config for: ${e} (custom transport)`,"debug");}getConfig(e){return this.configs.get(e)}isRemoteAgent(e){return this.configs.has(e)}getRemoteAgentIds(){return Array.from(this.configs.keys())}async query(e,t){let r=this.requireConfig(e),n=r.tools?.query??"crewx_queryAgent",i={agentId:r.agentId??e,query:t.query};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote query failed for agent ${e}: ${d}`,"error"),a}}async execute(e,t){let r=this.requireConfig(e),n=r.tools?.execute??"crewx_executeAgent",i={agentId:r.agentId??e,task:t.task};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote execute failed for agent ${e}: ${d}`,"error"),a}}mapToolNames(e,t){let r=this.requireConfig(e);r.tools={query:t.query??r.tools?.query??"crewx_queryAgent",execute:t.execute??r.tools?.execute??"crewx_executeAgent"},this.logger(`Updated tool name mapping for agent ${e}`,"debug");}async clearConfigs(){for(let e of this.transports.values())await e.close();this.configs.clear(),this.transports.clear(),this.logger("Cleared all remote agent configurations","debug");}requireConfig(e){let t=this.configs.get(e);if(!t)throw new Error(`Agent ${e} is not configured as a remote agent`);return t}async callRemoteTool(e,t,r){let n=this.transports.get(e);if(!n)throw new Error(`No transport available for agent ${e}`);let s={jsonrpc:"2.0",id:`${t}-${Date.now()}`,method:"tools/call",params:{name:t,arguments:r}};this.logger(`Calling remote MCP tool ${t} for agent ${e}`,"debug");let i=await n.send(s);if(i.error)throw new Error(i.error.message||"MCP server returned an error");return i.result}normalizeResponse(e){if(!e)return {success:false,content:[{type:"text",text:"Remote agent returned no response."}]};let t=e;if(Array.isArray(t.content)&&t.content.length>0)return t;let r=t.response??t.implementation??t.message??t.output,n=typeof r=="string"?r:JSON.stringify(r??e,null,2);return {...t,content:[{type:"text",text:n}]}}validateConfig(e){if(!e.url)throw new Error("Remote agent configuration requires a URL");if(!e.url.startsWith("http://")&&!e.url.startsWith("https://"))throw new Error("Remote agent URL must start with http:// or https://");if(e.type!=="mcp-http")throw new Error(`Unsupported remote agent type: ${e.type}`)}};});var bn={};lt(bn,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>Cn,resolveFileRemoteAgent:()=>Ws});function qs(o){let e=fs$1.readFileSync(o,"utf-8"),t=jsYaml.load(e);return {agents:Array.isArray(t?.agents)?t.agents:void 0}}function Bs(o){let e=Array.isArray(o.provider)?o.provider[0]:o.provider;return e||(Array.isArray(o.inline?.provider)?o.inline.provider[0]:o.inline?.provider)}function Ws(o,e=qs,t=fs$1.existsSync){let r=o.location.replace("file://","");if(!t(r))throw new Error(`Remote config file not found: ${r}`);if(!o.external_agent_id)throw new Error(`external_agent_id is required for file:// remote provider "${o.id}"`);let s=e(r).agents?.find(d=>d.id===o.external_agent_id);if(!s)throw new Error(`Agent "${o.external_agent_id}" not found in ${r}`);let i=Bs(s);if(!i)throw new Error(`Agent "${o.external_agent_id}" in ${r} has no provider configured`);if(i.startsWith("remote/"))throw new Error(`Chained remotes not allowed: ${o.id} \u2192 ${i}`);let a=F.resolve(F.dirname(r),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function Cn(o,e=ce){return (t,r)=>{let n=o.get(t);if(!n)throw new Error(`Remote provider "${t}" not found. Available: ${Array.from(o.keys()).join(", ")||"(none)"}`);if(n.location.startsWith("file://"))throw new Error(`Remote provider "${t}" uses file:// location which is not supported at the SDK level. Use the CLI commands (crewx query / crewx execute) which handle file:// remotes automatically.`);return new exports.RemoteProviderRuntime(t,n,e)}}function zs(o,e){let t=e.location;if(!t)throw new Error("Remote provider config requires a location");if(!t.startsWith("http://")&&!t.startsWith("https://"))throw new Error(`Unsupported remote location protocol for MCP-HTTP: ${t}`);return {type:"mcp-http",url:t,apiKey:e.apiKey,headers:e.headers,timeoutMs:e.timeout?.query??3e4,agentId:e.external_agent_id??o}}exports.RemoteProviderRuntime=void 0;var Rr=N(()=>{l();se();_r();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,r=ce){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let n=zs(e,t);this.manager.loadConfig(this.agentId,n);}async query(e,t){return (await this.manager.query(this.agentId,{agentId:this.agentId,query:e,model:t?.model,context:t?.context??t?.systemPrompt})).content.map(n=>n.text).join(`
31
+ `)}]}handleUpdate(e,t,r){let n=e.update;if(n.sessionUpdate==="agent_message_chunk"){let s=null;this.adapter.extractTextFromUpdate?s=this.adapter.extractTextFromUpdate(e):s=yr(e),s!==null&&(r.push(s),t?.onOutput?.(s,"stdout"));}else if(n.sessionUpdate==="tool_call"){let s=new Date().toISOString(),i=n,a={title:i.title??"",kind:i.kind,rawInput:i.rawInput,rawOutput:i.rawOutput,locations:i.locations,_meta:i._meta},d=this.resolveToolCall(a),c={timestamp:s,type:"tool_use",toolUseId:i.toolCallId,toolName:d.toolName,toolInput:d.toolInput};t?.onTaskLog?.([c]);}else if(n.sessionUpdate==="tool_call_update"){let s=new Date().toISOString(),i=n;if(i.status==="completed"||i.status==="failed"){let d=this.extractResultPreview(i.rawOutput),c={timestamp:s,type:"tool_result",toolUseId:i.toolCallId,resultPreview:d,isError:i.status==="failed"};t?.onTaskLog?.([c]);}else if(i.rawInput!=null&&typeof i.rawInput=="object"&&Object.keys(i.rawInput).length>0){let d={title:i.title??"",kind:i.kind,rawInput:i.rawInput,rawOutput:i.rawOutput,locations:i.locations,_meta:i._meta},c=this.resolveToolCall(d),u={timestamp:s,type:"tool_use",toolUseId:i.toolCallId,toolName:c.toolName,toolInput:c.toolInput};t?.onTaskLog?.([u]);}}else n.sessionUpdate;}resolveToolCall(e){let t=e._meta;if(t?.claudeCode?.toolName)return {toolName:t.claudeCode.toolName,toolInput:Pn(e.rawInput,e.locations)??(e.title||void 0)};if(this.adapter.parseToolCall){let s=this.adapter.parseToolCall(e);if(s)return {toolName:s.toolName??e.title??"unknown",toolInput:s.toolInput}}let r=js[e.kind??""]??e.title??"unknown",n=Pn(e.rawInput,e.locations)??(e.title||void 0);return {toolName:r,toolInput:n}}extractResultPreview(e){if(e!=null){if(typeof e=="string")return e;if(Array.isArray(e)){let t=e.filter(r=>r!=null&&typeof r=="object"&&r.type==="text"&&typeof r.text=="string").map(r=>r.text);if(t.length>0)return t.join(`
32
+ `)}if(typeof e=="object"){let t=e;if(typeof t.formatted_output=="string")return t.formatted_output;if(typeof t.content=="string")return t.content;if(Array.isArray(t.content)){let r=this.extractResultPreview(t.content);if(r)return r}if(typeof t.output=="string")return t.output;if(typeof t.text=="string")return t.text;if(typeof t.message=="string")return t.message;if(t.result!=null){let r=this.extractResultPreview(t.result);if(r)return r}if(t.error!=null){let r=this.extractResultPreview(t.error);if(r)return r}}return JSON.stringify(e)}}handleUsage(e,t){if(!t?.onUsage)return;if(this.adapter.extractUsage){let n=this.adapter.extractUsage(e);if(n){t.onUsage(n);return}}let r=e.usage;r&&t.onUsage({inputTokens:r.inputTokens??0,outputTokens:r.outputTokens??0,cachedInputTokens:r.cachedReadTokens??0,costUsd:0});}};});var Cn;exports.claudeAcpAdapter=void 0;var Ct=N(()=>{l();xe();Cn=[{id:"claude-opus-4-8[1m]",name:"Claude Opus 4.8 (Extended)"},{id:"claude-opus-4-8",name:"Claude Opus 4.8"},{id:"claude-opus-4-7[1m]",name:"Claude Opus 4.7 (Extended)"},{id:"claude-opus-4-7",name:"Claude Opus 4.7"},{id:"claude-opus-4-6[1m]",name:"Claude Opus 4.6 (Extended)"},{id:"claude-opus-4-6",name:"Claude Opus 4.6"},{id:"claude-sonnet-4-6[1m]",name:"Claude Sonnet 4.6 (Extended)"},{id:"claude-sonnet-4-6",name:"Claude Sonnet 4.6"},{id:"claude-haiku-4-5",name:"Claude Haiku 4.5"}],exports.claudeAcpAdapter={spawn:{command:"npx",args:["-y","@agentclientprotocol/claude-agent-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/claude-agent-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Claude",defaultMode:"default"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},extractUsage(o){let e=o.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"bypassPermissions",buildEffortAction(o){return o?{type:"set_config_option",configId:"effort",value:o}:null},buildSpawnEnv(o){if(!(!o||o==="default"))return {ANTHROPIC_MODEL:o}},resolveMode(o){return {yolo:"bypassPermissions"}[o]??o},parseEvent:se};});exports.codexAcpAdapter=void 0;var xr=N(()=>{l();xe();exports.codexAcpAdapter={spawn:{command:"npx",args:["-y","@agentclientprotocol/codex-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/codex-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Codex",defaultMode:"agent"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},extractUsage(o){let e=o.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"agent-full-access",buildEffortAction(o,e){if(!e)return null;let t=e.match(/^(.+?)\[([^\]]+)\]$/),r=t?t[1]:e,n=t?t[2]:void 0;return {type:"set_model",modelId:`${r}[${o||n||"medium"}]`}},resolveMode(o){return {yolo:"agent-full-access",default:"agent",plan:"read-only"}[o]??o},parseEvent:se};});exports.geminiAcpAdapter=void 0;var kr=N(()=>{l();xe();exports.geminiAcpAdapter={spawn:{command:"gemini",args:["--acp","--skip-trust"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Gemini"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},yoloModeId:"yolo",buildEffortAction(o){return null},resolveMode(o){return {acceptEdits:"autoEdit"}[o]??o},parseEvent:se};});var Fe;exports.copilotAcpAdapter=void 0;var vr=N(()=>{l();xe();Fe="https://agentclientprotocol.com/protocol/session-modes",exports.copilotAcpAdapter={spawn:{command:"copilot",args:["--acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"GitHub Copilot"},buildSessionParams(o){return {cwd:o.cwd?W.resolve(o.cwd):process.cwd(),mcpServers:[]}},yoloModeId:`${Fe}#autopilot`,buildEffortAction(o){return o?{type:"set_config_option",configId:"reasoning_effort",value:o}:null},resolveMode(o){return o.startsWith("https://")?o:{yolo:`${Fe}#autopilot`,default:`${Fe}#agent`,agent:`${Fe}#agent`,plan:`${Fe}#plan`,autopilot:`${Fe}#autopilot`}[o]??null},parseEvent:se};});exports.opencodeAcpAdapter=void 0;var _r=N(()=>{l();xe();exports.opencodeAcpAdapter={spawn:{command:"opencode",args:["acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"OpenCode"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},yoloModeId:void 0,buildEffortAction(o){return null},resolveMode(o){let e={default:"build"};return o==="yolo"?null:e[o]??o},parseEvent:se};});exports.ACP_ADAPTERS=void 0;var It=N(()=>{l();Ct();xr();kr();vr();_r();Ct();xr();kr();vr();_r();exports.ACP_ADAPTERS={claude:exports.claudeAcpAdapter,codex:exports.codexAcpAdapter,gemini:exports.geminiAcpAdapter,copilot:exports.copilotAcpAdapter,opencode:exports.opencodeAcpAdapter};});var bn={};ct(bn,{registerAcpProviders:()=>Tn});function Tn(o){if(o){ue("acp",o);return}ue("acp",(e,t)=>{let r=exports.ACP_ADAPTERS[e];if(!r)throw new exports.ProviderError(`Unknown ACP provider id: "${e}". Supported: ${Object.keys(exports.ACP_ADAPTERS).join(", ")}`,t);return new exports.AcpProviderRuntime(e,r,t)});}var Ar=N(()=>{l();ae();wr();It();ae();});function Fs(o){if(!o)return o;let e=o.trim().replace(/\/+$/,"");return e.toLowerCase().endsWith("/mcp")?e.slice(0,-4):e}exports.McpHttpTransport=void 0;var Rr=N(()=>{l();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=Fs(e.url);this.endpoint=`${t}/mcp`,this.headers={"Content-Type":"application/json",...e.headers??{}},e.apiKey&&(this.headers.Authorization=`Bearer ${e.apiKey}`),this.timeoutMs=e.timeoutMs??3e4;}async send(e){let t=new AbortController,r=setTimeout(()=>t.abort(),this.timeoutMs);try{let n=await fetch(this.endpoint,{method:"POST",headers:this.headers,body:JSON.stringify(e),signal:t.signal});if(clearTimeout(r),!n.ok){let a=await n.text();throw new Error(`HTTP ${n.status}: ${n.statusText}${a?` - ${a}`:""}`)}let s=n.headers.get("content-type");if(s?.includes("application/json"))return await n.json();let i=await n.text();return {jsonrpc:"2.0",id:e.id,error:{code:-32600,message:`Unexpected response content-type: ${s}`,data:i}}}catch(n){throw clearTimeout(r),n instanceof Error&&n.name==="AbortError"?new Error(`MCP-HTTP request timeout after ${this.timeoutMs}ms to ${this.endpoint}`):n}}async close(){}};});exports.RemoteAgentManager=void 0;var Pr=N(()=>{l();Rr();exports.RemoteAgentManager=class{logger;configs=new Map;transports=new Map;constructor(e={}){this.logger=e.logger??(()=>{});}loadConfig(e,t){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,new exports.McpHttpTransport({url:t.url,apiKey:t.apiKey,headers:t.headers,timeoutMs:t.timeoutMs})),this.logger(`Loaded remote agent config for: ${e}`,"debug");}loadConfigWithTransport(e,t,r){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,r),this.logger(`Loaded remote agent config for: ${e} (custom transport)`,"debug");}getConfig(e){return this.configs.get(e)}isRemoteAgent(e){return this.configs.has(e)}getRemoteAgentIds(){return Array.from(this.configs.keys())}async query(e,t){let r=this.requireConfig(e),n=r.tools?.query??"crewx_queryAgent",i={agentId:r.agentId??e,query:t.query};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote query failed for agent ${e}: ${d}`,"error"),a}}async execute(e,t){let r=this.requireConfig(e),n=r.tools?.execute??"crewx_executeAgent",i={agentId:r.agentId??e,task:t.task};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote execute failed for agent ${e}: ${d}`,"error"),a}}mapToolNames(e,t){let r=this.requireConfig(e);r.tools={query:t.query??r.tools?.query??"crewx_queryAgent",execute:t.execute??r.tools?.execute??"crewx_executeAgent"},this.logger(`Updated tool name mapping for agent ${e}`,"debug");}async clearConfigs(){for(let e of this.transports.values())await e.close();this.configs.clear(),this.transports.clear(),this.logger("Cleared all remote agent configurations","debug");}requireConfig(e){let t=this.configs.get(e);if(!t)throw new Error(`Agent ${e} is not configured as a remote agent`);return t}async callRemoteTool(e,t,r){let n=this.transports.get(e);if(!n)throw new Error(`No transport available for agent ${e}`);let s={jsonrpc:"2.0",id:`${t}-${Date.now()}`,method:"tools/call",params:{name:t,arguments:r}};this.logger(`Calling remote MCP tool ${t} for agent ${e}`,"debug");let i=await n.send(s);if(i.error)throw new Error(i.error.message||"MCP server returned an error");return i.result}normalizeResponse(e){if(!e)return {success:false,content:[{type:"text",text:"Remote agent returned no response."}]};let t=e;if(Array.isArray(t.content)&&t.content.length>0)return t;let r=t.response??t.implementation??t.message??t.output,n=typeof r=="string"?r:JSON.stringify(r??e,null,2);return {...t,content:[{type:"text",text:n}]}}validateConfig(e){if(!e.url)throw new Error("Remote agent configuration requires a URL");if(!e.url.startsWith("http://")&&!e.url.startsWith("https://"))throw new Error("Remote agent URL must start with http:// or https://");if(e.type!=="mcp-http")throw new Error(`Unsupported remote agent type: ${e.type}`)}};});var Sn={};ct(Sn,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>En,resolveFileRemoteAgent:()=>Js});function Vs(o){let e=fs.readFileSync(o,"utf-8"),t=jsYaml.load(e);return {agents:Array.isArray(t?.agents)?t.agents:void 0}}function Ks(o){let e=Array.isArray(o.provider)?o.provider[0]:o.provider;return e||(Array.isArray(o.inline?.provider)?o.inline.provider[0]:o.inline?.provider)}function Js(o,e=Vs,t=fs.existsSync){let r=o.location.replace("file://","");if(!t(r))throw new Error(`Remote config file not found: ${r}`);if(!o.external_agent_id)throw new Error(`external_agent_id is required for file:// remote provider "${o.id}"`);let s=e(r).agents?.find(d=>d.id===o.external_agent_id);if(!s)throw new Error(`Agent "${o.external_agent_id}" not found in ${r}`);let i=Ks(s);if(!i)throw new Error(`Agent "${o.external_agent_id}" in ${r} has no provider configured`);if(i.startsWith("remote/"))throw new Error(`Chained remotes not allowed: ${o.id} \u2192 ${i}`);let a=W.resolve(W.dirname(r),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function En(o,e=pe){return (t,r)=>{let n=o.get(t);if(!n)throw new Error(`Remote provider "${t}" not found. Available: ${Array.from(o.keys()).join(", ")||"(none)"}`);if(n.location.startsWith("file://"))throw new Error(`Remote provider "${t}" uses file:// location which is not supported at the SDK level. Use the CLI commands (crewx query / crewx execute) which handle file:// remotes automatically.`);return new exports.RemoteProviderRuntime(t,n,e)}}function Xs(o,e){let t=e.location;if(!t)throw new Error("Remote provider config requires a location");if(!t.startsWith("http://")&&!t.startsWith("https://"))throw new Error(`Unsupported remote location protocol for MCP-HTTP: ${t}`);return {type:"mcp-http",url:t,apiKey:e.apiKey,headers:e.headers,timeoutMs:e.timeout?.query??3e4,agentId:e.external_agent_id??o}}exports.RemoteProviderRuntime=void 0;var Cr=N(()=>{l();ae();Pr();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,r=pe){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let n=Xs(e,t);this.manager.loadConfig(this.agentId,n);}async query(e,t){return (await this.manager.query(this.agentId,{agentId:this.agentId,query:e,model:t?.model,context:t?.context??t?.systemPrompt})).content.map(n=>n.text).join(`
33
33
  `)}async execute(e,t){return (await this.manager.execute(this.agentId,{agentId:this.agentId,task:e,model:t?.model,context:t?.context??t?.systemPrompt})).content.map(n=>n.text).join(`
34
- `)}};});var In={};lt(In,{PluginProviderRuntime:()=>exports.PluginProviderRuntime,createPluginProviderFactory:()=>Sn});function Sn(o){return (e,t)=>{let r=o.get(e);if(!r)throw new exports.ProviderError(`Plugin provider "${e}" not found. Available: ${Array.from(o.keys()).join(", ")||"(none)"}`,`plugin/${e}`);return new exports.PluginProviderRuntime(e,r)}}function En(o,e,t,r){let n=o.map(s=>s.replace(/\{model\}/g,e));return r&&n.push(t),n}function Ks(o){if(!o||typeof o!="string")throw new Error("Plugin provider requires a cli_command")}function Tn(o){if(!Array.isArray(o))throw new Error("CLI arguments must be an array");for(let e of o)if(typeof e!="string")throw new Error("Each CLI argument must be a string")}function Js(o){for(let{pattern:e}of o)if(typeof e!="string")throw new Error("Error pattern must be a string")}function Xs(o){for(let[e,t]of Object.entries(o))if(typeof e!="string"||typeof t!="string")throw new Error("env entries must be string key/value pairs")}exports.PluginProviderRuntime=void 0;var Ar=N(()=>{l();se();yt();exports.PluginProviderRuntime=class{constructor(e,t){this.config=t;this.providerStr=`plugin/${e}`,Ks(t.cli_command),Tn(t.query_args),Tn(t.execute_args),t.error_patterns&&Js(t.error_patterns),t.env&&Xs(t.env);}config;providerStr;async query(e,t){let r=t?.model??this.config.default_model??"default",n=En(this.config.query_args,r,e,this.config.prompt_in_args),s=this.config.prompt_in_args?void 0:e;t?.onCommand?.(`${this.config.cli_command} ${n.join(" ")}`);let i=this.config.timeout?.query??6e5;return this.runProcess(n,t,s,i)}async execute(e,t){let r=t?.model??this.config.default_model??"default",n=En(this.config.execute_args,r,e,this.config.prompt_in_args),s=this.config.prompt_in_args?void 0:e;t?.onCommand?.(`${this.config.cli_command} ${n.join(" ")}`);let i=this.config.timeout?.execute??6e5;return this.runProcess(n,t,s,i)}runProcess(e,t,r,n){return new Promise((s,i)=>{let a={...process.env,...this.config.env??{}},d=Be({command:this.config.cli_command,allowShellFallback:true}),c=We(d,e),u=child_process.spawn(c.command,c.argv,{env:a,shell:c.shell??false,stdio:["pipe","pipe","pipe"],windowsHide:c.windowsHide});r!==void 0&&u.stdin.write(r),u.stdin.end(),u.pid!==void 0&&t?.onPid?.(u.pid);let m="",g="",p="",y="";u.stdout.on("data",w=>{let _=w.toString();m+=_,p+=_;let v=p.split(`
35
- `);p=v.pop()??"";for(let R of v)R.trim()&&t?.onOutput?.(R,"stdout");}),u.stderr.on("data",w=>{let _=w.toString();g+=_,y+=_;let v=y.split(`
36
- `);y=v.pop()??"";for(let R of v)R.trim()&&t?.onOutput?.(R,"stderr");});let x=setTimeout(()=>{u.kill("SIGTERM"),i(new exports.ProviderError(`Plugin provider "${this.providerStr}" timed out after ${n}ms`,this.providerStr));},n);u.on("error",w=>{if(clearTimeout(x),w.code==="ENOENT"){let _=this.config.not_installed_message??`CLI command "${this.config.cli_command}" not found. Is ${this.config.id} installed?`;i(new exports.ProviderError(_,this.providerStr));}else i(new exports.ProviderError(`Spawn error: ${w.message}`,this.providerStr));}),u.on("close",w=>{clearTimeout(x),p.trim()&&t?.onOutput?.(p,"stdout"),y.trim()&&t?.onOutput?.(y,"stderr");let _=w??0;if(t?.onExitCode?.(_),this.config.error_patterns){let v=g||m;for(let R of this.config.error_patterns)if(v.includes(R.pattern)){i(new exports.ProviderError(R.message,this.providerStr));return}}if(w!==0){i(new exports.ProviderError(`Process exited with code ${w}: ${g.slice(0,500)}`,this.providerStr));return}s(m.trim());});})}};});l();l();l();function mo(o){let e=n=>n.replace(/[.+^${}()|[\]\\]/g,"\\$&"),r=o.split("/").map(n=>n==="**"?".*":n.split("*").map(e).join("[^/]*"));return new RegExp(`^${r.join("\\/")}$`)}function oe(o,e){try{return mo(e).test(o)}catch{return false}}l();l();var fo=zod.z.object({model:zod.z.string().optional(),system_prompt:zod.z.string().optional(),prompt:zod.z.string().optional(),layout:zod.z.union([zod.z.string(),zod.z.object({id:zod.z.string(),props:zod.z.record(zod.z.unknown()).optional()}),zod.z.object({props:zod.z.record(zod.z.unknown())}),zod.z.object({template:zod.z.string()})]).optional()}).catchall(zod.z.unknown()),qr=zod.z.object({include:zod.z.array(zod.z.string()).optional()}).optional(),yo=zod.z.object({id:zod.z.string(),name:zod.z.string().optional(),role:zod.z.string().optional(),team:zod.z.string().optional(),provider:zod.z.union([zod.z.string(),zod.z.array(zod.z.string())]),working_directory:zod.z.string().optional(),description:zod.z.string().optional(),tags:zod.z.array(zod.z.string()).optional(),inline:fo.optional(),skills:qr}).catchall(zod.z.unknown()),Br=zod.z.object({agents:zod.z.array(yo).optional(),hooks:zod.z.array(zod.z.unknown()).optional(),settings:zod.z.record(zod.z.unknown()).optional(),skills:zod.z.unknown().optional(),layouts:zod.z.record(zod.z.unknown()).optional(),documents:zod.z.record(zod.z.unknown()).optional()}).catchall(zod.z.unknown());var xe=class extends Error{constructor(t,r){super(t);this.cause=r;this.name="ConfigLoadError";}cause};function ct(o){if(!o||typeof o!="string"||!o.trim())throw new xe("YAML content must be a non-empty string");let e;try{e=jsYaml.load(o);}catch(n){throw new xe(`YAML parse error: ${n.message}`,n)}let t=xo(e),r=Br.safeParse(t);if(!r.success)throw new xe(`Config validation error: ${r.error.message}`);return r.data}function ut(o){let e;try{e=fs$1.readFileSync(o,"utf-8");}catch(t){throw new xe(`Cannot read file: ${o}`,t)}return ct(e)}function xo(o){if(!o||typeof o!="object")return {agents:[]};let e=o,t;if(e.agents&&typeof e.agents=="object"&&!Array.isArray(e.agents)){let n=e.agents;t=Object.entries(n).map(([s,i])=>({id:s,...i&&typeof i=="object"?i:{}}));}else if(Array.isArray(e.agents))t=e.agents;else return {...e,agents:[]};let r=t.map(n=>{if(n.provider===void 0&&n.inline&&typeof n.inline=="object"){let s=n.inline;if(s.provider!==void 0)return {...n,provider:s.provider}}return n});return {...e,agents:r}}l();var ke=F.join("templates","agents");function _o(){try{let e=(typeof W=="function"?W:module$1.createRequire(typeof __filename<"u"?__filename:process.cwd()+"/")).resolve("@crewx/sdk/package.json");return F.dirname(e)}catch{return null}}function Ne(o){if(o&&fs$1.existsSync(o))return o;let e=process.env.CREWX_SDK_TEMPLATES_PATH;if(e&&fs$1.existsSync(e))return e;let t=_o();if(t){let n=F.join(t,ke);if(fs$1.existsSync(n))return n}let r=[F.join(__dirname,"..",ke),F.join(__dirname,"..","..",ke),F.join(__dirname,"..","..","..",ke),F.join(process.cwd(),"packages","sdk",ke),F.join(process.cwd(),ke)];for(let n of r)if(fs$1.existsSync(n))return n;throw new Error(`[@crewx/sdk] Templates directory not found.
37
- `+(t?` package anchor: ${F.join(t,ke)}
34
+ `)}};});var Nn={};ct(Nn,{PluginProviderRuntime:()=>exports.PluginProviderRuntime,createPluginProviderFactory:()=>Mn});function Mn(o){return (e,t)=>{let r=o.get(e);if(!r)throw new exports.ProviderError(`Plugin provider "${e}" not found. Available: ${Array.from(o.keys()).join(", ")||"(none)"}`,`plugin/${e}`);return new exports.PluginProviderRuntime(e,r)}}function In(o,e,t,r){let n=o.map(s=>s.replace(/\{model\}/g,e));return r&&n.push(t),n}function Ys(o){if(!o||typeof o!="string")throw new Error("Plugin provider requires a cli_command")}function On(o){if(!Array.isArray(o))throw new Error("CLI arguments must be an array");for(let e of o)if(typeof e!="string")throw new Error("Each CLI argument must be a string")}function Qs(o){for(let{pattern:e}of o)if(typeof e!="string")throw new Error("Error pattern must be a string")}function Zs(o){for(let[e,t]of Object.entries(o))if(typeof e!="string"||typeof t!="string")throw new Error("env entries must be string key/value pairs")}exports.PluginProviderRuntime=void 0;var Tr=N(()=>{l();ae();ht();exports.PluginProviderRuntime=class{constructor(e,t){this.config=t;this.providerStr=`plugin/${e}`,Ys(t.cli_command),On(t.query_args),On(t.execute_args),t.error_patterns&&Qs(t.error_patterns),t.env&&Zs(t.env);}config;providerStr;async query(e,t){let r=t?.model??this.config.default_model??"default",n=In(this.config.query_args,r,e,this.config.prompt_in_args),s=this.config.prompt_in_args?void 0:e;t?.onCommand?.(`${this.config.cli_command} ${n.join(" ")}`);let i=this.config.timeout?.query??6e5;return this.runProcess(n,t,s,i)}async execute(e,t){let r=t?.model??this.config.default_model??"default",n=In(this.config.execute_args,r,e,this.config.prompt_in_args),s=this.config.prompt_in_args?void 0:e;t?.onCommand?.(`${this.config.cli_command} ${n.join(" ")}`);let i=this.config.timeout?.execute??6e5;return this.runProcess(n,t,s,i)}runProcess(e,t,r,n){return new Promise((s,i)=>{let a={...process.env,...this.config.env??{}},d=We({command:this.config.cli_command,allowShellFallback:true}),c=ze(d,e),u=child_process.spawn(c.command,c.argv,{env:a,shell:c.shell??false,stdio:["pipe","pipe","pipe"],windowsHide:c.windowsHide});r!==void 0&&u.stdin.write(r),u.stdin.end(),u.pid!==void 0&&t?.onPid?.(u.pid);let g="",f="",p="",m="";u.stdout.on("data",A=>{let v=A.toString();g+=v,p+=v;let k=p.split(`
35
+ `);p=k.pop()??"";for(let x of k)x.trim()&&t?.onOutput?.(x,"stdout");}),u.stderr.on("data",A=>{let v=A.toString();f+=v,m+=v;let k=m.split(`
36
+ `);m=k.pop()??"";for(let x of k)x.trim()&&t?.onOutput?.(x,"stderr");});let w=setTimeout(()=>{u.kill("SIGTERM"),i(new exports.ProviderError(`Plugin provider "${this.providerStr}" timed out after ${n}ms`,this.providerStr));},n);u.on("error",A=>{if(clearTimeout(w),A.code==="ENOENT"){let v=this.config.not_installed_message??`CLI command "${this.config.cli_command}" not found. Is ${this.config.id} installed?`;i(new exports.ProviderError(v,this.providerStr));}else i(new exports.ProviderError(`Spawn error: ${A.message}`,this.providerStr));}),u.on("close",A=>{clearTimeout(w),p.trim()&&t?.onOutput?.(p,"stdout"),m.trim()&&t?.onOutput?.(m,"stderr");let v=A??0;if(t?.onExitCode?.(v),this.config.error_patterns){let k=f||g;for(let x of this.config.error_patterns)if(k.includes(x.pattern)){i(new exports.ProviderError(x.message,this.providerStr));return}}if(A!==0){i(new exports.ProviderError(`Process exited with code ${A}: ${f.slice(0,500)}`,this.providerStr));return}s(g.trim());});})}};});l();l();l();function ho(o){let e=n=>n.replace(/[.+^${}()|[\]\\]/g,"\\$&"),r=o.split("/").map(n=>n==="**"?".*":n.split("*").map(e).join("[^/]*"));return new RegExp(`^${r.join("\\/")}$`)}function ie(o,e){try{return ho(e).test(o)}catch{return false}}l();l();var wo=zod.z.object({model:zod.z.string().optional(),system_prompt:zod.z.string().optional(),prompt:zod.z.string().optional(),layout:zod.z.union([zod.z.string(),zod.z.object({id:zod.z.string(),props:zod.z.record(zod.z.unknown()).optional()}),zod.z.object({props:zod.z.record(zod.z.unknown())}),zod.z.object({template:zod.z.string()})]).optional()}).catchall(zod.z.unknown()),zr=zod.z.object({include:zod.z.array(zod.z.string()).optional()}).optional(),xo=zod.z.object({id:zod.z.string(),name:zod.z.string().optional(),role:zod.z.string().optional(),team:zod.z.string().optional(),provider:zod.z.union([zod.z.string(),zod.z.array(zod.z.string())]),working_directory:zod.z.string().optional(),description:zod.z.string().optional(),tags:zod.z.array(zod.z.string()).optional(),inline:wo.optional(),skills:zr}).catchall(zod.z.unknown()),Vr=zod.z.object({agents:zod.z.array(xo).optional(),hooks:zod.z.array(zod.z.unknown()).optional(),settings:zod.z.record(zod.z.unknown()).optional(),skills:zod.z.unknown().optional(),layouts:zod.z.record(zod.z.unknown()).optional(),documents:zod.z.record(zod.z.unknown()).optional()}).catchall(zod.z.unknown());var ve=class extends Error{constructor(t,r){super(t);this.cause=r;this.name="ConfigLoadError";}cause};function ut(o){if(!o||typeof o!="string"||!o.trim())throw new ve("YAML content must be a non-empty string");let e;try{e=jsYaml.load(o);}catch(n){throw new ve(`YAML parse error: ${n.message}`,n)}let t=_o(e),r=Vr.safeParse(t);if(!r.success)throw new ve(`Config validation error: ${r.error.message}`);return r.data}function pt(o){let e;try{e=fs.readFileSync(o,"utf-8");}catch(t){throw new ve(`Cannot read file: ${o}`,t)}return ut(e)}function _o(o){if(!o||typeof o!="object")return {agents:[]};let e=o,t;if(e.agents&&typeof e.agents=="object"&&!Array.isArray(e.agents)){let n=e.agents;t=Object.entries(n).map(([s,i])=>({id:s,...i&&typeof i=="object"?i:{}}));}else if(Array.isArray(e.agents))t=e.agents;else return {...e,agents:[]};let r=t.map(n=>{if(n.provider===void 0&&n.inline&&typeof n.inline=="object"){let s=n.inline;if(s.provider!==void 0)return {...n,provider:s.provider}}return n});return {...e,agents:r}}l();var _e=W.join("templates","agents");function Po(){try{let e=(typeof z=="function"?z:module$1.createRequire(typeof __filename<"u"?__filename:process.cwd()+"/")).resolve("@crewx/sdk/package.json");return W.dirname(e)}catch{return null}}function De(o){if(o&&fs.existsSync(o))return o;let e=process.env.CREWX_SDK_TEMPLATES_PATH;if(e&&fs.existsSync(e))return e;let t=Po();if(t){let n=W.join(t,_e);if(fs.existsSync(n))return n}let r=[W.join(__dirname,"..",_e),W.join(__dirname,"..","..",_e),W.join(__dirname,"..","..","..",_e),W.join(process.cwd(),"packages","sdk",_e),W.join(process.cwd(),_e)];for(let n of r)if(fs.existsSync(n))return n;throw new Error(`[@crewx/sdk] Templates directory not found.
37
+ `+(t?` package anchor: ${W.join(t,_e)}
38
38
  `:` package anchor: (unresolved)
39
39
  `)+r.map(n=>` candidate: ${n}`).join(`
40
40
  `)+`
41
- Set CREWX_SDK_TEMPLATES_PATH or pass options.templatesPath.`)}function Ft(){let o=Ne();return {yamlPath:F.join(o,"default.yaml"),dir:o}}l();var de=class extends Error{constructor(e,t){let r=t.length>0?` Available: ${t.join(", ")}`:"";super(`Agent not found: "${e}".${r}`),this.name="AgentNotFoundError";}},Ro={claude:{id:"claude",provider:"cli/claude"},gemini:{id:"gemini",provider:"cli/gemini"},copilot:{id:"copilot",provider:"cli/copilot"},codex:{id:"codex",provider:"cli/codex"}};function gt(o,e){let t=o.startsWith("@")?o.slice(1):o,r=e.find(s=>s.id===t);if(r)return r;let n=Ro[t];if(n)return n;throw new de(o,e.map(s=>s.id))}se();l();function Xr(o,e){if(o===void 0||o==="")return e;let t=parseInt(o,10);return Number.isNaN(t)?e:t}function Gr(o=process.env){return {queryMs:Xr(o.CREWX_TIMEOUT_QUERY,288e5),executeMs:Xr(o.CREWX_TIMEOUT_EXECUTE,288e5)}}l();l();var qo=[/^ANTHROPIC_/i,/^OPENAI_/i,/^AWS_SECRET/i,/^SLACK_/i,/^GITHUB_TOKEN$/i,/^CREWX_MCP_KEY$/i,/^DATABASE_/i,/^AWS_ACCESS_KEY/i,/^AWS_SESSION_TOKEN$/i,/^GH_TOKEN$/i,/^GH_APP_/i,/^NPM_TOKEN$/i,/^NPM_AUTH/i,/^GOOGLE_APPLICATION/i,/^GCLOUD_/i,/^AZURE_/i,/^ARM_/i,/^DOCKER_PASSWORD$/i,/^DOCKER_AUTH/i,/^SSH_PRIVATE/i,/^SSH_AUTH_SOCK$/i,/^CI_JOB_TOKEN$/i,/^ACTIONS_RUNTIME_TOKEN$/i,/^VAULT_TOKEN$/i,/^SONAR_TOKEN$/i,/^CODECOV_TOKEN$/i,/TOKEN$/i,/SECRET$/i,/PASSWORD$/i,/API_KEY$/i],Bo=/[;|&`$(){}!><\n\r]/,Wo=2,zo=["*","**","*:*","* *","**/*"];function Vo(){let o={};for(let[e,t]of Object.entries(process.env))t!==void 0&&(qo.some(r=>r.test(e))||(o[e]=t));return o}function Ko(o){if(Bo.test(o))throw new Error(`exec blocked: shell metacharacter detected in "${o}"`)}function Jo(o){return /^npx\s+@crewx\/[\w-]+/.test(o)}function Xo(o){if(zo.includes(o.trim()))throw new Error(`exec config error: overly broad pattern "${o}" is not allowed`);if(!/^[\w./@-]/.test(o))throw new Error("exec config error: pattern must start with a command name")}function Go(o,e){let t=e.allow??[],r=e.deny??[];for(let n of [...t,...r])Xo(n);return r.some(n=>oe(o,n))?false:Jo(o)?true:t.some(n=>oe(o,n))}var Yr=false;function Yo(o){Yr=o;}function Ke(o){if(!Yr)return;let e=JSON.stringify({span:"template_exec",...o,timestamp:new Date().toISOString()});console.error(e);}function Qo(o){let e=[],t="",r=false,n=false;for(let s=0;s<o.length;s++){let i=o[s];i==="'"&&!n?r=!r:i==='"'&&!r?n=!n:i===" "&&!r&&!n?t.length>0&&(e.push(t),t=""):t+=i;}return t.length>0&&e.push(t),e}function Qr(o,e){let t=Date.now(),r=parseInt(process.env.CREWX_EXEC_DEPTH??"0",10);if(isNaN(r)||r>=Wo)return Ke({command:o,status:"denied",reason:"invalid or max recursion depth"}),"(exec blocked: max recursion depth reached)";try{Ko(o);}catch{return Ke({command:o,status:"denied",reason:"shell metacharacter detected"}),`(exec blocked: shell metacharacter detected in "${o}")`}if(!Go(o,e))return Ke({command:o,status:"denied",reason:"not in allow list"}),`(exec blocked: ${o})`;try{let n=Qo(o),[s,...i]=n;if(!s)return `(exec failed: ${o})`;let a=Vo(),d=child_process.execFileSync(s,i,{timeout:e.timeout??5e3,maxBuffer:64*1024,encoding:"utf-8",env:{...a,CREWX_EXEC_DEPTH:String(r+1)},stdio:["pipe","pipe","pipe"]}),c=Date.now()-t;return Ke({command:o,status:"allowed",allowed_by:"policy",duration_ms:c}),`<exec-output cmd="${o}">
41
+ Set CREWX_SDK_TEMPLATES_PATH or pass options.templatesPath.`)}function Bt(){let o=De();return {yamlPath:W.join(o,"default.yaml"),dir:o}}l();var ce=class extends Error{constructor(e,t){let r=t.length>0?` Available: ${t.join(", ")}`:"";super(`Agent not found: "${e}".${r}`),this.name="AgentNotFoundError";}},Co={claude:{id:"claude",provider:"cli/claude"},gemini:{id:"gemini",provider:"cli/gemini"},copilot:{id:"copilot",provider:"cli/copilot"},codex:{id:"codex",provider:"cli/codex"}};function mt(o,e){let t=o.startsWith("@")?o.slice(1):o,r=e.find(s=>s.id===t);if(r)return r;let n=Co[t];if(n)return n;throw new ce(o,e.map(s=>s.id))}ae();l();function Qr(o,e){if(o===void 0||o==="")return e;let t=parseInt(o,10);return Number.isNaN(t)?e:t}function Zr(o=process.env){return {queryMs:Qr(o.CREWX_TIMEOUT_QUERY,288e5),executeMs:Qr(o.CREWX_TIMEOUT_EXECUTE,288e5)}}l();l();var zo=[/^ANTHROPIC_/i,/^OPENAI_/i,/^AWS_SECRET/i,/^SLACK_/i,/^GITHUB_TOKEN$/i,/^CREWX_MCP_KEY$/i,/^DATABASE_/i,/^AWS_ACCESS_KEY/i,/^AWS_SESSION_TOKEN$/i,/^GH_TOKEN$/i,/^GH_APP_/i,/^NPM_TOKEN$/i,/^NPM_AUTH/i,/^GOOGLE_APPLICATION/i,/^GCLOUD_/i,/^AZURE_/i,/^ARM_/i,/^DOCKER_PASSWORD$/i,/^DOCKER_AUTH/i,/^SSH_PRIVATE/i,/^SSH_AUTH_SOCK$/i,/^CI_JOB_TOKEN$/i,/^ACTIONS_RUNTIME_TOKEN$/i,/^VAULT_TOKEN$/i,/^SONAR_TOKEN$/i,/^CODECOV_TOKEN$/i,/TOKEN$/i,/SECRET$/i,/PASSWORD$/i,/API_KEY$/i],Vo=/[;|&`$(){}!><\n\r]/,Ko=2,Jo=["*","**","*:*","* *","**/*"];function Xo(){let o={};for(let[e,t]of Object.entries(process.env))t!==void 0&&(zo.some(r=>r.test(e))||(o[e]=t));return o}function Go(o){if(Vo.test(o))throw new Error(`exec blocked: shell metacharacter detected in "${o}"`)}function Yo(o){return /^npx\s+@crewx\/[\w-]+/.test(o)}function Qo(o){if(Jo.includes(o.trim()))throw new Error(`exec config error: overly broad pattern "${o}" is not allowed`);if(!/^[\w./@-]/.test(o))throw new Error("exec config error: pattern must start with a command name")}function Zo(o,e){let t=e.allow??[],r=e.deny??[];for(let n of [...t,...r])Qo(n);return r.some(n=>ie(o,n))?false:Yo(o)?true:t.some(n=>ie(o,n))}var en=false;function es(o){en=o;}function Je(o){if(!en)return;let e=JSON.stringify({span:"template_exec",...o,timestamp:new Date().toISOString()});console.error(e);}function ts(o){let e=[],t="",r=false,n=false;for(let s=0;s<o.length;s++){let i=o[s];i==="'"&&!n?r=!r:i==='"'&&!r?n=!n:i===" "&&!r&&!n?t.length>0&&(e.push(t),t=""):t+=i;}return t.length>0&&e.push(t),e}function tn(o,e){let t=Date.now(),r=parseInt(process.env.CREWX_EXEC_DEPTH??"0",10);if(isNaN(r)||r>=Ko)return Je({command:o,status:"denied",reason:"invalid or max recursion depth"}),"(exec blocked: max recursion depth reached)";try{Go(o);}catch{return Je({command:o,status:"denied",reason:"shell metacharacter detected"}),`(exec blocked: shell metacharacter detected in "${o}")`}if(!Zo(o,e))return Je({command:o,status:"denied",reason:"not in allow list"}),`(exec blocked: ${o})`;try{let n=ts(o),[s,...i]=n;if(!s)return `(exec failed: ${o})`;let a=Xo(),d=child_process.execFileSync(s,i,{timeout:e.timeout??5e3,maxBuffer:64*1024,encoding:"utf-8",env:{...a,CREWX_EXEC_DEPTH:String(r+1)},stdio:["pipe","pipe","pipe"]}),c=Date.now()-t;return Je({command:o,status:"allowed",allowed_by:"policy",duration_ms:c}),`<exec-output cmd="${o}">
42
42
  ${d.trim()}
43
- </exec-output>`}catch{return Ke({command:o,status:"error",reason:"execution failed"}),`(exec failed: ${o})`}}l();function Zr(o){return o==null?"":String(o)}l();function en(o,e){return `\`\`\`${e?.hash?.lang??""}
43
+ </exec-output>`}catch{return Je({command:o,status:"error",reason:"execution failed"}),`(exec failed: ${o})`}}l();function rn(o){return o==null?"":String(o)}l();function nn(o,e){return `\`\`\`${e?.hash?.lang??""}
44
44
  ${o??""}
45
- \`\`\``}l();function Qt(o,e){if(!o)return "";if(o.length<=e)return o;let t=o.length-e;return `${o.substring(0,e)} (...+${t} chars)`}function Zt(o){return Array.isArray(o)||typeof o=="string"?o.length:0}function er(o){return typeof o!="string"?"":o.replace(/\{\{/g,"&#123;&#123;").replace(/\}\}/g,"&#125;&#125;")}var tn=["B","KB","MB","GB"];function tr(o){if(o===0)return "0 B";let e=Math.min(Math.floor(Math.log(o)/Math.log(1024)),tn.length-1);return `${Math.round(o/Math.pow(1024,e)*100)/100} ${tn[e]}`}function rr(o){if(!o)return "";try{let e=o instanceof Date?o:new Date(o);return isNaN(e.getTime())?"":e.toLocaleString("ko-KR",{year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1})}catch{return ""}}var Je=class{hbs;execPolicy;execEnabled;constructor(e={}){this.hbs=ie__namespace.create(),this.execPolicy=e.execPolicy??{allow:[],deny:[]},this.execEnabled=e.execEnabled??true,this.registerHelpers();}registerHelpers(){let e=this.hbs,t=this.execPolicy,r=this.execEnabled;e.registerHelper("exec",function(n){return typeof n!="string"?"":r?new e.SafeString(Qr(n,t)):"(exec disabled)"}),e.registerHelper("include",function(n){return new e.SafeString(Zr(n))}),e.registerHelper("fenced_code",function(n,s){return new e.SafeString(en(n,s))}),e.registerHelper("eq",function(n,s){return n===s}),e.registerHelper("ne",function(n,s){return n!==s}),e.registerHelper("and",function(n,s){return n&&s}),e.registerHelper("or",function(n,s){return n||s}),e.registerHelper("not",function(n){return !n}),e.registerHelper("contains",function(n,s){return Array.isArray(n)&&n.includes(s)}),e.registerHelper("json",function(n){return JSON.stringify(n,null,2)}),e.registerHelper("truncate",function(n,s){return Qt(n,s)}),e.registerHelper("length",function(n){return Zt(n)}),e.registerHelper("escapeHandlebars",function(n){return new e.SafeString(er(n))}),e.registerHelper("formatFileSize",function(n){return tr(n)}),e.registerHelper("formatTimestamp",function(n){return rr(n)});}async render(e,t={}){return this.hbs.compile(e,{noEscape:true})(t)}};l();l();var _t=class{async readFile(e){return promises.readFile(e,"utf-8")}async exists(e){try{return await promises.access(e),!0}catch{return false}}resolvePath(...e){return e.length===1?F.resolve(e[0]):F.resolve(F.join(...e))}isAbsolute(e){return F.isAbsolute(e)}async readdir(e){try{return await promises.readdir(e)}catch{return []}}},_e=new _t;var Re=class{docs=new Map;fs;constructor(e){this.fs=e??_e;}async load(e,t){if(e)for(let[r,n]of Object.entries(e)){let s=n;if(typeof s=="string")this.docs.set(r,{content:s});else if(s&&typeof s=="object"){let i=s;"content"in i&&typeof i.content=="string"?this.docs.set(r,{content:i.content}):"path"in i&&typeof i.path=="string"?await this.loadFromFile(r,i.path,t):console.warn(`[DocumentLoader] Skipping '${r}': unsupported format`);}else console.warn(`[DocumentLoader] Skipping '${r}': unsupported format`);}}async getContent(e){return this.docs.get(e)?.content}async getToc(e){let t=this.docs.get(e);if(!t)return;let r=[];for(let n of t.content.split(`
45
+ \`\`\``}l();function er(o,e){if(!o)return "";if(o.length<=e)return o;let t=o.length-e;return `${o.substring(0,e)} (...+${t} chars)`}function tr(o){return Array.isArray(o)||typeof o=="string"?o.length:0}function rr(o){return typeof o!="string"?"":o.replace(/\{\{/g,"&#123;&#123;").replace(/\}\}/g,"&#125;&#125;")}var on=["B","KB","MB","GB"];function nr(o){if(o===0)return "0 B";let e=Math.min(Math.floor(Math.log(o)/Math.log(1024)),on.length-1);return `${Math.round(o/Math.pow(1024,e)*100)/100} ${on[e]}`}function or(o){if(!o)return "";try{let e=o instanceof Date?o:new Date(o);return isNaN(e.getTime())?"":e.toLocaleString("ko-KR",{year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1})}catch{return ""}}var Xe=class{hbs;execPolicy;execEnabled;constructor(e={}){this.hbs=de__namespace.create(),this.execPolicy=e.execPolicy??{allow:[],deny:[]},this.execEnabled=e.execEnabled??true,this.registerHelpers();}registerHelpers(){let e=this.hbs,t=this.execPolicy,r=this.execEnabled;e.registerHelper("exec",function(n){return typeof n!="string"?"":r?new e.SafeString(tn(n,t)):"(exec disabled)"}),e.registerHelper("include",function(n){return new e.SafeString(rn(n))}),e.registerHelper("fenced_code",function(n,s){return new e.SafeString(nn(n,s))}),e.registerHelper("eq",function(n,s){return n===s}),e.registerHelper("ne",function(n,s){return n!==s}),e.registerHelper("and",function(n,s){return n&&s}),e.registerHelper("or",function(n,s){return n||s}),e.registerHelper("not",function(n){return !n}),e.registerHelper("contains",function(n,s){return Array.isArray(n)&&n.includes(s)}),e.registerHelper("json",function(n){return JSON.stringify(n,null,2)}),e.registerHelper("truncate",function(n,s){return er(n,s)}),e.registerHelper("length",function(n){return tr(n)}),e.registerHelper("escapeHandlebars",function(n){return new e.SafeString(rr(n))}),e.registerHelper("formatFileSize",function(n){return nr(n)}),e.registerHelper("formatTimestamp",function(n){return or(n)});}async render(e,t={}){return this.hbs.compile(e,{noEscape:true})(t)}};l();l();var At=class{async readFile(e){return promises.readFile(e,"utf-8")}async exists(e){try{return await promises.access(e),!0}catch{return false}}resolvePath(...e){return e.length===1?W.resolve(e[0]):W.resolve(W.join(...e))}isAbsolute(e){return W.isAbsolute(e)}async readdir(e){try{return await promises.readdir(e)}catch{return []}}},Re=new At;var Pe=class{docs=new Map;fs;constructor(e){this.fs=e??Re;}async load(e,t){if(e)for(let[r,n]of Object.entries(e)){let s=n;if(typeof s=="string")this.docs.set(r,{content:s});else if(s&&typeof s=="object"){let i=s;"content"in i&&typeof i.content=="string"?this.docs.set(r,{content:i.content}):"path"in i&&typeof i.path=="string"?await this.loadFromFile(r,i.path,t):console.warn(`[DocumentLoader] Skipping '${r}': unsupported format`);}else console.warn(`[DocumentLoader] Skipping '${r}': unsupported format`);}}async getContent(e){return this.docs.get(e)?.content}async getToc(e){let t=this.docs.get(e);if(!t)return;let r=[];for(let n of t.content.split(`
46
46
  `)){let s=/^(#{1,6})\s+(.+)$/.exec(n.trim());s&&r.push({depth:s[1].length,text:s[2].trim()});}if(r.length!==0)return r.map(({depth:n,text:s})=>`${" ".repeat(n-1)}- ${s}`).join(`
47
- `)}getPath(e){return this.docs.get(e)?.path}getNames(){return Array.from(this.docs.keys())}async buildContext(){let e={};for(let t of this.docs.keys()){let r=await this.getContent(t)??"",n=await this.getToc(t),s=this.getPath(t);e[t]={content:r,toc:n,...s?{path:s}:{}};}return e}async loadFromFile(e,t,r){try{let n=this.resolve(t,r),s=await this.fs.readFile(n);this.docs.set(e,{content:s,path:n});}catch(n){let s=n instanceof Error?n.message:String(n);console.warn(`[DocumentLoader] Failed to load '${e}' from '${t}': ${s}`);}}resolve(e,t){return this.fs.isAbsolute(e)?e:t?this.fs.resolvePath(t,e):this.fs.resolvePath(e)}};l();l();var V=class extends Error{constructor(t,r,n){super(t);this.layoutId=r;this.cause=n;this.name="LayoutLoadError";}layoutId;cause},ue=class extends Error{constructor(t,r=[],n){super(t);this.errors=r;this.cause=n;this.name="PropsValidationError";}errors;cause};var ds={validationMode:"lenient",fallbackLayoutId:"crewx/default"},Xe=class{layouts=new Map;options;constructor(e){this.options={...ds,...e,templatesPath:e?.templatesPath??Ne()},this.loadAllLayouts();}load(e,t){let r=this.layouts.get(e);if(!r){let n=this.normalizeLayoutId(e);r=this.layouts.get(n);}if(!r&&(console.warn(`Layout not found: ${e}, falling back to ${this.options.fallbackLayoutId}`),r=this.layouts.get(this.options.fallbackLayoutId),!r))throw new V(`Fallback layout not found: ${this.options.fallbackLayoutId}`,this.options.fallbackLayoutId);return t&&Object.keys(t).length>0?{...r,defaultProps:{...r.defaultProps,...t}}:r}getLayoutIds(){return Array.from(this.layouts.keys())}hasLayout(e){if(this.layouts.has(e))return true;let t=this.normalizeLayoutId(e);return this.layouts.has(t)}reload(){this.layouts.clear(),this.loadAllLayouts();}registerLayout(e,t){if(!e||typeof e!="string")throw new V("Layout ID must be a non-empty string",e);let r=typeof t=="string"?{template:t}:t,n=typeof r.template=="string"?r.template:"";if(!n||n.trim().length===0)throw new V(`Custom layout template is empty for ${e}`,e);let s=r.propsSchema||{},i=this.extractDefaultProps(s),a=r.defaultProps||{},d={id:e,version:r.version||"1.0.0",description:r.description||`Custom layout ${e}`,template:n,propsSchema:this.parsePropsSchema(s),defaultProps:{...i,...a}},c=this.layouts.get(e),u=c?.template===n&&JSON.stringify(c?.defaultProps??{})===JSON.stringify(d.defaultProps??{})&&JSON.stringify(c?.propsSchema??{})===JSON.stringify(d.propsSchema??{});this.layouts.set(e,d),process.env.CREWX_VERBOSE==="1"&&(c?u||console.error(`Updated custom layout: ${e}`):console.error(`Registered custom layout: ${e}`));}registerLayouts(e){for(let[t,r]of Object.entries(e))try{this.registerLayout(t,r);}catch(n){console.warn(`Failed to register custom layout ${t}:`,n instanceof Error?n.message:n);}}loadAllLayouts(){let e=this.options.templatesPath;if(!fs$1.existsSync(e))throw new V(`Templates directory not found: ${e}`,void 0,new Error(`Directory does not exist: ${e}`));try{let t=fs$1.readdirSync(e).filter(r=>r.endsWith(".yaml")||r.endsWith(".yml"));t.length===0&&console.warn(`No layout files found in ${e}`);for(let r of t){let n=r.replace(/\.(yaml|yml)$/,""),s=F__namespace.join(e,r);try{let i=this.loadLayoutFile(s,n),a=`crewx/${n}`;this.layouts.set(a,i),a!=="crewx/minimal"&&process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded layout: ${a} from ${r}`);}catch(i){console.error(`Failed to load layout file ${r}:`,i);}}process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded ${this.layouts.size} layouts from ${e}`);}catch(t){throw new V(`Failed to read layouts directory: ${e}`,void 0,t instanceof Error?t:new Error(String(t)))}}loadLayoutFile(e,t){try{let r=fs$1.readFileSync(e,"utf-8");if(!r||r.trim().length===0)throw console.warn(`Empty YAML file: ${e}, will use fallback`),new V(`Empty YAML file: ${e}`,t,new Error("File content is empty"));let n=jsYaml.load(r);if(!n||typeof n!="object")throw console.warn(`Invalid YAML content in ${e} (parsed as ${typeof n}), will use fallback`),new V(`Invalid or empty YAML in ${e}`,t,new Error("YAML parsing returned null/undefined or non-object"));if(n.layouts&&typeof n.layouts=="object"){let s=this.resolveLayoutEntry(n.layouts,t);if(!s||s.template.trim().length===0)throw console.warn(`Empty or missing layout template in ${e} for ${t}`),new V(`Layout template not found or empty in layouts map: ${t}`,t);let i=s.propsSchema||n.propsSchema||{};return {id:`crewx/${t}`,version:n.version||"1.0.0",description:n.description||`CrewX ${t} layout`,template:s.template,propsSchema:this.parsePropsSchema(i),defaultProps:this.extractDefaultProps(i)}}else {if(!n.template||typeof n.template=="string"&&n.template.trim().length===0)throw console.warn(`Empty or missing template field in ${e}`),new V(`Layout template is missing or empty in ${e}`,t);return {id:n.id||`crewx/${t}`,version:n.version||"1.0.0",description:n.description||"",template:n.template,propsSchema:this.parsePropsSchema(n.propsSchema||{}),defaultProps:this.extractDefaultProps(n.propsSchema||{})}}}catch(r){throw new V(`Failed to load layout file: ${e}`,t,r instanceof Error?r:new Error(String(r)))}}parsePropsSchema(e){let t={};for(let[r,n]of Object.entries(e))typeof n=="object"&&n!==null&&(t[r]=n);return t}extractDefaultProps(e){let t={};for(let[r,n]of Object.entries(e))n&&typeof n=="object"&&("defaultValue"in n?t[r]=n.defaultValue:"default"in n&&(t[r]=n.default));return t}normalizeLayoutId(e){return e?e.includes("/")?e:`crewx/${e}`:this.options.fallbackLayoutId}resolveLayoutEntry(e,t){let r=new Set;if(t)if(r.add(t),t.includes("/")){let n=t.split("/"),s=n[n.length-1];s&&r.add(s);}else r.add(`crewx/${t}`);r.add("default");for(let n of r){let s=e[n];if(typeof s=="string"&&s.trim().length>0)return {template:s};if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}for(let n of Object.values(e)){if(typeof n=="string"&&n.trim().length>0)return {template:n};let s=n;if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}}};l();l();function ls(o){return Array.from(new Set(o.filter(e=>e?.isAssistant&&e?.metadata?.agent_id).map(e=>String(e.metadata.agent_id))))}function sn(o,e,t){if(!Array.isArray(o)||o.length===0||!(t&&typeof t.fn=="function"))return "";let n=ls(o),s=n.length>0?n[0]:"",i={messages:o,platform:typeof e=="string"?e:"",messagesCount:o.length,agentIds:n,primaryAgentId:s};return t.fn(i)}l();var Ge=class{defaultMode;constructor(e={}){this.defaultMode=e.defaultMode??"lenient";}validate(e,t,r=this.defaultMode){let n=[],s=this.validateObject(e??{},t,r,["props"],n);if(n.length>0&&r==="strict")throw new ue("Props validation failed in strict mode",n);return {valid:n.length===0,props:s,errors:n}}validateObject(e,t,r,n,s){let i={};if(r==="strict")for(let a of Object.keys(e))t[a]||s.push({path:this.buildPath([...n,a]),message:`Unknown prop '${a}'`,value:e[a]});for(let[a,d]of Object.entries(t)){let c=[...n,a],u=e[a],m=this.resolveProp(u,d,c,r,s);m.shouldAssign&&(i[a]=m.value);}return i}resolveProp(e,t,r,n,s){let i=this.buildPath(r);if(this.isNil(e)){if(t.isRequired&&s.push({path:i,message:`Required prop '${r[r.length-1]}' is missing`}),t.defaultValue!==void 0)return {shouldAssign:true,value:this.cloneValue(t.defaultValue)};if(t.type==="shape"&&t.shape){let d=this.applyDefaults(t.shape);if(Object.keys(d).length>0)return {shouldAssign:true,value:d}}return {shouldAssign:false}}let a=this.validateType(e,t,r,n,s);if(!a.valid){if(t.type==="shape"&&a.value&&this.isPlainObject(a.value))return {shouldAssign:true,value:a.value};if(s.push({path:i,message:a.error??"Invalid value",value:e}),t.defaultValue!==void 0)return {shouldAssign:true,value:this.cloneValue(t.defaultValue)};if(t.type==="shape"&&t.shape){let d=this.applyDefaults(t.shape);if(Object.keys(d).length>0)return {shouldAssign:true,value:d}}return {shouldAssign:false}}return {shouldAssign:true,value:a.value}}validateType(e,t,r,n,s){let{type:i}=t;switch(i){case "string":return this.validateString(e,t);case "number":return this.validateNumber(e,t);case "bool":return this.validateBoolean(e);case "array":return this.validateArray(e,t);case "arrayOf":return this.validateArrayOf(e,t,r,n,s);case "object":return this.validatePlainObject(e);case "shape":return this.validateShape(e,t,r,n,s);case "oneOfType":return this.validateOneOfType(e,t);case "func":return this.validateFunction(e);case "node":return {valid:true,value:e};default:return {valid:true,value:e}}}validateString(e,t){return typeof e!="string"?{valid:false,error:`Expected string, got ${this.describeType(e)}`}:t.oneOf&&!t.oneOf.includes(e)?{valid:false,error:`Expected one of: ${t.oneOf.join(", ")}`}:t.minLength!==void 0&&e.length<t.minLength?{valid:false,error:`String length must be >= ${t.minLength}`}:t.maxLength!==void 0&&e.length>t.maxLength?{valid:false,error:`String length must be <= ${t.maxLength}`}:t.pattern&&!new RegExp(t.pattern).test(e)?{valid:false,error:`String does not match pattern ${t.pattern}`}:{valid:true,value:e}}validateNumber(e,t){return typeof e!="number"||Number.isNaN(e)?{valid:false,error:`Expected number, got ${this.describeType(e)}`}:t.min!==void 0&&e<t.min?{valid:false,error:`Number must be >= ${t.min}`}:t.max!==void 0&&e>t.max?{valid:false,error:`Number must be <= ${t.max}`}:t.oneOf&&!t.oneOf.includes(e)?{valid:false,error:`Expected one of: ${t.oneOf.join(", ")}`}:{valid:true,value:e}}validateBoolean(e){return typeof e!="boolean"?{valid:false,error:`Expected boolean, got ${this.describeType(e)}`}:{valid:true,value:e}}validateArray(e,t){return Array.isArray(e)?t.minLength!==void 0&&e.length<t.minLength?{valid:false,error:`Array length must be >= ${t.minLength}`}:t.maxLength!==void 0&&e.length>t.maxLength?{valid:false,error:`Array length must be <= ${t.maxLength}`}:{valid:true,value:[...e]}:{valid:false,error:`Expected array, got ${this.describeType(e)}`}}validateArrayOf(e,t,r,n,s){let i=this.validateArray(e,t);if(!i.valid)return i;let a=[],d=t.itemType,c=t.itemOneOf,u=s.length;return i.value.forEach((m,g)=>{let p=[...r,String(g)];if(d){let y=this.validateType(m,{type:d},p,n,s);y.valid?a.push(y.value):s.push({path:this.buildPath(p),message:y.error??"Invalid array item",value:m});}else a.push(m);c&&!c.includes(m)&&s.push({path:this.buildPath(p),message:`Array item must be one of: ${c.join(", ")}`,value:m});}),{valid:s.length===u,value:a}}validatePlainObject(e){return this.isPlainObject(e)?{valid:true,value:{...e}}:{valid:false,error:`Expected object, got ${this.describeType(e)}`}}validateFunction(e){return typeof e!="function"?{valid:false,error:`Expected function, got ${this.describeType(e)}`}:{valid:true,value:e}}validateShape(e,t,r,n,s){if(!this.isPlainObject(e))return {valid:false,error:`Expected object, got ${this.describeType(e)}`};let i=s.length,a=this.validateObject(e,t.shape??{},n,r,s);return {valid:s.length===i,value:a}}validateOneOfType(e,t){let r=t.types??[];return r.some(s=>this.matchesType(e,s))?{valid:true,value:e}:{valid:false,error:`Value does not match any allowed type: ${r.join(", ")}`}}matchesType(e,t){switch(t){case "string":return typeof e=="string";case "number":return typeof e=="number"&&!Number.isNaN(e);case "bool":case "boolean":return typeof e=="boolean";case "array":return Array.isArray(e);case "object":return this.isPlainObject(e);case "func":case "function":return typeof e=="function";case "shape":return this.isPlainObject(e);case "node":return e==null||typeof e!="symbol";default:return true}}applyDefaults(e){let t={};for(let[r,n]of Object.entries(e)){if(n.defaultValue!==void 0){t[r]=this.cloneValue(n.defaultValue);continue}if(n.type==="shape"&&n.shape){let s=this.applyDefaults(n.shape);Object.keys(s).length>0&&(t[r]=s);}}return t}cloneValue(e){if(Array.isArray(e))return e.map(t=>this.cloneValue(t));if(this.isPlainObject(e)){let t={};for(let[r,n]of Object.entries(e))t[r]=this.cloneValue(n);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}isNil(e){return e==null}buildPath(e){return e.join(".")}describeType(e){return Array.isArray(e)?"array":e===null?"null":typeof e}};var Ye=class{handlebars;propsValidator;constructor(e){this.handlebars=ie__namespace.default.create(),this.propsValidator=e??new Ge,this.registerHelpers();}render(e,t,r={}){try{let n=this.prepareRenderContext(e,t,r);return this.handlebars.compile(e.template,{noEscape:!0})(n)}catch(n){throw n instanceof Error?new Error(`Template rendering failed for layout '${e.id}': ${n.message}`):new Error(`Unknown error rendering layout '${e.id}'`)}}validate(e,t,r="lenient"){return this.executeValidation(e,t,r)}resolveProps(e,t,r="lenient"){let n=this.mergeProps(e.defaultProps,t);return !e.propsSchema||Object.keys(e.propsSchema).length===0?{valid:true,props:n,errors:[]}:this.executeValidation(n,e.propsSchema,r)}prepareRenderContext(e,t,r){let{validationMode:n="lenient",skipValidation:s=false}=r,i=s?this.mergeProps(e.defaultProps,t.props):this.resolveProps(e,t.props,n).props;return {...t,vars:this.sanitizeVars(t.vars),props:i}}registerHelpers(){this.handlebars.registerHelper("formatConversation",sn),ie__namespace.default.helpers.each&&this.handlebars.registerHelper("each",ie__namespace.default.helpers.each),ie__namespace.default.helpers.if&&this.handlebars.registerHelper("if",ie__namespace.default.helpers.if),ie__namespace.default.helpers.unless&&this.handlebars.registerHelper("unless",ie__namespace.default.helpers.unless),ie__namespace.default.helpers.with&&this.handlebars.registerHelper("with",ie__namespace.default.helpers.with),this.handlebars.registerHelper("eq",function(e,t){return e===t}),this.handlebars.registerHelper("ne",function(e,t){return e!==t}),this.handlebars.registerHelper("gt",function(e,t){return e>t}),this.handlebars.registerHelper("lt",function(e,t){return e<t}),this.handlebars.registerHelper("json",function(e){return new ie__namespace.default.SafeString(JSON.stringify(e))}),this.handlebars.registerHelper("raw",function(e){return typeof e?.fn=="function"?e.fn(this):""}),this.handlebars.registerHelper("escapeHandlebars",function(e){return typeof e!="string"?"":e.replace(/\{\{/g,"&#123;&#123;").replace(/\}\}/g,"&#125;&#125;")}),this.handlebars.registerHelper("formatFileSize",function(e){if(e===0)return "0 B";let t=["B","KB","MB","GB"],r=Math.floor(Math.log(e)/Math.log(1024));return Math.round(e/Math.pow(1024,r)*100)/100+" "+t[r]});}executeValidation(e,t,r){try{return this.propsValidator.validate(e,t,r)}catch(n){if(n instanceof ue&&n.errors&&n.errors.length>0){let s=n.errors[0];if(s)throw new ue(s.message,n.errors)}throw n}}mergeProps(e,t){let r=this.cloneDeep(e??{});return t?this.deepMerge(r,t):r}deepMerge(e,t){for(let[r,n]of Object.entries(t)){if(this.isPlainObject(n)){let s=e[r];e[r]=this.deepMerge(this.isPlainObject(s)?s:{},n);continue}if(Array.isArray(n)){e[r]=this.cloneDeep(n);continue}e[r]=n;}return e}cloneDeep(e){if(Array.isArray(e))return e.map(t=>this.cloneDeep(t));if(this.isPlainObject(e)){let t={};for(let[r,n]of Object.entries(e))t[r]=this.cloneDeep(n);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}sanitizeVars(e){if(!e)return {};let t={...e};if(typeof e.user_input=="string"){t.user_input_raw=e.user_input;let r=e.user_input.replace(/\{\{\{/g,"&#123;&#123;&#123;").replace(/\}\}\}/g,"&#125;&#125;&#125;").replace(/\{\{/g,"&#123;&#123;").replace(/\}\}/g,"&#125;&#125;");t.user_input=this.handlebars.escapeExpression(r);}return t}};l();var nr="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function cs(o){let e=crypto$1.randomBytes(o*2),t="";for(let r=0;r<e.length&&t.length<o;r++){let n=e[r];n<248&&(t+=nr[n%62]);}for(;t.length<o;)t+=nr[crypto$1.randomBytes(1)[0]%62];return t}function Ae(o){return `${o}_${cs(8)}`}function us(o,e){let{createHash:t}=W("crypto"),r=t("sha256").update(e).digest(),n=Buffer.alloc(8);for(let i=0;i<32;i++)n[i%8]^=r[i];let s="";for(let i of n)s+=nr[i%62];return `${o}_${s}`}l();function or(o){let e=t=>String(t).padStart(2,"0");return `${o.getFullYear()}${e(o.getMonth()+1)}${e(o.getDate())}T${e(o.getHours())}${e(o.getMinutes())}${e(o.getSeconds())}`}l();function dn(o,e){return t=>{try{let r=e(t);r instanceof Promise&&r.catch(n=>{console.error(`[crewx] event listener error (${o}): ${n instanceof Error?n.message:String(n)}`);});}catch(r){console.error(`[crewx] event listener error (${o}): ${r instanceof Error?r.message:String(r)}`);}}}var Qe=class{_emitter=new events.EventEmitter;on(e,t){let r=dn(e,t);return this._emitter.on(e,r),()=>this._emitter.off(e,r)}once(e,t){let r=dn(e,t);return this._emitter.once(e,r),()=>this._emitter.off(e,r)}emit(e,t){this._emitter.emit(e,t);}};l();function sr(o){let e=new Map,t=r=>r.startsWith(`${o}::`)?r:`${o}::${r}`;return {async get(r){let n=e.get(t(r));return n?n.value:void 0},async set(r,n){e.set(t(r),{value:n});},async delete(r){return e.delete(t(r))},async list(r){let n=r?t(r):`${o}::`,s=[];for(let i of e.keys())i.startsWith(n)&&s.push(i.slice(o.length+2));return s}}}l();var ir=new async_hooks.AsyncLocalStorage;function ms(){return ir}function fs(o,e){return ir.run(o,e)}function ar(o){let e=o.log??o.logger??{debug:()=>{},info:()=>{},warn:()=>{},error:()=>{}},t=o.agentRunner??{run:async()=>({output:""})},r=o.db??{get:async()=>{},set:async()=>{},delete:async()=>false,list:async()=>[]},n=o.storage??{put:async()=>"",get:async()=>{},delete:async()=>false},s=o.audit??{log:async()=>{}},i=o.onInbound??(async()=>({accepted:true})),a=o.onEmitEvent??(async()=>({accepted:true})),d=o.onUpdateMessage??(async()=>{}),c=o.onResolveUser??(async g=>({userId:g,displayName:g})),u=async g=>{let p=ir.getStore();if(!p){e.warn("respondSync called outside sync window \u2014 graceful degradation (no-op)",{textPreview:typeof g=="object"&&"text"in g?g.text.slice(0,80):void 0});return}let y="text"in g?g.text:"";p.res.status(200).json({text:y});},m=o.httpRouter??{registerRoute:()=>{e.warn("httpRouter not configured \u2014 registerRoute is a no-op");}};return {instanceId:o.instanceId,config:o.config,capabilities:o.capabilities,log:e,agentRunner:t,db:r,storage:n,audit:s,abortSignal:o.abortSignal??new AbortController().signal,httpRouter:m,inbound:i,emitEvent:a,updateMessage:d,resolveUser:c,respondSync:u}}je();l();var ys=/^-\s*Status:\s*active/m,hs=/^---\n([\s\S]*?)\n---/,ws=/^type:\s*goal\s*$/m;async function ln(o,e=_e,t){let r=typeof t=="string"?[t]:Array.isArray(t)?t:void 0;if(r){let a=[];for(let d of r){let c=e.resolvePath(o,d);await e.exists(c)&&a.push(await e.readFile(c));}return a.join(`
47
+ `)}getPath(e){return this.docs.get(e)?.path}getNames(){return Array.from(this.docs.keys())}async buildContext(){let e={};for(let t of this.docs.keys()){let r=await this.getContent(t)??"",n=await this.getToc(t),s=this.getPath(t);e[t]={content:r,toc:n,...s?{path:s}:{}};}return e}async loadFromFile(e,t,r){try{let n=this.resolve(t,r),s=await this.fs.readFile(n);this.docs.set(e,{content:s,path:n});}catch(n){let s=n instanceof Error?n.message:String(n);console.warn(`[DocumentLoader] Failed to load '${e}' from '${t}': ${s}`);}}resolve(e,t){return this.fs.isAbsolute(e)?e:t?this.fs.resolvePath(t,e):this.fs.resolvePath(e)}};l();l();var J=class extends Error{constructor(t,r,n){super(t);this.layoutId=r;this.cause=n;this.name="LayoutLoadError";}layoutId;cause},ge=class extends Error{constructor(t,r=[],n){super(t);this.errors=r;this.cause=n;this.name="PropsValidationError";}errors;cause};var us={validationMode:"lenient",fallbackLayoutId:"crewx/default"},Ge=class{layouts=new Map;options;constructor(e){this.options={...us,...e,templatesPath:e?.templatesPath??De()},this.loadAllLayouts();}load(e,t){let r=this.layouts.get(e);if(!r){let n=this.normalizeLayoutId(e);r=this.layouts.get(n);}if(!r&&(console.warn(`Layout not found: ${e}, falling back to ${this.options.fallbackLayoutId}`),r=this.layouts.get(this.options.fallbackLayoutId),!r))throw new J(`Fallback layout not found: ${this.options.fallbackLayoutId}`,this.options.fallbackLayoutId);return t&&Object.keys(t).length>0?{...r,defaultProps:{...r.defaultProps,...t}}:r}getLayoutIds(){return Array.from(this.layouts.keys())}hasLayout(e){if(this.layouts.has(e))return true;let t=this.normalizeLayoutId(e);return this.layouts.has(t)}reload(){this.layouts.clear(),this.loadAllLayouts();}registerLayout(e,t){if(!e||typeof e!="string")throw new J("Layout ID must be a non-empty string",e);let r=typeof t=="string"?{template:t}:t,n=typeof r.template=="string"?r.template:"";if(!n||n.trim().length===0)throw new J(`Custom layout template is empty for ${e}`,e);let s=r.propsSchema||{},i=this.extractDefaultProps(s),a=r.defaultProps||{},d={id:e,version:r.version||"1.0.0",description:r.description||`Custom layout ${e}`,template:n,propsSchema:this.parsePropsSchema(s),defaultProps:{...i,...a}},c=this.layouts.get(e),u=c?.template===n&&JSON.stringify(c?.defaultProps??{})===JSON.stringify(d.defaultProps??{})&&JSON.stringify(c?.propsSchema??{})===JSON.stringify(d.propsSchema??{});this.layouts.set(e,d),process.env.CREWX_VERBOSE==="1"&&(c?u||console.error(`Updated custom layout: ${e}`):console.error(`Registered custom layout: ${e}`));}registerLayouts(e){for(let[t,r]of Object.entries(e))try{this.registerLayout(t,r);}catch(n){console.warn(`Failed to register custom layout ${t}:`,n instanceof Error?n.message:n);}}loadAllLayouts(){let e=this.options.templatesPath;if(!fs.existsSync(e))throw new J(`Templates directory not found: ${e}`,void 0,new Error(`Directory does not exist: ${e}`));try{let t=fs.readdirSync(e).filter(r=>r.endsWith(".yaml")||r.endsWith(".yml"));t.length===0&&console.warn(`No layout files found in ${e}`);for(let r of t){let n=r.replace(/\.(yaml|yml)$/,""),s=W__namespace.join(e,r);try{let i=this.loadLayoutFile(s,n),a=`crewx/${n}`;this.layouts.set(a,i),a!=="crewx/minimal"&&process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded layout: ${a} from ${r}`);}catch(i){console.error(`Failed to load layout file ${r}:`,i);}}process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded ${this.layouts.size} layouts from ${e}`);}catch(t){throw new J(`Failed to read layouts directory: ${e}`,void 0,t instanceof Error?t:new Error(String(t)))}}loadLayoutFile(e,t){try{let r=fs.readFileSync(e,"utf-8");if(!r||r.trim().length===0)throw console.warn(`Empty YAML file: ${e}, will use fallback`),new J(`Empty YAML file: ${e}`,t,new Error("File content is empty"));let n=jsYaml.load(r);if(!n||typeof n!="object")throw console.warn(`Invalid YAML content in ${e} (parsed as ${typeof n}), will use fallback`),new J(`Invalid or empty YAML in ${e}`,t,new Error("YAML parsing returned null/undefined or non-object"));if(n.layouts&&typeof n.layouts=="object"){let s=this.resolveLayoutEntry(n.layouts,t);if(!s||s.template.trim().length===0)throw console.warn(`Empty or missing layout template in ${e} for ${t}`),new J(`Layout template not found or empty in layouts map: ${t}`,t);let i=s.propsSchema||n.propsSchema||{};return {id:`crewx/${t}`,version:n.version||"1.0.0",description:n.description||`CrewX ${t} layout`,template:s.template,propsSchema:this.parsePropsSchema(i),defaultProps:this.extractDefaultProps(i)}}else {if(!n.template||typeof n.template=="string"&&n.template.trim().length===0)throw console.warn(`Empty or missing template field in ${e}`),new J(`Layout template is missing or empty in ${e}`,t);return {id:n.id||`crewx/${t}`,version:n.version||"1.0.0",description:n.description||"",template:n.template,propsSchema:this.parsePropsSchema(n.propsSchema||{}),defaultProps:this.extractDefaultProps(n.propsSchema||{})}}}catch(r){throw new J(`Failed to load layout file: ${e}`,t,r instanceof Error?r:new Error(String(r)))}}parsePropsSchema(e){let t={};for(let[r,n]of Object.entries(e))typeof n=="object"&&n!==null&&(t[r]=n);return t}extractDefaultProps(e){let t={};for(let[r,n]of Object.entries(e))n&&typeof n=="object"&&("defaultValue"in n?t[r]=n.defaultValue:"default"in n&&(t[r]=n.default));return t}normalizeLayoutId(e){return e?e.includes("/")?e:`crewx/${e}`:this.options.fallbackLayoutId}resolveLayoutEntry(e,t){let r=new Set;if(t)if(r.add(t),t.includes("/")){let n=t.split("/"),s=n[n.length-1];s&&r.add(s);}else r.add(`crewx/${t}`);r.add("default");for(let n of r){let s=e[n];if(typeof s=="string"&&s.trim().length>0)return {template:s};if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}for(let n of Object.values(e)){if(typeof n=="string"&&n.trim().length>0)return {template:n};let s=n;if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}}};l();l();function ps(o){return Array.from(new Set(o.filter(e=>e?.isAssistant&&e?.metadata?.agent_id).map(e=>String(e.metadata.agent_id))))}function ln(o,e,t){if(!Array.isArray(o)||o.length===0||!(t&&typeof t.fn=="function"))return "";let n=ps(o),s=n.length>0?n[0]:"",i={messages:o,platform:typeof e=="string"?e:"",messagesCount:o.length,agentIds:n,primaryAgentId:s};return t.fn(i)}l();var Ye=class{defaultMode;constructor(e={}){this.defaultMode=e.defaultMode??"lenient";}validate(e,t,r=this.defaultMode){let n=[],s=this.validateObject(e??{},t,r,["props"],n);if(n.length>0&&r==="strict")throw new ge("Props validation failed in strict mode",n);return {valid:n.length===0,props:s,errors:n}}validateObject(e,t,r,n,s){let i={};if(r==="strict")for(let a of Object.keys(e))t[a]||s.push({path:this.buildPath([...n,a]),message:`Unknown prop '${a}'`,value:e[a]});for(let[a,d]of Object.entries(t)){let c=[...n,a],u=e[a],g=this.resolveProp(u,d,c,r,s);g.shouldAssign&&(i[a]=g.value);}return i}resolveProp(e,t,r,n,s){let i=this.buildPath(r);if(this.isNil(e)){if(t.isRequired&&s.push({path:i,message:`Required prop '${r[r.length-1]}' is missing`}),t.defaultValue!==void 0)return {shouldAssign:true,value:this.cloneValue(t.defaultValue)};if(t.type==="shape"&&t.shape){let d=this.applyDefaults(t.shape);if(Object.keys(d).length>0)return {shouldAssign:true,value:d}}return {shouldAssign:false}}let a=this.validateType(e,t,r,n,s);if(!a.valid){if(t.type==="shape"&&a.value&&this.isPlainObject(a.value))return {shouldAssign:true,value:a.value};if(s.push({path:i,message:a.error??"Invalid value",value:e}),t.defaultValue!==void 0)return {shouldAssign:true,value:this.cloneValue(t.defaultValue)};if(t.type==="shape"&&t.shape){let d=this.applyDefaults(t.shape);if(Object.keys(d).length>0)return {shouldAssign:true,value:d}}return {shouldAssign:false}}return {shouldAssign:true,value:a.value}}validateType(e,t,r,n,s){let{type:i}=t;switch(i){case "string":return this.validateString(e,t);case "number":return this.validateNumber(e,t);case "bool":return this.validateBoolean(e);case "array":return this.validateArray(e,t);case "arrayOf":return this.validateArrayOf(e,t,r,n,s);case "object":return this.validatePlainObject(e);case "shape":return this.validateShape(e,t,r,n,s);case "oneOfType":return this.validateOneOfType(e,t);case "func":return this.validateFunction(e);case "node":return {valid:true,value:e};default:return {valid:true,value:e}}}validateString(e,t){return typeof e!="string"?{valid:false,error:`Expected string, got ${this.describeType(e)}`}:t.oneOf&&!t.oneOf.includes(e)?{valid:false,error:`Expected one of: ${t.oneOf.join(", ")}`}:t.minLength!==void 0&&e.length<t.minLength?{valid:false,error:`String length must be >= ${t.minLength}`}:t.maxLength!==void 0&&e.length>t.maxLength?{valid:false,error:`String length must be <= ${t.maxLength}`}:t.pattern&&!new RegExp(t.pattern).test(e)?{valid:false,error:`String does not match pattern ${t.pattern}`}:{valid:true,value:e}}validateNumber(e,t){return typeof e!="number"||Number.isNaN(e)?{valid:false,error:`Expected number, got ${this.describeType(e)}`}:t.min!==void 0&&e<t.min?{valid:false,error:`Number must be >= ${t.min}`}:t.max!==void 0&&e>t.max?{valid:false,error:`Number must be <= ${t.max}`}:t.oneOf&&!t.oneOf.includes(e)?{valid:false,error:`Expected one of: ${t.oneOf.join(", ")}`}:{valid:true,value:e}}validateBoolean(e){return typeof e!="boolean"?{valid:false,error:`Expected boolean, got ${this.describeType(e)}`}:{valid:true,value:e}}validateArray(e,t){return Array.isArray(e)?t.minLength!==void 0&&e.length<t.minLength?{valid:false,error:`Array length must be >= ${t.minLength}`}:t.maxLength!==void 0&&e.length>t.maxLength?{valid:false,error:`Array length must be <= ${t.maxLength}`}:{valid:true,value:[...e]}:{valid:false,error:`Expected array, got ${this.describeType(e)}`}}validateArrayOf(e,t,r,n,s){let i=this.validateArray(e,t);if(!i.valid)return i;let a=[],d=t.itemType,c=t.itemOneOf,u=s.length;return i.value.forEach((g,f)=>{let p=[...r,String(f)];if(d){let m=this.validateType(g,{type:d},p,n,s);m.valid?a.push(m.value):s.push({path:this.buildPath(p),message:m.error??"Invalid array item",value:g});}else a.push(g);c&&!c.includes(g)&&s.push({path:this.buildPath(p),message:`Array item must be one of: ${c.join(", ")}`,value:g});}),{valid:s.length===u,value:a}}validatePlainObject(e){return this.isPlainObject(e)?{valid:true,value:{...e}}:{valid:false,error:`Expected object, got ${this.describeType(e)}`}}validateFunction(e){return typeof e!="function"?{valid:false,error:`Expected function, got ${this.describeType(e)}`}:{valid:true,value:e}}validateShape(e,t,r,n,s){if(!this.isPlainObject(e))return {valid:false,error:`Expected object, got ${this.describeType(e)}`};let i=s.length,a=this.validateObject(e,t.shape??{},n,r,s);return {valid:s.length===i,value:a}}validateOneOfType(e,t){let r=t.types??[];return r.some(s=>this.matchesType(e,s))?{valid:true,value:e}:{valid:false,error:`Value does not match any allowed type: ${r.join(", ")}`}}matchesType(e,t){switch(t){case "string":return typeof e=="string";case "number":return typeof e=="number"&&!Number.isNaN(e);case "bool":case "boolean":return typeof e=="boolean";case "array":return Array.isArray(e);case "object":return this.isPlainObject(e);case "func":case "function":return typeof e=="function";case "shape":return this.isPlainObject(e);case "node":return e==null||typeof e!="symbol";default:return true}}applyDefaults(e){let t={};for(let[r,n]of Object.entries(e)){if(n.defaultValue!==void 0){t[r]=this.cloneValue(n.defaultValue);continue}if(n.type==="shape"&&n.shape){let s=this.applyDefaults(n.shape);Object.keys(s).length>0&&(t[r]=s);}}return t}cloneValue(e){if(Array.isArray(e))return e.map(t=>this.cloneValue(t));if(this.isPlainObject(e)){let t={};for(let[r,n]of Object.entries(e))t[r]=this.cloneValue(n);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}isNil(e){return e==null}buildPath(e){return e.join(".")}describeType(e){return Array.isArray(e)?"array":e===null?"null":typeof e}};var Qe=class{handlebars;propsValidator;constructor(e){this.handlebars=de__namespace.default.create(),this.propsValidator=e??new Ye,this.registerHelpers();}render(e,t,r={}){try{let n=this.prepareRenderContext(e,t,r);return this.handlebars.compile(e.template,{noEscape:!0})(n)}catch(n){throw n instanceof Error?new Error(`Template rendering failed for layout '${e.id}': ${n.message}`):new Error(`Unknown error rendering layout '${e.id}'`)}}validate(e,t,r="lenient"){return this.executeValidation(e,t,r)}resolveProps(e,t,r="lenient"){let n=this.mergeProps(e.defaultProps,t);return !e.propsSchema||Object.keys(e.propsSchema).length===0?{valid:true,props:n,errors:[]}:this.executeValidation(n,e.propsSchema,r)}prepareRenderContext(e,t,r){let{validationMode:n="lenient",skipValidation:s=false}=r,i=s?this.mergeProps(e.defaultProps,t.props):this.resolveProps(e,t.props,n).props;return {...t,vars:this.sanitizeVars(t.vars),props:i}}registerHelpers(){this.handlebars.registerHelper("formatConversation",ln),de__namespace.default.helpers.each&&this.handlebars.registerHelper("each",de__namespace.default.helpers.each),de__namespace.default.helpers.if&&this.handlebars.registerHelper("if",de__namespace.default.helpers.if),de__namespace.default.helpers.unless&&this.handlebars.registerHelper("unless",de__namespace.default.helpers.unless),de__namespace.default.helpers.with&&this.handlebars.registerHelper("with",de__namespace.default.helpers.with),this.handlebars.registerHelper("eq",function(e,t){return e===t}),this.handlebars.registerHelper("ne",function(e,t){return e!==t}),this.handlebars.registerHelper("gt",function(e,t){return e>t}),this.handlebars.registerHelper("lt",function(e,t){return e<t}),this.handlebars.registerHelper("json",function(e){return new de__namespace.default.SafeString(JSON.stringify(e))}),this.handlebars.registerHelper("raw",function(e){return typeof e?.fn=="function"?e.fn(this):""}),this.handlebars.registerHelper("escapeHandlebars",function(e){return typeof e!="string"?"":e.replace(/\{\{/g,"&#123;&#123;").replace(/\}\}/g,"&#125;&#125;")}),this.handlebars.registerHelper("formatFileSize",function(e){if(e===0)return "0 B";let t=["B","KB","MB","GB"],r=Math.floor(Math.log(e)/Math.log(1024));return Math.round(e/Math.pow(1024,r)*100)/100+" "+t[r]});}executeValidation(e,t,r){try{return this.propsValidator.validate(e,t,r)}catch(n){if(n instanceof ge&&n.errors&&n.errors.length>0){let s=n.errors[0];if(s)throw new ge(s.message,n.errors)}throw n}}mergeProps(e,t){let r=this.cloneDeep(e??{});return t?this.deepMerge(r,t):r}deepMerge(e,t){for(let[r,n]of Object.entries(t)){if(this.isPlainObject(n)){let s=e[r];e[r]=this.deepMerge(this.isPlainObject(s)?s:{},n);continue}if(Array.isArray(n)){e[r]=this.cloneDeep(n);continue}e[r]=n;}return e}cloneDeep(e){if(Array.isArray(e))return e.map(t=>this.cloneDeep(t));if(this.isPlainObject(e)){let t={};for(let[r,n]of Object.entries(e))t[r]=this.cloneDeep(n);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}sanitizeVars(e){if(!e)return {};let t={...e};if(typeof e.user_input=="string"){t.user_input_raw=e.user_input;let r=e.user_input.replace(/\{\{\{/g,"&#123;&#123;&#123;").replace(/\}\}\}/g,"&#125;&#125;&#125;").replace(/\{\{/g,"&#123;&#123;").replace(/\}\}/g,"&#125;&#125;");t.user_input=this.handlebars.escapeExpression(r);}return t}};l();var sr="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function gs(o){let e=crypto$1.randomBytes(o*2),t="";for(let r=0;r<e.length&&t.length<o;r++){let n=e[r];n<248&&(t+=sr[n%62]);}for(;t.length<o;)t+=sr[crypto$1.randomBytes(1)[0]%62];return t}function Ce(o){return `${o}_${gs(8)}`}function ms(o,e){let{createHash:t}=z("crypto"),r=t("sha256").update(e).digest(),n=Buffer.alloc(8);for(let i=0;i<32;i++)n[i%8]^=r[i];let s="";for(let i of n)s+=sr[i%62];return `${o}_${s}`}l();function ir(o){let e=t=>String(t).padStart(2,"0");return `${o.getFullYear()}${e(o.getMonth()+1)}${e(o.getDate())}T${e(o.getHours())}${e(o.getMinutes())}${e(o.getSeconds())}`}l();function un(o,e){return t=>{try{let r=e(t);r instanceof Promise&&r.catch(n=>{console.error(`[crewx] event listener error (${o}): ${n instanceof Error?n.message:String(n)}`);});}catch(r){console.error(`[crewx] event listener error (${o}): ${r instanceof Error?r.message:String(r)}`);}}}var Ze=class{_emitter=new events.EventEmitter;on(e,t){let r=un(e,t);return this._emitter.on(e,r),()=>this._emitter.off(e,r)}once(e,t){let r=un(e,t);return this._emitter.once(e,r),()=>this._emitter.off(e,r)}emit(e,t){this._emitter.emit(e,t);}};l();function ar(o){let e=new Map,t=r=>r.startsWith(`${o}::`)?r:`${o}::${r}`;return {async get(r){let n=e.get(t(r));return n?n.value:void 0},async set(r,n){e.set(t(r),{value:n});},async delete(r){return e.delete(t(r))},async list(r){let n=r?t(r):`${o}::`,s=[];for(let i of e.keys())i.startsWith(n)&&s.push(i.slice(o.length+2));return s}}}l();var dr=new async_hooks.AsyncLocalStorage;function hs(){return dr}function ws(o,e){return dr.run(o,e)}function lr(o){let e=o.log??o.logger??{debug:()=>{},info:()=>{},warn:()=>{},error:()=>{}},t=o.agentRunner??{run:async()=>({output:""})},r=o.db??{get:async()=>{},set:async()=>{},delete:async()=>false,list:async()=>[]},n=o.storage??{put:async()=>"",get:async()=>{},delete:async()=>false},s=o.audit??{log:async()=>{}},i=o.onInbound??(async()=>({accepted:true})),a=o.onEmitEvent??(async()=>({accepted:true})),d=o.onUpdateMessage??(async()=>{}),c=o.onResolveUser??(async f=>({userId:f,displayName:f})),u=async f=>{let p=dr.getStore();if(!p){e.warn("respondSync called outside sync window \u2014 graceful degradation (no-op)",{textPreview:typeof f=="object"&&"text"in f?f.text.slice(0,80):void 0});return}let m="text"in f?f.text:"";p.res.status(200).json({text:m});},g=o.httpRouter??{registerRoute:()=>{e.warn("httpRouter not configured \u2014 registerRoute is a no-op");}};return {instanceId:o.instanceId,config:o.config,capabilities:o.capabilities,log:e,agentRunner:t,db:r,storage:n,audit:s,abortSignal:o.abortSignal??new AbortController().signal,httpRouter:g,inbound:i,emitEvent:a,updateMessage:d,resolveUser:c,respondSync:u}}Ue();l();var xs=/^-\s*Status:\s*active/m,ks=/^---\n([\s\S]*?)\n---/,vs=/^type:\s*goal\s*$/m;async function pn(o,e=Re,t){let r=typeof t=="string"?[t]:Array.isArray(t)?t:void 0;if(r){let a=[];for(let d of r){let c=e.resolvePath(o,d);await e.exists(c)&&a.push(await e.readFile(c));}return a.join(`
48
48
  ---
49
- `)}let s=(await e.readdir(o)).filter(a=>a.endsWith(".md"));if(s.length===0)return "";let i=[];for(let a of s){let d=e.resolvePath(o,a),c=await e.readFile(d),u=hs.exec(c);!u||!ws.test(u[1])||ys.test(c)&&i.push(c);}return i.join(`
49
+ `)}let s=(await e.readdir(o)).filter(a=>a.endsWith(".md"));if(s.length===0)return "";let i=[];for(let a of s){let d=e.resolvePath(o,a),c=await e.readFile(d),u=ks.exec(c);!u||!vs.test(u[1])||xs.test(c)&&i.push(c);}return i.join(`
50
50
  ---
51
- `)}l();function xs(){let o=new Date,e=o.getFullYear(),t=String(o.getMonth()+1).padStart(2,"0"),r=String(o.getDate()).padStart(2,"0");return `${e}-${t}-${r}`}async function cn(o,e=_e){let t=e.resolvePath(o,`${xs()}.md`);return await e.exists(t)?e.readFile(t):""}je();l();function ks(o){return typeof o!="string"?"":o.replace(/</g,"&lt;").replace(/>/g,"&gt;")}function dr(o){return o.messages.map(e=>({text:ks(e.text),isAssistant:e.isAssistant,metadata:e.metadata,files:void 0}))}l();l();var vs={agentId:zod.z.string().describe("The agent ID to query"),query:zod.z.string().describe("The query message to send"),context:zod.z.string().optional().describe("Additional context"),thread:zod.z.string().optional().describe("Thread ID for conversation continuity")},_s={agentId:zod.z.string().describe("The agent ID to execute"),task:zod.z.string().describe("The task description to execute"),context:zod.z.string().optional().describe("Additional context"),thread:zod.z.string().optional().describe("Thread ID for conversation continuity")};function un(o,e,t){o.tool("crewx_listAgents","List available CrewX agents exposed by this server",async()=>{let r=[];for(let n of t){let s=e.agents.get(n);s&&r.push({id:s.id,name:s.name??s.id,description:s.description??""});}return {content:[{type:"text",text:JSON.stringify(r,null,2)}]}}),o.tool("crewx_queryAgent","Query a CrewX agent with a read-only question",vs,async({agentId:r,query:n,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.query(r,n,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Query failed"}],isError:true}}),o.tool("crewx_executeAgent","Execute a task on a CrewX agent (may modify state)",_s,async({agentId:r,task:n,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.execute(r,n,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Execute failed"}],isError:true}});}l();function pn(o){return o.headers.get("Origin")?null:new Response(JSON.stringify({error:"Forbidden: Origin header required"}),{status:403,headers:{"Content-Type":"application/json"}})}async function gn(o,e){return e?await e(o)?null:new Response(JSON.stringify({error:"Unauthorized"}),{status:401,headers:{"Content-Type":"application/json"}}):null}function Ps(o,e){let t=new mcp_js.McpServer({name:"crewx-mcp-server",version:"1.0.0"},{capabilities:{tools:{}}});return un(t,o,e),t}function lr(o,e){if(!e.agents||e.agents.length===0)throw new Error("crewx.handler() requires at least one agent in the agents option");let t=new Set(e.agents),r=new Map;return async n=>{let s=pn(n);if(s)return s;let i=await gn(n,e.auth);if(i)return i;let a=n.headers.get("mcp-session-id");if(a&&r.has(a))return r.get(a).transport.handleRequest(n);let d=Ps(o,t),c=new webStandardStreamableHttp_js.WebStandardStreamableHTTPServerTransport({sessionIdGenerator:()=>crypto.randomUUID(),onsessioninitialized:u=>{r.set(u,{transport:c,server:d});},onsessionclosed:u=>{r.delete(u);},enableJsonResponse:true});return await d.connect(c),c.handleRequest(n)}}l();function fn(o){let e=F__namespace.resolve(o);return process.platform==="win32"&&(e=e.replace(/\\/g,"/"),e=e.replace(/^([A-Z]):/,(t,r)=>`${r.toLowerCase()}:`)),e.length>1&&!/^[a-zA-Z]:\/$/.test(e)&&(e=e.replace(/\/+$/,"")),e}function cr(o){let e=fn(o);return crypto$1.createHash("sha256").update(e).digest("hex")}function Zs(o){return o?o.settings?.template?.exec:void 0}function ei(){try{let o=new Uint8Array(8);return globalThis.crypto.getRandomValues(o),Array.from(o,e=>e.toString(16).padStart(2,"0")).join("")}catch{let{randomBytes:o}=W("crypto");return o(8).toString("hex")}}var Cr=class o extends Qe{_agents;_templateEngine;_documentLoader;_layoutLoader;_layoutRenderer;_config;_projectRoot;_workspaceId;_workspaceName;_plugins=[];_tools=new Map;_activeAdapters=new Map;_pendingThreads=new Map;_remoteFactory;_remoteTargets=new Map;constructor(e,t={},r,n,s){super(),this._agents=new Map(e.map(d=>[d.id,d])),this._config=r,this._projectRoot=s??(typeof process<"u"?process.cwd():"/");let i=s??(typeof process<"u"?process.env.CREWX_WORKSPACE??process.cwd():"/");this._workspaceId=cr(i),this._workspaceName=F.basename(i);let a=Zs(r);this._templateEngine=new Je({execPolicy:t.execPolicy??a}),this._documentLoader=n??new Re,this._layoutLoader=new Xe({templatesPath:Ne()}),this._layoutRenderer=new Ye,this._remoteFactory=t.remoteFactory;}async resolveFileRemoteTarget(e){let t=this.getAgent(e),r=Array.isArray(t?.provider)?t?.provider[0]:t?.provider;if(!r?.startsWith("remote/"))return null;let n=r.slice(7),s=this.getRemoteProviderConfig(n);if(!s?.location?.startsWith("file://"))return null;let i=F.resolve(s.location.replace("file://","")),a=s.external_agent_id??e.replace(/^@/,""),d=this._remoteTargets.get(i);d||(d=(this._remoteFactory??(p=>o.loadYaml(p)))(i),this._remoteTargets.set(i,d),d.catch(()=>this._remoteTargets.delete(i)));let c=await d,u=c.getAgent("@"+a),m=Array.isArray(u?.provider)?u?.provider[0]:u?.provider;if(m?.startsWith("remote/"))throw new Error(`Chained remotes not allowed: "${n}" \u2192 "${m}"`);return {target:c,agentRef:"@"+a}}static async loadBuiltInConfig(e){let{yamlPath:t,dir:r}=Ft(),n;try{n=fs$1.readFileSync(t,"utf-8");}catch(i){throw new Error(`[@crewx/sdk] Cannot read built-in config: ${t}
52
- ${i.message}`)}let s=ct(n);if(s.documents&&typeof s.documents=="object"){let i={};for(let[a,d]of Object.entries(s.documents))if(d&&typeof d=="object"){let c=d;typeof c.path=="string"&&!F.isAbsolute(c.path)?i[a]={...c,path:F.resolve(r,c.path)}:i[a]=c;}else i[a]=d;return {...s,documents:i}}return s}static mergeCrewxConfig(e,t){let r=new Map;for(let v of e.agents??[])r.set(v.id,v);for(let v of t.agents??[])r.has(v.id)&&console.warn(`[agent-loader] User agent "${v.id}" overrides built-in`),r.set(v.id,v);let n=Array.from(r.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,d=t,c=Nn(a.vars,d.vars),u=Nn(a.settings,d.settings),m;e.skills&&t.skills&&typeof e.skills=="object"&&typeof t.skills=="object"&&!Array.isArray(e.skills)&&!Array.isArray(t.skills)?m={...e.skills,...t.skills}:m=t.skills??e.skills;let g=[...e.hooks??[],...t.hooks??[]],p=ti(a.providers,d.providers),y={...e},x={...t};for(let v of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete y[v],delete x[v];let _={...{...y,...x},agents:n,layouts:s,documents:i,skills:m};return g.length>0&&(_.hooks=g),c!==void 0&&(_.vars=c),u!==void 0&&(_.settings=u),p!==void 0&&(_.providers=p),_}static async loadYaml(e,t,r){let n=t?.includeBuiltIns!==false,s,i;if(n){let u=await o.loadBuiltInConfig(r);if(e!==void 0){let m=ut(e);s=o.mergeCrewxConfig(u,m),i=F.dirname(e);}else s=u,i=process.cwd();}else {if(e===void 0)throw new Error("[@crewx/sdk] loadYaml: path is required when includeBuiltIns is false");s=ut(e),i=F.dirname(e);}let a=new Re(r);await a.load(s.documents,i);let d=s.agents??[];return await Dn(d,s,t),new o(d,t??{},s,a,i)}static async fromConfig(e,t,r,n){let s=t?.includeBuiltIns===true,i=e;if(s){let u=await o.loadBuiltInConfig(n);i=o.mergeCrewxConfig(u,e);}let a=new Re(n);await a.load(i.documents,r??(typeof process<"u"?process.cwd():"/"));let d=i.agents??[];return await Dn(d,i,t),new o(d,t??{},i,a,r)}get agents(){return this._agents}get config(){return this._config}get plugins(){return this._plugins}get tools(){return this._tools}get workspaceId(){return this._workspaceId}get workspaceName(){return this._workspaceName}getAgent(e){let t=e.startsWith("@")?e.slice(1):e;return this._agents.get(t)}getRemoteProviderConfig(e){let t=this._config?.providers;return Array.isArray(t)?t.find(n=>n.type==="remote"&&n.id===e):void 0}computeTaskLogPath(e,t){let r=or(t);return F.join(this._projectRoot,".crewx","logs",`${r}_${e}.log`)}registerTool(e,t){this._tools.set(e,{name:e,...t});}async use(e){this._plugins.includes(e)||(await e.attach(this),this._plugins.push(e));}handler(e){return lr(this,e)}async registerChannelAdapter(e){let{adapter:t,instanceId:r,config:n}=e;if(this._activeAdapters.has(r))throw new Error(`Adapter instance already registered: ${r}`);let s=new Set(t.manifest.capabilities),i=e.store??sr(r),a=e.defaultMode??"query",d=t.manifest.platform,c=e.agentRunner??{run:async(p,y,x)=>{let _=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${p}`,y,{threadId:x?.threadId,platform:d});return {output:_.ok?_.data:_.error?.message??""}}},u=e.onInbound??(async p=>{let y=p.routingHints?.agentId??e.defaultAgent;if(!y)return {accepted:false,reason:"no_agent"};let{output:x}=await c.run(y,p.text,{threadId:p.threadId});return {accepted:true,output:x}}),m=ar({instanceId:r,config:n,capabilities:s,db:i,agentRunner:c,onInbound:u}),g={adapter:t,ctx:m,state:"starting"};this._activeAdapters.set(r,g),this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"starting",timestamp:new Date});try{await t.start(m),g.state="started",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"started",timestamp:new Date});}catch(p){throw g.state="failed",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"failed",error:p instanceof Error?p:new Error(String(p)),timestamp:new Date}),this._activeAdapters.delete(r),p}}async unregisterChannelAdapter(e){let t=this._activeAdapters.get(e);if(t){t.state="stopping",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopping",timestamp:new Date});try{await t.adapter.stop(t.ctx),t.state="stopped",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopped",timestamp:new Date});}catch(r){t.state="failed",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"failed",error:r instanceof Error?r:new Error(String(r)),timestamp:new Date});}finally{this._activeAdapters.delete(e);}}}async stopAllAdapters(e={}){let t=e.timeoutMs??1e4,r=Array.from(this._activeAdapters.keys()),n=await Promise.allSettled(r.map(s=>Promise.race([this.unregisterChannelAdapter(s),new Promise((i,a)=>setTimeout(()=>a(new Error(`Adapter stop timeout: ${s}`)),t))])));for(let s=0;s<n.length;s++)n[s].status==="rejected"&&console.error(`[crewx] adapter stop error (${r[s]}): ${n[s].reason}`);}async close(){await this.stopAllAdapters({timeoutMs:1e4});let e=[...this._remoteTargets.values()];this._remoteTargets.clear(),await Promise.allSettled(e.map(async r=>{try{await(await r).close();}catch(n){console.error(`[crewx] remote target close error: ${n instanceof Error?n.message:String(n)}`);}}));let t=[...this._plugins].reverse();for(let r of t)try{await r.detach(this);}catch(n){console.error(`[crewx] plugin ${r.name} detach error: ${n instanceof Error?n.message:String(n)}`);}this._plugins.length=0;}filterAgents(e){let t=a=>a?a.split(",").map(d=>d.trim().toLowerCase()).filter(Boolean):void 0,r=t(e.role),n=t(e.team),s=t(e.provider),i=Array.from(this._agents.values());return r&&(i=i.filter(a=>a.role&&r.some(d=>oe(a.role.toLowerCase(),d)))),n&&(i=i.filter(a=>a.team&&n.some(d=>oe(a.team.toLowerCase(),d)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(c=>s.some(u=>oe(c.toLowerCase(),u))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,r=this._agents.get(t);if(!r)throw new de(t,Array.from(this._agents.keys()));return r.inline?.prompt??r.inline?.system_prompt??r.description??`You are an expert ${t}.`}async renderPrompt(e,t){let n={...await this._documentLoader.buildContext(),...t?.documents??{}},s={...t,documents:n};return this._templateEngine.render(e,s)}registerLayout(e,t){this._layoutLoader.registerLayout(e,t);}async renderAgentPromptFull(e,t){let r=e.startsWith("@")?e.slice(1):e,n=this._agents.get(r);if(!n)throw new de(r,Array.from(this._agents.keys()));let s=this._resolveLayoutSpec(n,t?.layout),i=this._extractLayoutId(s),a=this._extractLayoutProps(n,s,t?.layout),d=this._layoutLoader.load(i,a),c=n.inline?.prompt??n.inline?.system_prompt??n.description??`You are an expert ${r}.`,u=await this._documentLoader.buildContext(),m=t?.env??(typeof process<"u"?process.env:{}),g=t?.vars?.security_key??ei(),p={...t?.vars??{},documents:u,env:m,agent:{id:n.id,name:n.name??n.id,role:n.role??"",team:n.team??"",description:n.description??""}},y=await this._templateEngine.render(c,p),x={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},w=n.provider,_=Array.isArray(w)?w:typeof w=="string"&&w.length>0?[w]:[],v=_.join(", ")||(typeof w=="string"?w:""),R=n.options,I=["goals","daily"],b={goals:false,daily:false},U;if(!Array.isArray(R)&&typeof R=="object"&&R!==null){let k=R;if("goals"in k){let E=k.goals;typeof E=="string"||Array.isArray(E)?b.goals=E:b.goals=!!E;}"daily"in k&&(b.daily=!!k.daily);let A={};for(let[E,C]of Object.entries(k))I.includes(E)||(A[E]=C);U=Object.keys(A).length>0?A:void 0;}let j=Array.isArray(R)?R:void 0,T={};for(let[k,A]of Object.entries(u))T[k]={content:A.content??"",toc:A.toc,summary:A.summary,path:A.path};if(b.goals){let k=F.join(this._projectRoot,"docs","goal"),A=await ln(k,void 0,b.goals);A&&(T.active_goals={content:A});}if(b.daily){let k=F.join(this._projectRoot,"docs","daily"),A=await cn(k);A&&(T.today_daily={content:A});}let q={user_input:t?.vars?.user_input??void 0,agent:{id:n.id,name:n.name??n.id,role:n.role??"",team:n.team??"",description:n.description??"",provider:v,providerList:_,model:n.inline?.model,workingDirectory:n.working_directory??n.workingDirectory??".",inline:{...n.inline??{},prompt:y},specialties:n.specialties??[],capabilities:n.capabilities??[],remote:n.remote??null,optionsByMode:U,optionsArray:j},agentMetadata:{specialties:n.specialties??[],capabilities:n.capabilities??[],description:n.description??""},contextOptions:b,documents:T,skills:t?.skills??[],session:x,env:m,vars:{security_key:g,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:x.platform,mode:x.mode,messages:t?.messages??[],tools:this._tools.size>0?{list:Array.from(this._tools.values()).map(k=>({name:k.name,description:k.description,parameters:k.parameters})),json:JSON.stringify(Array.from(this._tools.values()).map(k=>({name:k.name,description:k.description,parameters:k.parameters})),null,2),count:this._tools.size}:null,metadata:{}};return this._layoutRenderer.render(d,q)}_filterToolsByMode(e){return e?e.map(t=>this._tools.get(t)).filter(t=>t!==void 0):Array.from(this._tools.values())}_resolveLayoutSpec(e,t){if(t!==void 0)return t;let r=e.inline?.layout;if(r!==void 0)return r;let n=this._config?.layouts?.default;return typeof n=="string"&&n?n:"crewx/default"}_extractLayoutId(e){if(typeof e=="string")return e;if("id"in e)return e.id;let t=`crewx/__inline_${Date.now()}`;return this._layoutLoader.registerLayout(t,e.template),t}_extractLayoutProps(e,t,r){let n=e.inline?.layout,s=n&&typeof n=="object"&&"props"in n?n.props:void 0,i=r&&typeof r=="object"&&"id"in r?r.props:void 0;if(s||i)return {...s??{},...i??{}}}_getConversationProvider(){return this._plugins.find(t=>t.name==="conversation")?.conversationProvider}async _fetchHistoryMessages(e,t,r){if(r&&r.length>0)return r;if(!e)return;let n=this._getConversationProvider();if(n)try{let s=await n.fetchHistory(e,{currentTraceId:t});return s.messages.length===0?void 0:dr(s)}catch{return}}_resolveTimeout(e){let t=Gr();return e==="query"?t.queryMs:t.executeMs}emitToolEvents(e,t,r,n,s,i,a){try{let c=exports.BUILTIN_ADAPTERS[r]?.parseEvent?.(n)??Gt(new Date().toISOString(),n);for(let u of c)u.type==="tool_use"&&u.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName,rawName:u.toolName,input:u.toolInput?this.tryParseJson(u.toolInput):void 0,toolUseId:u.toolUseId}}),u.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName??"unknown",rawName:u.toolName??"unknown",toolUseId:u.toolUseId,result:u.resultPreview,isError:u.isError}});}catch{}}emitTaskLogEntries(e,t,r,n,s,i,a){try{for(let d of a)d.type==="tool_use"&&d.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:n,sessionId:s,provider:i,tool:{name:d.toolName,rawName:d.toolName,input:d.toolInput?this.tryParseJson(d.toolInput):void 0,toolUseId:d.toolUseId}}),d.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:n,sessionId:s,provider:i,tool:{name:d.toolName??"unknown",rawName:d.toolName??"unknown",toolUseId:d.toolUseId,result:d.resultPreview,isError:d.isError}});}catch{}}tryParseJson(e){try{return JSON.parse(e)}catch{return e}}async query(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.query(n.agentRef,t,r);let s=Date.now(),i=r?.taskId??Ae("tsk"),a=new Date,d;try{d=gt(e,Array.from(this._agents.values()));}catch(k){if(k instanceof de){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let A=Date.now()-s,E={code:"AGENT_NOT_FOUND",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:A,error:E,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:E,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:A}}}throw k}let c=Array.isArray(d.provider)?d.provider[0]??"cli/claude":d.provider,u=r?.provider??c,m=r?.model??d.inline?.model;m&&m.includes("{{")&&(m=await this._templateEngine.render(m,{...r?.vars??{}}));let g;try{g=ce(u);}catch(k){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let A=Date.now()-s,E={code:"PROVIDER_ERROR",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:A,error:E,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:E,meta:{agentId:d.id,provider:u,model:m,durationMs:A}}}let p=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),y;try{y=await this.renderAgentPromptFull(e,{session:{mode:"query",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:p});}catch(k){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${k instanceof Error?k.message:String(k)}`);}let x,w,_,v=m,R=false,I=k=>{R||(R=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",pid:k,model:v,provider:u,codingAgentCommand:x,renderedPrompt:y,metadata:{...r?.metadata??{},provider:u},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},b=d.options,U=Array.isArray(b?.query?.tools)?b.query.tools:void 0,j=this._tools.size>0?this._filterToolsByMode(U):[],T=(()=>{let k=b?.query;if(!k||Array.isArray(k))return;let{tools:A,effort:E,mode:C,...B}=k,J=Object.entries(B).filter(([,H])=>H!=null);if(J.length!==0)return Object.fromEntries(J.map(([H,Y])=>[H,String(Y)]))})(),$=d.inline?.max_steps;u.startsWith("api/")&&I();let q=false;try{let k=await g.query(t,{model:m,effort:b?.query?.effort,mode:b?.query?.mode,context:r?.context,systemPrompt:y??d.inline?.system_prompt??d.inline?.prompt??d.description??`You are ${d.id}.`,additionalArgs:Array.isArray(b?.query)?b.query:void 0,tools:j.length>0?j:void 0,maxSteps:$,configOptions:T,timeoutMs:this._resolveTimeout("query"),cwd:r?.cwd,env:{CREWX_AGENT_ID:d.id,CREWX_AGENT_ROLE:d.role??"",CREWX_AGENT_TEAM:d.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:u,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,a)},onPid:C=>I(C),onOutput:(C,B)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:C,level:B}),B==="stdout"&&this.emitToolEvents(i,e,u,C,d.id,r?.threadId??"","");},onTaskLog:C=>{this.emitTaskLogEntries(i,e,d.id,r?.threadId??"","",u,C);for(let B of C)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(B),level:"info"});},onCommand:C=>{x=C;},onUsage:C=>{w=C;},onExitCode:C=>{_=C;},onModel:C=>{v||(v=C);}});I();let A=Date.now()-s,E={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:k,durationMs:A,exitCode:_,inputTokens:w?.inputTokens,outputTokens:w?.outputTokens,cachedInputTokens:w?.cachedInputTokens,costUsd:w?.costUsd,model:v,metadata:Object.keys(E).length>0?E:void 0}),q=!0,{ok:!0,data:k,meta:{agentId:d.id,provider:u,model:m,durationMs:A,taskId:i}}}catch(k){if(k instanceof exports.ClientToolCallRequiredError){let C=Ae("thd");return this._pendingThreads.set(C,{agentRef:d.id,providerStr:u,continuationState:k.continuationState,toolCall:k.toolCall,traceId:i,startMs:s,model:m}),q=true,{ok:true,status:"requires_action",data:"",toolCall:k.toolCall,threadId:C,meta:{agentId:d.id,provider:u,model:m,durationMs:Date.now()-s,taskId:i}}}I();let A=Date.now()-s,E={code:"QUERY_FAILED",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:A,error:E,exitCode:_,inputTokens:w?.inputTokens,outputTokens:w?.outputTokens,cachedInputTokens:w?.cachedInputTokens,costUsd:w?.costUsd,model:v,metadata:r?.metadata?{...r.metadata}:void 0}),q=true,{ok:false,data:"",error:E,meta:{agentId:d.id,provider:u,model:m,durationMs:A,taskId:i}}}finally{q||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:Date.now()-s,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:_??-1,inputTokens:w?.inputTokens,outputTokens:w?.outputTokens,cachedInputTokens:w?.cachedInputTokens,costUsd:w?.costUsd,model:v});}}async continueQuery(e,t){let r=this._pendingThreads.get(e);if(!r)return {ok:false,data:"",error:{code:"THREAD_NOT_FOUND",message:`No pending thread: ${e}`},meta:{agentId:"",provider:"",durationMs:0}};this._pendingThreads.delete(e);let n=ce(r.providerStr);if(!n.continueWithToolResults)return {ok:false,data:"",error:{code:"UNSUPPORTED",message:"Provider does not support client tool continuation"},meta:{agentId:r.agentRef,provider:r.providerStr,durationMs:0}};let s=t.map(i=>({...i,toolName:r.toolCall.toolCallId===i.toolCallId?r.toolCall.toolName:i.toolCallId}));try{let i=await n.continueWithToolResults(r.continuationState,s),a=Date.now()-r.startMs;return this.emit("task:end",{traceId:r.traceId,timestamp:new Date,agentRef:r.agentRef,mode:"query",result:i,durationMs:a}),{ok:!0,status:"complete",data:i,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}catch(i){if(i instanceof exports.ClientToolCallRequiredError)return this._pendingThreads.set(e,{...r,continuationState:i.continuationState,toolCall:i.toolCall}),{ok:true,status:"requires_action",data:"",toolCall:i.toolCall,threadId:e,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:Date.now()-r.startMs}};let a=Date.now()-r.startMs;return {ok:false,data:"",error:{code:"CONTINUE_FAILED",message:i.message},meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}}async execute(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.execute(n.agentRef,t,r);let s=Date.now(),i=r?.taskId??Ae("tsk"),a=new Date,d;try{d=gt(e,Array.from(this._agents.values()));}catch(k){if(k instanceof de){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let A=Date.now()-s,E={code:"AGENT_NOT_FOUND",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:A,error:E,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:E,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:A}}}throw k}let c=Array.isArray(d.provider)?d.provider[0]??"cli/claude":d.provider,u=r?.provider??c,m=r?.model??d.inline?.model;m&&m.includes("{{")&&(m=await this._templateEngine.render(m,{...r?.vars??{}}));let g;try{g=ce(u);}catch(k){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let A=Date.now()-s,E={code:"PROVIDER_ERROR",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:A,error:E,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:E,meta:{agentId:d.id,provider:u,model:m,durationMs:A}}}let p=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),y;try{y=await this.renderAgentPromptFull(e,{session:{mode:"execute",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:p});}catch(k){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${k instanceof Error?k.message:String(k)}`);}let x,w,_,v=m,R=false,I=k=>{R||(R=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",pid:k,model:v,provider:u,codingAgentCommand:x,renderedPrompt:y,metadata:{...r?.metadata??{},provider:u},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},b=d.options,U=Array.isArray(b?.execute?.tools)?b.execute.tools:void 0,j=this._tools.size>0?this._filterToolsByMode(U):[],T=(()=>{let k=b?.execute;if(!k||Array.isArray(k))return;let{tools:A,effort:E,mode:C,...B}=k,J=Object.entries(B).filter(([,H])=>H!=null);if(J.length!==0)return Object.fromEntries(J.map(([H,Y])=>[H,String(Y)]))})(),$=d.inline?.max_steps;u.startsWith("api/")&&I();let q=false;try{let k=await g.execute(t,{model:m,effort:b?.execute?.effort,mode:b?.execute?.mode,context:r?.context,systemPrompt:y??d.inline?.system_prompt??d.inline?.prompt??d.description??`You are ${d.id}.`,additionalArgs:Array.isArray(b?.execute)?b.execute:void 0,tools:j.length>0?j:void 0,maxSteps:$,configOptions:T,timeoutMs:this._resolveTimeout("execute"),cwd:r?.cwd,env:{CREWX_AGENT_ID:d.id,CREWX_AGENT_ROLE:d.role??"",CREWX_AGENT_TEAM:d.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:u,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,a)},onPid:C=>I(C),onOutput:(C,B)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:C,level:B}),B==="stdout"&&this.emitToolEvents(i,e,u,C,d.id,r?.threadId??"","");},onTaskLog:C=>{this.emitTaskLogEntries(i,e,d.id,r?.threadId??"","",u,C);for(let B of C)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(B),level:"info"});},onCommand:C=>{x=C;},onUsage:C=>{w=C;},onExitCode:C=>{_=C;},onModel:C=>{v||(v=C);}});I();let A=Date.now()-s,E={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:k,durationMs:A,exitCode:_,inputTokens:w?.inputTokens,outputTokens:w?.outputTokens,cachedInputTokens:w?.cachedInputTokens,costUsd:w?.costUsd,model:v,metadata:Object.keys(E).length>0?E:void 0}),q=!0,{ok:!0,data:k,meta:{agentId:d.id,provider:u,model:m,durationMs:A,taskId:i}}}catch(k){I();let A=Date.now()-s,E={code:"EXECUTE_FAILED",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:A,error:E,exitCode:_,inputTokens:w?.inputTokens,outputTokens:w?.outputTokens,cachedInputTokens:w?.cachedInputTokens,costUsd:w?.costUsd,model:v,metadata:r?.metadata?{...r.metadata}:void 0}),q=true,{ok:false,data:"",error:E,meta:{agentId:d.id,provider:u,model:m,durationMs:A}}}finally{q||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:Date.now()-s,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:_??-1,inputTokens:w?.inputTokens,outputTokens:w?.outputTokens,cachedInputTokens:w?.cachedInputTokens,costUsd:w?.costUsd,model:v});}}};function Nn(o,e){let t=br(o)?o:void 0,r=br(e)?e:void 0;if(!(!t&&!r))return {...t??{},...r??{}}}function br(o){return typeof o=="object"&&o!==null&&!Array.isArray(o)}function ti(o,e){let t=Array.isArray(o)?o:void 0,r=Array.isArray(e)?e:void 0;if(!t&&!r)return;let n=a=>{if(!br(a))return;let d=a.id;if(typeof d=="string")return `id:${d}`;let c=a.name;if(typeof c=="string")return `name:${c}`},s=new Set;for(let a of r??[]){let d=n(a);d&&s.add(d);}let i=[];for(let a of t??[]){let d=n(a);d&&s.has(d)||i.push(a);}for(let a of r??[])i.push(a);return i}async function Dn(o,e,t){if(o.some(n=>(Array.isArray(n.provider)?n.provider:[n.provider]).some(i=>i.startsWith("api/")))){let{registerApiProviders:n}=await Promise.resolve().then(()=>(pr(),xn));n(t?.api);}ni(o,e),oi(o,e),ri(o);}function ri(o){if(!o.some(r=>(Array.isArray(r.provider)?r.provider:[r.provider]).some(s=>s.startsWith("acp/"))))return;let{registerAcpProviders:t}=(kr(),Ht(Pn));t();}function ni(o,e){if(!o.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("remote/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createRemoteProviderFactory:n}=(Rr(),Ht(bn)),s=new Map;for(let i of r)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&le("remote",n(s,ce));}function oi(o,e){if(!o.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("plugin/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createPluginProviderFactory:n}=(Ar(),Ht(In)),s=new Map;for(let i of r)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&le("plugin",n(s));}l();var Er=class{detach(e){}};l();var si="crewx:fs:",Tr=class{prefix;store;constructor(e){this.prefix=e?.prefix??si,this.store=e?.storage??new Map;}async readFile(e){let t=this.toKey(e),r=this.store.get(t);if(r===void 0)throw new Error(`BrowserFsAdapter: file not found: ${e}`);return r}async exists(e){return this.store.has(this.toKey(e))}resolvePath(...e){let t=e.map(i=>i.replace(/\\/g,"/")).join("/").replace(/\/+/g,"/"),r=t.split("/"),n=[];for(let i of r)i==="."||i===""||(i===".."?n.pop():n.push(i));let s=n.join("/");return t.startsWith("/")?`/${s}`:s}isAbsolute(e){return e.startsWith("/")}setItem(e,t){this.store.set(this.toKey(e),t);}removeItem(e){this.store.delete(this.toKey(e));}keys(){return Array.from(this.store.keys()).filter(e=>e.startsWith(this.prefix)).map(e=>e.slice(this.prefix.length))}async readdir(e){let t=e.replace(/\\/g,"/").replace(/\/$/,""),r=this.toKey(t+"/"),n=[];for(let s of this.store.keys())if(s.startsWith(r)){let a=s.slice(r.length).split("/")[0];a&&!n.includes(a)&&n.push(a);}return n}toKey(e){return `${this.prefix}${e.replace(/\\/g,"/")}`}};l();function ii(o,e){let t=o.skills?.include;if(t===void 0)return [...e];if(t.length===0)return [];let r=new Set(t);return e.filter(n=>r.has(n))}se();ur();pr();l();mr();he();l();Rt();St();Pt();function ai(o,e,t,r){let n=t.agentInfo?.name,s=e??n??o,a=(r.modes?.availableModes??[]).map(y=>({id:y.id,name:y.name,...y.description!=null?{description:y.description}:{}})),d=[],c=r.configOptions??[];for(let y of c)if(y.category==="thought_level"&&y.type==="select"){let x=y.options??[];if(x.length>0&&x[0]?.group!=null)for(let w of x)for(let _ of w.options??[])d.push(_.value);else for(let w of x)w.value!=null&&d.push(w.value);}let u=r.models?.availableModels??[],m=o==="claude"?Rn.map(y=>({id:y.id,name:y.name})):u.map(y=>({id:y.modelId})),g=t.agentCapabilities??{},p={loadSession:g.loadSession??false,image:g.promptCapabilities?.image??false,audio:g.promptCapabilities?.audio??false,mcp:g.mcpCapabilities!=null};return {id:`acp/${o}`,name:s,modes:a,effort:d,models:m,capabilities:p}}async function Ln(o){let e=exports.ACP_ADAPTERS[o];if(!e)return null;let t=e.meta?.displayName,r=new exports.AcpConnection({spawn:e.spawn,cwd:process.cwd()});try{await r.connect(e.clientInfo);let n=r.initResponse;if(!n)return null;let s=e.buildSessionParams({cwd:process.cwd()}),i=await r.newSessionRaw(s);return ai(o,t,n,i)}catch{return null}finally{await r.dispose();}}async function di(){let o=Object.keys(exports.ACP_ADAPTERS),e=await Promise.allSettled(o.map(r=>Ln(r))),t=[];for(let r of e)r.status==="fulfilled"&&r.value!==null&&t.push(r.value);return t}Rt();fr();St();kr();qt();je();l();var Sr=0;function li(o){let e=Array.from(o.agents.keys());return {name:"delegate_to_agent",description:`Delegate a task to another agent. Available agents: ${e.join(", ")}`,parameters:{type:"object",properties:{agent:{type:"string",description:`Agent ID to delegate to. One of: ${e.join(", ")}`},message:{type:"string",description:"Task description for the target agent"},mode:{type:"string",description:'Execution mode: "query" for questions, "execute" for actions. Default: query'}},required:["agent","message"]},execute:async t=>{if(Sr>=3)return "Error: Maximum delegation depth (3) reached. Cannot delegate further.";let r=t.agent,n=t.message,s=t.mode??"query";if(!e.includes(r))return `Error: Unknown agent "${r}". Available: ${e.join(", ")}`;Sr++;try{if(s==="execute"){let a=await o.execute(r,n);return a.ok?a.data:`Error: ${a.error?.message??"Unknown error"}`}let i=await o.query(r,n);return i.ok?i.data:`Error: ${i.error?.message??"Unknown error"}`}finally{Sr--;}}}}l();var $n=typeof process<"u"?process.env:{};function ci(){return $n.CREWX_CLI||"npx crewx"}function ui(){return $n.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}l();var pi=/^[a-zA-Z0-9._-]+$/,Ir=class{constructor(e){this.storage=e;}storage;listBoxes(e){this.validateId(e);let r=this.storage.listBoxes(e).map(n=>this.toBoxResponse(n));return {boxes:r,total:r.length}}getBox(e,t){this.validateId(e),this.validateId(t);let r=this.storage.findBox(e,t);return r?this.toBoxResponse(r):null}createBox(e,t){this.validateId(e);let r=this.generateBoxId(),n=new Date().toISOString(),s=this.storage.insertBox(e,{id:r,seq:t.seq,firstTaskId:t.firstTaskId,midTaskId:t.midTaskId,lastTaskId:t.lastTaskId,taskCount:t.taskCount,summary:t.summary??null,sourceTokens:t.sourceTokens,summaryTokens:t.summaryTokens??null,createdAt:n});return this.toBoxResponse(s)}toBoxResponse(e){return {id:e.id,threadId:e.thread_id,seq:e.seq,firstTaskId:e.first_task_id,lastTaskId:e.last_task_id,taskCount:e.task_count,sourceTokens:e.source_tokens,summaryTokens:e.summary_tokens,summary:e.summary,previewFirst:this.storage.getTaskPreview(e.first_task_id,200),previewMid:this.storage.getTaskPreview(e.mid_task_id,200),previewLast:this.storage.getTaskPreview(e.last_task_id,200),createdAt:e.created_at}}validateId(e){if(!pi.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return Ae("box")}};l();function gi(o,e,t,r,n){let{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}=r,d=s*i,c=s*a,u=d+c,m=e.getThreadMessages(o),g=[],p=0,y=false,x=[];for(let v=0;v<m.length;v+=2){let R=m[v],I=m[v+1],b=R?.content||"",U=I?.content||"",j=n.countTokens(b+U),T=[];R&&T.push(R),I&&T.push(I),x.push({messages:T,tokens:j});}for(let v=x.length-1;v>=0;v--){let R=x[v];if(p+R.tokens>d){y=true;break}p+=R.tokens,g.unshift(...R.messages);}let w=[],_=0;if(y&&c>0)try{let{boxes:v}=t.listBoxes(o);for(let R=v.length-1;R>=0;R--){let I=v[R],b=I.summaryTokens??I.sourceTokens;if(_+b>c)break;_+=b,w.unshift({boxId:I.id,seq:I.seq,taskCount:I.taskCount,sourceTokens:I.sourceTokens,summary:I.summary,previewFirst:I.previewFirst,previewMid:I.previewMid,previewLast:I.previewLast,createdAt:I.createdAt});}}catch(v){if(v instanceof Error&&!/not found/i.test(v.message))throw v}return {hot:g,warm:w,hotTokens:p,warmTokens:_,hotOverflow:y,totalBudget:u,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}je();ve();l();var It=class extends Error{constructor(t,r){super(`Task ${t} timed out after ${r}ms`);this.taskId=t;this.timeoutMs=r;this.name="ParallelRunnerTimeoutError";}taskId;timeoutMs},it=class{constructor(e={}){this.defaults=e;}defaults;metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0};async run(e,t={}){if(!Array.isArray(e))throw new TypeError("ParallelRunner.run expects an array of tasks");if(e.length===0)return this.metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0},[];let r=this.mergeOptions(t),n=Math.max(1,r.maxConcurrency??5),s=r.timeoutMs,i=r.failFast??false,a=r.callbacks,d=r.evaluateTaskSuccess??(()=>true),c=[],u=0,m=0,g=0,p=false,y=0,x=perf_hooks.performance.now(),w=async T=>{a?.onTaskStart&&await a.onTaskStart(T),g+=1;let $=new AbortController,q={signal:$.signal},k,A;typeof s=="number"&&Number.isFinite(s)&&s>0&&(A=new Promise((J,H)=>{k=setTimeout(()=>{let Y=new It(T.id,s);$.abort(Y),H(Y);},s);}));let E=perf_hooks.performance.now(),C=T.run(q),B=A?Promise.race([C,A]):C;try{let J=await B,H=perf_hooks.performance.now(),Y=H-E,Me=d(J,T),dt={taskId:T.id,success:Me,value:J,durationMs:Y,startedAt:E,finishedAt:H,metadata:T.metadata,aborted:!1};c.push(dt),Me?u+=1:m+=1,a?.onTaskComplete&&await a.onTaskComplete(dt),i&&!Me&&(p=!0);}catch(J){let H=perf_hooks.performance.now(),Y=H-E,Me=J instanceof Error?J:new Error(String(J)),dt={taskId:T.id,success:false,error:Me,durationMs:Y,startedAt:E,finishedAt:H,metadata:T.metadata,aborted:$.signal.aborted};c.push(dt),m+=1,a?.onError&&await a.onError(T,Me,Y),i&&(p=true);}finally{k&&clearTimeout(k),A&&C.catch(()=>{});}},_=async()=>{for(;!p;){let T=y;if(T>=e.length)break;y+=1;let $=e[T];if(!$||(await w($),p))break}},v=Math.min(n,e.length),R=[];for(let T=0;T<v;T++)R.push(_());await Promise.all(R);let b=perf_hooks.performance.now()-x,U=c.length?c.reduce((T,$)=>T+$.durationMs,0)/c.length:0,j=b>0?c.length/(b/1e3):c.length;return this.metrics={totalTasks:e.length,startedTasks:g,completedTasks:c.length,successCount:u,failureCount:m,totalDurationMs:b,averageDurationMs:U,throughput:j},c}getMetrics(){return this.metrics}mergeOptions(e){return {maxConcurrency:e.maxConcurrency??this.defaults.maxConcurrency,timeoutMs:e.timeoutMs??this.defaults.timeoutMs,failFast:e.failFast??this.defaults.failFast,evaluateTaskSuccess:e.evaluateTaskSuccess??this.defaults.evaluateTaskSuccess,callbacks:this.mergeCallbacks(this.defaults.callbacks,e.callbacks)}}mergeCallbacks(e,t){if(!(!e&&!t))return {onTaskStart:async r=>{e?.onTaskStart&&await e.onTaskStart(r),t?.onTaskStart&&await t.onTaskStart(r);},onTaskComplete:async r=>{e?.onTaskComplete&&await e.onTaskComplete(r),t?.onTaskComplete&&await t.onTaskComplete(r);},onError:async(r,n,s)=>{e?.onError&&await e.onError(r,n,s),t?.onError&&await t.onError(r,n,s);}}}};l();l();var at=class{async query(e){throw new Error("AgentRuntime.query is not implemented. Provide a subclass or mock AgentRuntime.prototype.query.")}async execute(e){throw new Error("AgentRuntime.execute is not implemented. Provide a subclass or mock AgentRuntime.prototype.execute.")}};var jn=3,Un=3e4,Hn=500,mi=o=>{if(typeof o!="number"||Number.isNaN(o)||!Number.isFinite(o))return jn;let e=Math.floor(o);return e>0?e:jn},fi=o=>o===void 0||typeof o!="number"||Number.isNaN(o)||o<=0?Un:o,yi=o=>{if(!o)return {maxRetries:0,retryDelay:Hn};let e=Number.isInteger(o.maxRetries)&&o.maxRetries>=0?o.maxRetries:0,t=typeof o.retryDelay=="number"&&o.retryDelay>=0?o.retryDelay:Hn;return {maxRetries:e,retryDelay:t}},Or=o=>{let e=o.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},hi=(o,e)=>o<=0?Promise.resolve():new Promise((t,r)=>{let n=setTimeout(()=>{e.removeEventListener("abort",s),t();},o),s=()=>{clearTimeout(n),r(Or(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),wi=async(o,e,t)=>{let r,n;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw Or(t);try{let i=await o();if(r=i,i.success||s===e.maxRetries)return i}catch(i){if(n=i,t.aborted)throw Or(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await hi(e.retryDelay,t);}if(r)return r;throw n?n instanceof Error?n:new Error(String(n)):new Error("Parallel helper encountered an unexpected state")},Fn=(o,e,t)=>{e.completed+=1,t?e.success+=1:e.failure+=1;try{o.onProgress?.(e.completed,e.total);}catch(r){process.env.NODE_ENV!=="production"&&console.warn("Parallel helper onProgress callback threw an error:",r);}},xi=o=>o.map(t=>({metadata:t.metadata,taskResult:t})).slice().sort((t,r)=>t.metadata.index-r.metadata.index).map(({metadata:t,taskResult:r})=>{if(r.value){let s=r.value;return {...s,agentId:s.agentId??t.request.agentId,metadata:{...s.metadata,requestIndex:t.index,mode:t.mode}}}let n=r.error??new Error("Unknown error");return {agentId:t.request.agentId,content:n.message,success:false,metadata:{error:n.message,aborted:r.aborted??false,requestIndex:t.index,mode:t.mode}}}),ki=o=>o.filter(e=>!e.success).map(e=>{let t=e.metadata;if(e.error instanceof Error)return {index:t.index,error:e.error};if(e.value&&!e.value.success){let r=String(e.value.metadata?.error??e.value.content??"Agent returned unsuccessful result");return {index:t.index,error:new Error(r)}}return {index:t.index,error:new Error("Unknown failure")}}),vi=(o,e)=>({onTaskComplete:async t=>{Fn(e,o,t.success);},onError:async()=>{Fn(e,o,false);}}),qn=async(o,e,t={})=>{if(!Array.isArray(o))throw new TypeError("Parallel helpers expect an array of requests");if(o.length===0){let w={total:0,completed:0,successCount:0,failureCount:0,results:[],errors:[],metrics:{totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0}};return t.onComplete?.(w),[]}let r=mi(t.concurrency),n=fi(t.timeout),s=yi(t.retryPolicy),i=new it,a=new at,d=o.map((x,w)=>({id:`${e}:${x.agentId??"anonymous"}:${w}`,metadata:{index:w,mode:e,request:x},run:_=>wi(()=>e==="query"?a.query(x):a.execute(x),s,_.signal)})),c={completed:0,success:0,failure:0,total:o.length},u=await i.run(d,{maxConcurrency:r,timeoutMs:n,evaluateTaskSuccess:x=>x.success,callbacks:vi(c,t)}),m=xi(u),g=ki(u),p=i.getMetrics(),y={total:o.length,completed:o.length,successCount:m.filter(x=>x.success).length,failureCount:m.filter(x=>!x.success).length,results:m,errors:g,metrics:p};return t.onComplete?.(y),m},_i=(o,e)=>qn(o,"query",e),Ri=(o,e)=>qn(o,"execute",e);Ar();l();l();var He=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:F.join(Ci__default.default.homedir(),".crewx","crewx.db")}resolveDbPaths(){return [this.resolveDbPath()]}isMissingTableError(e){return e instanceof Error&&/no such table:/i.test(e.message)}dbExists(e){return fs$1.existsSync(e??this.resolveDbPath())}};l();function ge(o){let e=W("better-sqlite3"),{drizzle:t}=W("drizzle-orm/better-sqlite3"),r=new e(o);return r.exec("PRAGMA journal_mode = WAL"),r.exec("PRAGMA busy_timeout = 5000"),r.exec("PRAGMA foreign_keys = ON"),{db:t(r),runRaw:(n,s=[])=>r.prepare(n).run(...s),close:()=>r.close()}}l();var Wn=new Set,Ei={agent_id:"TEXT",status:"TEXT DEFAULT 'running'",started_at:"TEXT",trace_id:"TEXT",parent_task_id:"TEXT",crewx_version:"TEXT",pid:"INTEGER",thread_id:"TEXT",workspace_id:"TEXT",workspace_ref:"TEXT",workspace_name:"TEXT",project_id:"TEXT",project_name:"TEXT"};function Ti(o,e){return (o.get(`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='${e}'`)?.cnt??0)>0}function Si(o,e){if(e>0||!Ti(o,"tasks"))return;let t=o.all("PRAGMA table_info(tasks)"),r=new Set(t.map(n=>n.name));for(let[n,s]of Object.entries(Ei))r.has(n)||o.run(`ALTER TABLE tasks ADD COLUMN ${n} ${s}`);}function Ii(o,e,t){let r=o.all(t`SELECT hash FROM __drizzle_migrations`),n=new Set(r.map(i=>i.hash)),s=JSON.parse(fs$1.readFileSync(F__namespace.default.join(e,"meta/_journal.json"),"utf-8"));for(let i of s.entries){let a=F__namespace.default.join(e,`${i.tag}.sql`);if(!fs$1.existsSync(a))continue;let d=fs$1.readFileSync(a,"utf-8"),c=crypto$1.createHash("sha256").update(d).digest("hex");if(n.has(c))continue;let u=/ALTER\s+TABLE\s+[`"]?(\w+)[`"]?\s+ADD\s+[`"]?(\w+)[`"]?/gi,m=[],g;for(;(g=u.exec(d))!==null;)m.push({table:g[1],column:g[2]});if(m.length===0||!d.split(/-->\s*statement-breakpoint/).map(x=>x.trim()).filter(Boolean).every(x=>/^ALTER\s+TABLE\s+.+\s+ADD\s+/i.test(x)))continue;m.every(({table:x,column:w})=>o.all(`PRAGMA table_info("${x}")`).some(v=>v.name===w))&&o.run(t`INSERT INTO __drizzle_migrations (hash, created_at) VALUES (${c}, ${i.when})`);}}function Oi(o){let{migrate:e}=W("drizzle-orm/better-sqlite3/migrator"),{sql:t}=W("drizzle-orm"),r=[F__namespace.default.join(__dirname,"../migrations"),F__namespace.default.join(__dirname,"migrations"),F__namespace.default.join(__dirname,"../../../../drizzle/migrations"),F__namespace.default.join(process.cwd(),"drizzle/migrations")],n=r.find(c=>fs$1.existsSync(F__namespace.default.join(c,"meta/_journal.json")));if(!n)throw new Error(`migrations folder not found. Searched:
51
+ `)}l();function _s(){let o=new Date,e=o.getFullYear(),t=String(o.getMonth()+1).padStart(2,"0"),r=String(o.getDate()).padStart(2,"0");return `${e}-${t}-${r}`}async function gn(o,e=Re){let t=e.resolvePath(o,`${_s()}.md`);return await e.exists(t)?e.readFile(t):""}Ue();l();var et=new async_hooks.AsyncLocalStorage;function cr(o){if(o)return {parentTaskId:o.parentTaskId??null,rootTraceId:o.rootTraceId,callerAgentId:o.callerAgentId??null}}l();function Rs(o){return typeof o!="string"?"":o.replace(/</g,"&lt;").replace(/>/g,"&gt;")}function ur(o){return o.messages.map(e=>({text:Rs(e.text),isAssistant:e.isAssistant,metadata:e.metadata,files:void 0}))}l();l();var Ps={agentId:zod.z.string().describe("The agent ID to query"),query:zod.z.string().describe("The query message to send"),context:zod.z.string().optional().describe("Additional context"),thread:zod.z.string().optional().describe("Thread ID for conversation continuity")},Cs={agentId:zod.z.string().describe("The agent ID to execute"),task:zod.z.string().describe("The task description to execute"),context:zod.z.string().optional().describe("Additional context"),thread:zod.z.string().optional().describe("Thread ID for conversation continuity")};function mn(o,e,t){o.tool("crewx_listAgents","List available CrewX agents exposed by this server",async()=>{let r=[];for(let n of t){let s=e.agents.get(n);s&&r.push({id:s.id,name:s.name??s.id,description:s.description??""});}return {content:[{type:"text",text:JSON.stringify(r,null,2)}]}}),o.tool("crewx_queryAgent","Query a CrewX agent with a read-only question",Ps,async({agentId:r,query:n,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.query(r,n,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Query failed"}],isError:true}}),o.tool("crewx_executeAgent","Execute a task on a CrewX agent (may modify state)",Cs,async({agentId:r,task:n,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.execute(r,n,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Execute failed"}],isError:true}});}l();function fn(o){return o.headers.get("Origin")?null:new Response(JSON.stringify({error:"Forbidden: Origin header required"}),{status:403,headers:{"Content-Type":"application/json"}})}async function yn(o,e){return e?await e(o)?null:new Response(JSON.stringify({error:"Unauthorized"}),{status:401,headers:{"Content-Type":"application/json"}}):null}function Es(o,e){let t=new mcp_js.McpServer({name:"crewx-mcp-server",version:"1.0.0"},{capabilities:{tools:{}}});return mn(t,o,e),t}function pr(o,e){if(!e.agents||e.agents.length===0)throw new Error("crewx.handler() requires at least one agent in the agents option");let t=new Set(e.agents),r=new Map;return async n=>{let s=fn(n);if(s)return s;let i=await yn(n,e.auth);if(i)return i;let a=n.headers.get("mcp-session-id");if(a&&r.has(a))return r.get(a).transport.handleRequest(n);let d=Es(o,t),c=new webStandardStreamableHttp_js.WebStandardStreamableHTTPServerTransport({sessionIdGenerator:()=>crypto.randomUUID(),onsessioninitialized:u=>{r.set(u,{transport:c,server:d});},onsessionclosed:u=>{r.delete(u);},enableJsonResponse:true});return await d.connect(c),c.handleRequest(n)}}l();function wn(o){let e=W__namespace.resolve(o);return process.platform==="win32"&&(e=e.replace(/\\/g,"/"),e=e.replace(/^([A-Z]):/,(t,r)=>`${r.toLowerCase()}:`)),e.length>1&&!/^[a-zA-Z]:\/$/.test(e)&&(e=e.replace(/\/+$/,"")),e}function gr(o){let e=wn(o);return crypto$1.createHash("sha256").update(e).digest("hex")}function ni(o){return o?o.settings?.template?.exec:void 0}function oi(){try{let o=new Uint8Array(8);return globalThis.crypto.getRandomValues(o),Array.from(o,e=>e.toString(16).padStart(2,"0")).join("")}catch{let{randomBytes:o}=z("crypto");return o(8).toString("hex")}}var Er=class o extends Ze{_agents;_templateEngine;_documentLoader;_layoutLoader;_layoutRenderer;_config;_projectRoot;_workspaceId;_workspaceName;_plugins=[];_tools=new Map;_activeAdapters=new Map;_pendingThreads=new Map;_remoteFactory;_remoteTargets=new Map;constructor(e,t={},r,n,s){super(),this._agents=new Map(e.map(d=>[d.id,d])),this._config=r,this._projectRoot=s??(typeof process<"u"?process.cwd():"/");let i=s??(typeof process<"u"?process.env.CREWX_WORKSPACE??process.cwd():"/");this._workspaceId=gr(i),this._workspaceName=W.basename(i);let a=ni(r);this._templateEngine=new Xe({execPolicy:t.execPolicy??a}),this._documentLoader=n??new Pe,this._layoutLoader=new Ge({templatesPath:De()}),this._layoutRenderer=new Qe,this._remoteFactory=t.remoteFactory;}async resolveFileRemoteTarget(e){let t=this.getAgent(e),r=Array.isArray(t?.provider)?t?.provider[0]:t?.provider;if(!r?.startsWith("remote/"))return null;let n=r.slice(7),s=this.getRemoteProviderConfig(n);if(!s?.location?.startsWith("file://"))return null;let i=W.resolve(s.location.replace("file://","")),a=s.external_agent_id??e.replace(/^@/,""),d=this._remoteTargets.get(i);d||(d=(this._remoteFactory??(p=>o.loadYaml(p)))(i),this._remoteTargets.set(i,d),d.catch(()=>this._remoteTargets.delete(i)));let c=await d,u=c.getAgent("@"+a),g=Array.isArray(u?.provider)?u?.provider[0]:u?.provider;if(g?.startsWith("remote/"))throw new Error(`Chained remotes not allowed: "${n}" \u2192 "${g}"`);return {target:c,agentRef:"@"+a}}static async loadBuiltInConfig(e){let{yamlPath:t,dir:r}=Bt(),n;try{n=fs.readFileSync(t,"utf-8");}catch(i){throw new Error(`[@crewx/sdk] Cannot read built-in config: ${t}
52
+ ${i.message}`)}let s=ut(n);if(s.documents&&typeof s.documents=="object"){let i={};for(let[a,d]of Object.entries(s.documents))if(d&&typeof d=="object"){let c=d;typeof c.path=="string"&&!W.isAbsolute(c.path)?i[a]={...c,path:W.resolve(r,c.path)}:i[a]=c;}else i[a]=d;return {...s,documents:i}}return s}static mergeCrewxConfig(e,t){let r=new Map;for(let k of e.agents??[])r.set(k.id,k);for(let k of t.agents??[])r.has(k.id)&&console.warn(`[agent-loader] User agent "${k.id}" overrides built-in`),r.set(k.id,k);let n=Array.from(r.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,d=t,c=$n(a.vars,d.vars),u=$n(a.settings,d.settings),g;e.skills&&t.skills&&typeof e.skills=="object"&&typeof t.skills=="object"&&!Array.isArray(e.skills)&&!Array.isArray(t.skills)?g={...e.skills,...t.skills}:g=t.skills??e.skills;let f=[...e.hooks??[],...t.hooks??[]],p=si(a.providers,d.providers),m={...e},w={...t};for(let k of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete m[k],delete w[k];let v={...{...m,...w},agents:n,layouts:s,documents:i,skills:g};return f.length>0&&(v.hooks=f),c!==void 0&&(v.vars=c),u!==void 0&&(v.settings=u),p!==void 0&&(v.providers=p),v}static async loadYaml(e,t,r){let n=t?.includeBuiltIns!==false,s,i;if(n){let u=await o.loadBuiltInConfig(r);if(e!==void 0){let g=pt(e);s=o.mergeCrewxConfig(u,g),i=W.dirname(e);}else s=u,i=process.cwd();}else {if(e===void 0)throw new Error("[@crewx/sdk] loadYaml: path is required when includeBuiltIns is false");s=pt(e),i=W.dirname(e);}let a=new Pe(r);await a.load(s.documents,i);let d=s.agents??[];return await jn(d,s,t),new o(d,t??{},s,a,i)}static async fromConfig(e,t,r,n){let s=t?.includeBuiltIns===true,i=e;if(s){let u=await o.loadBuiltInConfig(n);i=o.mergeCrewxConfig(u,e);}let a=new Pe(n);await a.load(i.documents,r??(typeof process<"u"?process.cwd():"/"));let d=i.agents??[];return await jn(d,i,t),new o(d,t??{},i,a,r)}get agents(){return this._agents}get config(){return this._config}get plugins(){return this._plugins}get tools(){return this._tools}get workspaceId(){return this._workspaceId}get workspaceName(){return this._workspaceName}getAgent(e){let t=e.startsWith("@")?e.slice(1):e;return this._agents.get(t)}getRemoteProviderConfig(e){let t=this._config?.providers;return Array.isArray(t)?t.find(n=>n.type==="remote"&&n.id===e):void 0}computeTaskLogPath(e,t){let r=ir(t);return W.join(this._projectRoot,".crewx","logs",`${r}_${e}.log`)}registerTool(e,t){this._tools.set(e,{name:e,...t});}async use(e){this._plugins.includes(e)||(await e.attach(this),this._plugins.push(e));}handler(e){return pr(this,e)}async registerChannelAdapter(e){let{adapter:t,instanceId:r,config:n}=e;if(this._activeAdapters.has(r))throw new Error(`Adapter instance already registered: ${r}`);let s=new Set(t.manifest.capabilities),i=e.store??ar(r),a=e.defaultMode??"query",d=t.manifest.platform,c=e.agentRunner??{run:async(p,m,w)=>{let v=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${p}`,m,{threadId:w?.threadId,platform:d});return {output:v.ok?v.data:v.error?.message??""}}},u=e.onInbound??(async p=>{let m=p.routingHints?.agentId??e.defaultAgent;if(!m)return {accepted:false,reason:"no_agent"};let{output:w}=await c.run(m,p.text,{threadId:p.threadId});return {accepted:true,output:w}}),g=lr({instanceId:r,config:n,capabilities:s,db:i,agentRunner:c,onInbound:u}),f={adapter:t,ctx:g,state:"starting"};this._activeAdapters.set(r,f),this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"starting",timestamp:new Date});try{await t.start(g),f.state="started",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"started",timestamp:new Date});}catch(p){throw f.state="failed",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"failed",error:p instanceof Error?p:new Error(String(p)),timestamp:new Date}),this._activeAdapters.delete(r),p}}async unregisterChannelAdapter(e){let t=this._activeAdapters.get(e);if(t){t.state="stopping",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopping",timestamp:new Date});try{await t.adapter.stop(t.ctx),t.state="stopped",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopped",timestamp:new Date});}catch(r){t.state="failed",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"failed",error:r instanceof Error?r:new Error(String(r)),timestamp:new Date});}finally{this._activeAdapters.delete(e);}}}async stopAllAdapters(e={}){let t=e.timeoutMs??1e4,r=Array.from(this._activeAdapters.keys()),n=await Promise.allSettled(r.map(s=>Promise.race([this.unregisterChannelAdapter(s),new Promise((i,a)=>setTimeout(()=>a(new Error(`Adapter stop timeout: ${s}`)),t))])));for(let s=0;s<n.length;s++)n[s].status==="rejected"&&console.error(`[crewx] adapter stop error (${r[s]}): ${n[s].reason}`);}async close(){await this.stopAllAdapters({timeoutMs:1e4});let e=[...this._remoteTargets.values()];this._remoteTargets.clear(),await Promise.allSettled(e.map(async r=>{try{await(await r).close();}catch(n){console.error(`[crewx] remote target close error: ${n instanceof Error?n.message:String(n)}`);}}));let t=[...this._plugins].reverse();for(let r of t)try{await r.detach(this);}catch(n){console.error(`[crewx] plugin ${r.name} detach error: ${n instanceof Error?n.message:String(n)}`);}this._plugins.length=0;}filterAgents(e){let t=a=>a?a.split(",").map(d=>d.trim().toLowerCase()).filter(Boolean):void 0,r=t(e.role),n=t(e.team),s=t(e.provider),i=Array.from(this._agents.values());return r&&(i=i.filter(a=>a.role&&r.some(d=>ie(a.role.toLowerCase(),d)))),n&&(i=i.filter(a=>a.team&&n.some(d=>ie(a.team.toLowerCase(),d)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(c=>s.some(u=>ie(c.toLowerCase(),u))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,r=this._agents.get(t);if(!r)throw new ce(t,Array.from(this._agents.keys()));return r.inline?.prompt??r.inline?.system_prompt??r.description??`You are an expert ${t}.`}async renderPrompt(e,t){let n={...await this._documentLoader.buildContext(),...t?.documents??{}},s={...t,documents:n};return this._templateEngine.render(e,s)}registerLayout(e,t){this._layoutLoader.registerLayout(e,t);}async renderAgentPromptFull(e,t){let r=e.startsWith("@")?e.slice(1):e,n=this._agents.get(r);if(!n)throw new ce(r,Array.from(this._agents.keys()));let s=this._resolveLayoutSpec(n,t?.layout),i=this._extractLayoutId(s),a=this._extractLayoutProps(n,s,t?.layout),d=this._layoutLoader.load(i,a),c=n.inline?.prompt??n.inline?.system_prompt??n.description??`You are an expert ${r}.`,u=await this._documentLoader.buildContext(),g=t?.env??(typeof process<"u"?process.env:{}),f=t?.vars?.security_key??oi(),p={...t?.vars??{},documents:u,env:g,agent:{id:n.id,name:n.name??n.id,role:n.role??"",team:n.team??"",description:n.description??""}},m=await this._templateEngine.render(c,p),w={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},A=n.provider,v=Array.isArray(A)?A:typeof A=="string"&&A.length>0?[A]:[],k=v.join(", ")||(typeof A=="string"?A:""),x=n.options,S=["goals","daily"],T={goals:false,daily:false},B;if(!Array.isArray(x)&&typeof x=="object"&&x!==null){let L=x;if("goals"in L){let U=L.goals;typeof U=="string"||Array.isArray(U)?T.goals=U:T.goals=!!U;}"daily"in L&&(T.daily=!!L.daily);let q={};for(let[U,_]of Object.entries(L))S.includes(U)||(q[U]=_);if(Object.keys(q).length>0){let U=v.some(M=>M.startsWith("cli/")),_={};for(let[M,b]of Object.entries(q)){let R={};if(Array.isArray(b))U&&(R.rawArgs=b);else if(typeof b=="object"&&b!==null){let F=b;Object.keys(F).length>0&&(R.named=F);}(R.named||R.rawArgs&&R.rawArgs.length>0)&&(_[M]=R);}B=Object.keys(_).length>0?_:void 0;}}let $=Array.isArray(x)?x:void 0,P={};for(let[L,q]of Object.entries(u))P[L]={content:q.content??"",toc:q.toc,summary:q.summary,path:q.path};if(T.goals){let L=W.join(this._projectRoot,"docs","goal"),q=await pn(L,void 0,T.goals);q&&(P.active_goals={content:q});}if(T.daily){let L=W.join(this._projectRoot,"docs","daily"),q=await gn(L);q&&(P.today_daily={content:q});}let G={user_input:t?.vars?.user_input??void 0,agent:{id:n.id,name:n.name??n.id,role:n.role??"",team:n.team??"",description:n.description??"",provider:k,providerList:v,model:n.inline?.model,workingDirectory:n.working_directory??n.workingDirectory??".",inline:{...n.inline??{},prompt:m},specialties:n.specialties??[],capabilities:n.capabilities??[],remote:n.remote??null,optionsByMode:B,optionsArray:$},agentMetadata:{specialties:n.specialties??[],capabilities:n.capabilities??[],description:n.description??""},contextOptions:T,documents:P,skills:t?.skills??[],session:w,env:g,vars:{security_key:f,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:w.platform,mode:w.mode,messages:t?.messages??[],tools:this._tools.size>0?{list:Array.from(this._tools.values()).map(L=>({name:L.name,description:L.description,parameters:L.parameters})),json:JSON.stringify(Array.from(this._tools.values()).map(L=>({name:L.name,description:L.description,parameters:L.parameters})),null,2),count:this._tools.size}:null,metadata:{}};return this._layoutRenderer.render(d,G)}_filterToolsByMode(e){return e?e.map(t=>this._tools.get(t)).filter(t=>t!==void 0):Array.from(this._tools.values())}_resolveLayoutSpec(e,t){if(t!==void 0)return t;let r=e.inline?.layout;if(r!==void 0)return r;let n=this._config?.layouts?.default;return typeof n=="string"&&n?n:"crewx/default"}_extractLayoutId(e){if(typeof e=="string")return e;if("id"in e)return e.id;let t=`crewx/__inline_${Date.now()}`;return this._layoutLoader.registerLayout(t,e.template),t}_extractLayoutProps(e,t,r){let n=e.inline?.layout,s=n&&typeof n=="object"&&"props"in n?n.props:void 0,i=r&&typeof r=="object"&&"id"in r?r.props:void 0;if(s||i)return {...s??{},...i??{}}}_getConversationProvider(){return this._plugins.find(t=>t.name==="conversation")?.conversationProvider}async _fetchHistoryMessages(e,t,r){if(r&&r.length>0)return r;if(!e)return;let n=this._getConversationProvider();if(n)try{let s=await n.fetchHistory(e,{currentTraceId:t});return s.messages.length===0?void 0:ur(s)}catch{return}}_resolveTimeout(e){let t=Zr();return e==="query"?t.queryMs:t.executeMs}emitToolEvents(e,t,r,n,s,i,a){try{let c=exports.BUILTIN_ADAPTERS[r]?.parseEvent?.(n)??Qt(new Date().toISOString(),n);for(let u of c)u.type==="tool_use"&&u.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName,rawName:u.toolName,input:u.toolInput?this.tryParseJson(u.toolInput):void 0,toolUseId:u.toolUseId}}),u.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName??"unknown",rawName:u.toolName??"unknown",toolUseId:u.toolUseId,result:u.resultPreview,isError:u.isError}});}catch{}}emitTaskLogEntries(e,t,r,n,s,i,a){try{for(let d of a)d.type==="tool_use"&&d.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:n,sessionId:s,provider:i,tool:{name:d.toolName,rawName:d.toolName,input:d.toolInput?this.tryParseJson(d.toolInput):void 0,toolUseId:d.toolUseId}}),d.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:n,sessionId:s,provider:i,tool:{name:d.toolName??"unknown",rawName:d.toolName??"unknown",toolUseId:d.toolUseId,result:d.resultPreview,isError:d.isError}});}catch{}}tryParseJson(e){try{return JSON.parse(e)}catch{return e}}async query(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.query(n.agentRef,t,r);let s=et.getStore()??cr(r?.trace),i=r?.taskId??Ce("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return et.run(d,async()=>{let c=Date.now(),u=new Date,g;try{g=mt(e,Array.from(this._agents.values()));}catch(_){if(_ instanceof ce){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"AGENT_NOT_FOUND",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:M}}}throw _}d.callerAgentId=g.id;let f=Array.isArray(g.provider)?g.provider[0]??"cli/claude":g.provider,p=r?.provider??f,m=r?.model??g.inline?.model;m&&m.includes("{{")&&(m=await this._templateEngine.render(m,{...r?.vars??{}}));let w;try{w=pe(p);}catch(_){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"PROVIDER_ERROR",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M}}}let A=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),v;try{v=await this.renderAgentPromptFull(e,{session:{mode:"query",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:A});}catch(_){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${_ instanceof Error?_.message:String(_)}`);}let k,x,S,T=m,B=false,$=_=>{B||(B=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",pid:_,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:T,provider:p,codingAgentCommand:k,renderedPrompt:v,metadata:{...r?.metadata??{},provider:p},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},P=g.options,H=Array.isArray(P?.query?.tools)?P.query.tools:void 0,G=this._tools.size>0?this._filterToolsByMode(H):[],L=(()=>{let _=P?.query;if(!_||Array.isArray(_))return;let{tools:M,effort:b,mode:R,...F}=_,Y=Object.entries(F).filter(([,K])=>K!=null);if(Y.length!==0)return Object.fromEntries(Y.map(([K,Ft])=>[K,String(Ft)]))})(),q=g.inline?.max_steps;p.startsWith("api/")&&$();let U=false;try{let _=await w.query(t,{model:m,effort:P?.query?.effort,mode:P?.query?.mode,context:r?.context,systemPrompt:v??g.inline?.system_prompt??g.inline?.prompt??g.description??`You are ${g.id}.`,additionalArgs:Array.isArray(P?.query)?P.query:void 0,tools:G.length>0?G:void 0,maxSteps:q,configOptions:L,timeoutMs:this._resolveTimeout("query"),cwd:r?.cwd,env:{CREWX_AGENT_ID:g.id,CREWX_AGENT_ROLE:g.role??"",CREWX_AGENT_TEAM:g.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:p,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,u)},onPid:R=>$(R),onOutput:(R,F)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:R,level:F}),F==="stdout"&&this.emitToolEvents(i,e,p,R,g.id,r?.threadId??"","");},onTaskLog:R=>{this.emitTaskLogEntries(i,e,g.id,r?.threadId??"","",p,R);for(let F of R)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(F),level:"info"});},onCommand:R=>{k=R;},onUsage:R=>{x=R;},onExitCode:R=>{S=R;},onModel:R=>{T||(T=R);}});$();let M=Date.now()-c,b={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:_,durationMs:M,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:Object.keys(b).length>0?b:void 0}),U=!0,{ok:!0,data:_,meta:{agentId:g.id,provider:p,model:m,durationMs:M,taskId:i}}}catch(_){if(_ instanceof exports.ClientToolCallRequiredError){let R=Ce("thd");return this._pendingThreads.set(R,{agentRef:g.id,providerStr:p,continuationState:_.continuationState,toolCall:_.toolCall,traceId:i,startMs:c,model:m}),U=true,{ok:true,status:"requires_action",data:"",toolCall:_.toolCall,threadId:R,meta:{agentId:g.id,provider:p,model:m,durationMs:Date.now()-c,taskId:i}}}$();let M=Date.now()-c,b={code:"QUERY_FAILED",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:M,error:b,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:r?.metadata?{...r.metadata}:void 0}),U=true,{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M,taskId:i}}}finally{U||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:Date.now()-c,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:S??-1,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T});}})}async continueQuery(e,t){let r=this._pendingThreads.get(e);if(!r)return {ok:false,data:"",error:{code:"THREAD_NOT_FOUND",message:`No pending thread: ${e}`},meta:{agentId:"",provider:"",durationMs:0}};this._pendingThreads.delete(e);let n=pe(r.providerStr);if(!n.continueWithToolResults)return {ok:false,data:"",error:{code:"UNSUPPORTED",message:"Provider does not support client tool continuation"},meta:{agentId:r.agentRef,provider:r.providerStr,durationMs:0}};let s=t.map(i=>({...i,toolName:r.toolCall.toolCallId===i.toolCallId?r.toolCall.toolName:i.toolCallId}));try{let i=await n.continueWithToolResults(r.continuationState,s),a=Date.now()-r.startMs;return this.emit("task:end",{traceId:r.traceId,timestamp:new Date,agentRef:r.agentRef,mode:"query",result:i,durationMs:a}),{ok:!0,status:"complete",data:i,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}catch(i){if(i instanceof exports.ClientToolCallRequiredError)return this._pendingThreads.set(e,{...r,continuationState:i.continuationState,toolCall:i.toolCall}),{ok:true,status:"requires_action",data:"",toolCall:i.toolCall,threadId:e,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:Date.now()-r.startMs}};let a=Date.now()-r.startMs;return {ok:false,data:"",error:{code:"CONTINUE_FAILED",message:i.message},meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}}async execute(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.execute(n.agentRef,t,r);let s=et.getStore()??cr(r?.trace),i=r?.taskId??Ce("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return et.run(d,async()=>{let c=Date.now(),u=new Date,g;try{g=mt(e,Array.from(this._agents.values()));}catch(_){if(_ instanceof ce){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"AGENT_NOT_FOUND",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:M}}}throw _}d.callerAgentId=g.id;let f=Array.isArray(g.provider)?g.provider[0]??"cli/claude":g.provider,p=r?.provider??f,m=r?.model??g.inline?.model;m&&m.includes("{{")&&(m=await this._templateEngine.render(m,{...r?.vars??{}}));let w;try{w=pe(p);}catch(_){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"PROVIDER_ERROR",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M}}}let A=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),v;try{v=await this.renderAgentPromptFull(e,{session:{mode:"execute",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:A});}catch(_){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${_ instanceof Error?_.message:String(_)}`);}let k,x,S,T=m,B=false,$=_=>{B||(B=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",pid:_,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:T,provider:p,codingAgentCommand:k,renderedPrompt:v,metadata:{...r?.metadata??{},provider:p},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},P=g.options,H=Array.isArray(P?.execute?.tools)?P.execute.tools:void 0,G=this._tools.size>0?this._filterToolsByMode(H):[],L=(()=>{let _=P?.execute;if(!_||Array.isArray(_))return;let{tools:M,effort:b,mode:R,...F}=_,Y=Object.entries(F).filter(([,K])=>K!=null);if(Y.length!==0)return Object.fromEntries(Y.map(([K,Ft])=>[K,String(Ft)]))})(),q=g.inline?.max_steps;p.startsWith("api/")&&$();let U=false;try{let _=await w.execute(t,{model:m,effort:P?.execute?.effort,mode:P?.execute?.mode,context:r?.context,systemPrompt:v??g.inline?.system_prompt??g.inline?.prompt??g.description??`You are ${g.id}.`,additionalArgs:Array.isArray(P?.execute)?P.execute:void 0,tools:G.length>0?G:void 0,maxSteps:q,configOptions:L,timeoutMs:this._resolveTimeout("execute"),cwd:r?.cwd,env:{CREWX_AGENT_ID:g.id,CREWX_AGENT_ROLE:g.role??"",CREWX_AGENT_TEAM:g.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:p,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,u)},onPid:R=>$(R),onOutput:(R,F)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:R,level:F}),F==="stdout"&&this.emitToolEvents(i,e,p,R,g.id,r?.threadId??"","");},onTaskLog:R=>{this.emitTaskLogEntries(i,e,g.id,r?.threadId??"","",p,R);for(let F of R)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(F),level:"info"});},onCommand:R=>{k=R;},onUsage:R=>{x=R;},onExitCode:R=>{S=R;},onModel:R=>{T||(T=R);}});$();let M=Date.now()-c,b={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:_,durationMs:M,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:Object.keys(b).length>0?b:void 0}),U=!0,{ok:!0,data:_,meta:{agentId:g.id,provider:p,model:m,durationMs:M,taskId:i}}}catch(_){$();let M=Date.now()-c,b={code:"EXECUTE_FAILED",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:M,error:b,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:r?.metadata?{...r.metadata}:void 0}),U=true,{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M}}}finally{U||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:Date.now()-c,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:S??-1,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T});}})}};function $n(o,e){let t=Sr(o)?o:void 0,r=Sr(e)?e:void 0;if(!(!t&&!r))return {...t??{},...r??{}}}function Sr(o){return typeof o=="object"&&o!==null&&!Array.isArray(o)}function si(o,e){let t=Array.isArray(o)?o:void 0,r=Array.isArray(e)?e:void 0;if(!t&&!r)return;let n=a=>{if(!Sr(a))return;let d=a.id;if(typeof d=="string")return `id:${d}`;let c=a.name;if(typeof c=="string")return `name:${c}`},s=new Set;for(let a of r??[]){let d=n(a);d&&s.add(d);}let i=[];for(let a of t??[]){let d=n(a);d&&s.has(d)||i.push(a);}for(let a of r??[])i.push(a);return i}async function jn(o,e,t){if(o.some(n=>(Array.isArray(n.provider)?n.provider:[n.provider]).some(i=>i.startsWith("api/")))){let{registerApiProviders:n}=await Promise.resolve().then(()=>(fr(),_n));n(t?.api);}ai(o,e),di(o,e),ii(o);}function ii(o){if(!o.some(r=>(Array.isArray(r.provider)?r.provider:[r.provider]).some(s=>s.startsWith("acp/"))))return;let{registerAcpProviders:t}=(Ar(),qt(bn));t();}function ai(o,e){if(!o.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("remote/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createRemoteProviderFactory:n}=(Cr(),qt(Sn)),s=new Map;for(let i of r)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&ue("remote",n(s,pe));}function di(o,e){if(!o.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("plugin/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createPluginProviderFactory:n}=(Tr(),qt(Nn)),s=new Map;for(let i of r)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&ue("plugin",n(s));}l();var Ir=class{detach(e){}};l();var li="crewx:fs:",Or=class{prefix;store;constructor(e){this.prefix=e?.prefix??li,this.store=e?.storage??new Map;}async readFile(e){let t=this.toKey(e),r=this.store.get(t);if(r===void 0)throw new Error(`BrowserFsAdapter: file not found: ${e}`);return r}async exists(e){return this.store.has(this.toKey(e))}resolvePath(...e){let t=e.map(i=>i.replace(/\\/g,"/")).join("/").replace(/\/+/g,"/"),r=t.split("/"),n=[];for(let i of r)i==="."||i===""||(i===".."?n.pop():n.push(i));let s=n.join("/");return t.startsWith("/")?`/${s}`:s}isAbsolute(e){return e.startsWith("/")}setItem(e,t){this.store.set(this.toKey(e),t);}removeItem(e){this.store.delete(this.toKey(e));}keys(){return Array.from(this.store.keys()).filter(e=>e.startsWith(this.prefix)).map(e=>e.slice(this.prefix.length))}async readdir(e){let t=e.replace(/\\/g,"/").replace(/\/$/,""),r=this.toKey(t+"/"),n=[];for(let s of this.store.keys())if(s.startsWith(r)){let a=s.slice(r.length).split("/")[0];a&&!n.includes(a)&&n.push(a);}return n}toKey(e){return `${this.prefix}${e.replace(/\\/g,"/")}`}};l();function ci(o,e){let t=o.skills?.include;if(t===void 0)return [...e];if(t.length===0)return [];let r=new Set(t);return e.filter(n=>r.has(n))}ae();mr();fr();l();hr();xe();l();Rt();It();Ct();function ui(o,e,t,r){let n=t.agentInfo?.name,s=e??n??o,a=(r.modes?.availableModes??[]).map(m=>({id:m.id,name:m.name,...m.description!=null?{description:m.description}:{}})),d=[],c=r.configOptions??[];for(let m of c)if(m.category==="thought_level"&&m.type==="select"){let w=m.options??[];if(w.length>0&&w[0]?.group!=null)for(let A of w)for(let v of A.options??[])d.push(v.value);else for(let A of w)A.value!=null&&d.push(A.value);}let u=r.models?.availableModels??[],g=o==="claude"?Cn.map(m=>({id:m.id,name:m.name})):u.map(m=>({id:m.modelId})),f=t.agentCapabilities??{},p={loadSession:f.loadSession??false,image:f.promptCapabilities?.image??false,audio:f.promptCapabilities?.audio??false,mcp:f.mcpCapabilities!=null};return {id:`acp/${o}`,name:s,modes:a,effort:d,models:g,capabilities:p}}async function Un(o){let e=exports.ACP_ADAPTERS[o];if(!e)return null;let t=e.meta?.displayName,r=new exports.AcpConnection({spawn:e.spawn,cwd:process.cwd()});try{await r.connect(e.clientInfo);let n=r.initResponse;if(!n)return null;let s=e.buildSessionParams({cwd:process.cwd()}),i=await r.newSessionRaw(s);return ui(o,t,n,i)}catch{return null}finally{await r.dispose();}}async function pi(){let o=Object.keys(exports.ACP_ADAPTERS),e=await Promise.allSettled(o.map(r=>Un(r))),t=[];for(let r of e)r.status==="fulfilled"&&r.value!==null&&t.push(r.value);return t}Rt();wr();It();Ar();Wt();Ue();l();var Mr=0;function gi(o){let e=Array.from(o.agents.keys());return {name:"delegate_to_agent",description:`Delegate a task to another agent. Available agents: ${e.join(", ")}`,parameters:{type:"object",properties:{agent:{type:"string",description:`Agent ID to delegate to. One of: ${e.join(", ")}`},message:{type:"string",description:"Task description for the target agent"},mode:{type:"string",description:'Execution mode: "query" for questions, "execute" for actions. Default: query'}},required:["agent","message"]},execute:async t=>{if(Mr>=3)return "Error: Maximum delegation depth (3) reached. Cannot delegate further.";let r=t.agent,n=t.message,s=t.mode??"query";if(!e.includes(r))return `Error: Unknown agent "${r}". Available: ${e.join(", ")}`;Mr++;try{if(s==="execute"){let a=await o.execute(r,n);return a.ok?a.data:`Error: ${a.error?.message??"Unknown error"}`}let i=await o.query(r,n);return i.ok?i.data:`Error: ${i.error?.message??"Unknown error"}`}finally{Mr--;}}}}l();var Fn=typeof process<"u"?process.env:{};function mi(){return Fn.CREWX_CLI||"npx crewx"}function fi(){return Fn.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}l();var yi=/^[a-zA-Z0-9._-]+$/,Nr=class{constructor(e){this.storage=e;}storage;listBoxes(e){this.validateId(e);let r=this.storage.listBoxes(e).map(n=>this.toBoxResponse(n));return {boxes:r,total:r.length}}getBox(e,t){this.validateId(e),this.validateId(t);let r=this.storage.findBox(e,t);return r?this.toBoxResponse(r):null}createBox(e,t){this.validateId(e);let r=this.generateBoxId(),n=new Date().toISOString(),s=this.storage.insertBox(e,{id:r,seq:t.seq,firstTaskId:t.firstTaskId,midTaskId:t.midTaskId,lastTaskId:t.lastTaskId,taskCount:t.taskCount,summary:t.summary??null,sourceTokens:t.sourceTokens,summaryTokens:t.summaryTokens??null,createdAt:n});return this.toBoxResponse(s)}toBoxResponse(e){return {id:e.id,threadId:e.thread_id,seq:e.seq,firstTaskId:e.first_task_id,lastTaskId:e.last_task_id,taskCount:e.task_count,sourceTokens:e.source_tokens,summaryTokens:e.summary_tokens,summary:e.summary,previewFirst:this.storage.getTaskPreview(e.first_task_id,200),previewMid:this.storage.getTaskPreview(e.mid_task_id,200),previewLast:this.storage.getTaskPreview(e.last_task_id,200),createdAt:e.created_at}}validateId(e){if(!yi.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return Ce("box")}};l();function hi(o,e,t,r,n){let{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}=r,d=s*i,c=s*a,u=d+c,g=e.getThreadMessages(o),f=[],p=0,m=false,w=[];for(let k=0;k<g.length;k+=2){let x=g[k],S=g[k+1],T=x?.content||"",B=S?.content||"",$=n.countTokens(T+B),P=[];x&&P.push(x),S&&P.push(S),w.push({messages:P,tokens:$});}for(let k=w.length-1;k>=0;k--){let x=w[k];if(p+x.tokens>d){m=true;break}p+=x.tokens,f.unshift(...x.messages);}let A=[],v=0;if(m&&c>0)try{let{boxes:k}=t.listBoxes(o);for(let x=k.length-1;x>=0;x--){let S=k[x],T=S.summaryTokens??S.sourceTokens;if(v+T>c)break;v+=T,A.unshift({boxId:S.id,seq:S.seq,taskCount:S.taskCount,sourceTokens:S.sourceTokens,summary:S.summary,previewFirst:S.previewFirst,previewMid:S.previewMid,previewLast:S.previewLast,createdAt:S.createdAt});}}catch(k){if(k instanceof Error&&!/not found/i.test(k.message))throw k}return {hot:f,warm:A,hotTokens:p,warmTokens:v,hotOverflow:m,totalBudget:u,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}Ue();Ae();l();var Ot=class extends Error{constructor(t,r){super(`Task ${t} timed out after ${r}ms`);this.taskId=t;this.timeoutMs=r;this.name="ParallelRunnerTimeoutError";}taskId;timeoutMs},dt=class{constructor(e={}){this.defaults=e;}defaults;metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0};async run(e,t={}){if(!Array.isArray(e))throw new TypeError("ParallelRunner.run expects an array of tasks");if(e.length===0)return this.metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0},[];let r=this.mergeOptions(t),n=Math.max(1,r.maxConcurrency??5),s=r.timeoutMs,i=r.failFast??false,a=r.callbacks,d=r.evaluateTaskSuccess??(()=>true),c=[],u=0,g=0,f=0,p=false,m=0,w=perf_hooks.performance.now(),A=async P=>{a?.onTaskStart&&await a.onTaskStart(P),f+=1;let H=new AbortController,G={signal:H.signal},L,q;typeof s=="number"&&Number.isFinite(s)&&s>0&&(q=new Promise((b,R)=>{L=setTimeout(()=>{let F=new Ot(P.id,s);H.abort(F),R(F);},s);}));let U=perf_hooks.performance.now(),_=P.run(G),M=q?Promise.race([_,q]):_;try{let b=await M,R=perf_hooks.performance.now(),F=R-U,Y=d(b,P),K={taskId:P.id,success:Y,value:b,durationMs:F,startedAt:U,finishedAt:R,metadata:P.metadata,aborted:!1};c.push(K),Y?u+=1:g+=1,a?.onTaskComplete&&await a.onTaskComplete(K),i&&!Y&&(p=!0);}catch(b){let R=perf_hooks.performance.now(),F=R-U,Y=b instanceof Error?b:new Error(String(b)),K={taskId:P.id,success:false,error:Y,durationMs:F,startedAt:U,finishedAt:R,metadata:P.metadata,aborted:H.signal.aborted};c.push(K),g+=1,a?.onError&&await a.onError(P,Y,F),i&&(p=true);}finally{L&&clearTimeout(L),q&&_.catch(()=>{});}},v=async()=>{for(;!p;){let P=m;if(P>=e.length)break;m+=1;let H=e[P];if(!H||(await A(H),p))break}},k=Math.min(n,e.length),x=[];for(let P=0;P<k;P++)x.push(v());await Promise.all(x);let T=perf_hooks.performance.now()-w,B=c.length?c.reduce((P,H)=>P+H.durationMs,0)/c.length:0,$=T>0?c.length/(T/1e3):c.length;return this.metrics={totalTasks:e.length,startedTasks:f,completedTasks:c.length,successCount:u,failureCount:g,totalDurationMs:T,averageDurationMs:B,throughput:$},c}getMetrics(){return this.metrics}mergeOptions(e){return {maxConcurrency:e.maxConcurrency??this.defaults.maxConcurrency,timeoutMs:e.timeoutMs??this.defaults.timeoutMs,failFast:e.failFast??this.defaults.failFast,evaluateTaskSuccess:e.evaluateTaskSuccess??this.defaults.evaluateTaskSuccess,callbacks:this.mergeCallbacks(this.defaults.callbacks,e.callbacks)}}mergeCallbacks(e,t){if(!(!e&&!t))return {onTaskStart:async r=>{e?.onTaskStart&&await e.onTaskStart(r),t?.onTaskStart&&await t.onTaskStart(r);},onTaskComplete:async r=>{e?.onTaskComplete&&await e.onTaskComplete(r),t?.onTaskComplete&&await t.onTaskComplete(r);},onError:async(r,n,s)=>{e?.onError&&await e.onError(r,n,s),t?.onError&&await t.onError(r,n,s);}}}};l();l();var lt=class{async query(e){throw new Error("AgentRuntime.query is not implemented. Provide a subclass or mock AgentRuntime.prototype.query.")}async execute(e){throw new Error("AgentRuntime.execute is not implemented. Provide a subclass or mock AgentRuntime.prototype.execute.")}};var Hn=3,qn=3e4,Bn=500,wi=o=>{if(typeof o!="number"||Number.isNaN(o)||!Number.isFinite(o))return Hn;let e=Math.floor(o);return e>0?e:Hn},xi=o=>o===void 0||typeof o!="number"||Number.isNaN(o)||o<=0?qn:o,ki=o=>{if(!o)return {maxRetries:0,retryDelay:Bn};let e=Number.isInteger(o.maxRetries)&&o.maxRetries>=0?o.maxRetries:0,t=typeof o.retryDelay=="number"&&o.retryDelay>=0?o.retryDelay:Bn;return {maxRetries:e,retryDelay:t}},Dr=o=>{let e=o.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},vi=(o,e)=>o<=0?Promise.resolve():new Promise((t,r)=>{let n=setTimeout(()=>{e.removeEventListener("abort",s),t();},o),s=()=>{clearTimeout(n),r(Dr(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),_i=async(o,e,t)=>{let r,n;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw Dr(t);try{let i=await o();if(r=i,i.success||s===e.maxRetries)return i}catch(i){if(n=i,t.aborted)throw Dr(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await vi(e.retryDelay,t);}if(r)return r;throw n?n instanceof Error?n:new Error(String(n)):new Error("Parallel helper encountered an unexpected state")},Wn=(o,e,t)=>{e.completed+=1,t?e.success+=1:e.failure+=1;try{o.onProgress?.(e.completed,e.total);}catch(r){process.env.NODE_ENV!=="production"&&console.warn("Parallel helper onProgress callback threw an error:",r);}},Ai=o=>o.map(t=>({metadata:t.metadata,taskResult:t})).slice().sort((t,r)=>t.metadata.index-r.metadata.index).map(({metadata:t,taskResult:r})=>{if(r.value){let s=r.value;return {...s,agentId:s.agentId??t.request.agentId,metadata:{...s.metadata,requestIndex:t.index,mode:t.mode}}}let n=r.error??new Error("Unknown error");return {agentId:t.request.agentId,content:n.message,success:false,metadata:{error:n.message,aborted:r.aborted??false,requestIndex:t.index,mode:t.mode}}}),Ri=o=>o.filter(e=>!e.success).map(e=>{let t=e.metadata;if(e.error instanceof Error)return {index:t.index,error:e.error};if(e.value&&!e.value.success){let r=String(e.value.metadata?.error??e.value.content??"Agent returned unsuccessful result");return {index:t.index,error:new Error(r)}}return {index:t.index,error:new Error("Unknown failure")}}),Pi=(o,e)=>({onTaskComplete:async t=>{Wn(e,o,t.success);},onError:async()=>{Wn(e,o,false);}}),zn=async(o,e,t={})=>{if(!Array.isArray(o))throw new TypeError("Parallel helpers expect an array of requests");if(o.length===0){let A={total:0,completed:0,successCount:0,failureCount:0,results:[],errors:[],metrics:{totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0}};return t.onComplete?.(A),[]}let r=wi(t.concurrency),n=xi(t.timeout),s=ki(t.retryPolicy),i=new dt,a=new lt,d=o.map((w,A)=>({id:`${e}:${w.agentId??"anonymous"}:${A}`,metadata:{index:A,mode:e,request:w},run:v=>_i(()=>e==="query"?a.query(w):a.execute(w),s,v.signal)})),c={completed:0,success:0,failure:0,total:o.length},u=await i.run(d,{maxConcurrency:r,timeoutMs:n,evaluateTaskSuccess:w=>w.success,callbacks:Pi(c,t)}),g=Ai(u),f=Ri(u),p=i.getMetrics(),m={total:o.length,completed:o.length,successCount:g.filter(w=>w.success).length,failureCount:g.filter(w=>!w.success).length,results:g,errors:f,metrics:p};return t.onComplete?.(m),g},Ci=(o,e)=>zn(o,"query",e),Ti=(o,e)=>zn(o,"execute",e);Tr();l();l();var He=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:W.join(Si__default.default.homedir(),".crewx","crewx.db")}resolveDbPaths(){return [this.resolveDbPath()]}isMissingTableError(e){return e instanceof Error&&/no such table:/i.test(e.message)}dbExists(e){return fs.existsSync(e??this.resolveDbPath())}};l();function fe(o){let e=z("better-sqlite3"),{drizzle:t}=z("drizzle-orm/better-sqlite3"),r=new e(o);return r.exec("PRAGMA journal_mode = WAL"),r.exec("PRAGMA busy_timeout = 5000"),r.exec("PRAGMA foreign_keys = ON"),{db:t(r),runRaw:(n,s=[])=>r.prepare(n).run(...s),close:()=>r.close()}}l();var Kn=new Set,Oi={agent_id:"TEXT",status:"TEXT DEFAULT 'running'",started_at:"TEXT",trace_id:"TEXT",parent_task_id:"TEXT",crewx_version:"TEXT",pid:"INTEGER",thread_id:"TEXT",workspace_id:"TEXT",workspace_ref:"TEXT",workspace_name:"TEXT",project_id:"TEXT",project_name:"TEXT"};function Mi(o,e){return (o.get(`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='${e}'`)?.cnt??0)>0}function Ni(o,e){if(e>0||!Mi(o,"tasks"))return;let t=o.all("PRAGMA table_info(tasks)"),r=new Set(t.map(n=>n.name));for(let[n,s]of Object.entries(Oi))r.has(n)||o.run(`ALTER TABLE tasks ADD COLUMN ${n} ${s}`);}function Di(o,e,t){let r=o.all(t`SELECT hash FROM __drizzle_migrations`),n=new Set(r.map(i=>i.hash)),s=JSON.parse(fs.readFileSync(W__namespace.default.join(e,"meta/_journal.json"),"utf-8"));for(let i of s.entries){let a=W__namespace.default.join(e,`${i.tag}.sql`);if(!fs.existsSync(a))continue;let d=fs.readFileSync(a,"utf-8"),c=crypto$1.createHash("sha256").update(d).digest("hex");if(n.has(c))continue;let u=/ALTER\s+TABLE\s+[`"]?(\w+)[`"]?\s+ADD\s+[`"]?(\w+)[`"]?/gi,g=[],f;for(;(f=u.exec(d))!==null;)g.push({table:f[1],column:f[2]});if(g.length===0||!d.split(/-->\s*statement-breakpoint/).map(w=>w.trim()).filter(Boolean).every(w=>/^ALTER\s+TABLE\s+.+\s+ADD\s+/i.test(w)))continue;g.every(({table:w,column:A})=>o.all(`PRAGMA table_info("${w}")`).some(k=>k.name===A))&&o.run(t`INSERT INTO __drizzle_migrations (hash, created_at) VALUES (${c}, ${i.when})`);}}function Li(o){let{migrate:e}=z("drizzle-orm/better-sqlite3/migrator"),{sql:t}=z("drizzle-orm"),r=[W__namespace.default.join(__dirname,"../migrations"),W__namespace.default.join(__dirname,"migrations"),W__namespace.default.join(__dirname,"../../../../drizzle/migrations"),W__namespace.default.join(process.cwd(),"drizzle/migrations")],n=r.find(c=>fs.existsSync(W__namespace.default.join(c,"meta/_journal.json")));if(!n)throw new Error(`migrations folder not found. Searched:
53
53
  ${r.join(`
54
- `)}`);let s=o.get(t`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='__drizzle_migrations'`),i=0;s?.cnt&&(i=o.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0),Si(o,i),s?.cnt&&Ii(o,n,t),e(o,{migrationsFolder:n});let d=(o.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0)-i;if(d>0){let c=s?.cnt?"Database migrated":"Database initialized";console.log(`[crewx] ${c} (${d} migration${d>1?"s":""} applied).`);}}function Ot(o,e){Wn.has(e)||(Oi(o),Wn.add(e));}l();var M=class extends Error{code;cause;constructor(e,t,r){super(t),this.name="RepositoryError",this.code=e,this.cause=r,Object.setPrototypeOf(this,new.target.prototype);}};l();l();var Vn=sqliteCore.sqliteTable("workspaces",{id:sqliteCore.text("id").primaryKey(),slug:sqliteCore.text("slug").notNull().unique(),name:sqliteCore.text("name").notNull(),workspace_path:sqliteCore.text("workspace_path"),description:sqliteCore.text("description"),is_active:sqliteCore.integer("is_active").notNull().default(1),created_at:sqliteCore.text("created_at").notNull(),updated_at:sqliteCore.text("updated_at").notNull()});l();var h=sqliteCore.sqliteTable("tasks",{id:sqliteCore.text("id").primaryKey(),agent_id:sqliteCore.text("agent_id").notNull(),user_id:sqliteCore.text("user_id"),prompt:sqliteCore.text("prompt").notNull(),mode:sqliteCore.text("mode").notNull().default("execute"),status:sqliteCore.text("status").notNull().default("running"),result:sqliteCore.text("result"),error:sqliteCore.text("error"),started_at:sqliteCore.text("started_at").notNull(),completed_at:sqliteCore.text("completed_at"),duration_ms:sqliteCore.integer("duration_ms"),metadata:sqliteCore.text("metadata"),workspace_id:sqliteCore.text("workspace_id"),trace_id:sqliteCore.text("trace_id"),parent_task_id:sqliteCore.text("parent_task_id"),caller_agent_id:sqliteCore.text("caller_agent_id"),model:sqliteCore.text("model"),platform:sqliteCore.text("platform").default("cli"),crewx_version:sqliteCore.text("crewx_version"),input_tokens:sqliteCore.integer("input_tokens").default(0),output_tokens:sqliteCore.integer("output_tokens").default(0),cost_usd:sqliteCore.real("cost_usd").default(0),pid:sqliteCore.integer("pid"),rendered_prompt:sqliteCore.text("rendered_prompt"),command:sqliteCore.text("command"),coding_agent_command:sqliteCore.text("coding_agent_command"),exit_code:sqliteCore.integer("exit_code"),logs:sqliteCore.text("logs"),thread_id:sqliteCore.text("thread_id"),workspace_ref:sqliteCore.text("workspace_ref"),project_id:sqliteCore.text("project_id"),project_ref:sqliteCore.text("project_ref"),cached_input_tokens:sqliteCore.integer("cached_input_tokens").default(0)},o=>({idx_tasks_agent_id:sqliteCore.index("idx_tasks_agent_id").on(o.agent_id),idx_tasks_status:sqliteCore.index("idx_tasks_status").on(o.status),idx_tasks_started_at:sqliteCore.index("idx_tasks_started_at").on(o.started_at),idx_tasks_trace_id:sqliteCore.index("idx_tasks_trace_id").on(o.trace_id),idx_tasks_parent_task_id:sqliteCore.index("idx_tasks_parent_task_id").on(o.parent_task_id),idx_tasks_crewx_version:sqliteCore.index("idx_tasks_crewx_version").on(o.crewx_version),idx_tasks_pid:sqliteCore.index("idx_tasks_pid").on(o.pid),idx_tasks_thread_id:sqliteCore.index("idx_tasks_thread_id").on(o.thread_id),idx_tasks_workspace_id:sqliteCore.index("idx_tasks_workspace_id").on(o.workspace_id),idx_tasks_workspace_ref:sqliteCore.index("idx_tasks_workspace_ref").on(o.workspace_ref),idx_tasks_project_id:sqliteCore.index("idx_tasks_project_id").on(o.project_id),idx_tasks_ws_started:sqliteCore.index("idx_tasks_ws_started").on(o.workspace_id,o.started_at)}));l();var Jn=sqliteCore.sqliteTable("threads",{id:sqliteCore.text("id").primaryKey(),workspace_id:sqliteCore.text("workspace_id").references(()=>Vn.id,{onDelete:"set null"}),platform:sqliteCore.text("platform").notNull().default("cli"),title:sqliteCore.text("title"),first_message:sqliteCore.text("first_message"),last_message:sqliteCore.text("last_message"),message_count:sqliteCore.integer("message_count").notNull().default(0),created_at:sqliteCore.text("created_at").notNull(),updated_at:sqliteCore.text("updated_at").notNull(),metadata:sqliteCore.text("metadata"),title_locked:sqliteCore.integer("title_locked").notNull().default(0),pinned:sqliteCore.integer("pinned").notNull().default(0),starred:sqliteCore.integer("starred").notNull().default(0)},o=>({idx_threads_updated_at:sqliteCore.index("idx_threads_updated_at").on(o.updated_at),idx_threads_workspace_id:sqliteCore.index("idx_threads_workspace_id").on(o.workspace_id)}));l();var Te=sqliteCore.sqliteTable("spans",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>h.id,{onDelete:"set null"}),parent_span_id:sqliteCore.text("parent_span_id").references(()=>Te.id,{onDelete:"set null"}),name:sqliteCore.text("name").notNull(),kind:sqliteCore.text("kind").notNull().default("internal"),status:sqliteCore.text("status").notNull().default("ok"),started_at:sqliteCore.text("started_at").notNull(),completed_at:sqliteCore.text("completed_at"),duration_ms:sqliteCore.integer("duration_ms"),input:sqliteCore.text("input"),output:sqliteCore.text("output"),error:sqliteCore.text("error"),attributes:sqliteCore.text("attributes")},o=>({idx_spans_task_id:sqliteCore.index("idx_spans_task_id").on(o.task_id),idx_spans_parent_span_id:sqliteCore.index("idx_spans_parent_span_id").on(o.parent_span_id)}));l();sqliteCore.sqliteTable("tool_calls",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>h.id,{onDelete:"cascade"}),session_id:sqliteCore.text("session_id"),tool_name:sqliteCore.text("tool_name").notNull(),files:sqliteCore.text("files"),input:sqliteCore.text("input"),output:sqliteCore.text("output"),duration_ms:sqliteCore.integer("duration_ms"),timestamp:sqliteCore.text("timestamp").notNull()},o=>({idx_tool_calls_task_id:sqliteCore.index("idx_tool_calls_task_id").on(o.task_id),idx_tool_calls_tool_name:sqliteCore.index("idx_tool_calls_tool_name").on(o.tool_name),idx_tool_calls_timestamp:sqliteCore.index("idx_tool_calls_timestamp").on(o.timestamp)}));l();sqliteCore.sqliteTable("thread_boxes",{id:sqliteCore.text("id").primaryKey(),thread_id:sqliteCore.text("thread_id").notNull().references(()=>Jn.id,{onDelete:"cascade"}),seq:sqliteCore.integer("seq").notNull(),first_task_id:sqliteCore.text("first_task_id").notNull(),mid_task_id:sqliteCore.text("mid_task_id").notNull(),last_task_id:sqliteCore.text("last_task_id").notNull(),task_count:sqliteCore.integer("task_count").notNull(),summary:sqliteCore.text("summary"),source_tokens:sqliteCore.integer("source_tokens").notNull(),summary_tokens:sqliteCore.integer("summary_tokens"),created_at:sqliteCore.text("created_at").notNull()},o=>({idx_thread_boxes_thread_id:sqliteCore.index("idx_thread_boxes_thread_id").on(o.thread_id),idx_thread_boxes_seq:sqliteCore.index("idx_thread_boxes_seq").on(o.thread_id,o.seq),uniq_thread_boxes_thread_seq:sqliteCore.unique().on(o.thread_id,o.seq)}));l();sqliteCore.sqliteTable("request_logs",{id:sqliteCore.text("id").primaryKey(),path:sqliteCore.text("path").notNull(),method:sqliteCore.text("method").notNull(),status_code:sqliteCore.integer("status_code").notNull(),duration_ms:sqliteCore.integer("duration_ms").notNull(),ip:sqliteCore.text("ip"),request_headers:sqliteCore.text("request_headers"),response_headers:sqliteCore.text("response_headers"),request_body:sqliteCore.text("request_body"),response_body:sqliteCore.text("response_body"),query:sqliteCore.text("query"),user_id:sqliteCore.text("user_id"),project_id:sqliteCore.text("project_id"),partition_key:sqliteCore.text("partition_key").notNull(),timestamp:sqliteCore.text("timestamp").notNull().default(drizzleOrm.sql`(datetime('now'))`),metadata:sqliteCore.text("metadata")},o=>({idx_request_logs_timestamp:sqliteCore.index("idx_request_logs_timestamp").on(o.timestamp),idx_request_logs_path:sqliteCore.index("idx_request_logs_path").on(o.path),idx_request_logs_status_code:sqliteCore.index("idx_request_logs_status_code").on(o.status_code),idx_request_logs_partition_key:sqliteCore.index("idx_request_logs_partition_key").on(o.partition_key)}));var Lr=class extends He{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=F.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let n=F.dirname(t);fs$1.existsSync(n)||fs$1.mkdirSync(n,{recursive:true});}else if(!fs$1.existsSync(t))throw new M("NOT_FOUND","Database not found");let r=ge(t);if(e)try{Ot(r.db,t);}catch(n){throw r.close(),n}return r}startTask(e){let t=this.openHandle(true);try{t.db.insert(h).values({id:e.id,agent_id:e.agentId,prompt:e.prompt,mode:e.mode,status:e.status,started_at:e.startedAt,pid:e.pid??null,parent_task_id:e.parentTaskId??null,caller_agent_id:e.callerAgentId??null,trace_id:e.traceId??null,command:e.command??null,metadata:e.metadata??null,workspace_id:e.workspaceId??null,platform:e.platform??"cli",crewx_version:e.crewxVersion??null,thread_id:e.threadId??null,model:e.model??null,rendered_prompt:e.renderedPrompt??null,coding_agent_command:e.codingAgentCommand??null}).onConflictDoNothing().run();}catch(r){throw r instanceof M?r:new M("DB_ERROR","Failed to start task",r)}finally{t.close();}}finishTask(e){let t=this.openHandle(true);try{t.runRaw(`UPDATE tasks SET status=?, result=?, error=?, completed_at=?, duration_ms=?,
54
+ `)}`);let s=o.get(t`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='__drizzle_migrations'`),i=0;s?.cnt&&(i=o.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0),Ni(o,i),s?.cnt&&Di(o,n,t),e(o,{migrationsFolder:n});let d=(o.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0)-i;if(d>0){let c=s?.cnt?"Database migrated":"Database initialized";console.log(`[crewx] ${c} (${d} migration${d>1?"s":""} applied).`);}}function Mt(o,e){Kn.has(e)||(Li(o),Kn.add(e));}l();var O=class extends Error{code;cause;constructor(e,t,r){super(t),this.name="RepositoryError",this.code=e,this.cause=r,Object.setPrototypeOf(this,new.target.prototype);}};l();l();var Xn=sqliteCore.sqliteTable("workspaces",{id:sqliteCore.text("id").primaryKey(),slug:sqliteCore.text("slug").notNull().unique(),name:sqliteCore.text("name").notNull(),workspace_path:sqliteCore.text("workspace_path"),description:sqliteCore.text("description"),is_active:sqliteCore.integer("is_active").notNull().default(1),created_at:sqliteCore.text("created_at").notNull(),updated_at:sqliteCore.text("updated_at").notNull()});l();var h=sqliteCore.sqliteTable("tasks",{id:sqliteCore.text("id").primaryKey(),agent_id:sqliteCore.text("agent_id").notNull(),user_id:sqliteCore.text("user_id"),prompt:sqliteCore.text("prompt").notNull(),mode:sqliteCore.text("mode").notNull().default("execute"),status:sqliteCore.text("status").notNull().default("running"),result:sqliteCore.text("result"),error:sqliteCore.text("error"),started_at:sqliteCore.text("started_at").notNull(),completed_at:sqliteCore.text("completed_at"),duration_ms:sqliteCore.integer("duration_ms"),metadata:sqliteCore.text("metadata"),workspace_id:sqliteCore.text("workspace_id"),trace_id:sqliteCore.text("trace_id"),parent_task_id:sqliteCore.text("parent_task_id"),caller_agent_id:sqliteCore.text("caller_agent_id"),model:sqliteCore.text("model"),platform:sqliteCore.text("platform").default("cli"),crewx_version:sqliteCore.text("crewx_version"),input_tokens:sqliteCore.integer("input_tokens").default(0),output_tokens:sqliteCore.integer("output_tokens").default(0),cost_usd:sqliteCore.real("cost_usd").default(0),pid:sqliteCore.integer("pid"),rendered_prompt:sqliteCore.text("rendered_prompt"),command:sqliteCore.text("command"),coding_agent_command:sqliteCore.text("coding_agent_command"),exit_code:sqliteCore.integer("exit_code"),logs:sqliteCore.text("logs"),thread_id:sqliteCore.text("thread_id"),workspace_ref:sqliteCore.text("workspace_ref"),project_id:sqliteCore.text("project_id"),project_ref:sqliteCore.text("project_ref"),cached_input_tokens:sqliteCore.integer("cached_input_tokens").default(0)},o=>({idx_tasks_agent_id:sqliteCore.index("idx_tasks_agent_id").on(o.agent_id),idx_tasks_status:sqliteCore.index("idx_tasks_status").on(o.status),idx_tasks_started_at:sqliteCore.index("idx_tasks_started_at").on(o.started_at),idx_tasks_trace_id:sqliteCore.index("idx_tasks_trace_id").on(o.trace_id),idx_tasks_parent_task_id:sqliteCore.index("idx_tasks_parent_task_id").on(o.parent_task_id),idx_tasks_crewx_version:sqliteCore.index("idx_tasks_crewx_version").on(o.crewx_version),idx_tasks_pid:sqliteCore.index("idx_tasks_pid").on(o.pid),idx_tasks_thread_id:sqliteCore.index("idx_tasks_thread_id").on(o.thread_id),idx_tasks_workspace_id:sqliteCore.index("idx_tasks_workspace_id").on(o.workspace_id),idx_tasks_workspace_ref:sqliteCore.index("idx_tasks_workspace_ref").on(o.workspace_ref),idx_tasks_project_id:sqliteCore.index("idx_tasks_project_id").on(o.project_id),idx_tasks_ws_started:sqliteCore.index("idx_tasks_ws_started").on(o.workspace_id,o.started_at)}));l();var Yn=sqliteCore.sqliteTable("threads",{id:sqliteCore.text("id").primaryKey(),workspace_id:sqliteCore.text("workspace_id").references(()=>Xn.id,{onDelete:"set null"}),platform:sqliteCore.text("platform").notNull().default("cli"),title:sqliteCore.text("title"),first_message:sqliteCore.text("first_message"),last_message:sqliteCore.text("last_message"),message_count:sqliteCore.integer("message_count").notNull().default(0),created_at:sqliteCore.text("created_at").notNull(),updated_at:sqliteCore.text("updated_at").notNull(),metadata:sqliteCore.text("metadata"),title_locked:sqliteCore.integer("title_locked").notNull().default(0),pinned:sqliteCore.integer("pinned").notNull().default(0),starred:sqliteCore.integer("starred").notNull().default(0)},o=>({idx_threads_updated_at:sqliteCore.index("idx_threads_updated_at").on(o.updated_at),idx_threads_workspace_id:sqliteCore.index("idx_threads_workspace_id").on(o.workspace_id)}));l();var Ie=sqliteCore.sqliteTable("spans",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>h.id,{onDelete:"set null"}),parent_span_id:sqliteCore.text("parent_span_id").references(()=>Ie.id,{onDelete:"set null"}),name:sqliteCore.text("name").notNull(),kind:sqliteCore.text("kind").notNull().default("internal"),status:sqliteCore.text("status").notNull().default("ok"),started_at:sqliteCore.text("started_at").notNull(),completed_at:sqliteCore.text("completed_at"),duration_ms:sqliteCore.integer("duration_ms"),input:sqliteCore.text("input"),output:sqliteCore.text("output"),error:sqliteCore.text("error"),attributes:sqliteCore.text("attributes")},o=>({idx_spans_task_id:sqliteCore.index("idx_spans_task_id").on(o.task_id),idx_spans_parent_span_id:sqliteCore.index("idx_spans_parent_span_id").on(o.parent_span_id)}));l();sqliteCore.sqliteTable("tool_calls",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>h.id,{onDelete:"cascade"}),session_id:sqliteCore.text("session_id"),tool_name:sqliteCore.text("tool_name").notNull(),files:sqliteCore.text("files"),input:sqliteCore.text("input"),output:sqliteCore.text("output"),duration_ms:sqliteCore.integer("duration_ms"),timestamp:sqliteCore.text("timestamp").notNull()},o=>({idx_tool_calls_task_id:sqliteCore.index("idx_tool_calls_task_id").on(o.task_id),idx_tool_calls_tool_name:sqliteCore.index("idx_tool_calls_tool_name").on(o.tool_name),idx_tool_calls_timestamp:sqliteCore.index("idx_tool_calls_timestamp").on(o.timestamp)}));l();sqliteCore.sqliteTable("thread_boxes",{id:sqliteCore.text("id").primaryKey(),thread_id:sqliteCore.text("thread_id").notNull().references(()=>Yn.id,{onDelete:"cascade"}),seq:sqliteCore.integer("seq").notNull(),first_task_id:sqliteCore.text("first_task_id").notNull(),mid_task_id:sqliteCore.text("mid_task_id").notNull(),last_task_id:sqliteCore.text("last_task_id").notNull(),task_count:sqliteCore.integer("task_count").notNull(),summary:sqliteCore.text("summary"),source_tokens:sqliteCore.integer("source_tokens").notNull(),summary_tokens:sqliteCore.integer("summary_tokens"),created_at:sqliteCore.text("created_at").notNull()},o=>({idx_thread_boxes_thread_id:sqliteCore.index("idx_thread_boxes_thread_id").on(o.thread_id),idx_thread_boxes_seq:sqliteCore.index("idx_thread_boxes_seq").on(o.thread_id,o.seq),uniq_thread_boxes_thread_seq:sqliteCore.unique().on(o.thread_id,o.seq)}));l();sqliteCore.sqliteTable("request_logs",{id:sqliteCore.text("id").primaryKey(),path:sqliteCore.text("path").notNull(),method:sqliteCore.text("method").notNull(),status_code:sqliteCore.integer("status_code").notNull(),duration_ms:sqliteCore.integer("duration_ms").notNull(),ip:sqliteCore.text("ip"),request_headers:sqliteCore.text("request_headers"),response_headers:sqliteCore.text("response_headers"),request_body:sqliteCore.text("request_body"),response_body:sqliteCore.text("response_body"),query:sqliteCore.text("query"),user_id:sqliteCore.text("user_id"),project_id:sqliteCore.text("project_id"),partition_key:sqliteCore.text("partition_key").notNull(),timestamp:sqliteCore.text("timestamp").notNull().default(drizzleOrm.sql`(datetime('now'))`),metadata:sqliteCore.text("metadata")},o=>({idx_request_logs_timestamp:sqliteCore.index("idx_request_logs_timestamp").on(o.timestamp),idx_request_logs_path:sqliteCore.index("idx_request_logs_path").on(o.path),idx_request_logs_status_code:sqliteCore.index("idx_request_logs_status_code").on(o.status_code),idx_request_logs_partition_key:sqliteCore.index("idx_request_logs_partition_key").on(o.partition_key)}));var Ur=class extends He{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=W.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let n=W.dirname(t);fs.existsSync(n)||fs.mkdirSync(n,{recursive:true});}else if(!fs.existsSync(t))throw new O("NOT_FOUND","Database not found");let r=fe(t);if(e)try{Mt(r.db,t);}catch(n){throw r.close(),n}return r}startTask(e){let t=this.openHandle(true);try{t.db.insert(h).values({id:e.id,agent_id:e.agentId,prompt:e.prompt,mode:e.mode,status:e.status,started_at:e.startedAt,pid:e.pid??null,parent_task_id:e.parentTaskId??null,caller_agent_id:e.callerAgentId??null,trace_id:e.traceId??null,command:e.command??null,metadata:e.metadata??null,workspace_id:e.workspaceId??null,platform:e.platform??"cli",crewx_version:e.crewxVersion??null,thread_id:e.threadId??null,model:e.model??null,rendered_prompt:e.renderedPrompt??null,coding_agent_command:e.codingAgentCommand??null}).onConflictDoNothing().run();}catch(r){throw r instanceof O?r:new O("DB_ERROR","Failed to start task",r)}finally{t.close();}}finishTask(e){let t=this.openHandle(true);try{t.runRaw(`UPDATE tasks SET status=?, result=?, error=?, completed_at=?, duration_ms=?,
55
55
  exit_code=?, input_tokens=?, output_tokens=?, cached_input_tokens=?, cost_usd=?,
56
- model=COALESCE(?, model) WHERE id=?`,[e.status,e.result??null,e.error??null,e.completedAt,e.durationMs??null,e.exitCode??null,e.inputTokens??0,e.outputTokens??0,e.cachedInputTokens??0,e.costUsd??0,e.model??null,e.id]);}catch(r){throw r instanceof M?r:new M("DB_ERROR","Failed to finish task",r)}finally{t.close();}}appendLog(e,t){let r=this.openHandle(true);try{r.db.transaction(n=>{let s=n.select({logs:h.logs}).from(h).where(drizzleOrm.eq(h.id,e)).limit(1).get(),i=s?.logs?JSON.parse(s.logs):[];i.push(t),n.update(h).set({logs:JSON.stringify(i)}).where(drizzleOrm.eq(h.id,e)).run();},{behavior:"immediate"});}catch(n){throw n instanceof M?n:new M("DB_ERROR","Failed to append log",n)}finally{r.close();}}getRunningTasks(){if(!this.dbExists())return [];let e=this.openHandle(false);try{return e.db.select().from(h).where(drizzleOrm.eq(h.status,"running")).orderBy(drizzleOrm.desc(h.started_at)).all()}catch(t){throw new M("DB_ERROR","Failed to get running tasks",t)}finally{e.close();}}getAllTasks(){if(!this.dbExists())return [];let e=this.openHandle(false);try{return e.db.select().from(h).orderBy(drizzleOrm.desc(h.started_at)).limit(100).all()}catch(t){throw new M("DB_ERROR","Failed to get all tasks",t)}finally{e.close();}}getTask(e){if(!this.dbExists())return;let t=this.openHandle(false);try{return t.db.select().from(h).where(drizzleOrm.eq(h.id,e)).limit(1).get()??void 0}catch(r){throw new M("DB_ERROR","Failed to get task",r)}finally{t.close();}}killTask(e){if(!this.dbExists())return {killed:false};let t=this.openHandle(true);try{let r=t.db.select({id:h.id,status:h.status,pid:h.pid}).from(h).where(drizzleOrm.eq(h.id,e)).limit(1).get();if(!r||r.status!=="running")return {killed:!1};if(r.pid)try{process.kill(r.pid,"SIGTERM");}catch{}return t.db.update(h).set({status:"failed",error:"Killed by user",completed_at:new Date().toISOString()}).where(drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.status,"running"))).run(),{killed:!0,pid:r.pid??void 0}}catch(r){throw r instanceof M?r:new M("DB_ERROR","Failed to kill task",r)}finally{t.close();}}reapOrphanedTasks(){if(!this.dbExists())return 0;let e=this.openHandle(true);try{let t=e.db.select({id:h.id,pid:h.pid}).from(h).where(drizzleOrm.eq(h.status,"running")).all(),r=0;for(let n of t){let s=!1;if(n.pid)try{process.kill(n.pid,0),s=!0;}catch{}s||(e.db.update(h).set({status:"failed",error:"Reaped: process not found (orphaned task)",completed_at:new Date().toISOString()}).where(drizzleOrm.and(drizzleOrm.eq(h.id,n.id),drizzleOrm.eq(h.status,"running"))).run(),r++);}return r}finally{e.close();}}findTaskStatus(e,t){let r=this.resolveDbPaths();for(let n of r){if(!fs$1.existsSync(n))continue;let s=ge(n);try{let i=t?drizzleOrm.eq(h.workspace_id,t):void 0,a=i?drizzleOrm.and(drizzleOrm.eq(h.id,e),i):drizzleOrm.eq(h.id,e),d=s.db.select().from(h).where(a).limit(1).get()??void 0;if(!d){let c=drizzleOrm.or(drizzleOrm.eq(h.thread_id,e),drizzleOrm.and(drizzleOrm.isNull(h.thread_id),drizzleOrm.like(h.command,`%--thread=${e}%`))),u=i?drizzleOrm.and(c,i):c;d=s.db.select().from(h).where(u).orderBy(drizzleOrm.desc(h.started_at)).limit(1).get()??void 0;}if(d)return d}catch(i){throw new M("DB_ERROR","Failed to find task status",i)}finally{s.close();}}}findChildTasks(e,t){let r=this.resolveDbPaths(),n=new Set,s=[];for(let i of r){if(!fs$1.existsSync(i))continue;let a=ge(i);try{let d=t?drizzleOrm.and(drizzleOrm.eq(h.parent_task_id,e),drizzleOrm.eq(h.workspace_id,t)):drizzleOrm.eq(h.parent_task_id,e),c=a.db.select().from(h).where(d).orderBy(drizzleOrm.asc(h.started_at)).all();for(let u of c)n.has(u.id)||(n.add(u.id),s.push(u));}catch(d){throw new M("DB_ERROR","Failed to find child tasks",d)}finally{a.close();}}return s}getWorkspaceUsageSummary(e){if(!this.dbExists())return [];let t=this.openHandle(false);try{return t.db.all(e?drizzleOrm.sql`
56
+ model=COALESCE(?, model) WHERE id=?`,[e.status,e.result??null,e.error??null,e.completedAt,e.durationMs??null,e.exitCode??null,e.inputTokens??0,e.outputTokens??0,e.cachedInputTokens??0,e.costUsd??0,e.model??null,e.id]);}catch(r){throw r instanceof O?r:new O("DB_ERROR","Failed to finish task",r)}finally{t.close();}}appendLog(e,t){let r=this.openHandle(true);try{r.db.transaction(n=>{let s=n.select({logs:h.logs}).from(h).where(drizzleOrm.eq(h.id,e)).limit(1).get(),i=s?.logs?JSON.parse(s.logs):[];i.push(t),n.update(h).set({logs:JSON.stringify(i)}).where(drizzleOrm.eq(h.id,e)).run();},{behavior:"immediate"});}catch(n){throw n instanceof O?n:new O("DB_ERROR","Failed to append log",n)}finally{r.close();}}getRunningTasks(){if(!this.dbExists())return [];let e=this.openHandle(false);try{return e.db.select().from(h).where(drizzleOrm.eq(h.status,"running")).orderBy(drizzleOrm.desc(h.started_at)).all()}catch(t){throw new O("DB_ERROR","Failed to get running tasks",t)}finally{e.close();}}getAllTasks(){if(!this.dbExists())return [];let e=this.openHandle(false);try{return e.db.select().from(h).orderBy(drizzleOrm.desc(h.started_at)).limit(100).all()}catch(t){throw new O("DB_ERROR","Failed to get all tasks",t)}finally{e.close();}}getTask(e){if(!this.dbExists())return;let t=this.openHandle(false);try{return t.db.select().from(h).where(drizzleOrm.eq(h.id,e)).limit(1).get()??void 0}catch(r){throw new O("DB_ERROR","Failed to get task",r)}finally{t.close();}}killTask(e){if(!this.dbExists())return {killed:false};let t=this.openHandle(true);try{let r=t.db.select({id:h.id,status:h.status,pid:h.pid}).from(h).where(drizzleOrm.eq(h.id,e)).limit(1).get();if(!r||r.status!=="running")return {killed:!1};if(r.pid)try{process.kill(r.pid,"SIGTERM");}catch{}return t.db.update(h).set({status:"failed",error:"Killed by user",completed_at:new Date().toISOString()}).where(drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.status,"running"))).run(),{killed:!0,pid:r.pid??void 0}}catch(r){throw r instanceof O?r:new O("DB_ERROR","Failed to kill task",r)}finally{t.close();}}reapOrphanedTasks(){if(!this.dbExists())return 0;let e=this.openHandle(true);try{let t=e.db.select({id:h.id,pid:h.pid}).from(h).where(drizzleOrm.eq(h.status,"running")).all(),r=0;for(let n of t){let s=!1;if(n.pid)try{process.kill(n.pid,0),s=!0;}catch{}s||(e.db.update(h).set({status:"failed",error:"Reaped: process not found (orphaned task)",completed_at:new Date().toISOString()}).where(drizzleOrm.and(drizzleOrm.eq(h.id,n.id),drizzleOrm.eq(h.status,"running"))).run(),r++);}return r}finally{e.close();}}findTaskStatus(e,t){let r=this.resolveDbPaths();for(let n of r){if(!fs.existsSync(n))continue;let s=fe(n);try{let i=t?drizzleOrm.eq(h.workspace_id,t):void 0,a=i?drizzleOrm.and(drizzleOrm.eq(h.id,e),i):drizzleOrm.eq(h.id,e),d=s.db.select().from(h).where(a).limit(1).get()??void 0;if(!d){let c=drizzleOrm.or(drizzleOrm.eq(h.thread_id,e),drizzleOrm.and(drizzleOrm.isNull(h.thread_id),drizzleOrm.like(h.command,`%--thread=${e}%`))),u=i?drizzleOrm.and(c,i):c;d=s.db.select().from(h).where(u).orderBy(drizzleOrm.desc(h.started_at)).limit(1).get()??void 0;}if(d)return d}catch(i){throw new O("DB_ERROR","Failed to find task status",i)}finally{s.close();}}}findChildTasks(e,t){let r=this.resolveDbPaths(),n=new Set,s=[];for(let i of r){if(!fs.existsSync(i))continue;let a=fe(i);try{let d=t?drizzleOrm.and(drizzleOrm.eq(h.parent_task_id,e),drizzleOrm.eq(h.workspace_id,t)):drizzleOrm.eq(h.parent_task_id,e),c=a.db.select().from(h).where(d).orderBy(drizzleOrm.asc(h.started_at)).all();for(let u of c)n.has(u.id)||(n.add(u.id),s.push(u));}catch(d){throw new O("DB_ERROR","Failed to find child tasks",d)}finally{a.close();}}return s}getWorkspaceUsageSummary(e){if(!this.dbExists())return [];let t=this.openHandle(false);try{return t.db.all(e?drizzleOrm.sql`
57
57
  SELECT
58
58
  COALESCE(workspace_id, 'unknown') AS workspace_id,
59
59
  COALESCE(SUM(input_tokens), 0) AS input_tokens,
@@ -74,7 +74,7 @@ ${r.join(`
74
74
  FROM tasks
75
75
  GROUP BY workspace_id
76
76
  ORDER BY (COALESCE(SUM(input_tokens), 0) + COALESCE(SUM(output_tokens), 0)) DESC
77
- `)}catch(r){throw new M("DB_ERROR","Failed to get workspace usage summary",r)}finally{t.close();}}getThreadTokenUsage(e,t){let r=this.resolveDbPaths(),n=new Set,s=0,i=0,a=0;for(let d of r){if(!fs$1.existsSync(d))continue;let c=ge(d);try{let u=drizzleOrm.or(drizzleOrm.eq(h.thread_id,e),drizzleOrm.and(drizzleOrm.isNull(h.thread_id),drizzleOrm.like(h.command,`%--thread=${e}%`))),m=t?drizzleOrm.and(u,drizzleOrm.eq(h.workspace_id,t)):u,g=c.db.select({id:h.id,input_tokens:h.input_tokens,output_tokens:h.output_tokens,cost_usd:h.cost_usd}).from(h).where(m).all();for(let p of g)n.has(p.id)||(n.add(p.id),s+=p.input_tokens??0,i+=p.output_tokens??0,a+=p.cost_usd??0);}catch(u){throw new M("DB_ERROR","Failed to get thread token usage",u)}finally{c.close();}}return {inputTokens:s,outputTokens:i,costUsd:a}}findTasksByThread(e,t){let r=this.resolveDbPaths(),n=new Set,s=[];for(let i of r){if(!fs$1.existsSync(i))continue;let a=ge(i);try{let d=drizzleOrm.or(drizzleOrm.eq(h.thread_id,e),drizzleOrm.and(drizzleOrm.isNull(h.thread_id),drizzleOrm.like(h.command,`%--thread=${e}%`))),c=t?drizzleOrm.and(d,drizzleOrm.eq(h.workspace_id,t)):d,u=a.db.select().from(h).where(c).orderBy(drizzleOrm.asc(h.started_at)).all();for(let m of u)n.has(m.id)||(n.add(m.id),s.push(m));}catch(d){throw new M("DB_ERROR","Failed to find tasks by thread",d)}finally{a.close();}}return s}findAllTasks(e){if(!this.dbExists())return {rows:[],total:0};let t=this.openHandle(false);try{let r=[];e.workspaceId&&r.push(drizzleOrm.eq(h.workspace_id,e.workspaceId));let n=e.agents&&e.agents.length>0?e.agents:e.agentId?[e.agentId]:null;n&&r.push(drizzleOrm.inArray(h.agent_id,n));let s=e.statuses&&e.statuses.length>0?e.statuses:e.status?[e.status]:null;s&&r.push(drizzleOrm.inArray(h.status,s));let i=e.q??e.search;i&&r.push(drizzleOrm.like(h.prompt,`%${i}%`)),e.from&&r.push(drizzleOrm.gte(h.started_at,e.from)),e.to&&r.push(drizzleOrm.lt(h.started_at,e.to));let a=r.length>0?drizzleOrm.and(...r):void 0,d=t.db.select({count:drizzleOrm.sql`count(*)`}).from(h).where(a).get(),c=(e.sortDir??"DESC")==="ASC"?drizzleOrm.asc(h.started_at):drizzleOrm.desc(h.started_at);return {rows:t.db.select().from(h).where(a).orderBy(c).limit(e.limit).offset(e.offset).all(),total:d?.count??0}}catch(r){throw new M("DB_ERROR","Failed to find all tasks",r)}finally{t.close();}}getAgentUsage(e,t,r){if(!this.dbExists())return [];let n=this.openHandle(false);try{return n.db.all(r?drizzleOrm.sql`
77
+ `)}catch(r){throw new O("DB_ERROR","Failed to get workspace usage summary",r)}finally{t.close();}}getThreadTokenUsage(e,t){let r=this.resolveDbPaths(),n=new Set,s=0,i=0,a=0;for(let d of r){if(!fs.existsSync(d))continue;let c=fe(d);try{let u=drizzleOrm.or(drizzleOrm.eq(h.thread_id,e),drizzleOrm.and(drizzleOrm.isNull(h.thread_id),drizzleOrm.like(h.command,`%--thread=${e}%`))),g=t?drizzleOrm.and(u,drizzleOrm.eq(h.workspace_id,t)):u,f=c.db.select({id:h.id,input_tokens:h.input_tokens,output_tokens:h.output_tokens,cost_usd:h.cost_usd}).from(h).where(g).all();for(let p of f)n.has(p.id)||(n.add(p.id),s+=p.input_tokens??0,i+=p.output_tokens??0,a+=p.cost_usd??0);}catch(u){throw new O("DB_ERROR","Failed to get thread token usage",u)}finally{c.close();}}return {inputTokens:s,outputTokens:i,costUsd:a}}findTasksByThread(e,t){let r=this.resolveDbPaths(),n=new Set,s=[];for(let i of r){if(!fs.existsSync(i))continue;let a=fe(i);try{let d=drizzleOrm.or(drizzleOrm.eq(h.thread_id,e),drizzleOrm.and(drizzleOrm.isNull(h.thread_id),drizzleOrm.like(h.command,`%--thread=${e}%`))),c=t?drizzleOrm.and(d,drizzleOrm.eq(h.workspace_id,t)):d,u=a.db.select().from(h).where(c).orderBy(drizzleOrm.asc(h.started_at)).all();for(let g of u)n.has(g.id)||(n.add(g.id),s.push(g));}catch(d){throw new O("DB_ERROR","Failed to find tasks by thread",d)}finally{a.close();}}return s}findAllTasks(e){if(!this.dbExists())return {rows:[],total:0};let t=this.openHandle(false);try{let r=[];e.workspaceId&&r.push(drizzleOrm.eq(h.workspace_id,e.workspaceId));let n=e.agents&&e.agents.length>0?e.agents:e.agentId?[e.agentId]:null;n&&r.push(drizzleOrm.inArray(h.agent_id,n));let s=e.statuses&&e.statuses.length>0?e.statuses:e.status?[e.status]:null;s&&r.push(drizzleOrm.inArray(h.status,s));let i=e.q??e.search;i&&r.push(drizzleOrm.like(h.prompt,`%${i}%`)),e.from&&r.push(drizzleOrm.gte(h.started_at,e.from)),e.to&&r.push(drizzleOrm.lt(h.started_at,e.to));let a=r.length>0?drizzleOrm.and(...r):void 0,d=t.db.select({count:drizzleOrm.sql`count(*)`}).from(h).where(a).get(),c=(e.sortDir??"DESC")==="ASC"?drizzleOrm.asc(h.started_at):drizzleOrm.desc(h.started_at);return {rows:t.db.select().from(h).where(a).orderBy(c).limit(e.limit).offset(e.offset).all(),total:d?.count??0}}catch(r){throw new O("DB_ERROR","Failed to find all tasks",r)}finally{t.close();}}getAgentUsage(e,t,r){if(!this.dbExists())return [];let n=this.openHandle(false);try{return n.db.all(r?drizzleOrm.sql`
78
78
  SELECT
79
79
  t.agent_id,
80
80
  t.workspace_id,
@@ -105,7 +105,7 @@ ${r.join(`
105
105
  AND t.started_at < ${t}
106
106
  GROUP BY t.agent_id, t.workspace_id
107
107
  ORDER BY (COALESCE(SUM(t.input_tokens), 0) + COALESCE(SUM(t.output_tokens), 0)) DESC
108
- `).map(i=>({agentId:i.agent_id,workspaceId:i.workspace_id??null,totalTasks:i.total_tasks,inputTokens:i.input_tokens,outputTokens:i.output_tokens,cachedInputTokens:i.cached_input_tokens,costUsd:i.cost_usd}))}catch(s){throw new M("DB_ERROR","Failed to get agent usage",s)}finally{n.close();}}getAgentUsageTrendRaw(e,t,r){if(!this.dbExists())return [];let n=this.openHandle(false);try{return n.db.all(r?drizzleOrm.sql`
108
+ `).map(i=>({agentId:i.agent_id,workspaceId:i.workspace_id??null,totalTasks:i.total_tasks,inputTokens:i.input_tokens,outputTokens:i.output_tokens,cachedInputTokens:i.cached_input_tokens,costUsd:i.cost_usd}))}catch(s){throw new O("DB_ERROR","Failed to get agent usage",s)}finally{n.close();}}getAgentUsageTrendRaw(e,t,r){if(!this.dbExists())return [];let n=this.openHandle(false);try{return n.db.all(r?drizzleOrm.sql`
109
109
  SELECT
110
110
  date(t.started_at) AS date,
111
111
  t.agent_id,
@@ -134,10 +134,10 @@ ${r.join(`
134
134
  AND t.started_at < ${t}
135
135
  GROUP BY date(t.started_at), t.agent_id
136
136
  ORDER BY date(t.started_at) ASC
137
- `).map(i=>({date:i.date,agentId:i.agent_id,inputTokens:i.input_tokens,outputTokens:i.output_tokens,cachedInputTokens:i.cached_input_tokens,costUsd:i.cost_usd}))}catch(s){throw new M("DB_ERROR","Failed to get agent usage trend",s)}finally{n.close();}}findTaskForStop(e,t){if(!this.dbExists())return;let r=this.openHandle(false);try{return r.db.select().from(h).where(drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.workspace_id,t))).limit(1).get()??void 0}catch(n){throw new M("DB_ERROR","Failed to find task for stop",n)}finally{r.close();}}markTaskFailed(e,t,r){if(!this.dbExists())return;let n=this.openHandle(true);try{let s=new Date().toISOString(),i=r?drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.status,"running"),drizzleOrm.eq(h.workspace_id,r)):drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.status,"running"));n.db.update(h).set({status:"failed",error:t,completed_at:s}).where(i).run();}catch(s){throw s instanceof M?s:new M("DB_ERROR","Failed to mark task failed",s)}finally{n.close();}}findTasksByPromptHint(e,t){let r=this.resolveDbPaths(),n=new Set,s=[];for(let i of r){if(!fs$1.existsSync(i))continue;let a=ge(i);try{let d=t?drizzleOrm.and(drizzleOrm.like(h.prompt,`%${e}%`),drizzleOrm.eq(h.workspace_id,t)):drizzleOrm.like(h.prompt,`%${e}%`),c=a.db.select().from(h).where(d).orderBy(drizzleOrm.asc(h.started_at)).all();for(let u of c)n.has(u.id)||(n.add(u.id),s.push(u));}catch(d){throw new M("DB_ERROR","Failed to find tasks by prompt hint",d)}finally{a.close();}}return s}};l();var $r=class extends He{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=F.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let n=F.dirname(t);fs$1.existsSync(n)||fs$1.mkdirSync(n,{recursive:true});}else if(!fs$1.existsSync(t))throw new M("NOT_FOUND","Database not found");let r=ge(t);if(e)try{Ot(r.db,t);}catch(n){throw r.close(),n}return r}insertSpan(e){let t=this.openHandle(true);try{t.db.insert(Te).values(e).run();}catch(r){throw r instanceof M?r:new M("DB_ERROR","Failed to insert span",r)}finally{t.close();}}findByTaskId(e){if(!this.dbExists())return [];let t=this.openHandle(false);try{return t.db.select().from(Te).where(drizzleOrm.eq(Te.task_id,e)).all()}catch(r){throw new M("DB_ERROR","Failed to find spans by task id",r)}finally{t.close();}}findById(e){if(!this.dbExists())return;let t=this.openHandle(false);try{return t.db.select().from(Te).where(drizzleOrm.eq(Te.id,e)).limit(1).get()??void 0}catch(r){throw new M("DB_ERROR","Failed to find span by id",r)}finally{t.close();}}};Rr();_r();vr();l();l();var jt=class{capabilities={required:[]}};l();l();l();var to=2e3;function ro(o){let e=o.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f\u2028\u2029]/g,"");return e.length<=to?e:e.slice(0,to-11)+" [redacted]"}var aa=10*1024*1024,da={b:1,kb:1024,mb:1024*1024,gb:1024*1024*1024};function jr(o,e){return o===void 0?true:Array.isArray(o)?o.includes(e):o===e}function la(o,e){return o===void 0?true:Array.isArray(o)?o.some(t=>e.includes(t)):e.includes(o)}function oo(o){if(typeof o=="number")return o;let e=o.match(/^(\d+(?:\.\d+)?)\s*(b|kb|mb|gb)?$/i);if(!e)return 0;let t=parseFloat(e[1]),r=(e[2]??"b").toLowerCase();return Math.floor(t*(da[r]??1))}function so(o){return typeof o=="string"}function io(o){try{let e=fs$1.statSync(o);return e.size>aa?(process.stderr.write(`[YamlHookPlugin] File too large for line count: ${o} (${e.size} bytes)
138
- `),null):fs$1.readFileSync(o,"utf8").split(`
139
- `).length}catch{return null}}function ao(o){try{return fs$1.statSync(o).size}catch{return null}}function ca(o,e,t){if(!o)return true;let r=e,n=r?.path??r?.file_path??r?.filePath??r?.filename;if(typeof n!="string")return false;if(oe(n,o))return true;if(t&&n.startsWith("/")){let{relative:s,isAbsolute:i}=W("path");if(i(n)){let a=s(t,n);if(a&&!a.startsWith("..")&&oe(a,o))return true}}return false}function ua(o,e){return o?JSON.stringify(e).includes(o):true}function pa(o,e){if(!o)return true;try{let t=new RegExp(o),r=JSON.stringify(e);return t.test(r)}catch{return false}}function ga(o,e){if(!o)return true;try{let t=new RegExp(o),r=JSON.stringify(e);return t.test(r)}catch{return false}}function ma(o,e){if(o.pathSizeMin===void 0&&o.pathSizeMax===void 0)return true;let t=e,r=t?.path??t?.file_path??t?.filePath??t?.filename;if(typeof r!="string")return false;if(o.pathSizeMin!==void 0)if(so(o.pathSizeMin)){let n=ao(r);if(n===null||n<oo(o.pathSizeMin))return false}else {let n=io(r);if(n===null||n<o.pathSizeMin)return false}if(o.pathSizeMax!==void 0)if(so(o.pathSizeMax)){let n=ao(r);if(n===null||n>oo(o.pathSizeMax))return false}else {let n=io(r);if(n===null||n>o.pathSizeMax)return false}return true}function fa(o){let e=[],t=[];for(let r=0;r<o.length;r++){let n=o[r];if(!n||typeof n!="object"){t.push(`Hook at index ${r}: not an object, skipping`);continue}let s=n;if(typeof s.name!="string"||!s.name){t.push(`Hook at index ${r}: missing or invalid "name", skipping`);continue}let i=s.guide&&typeof s.guide=="object",a=s.deny&&typeof s.deny=="object",d=typeof s.plugin=="string";if(!i&&!a&&!d){t.push(`Hook "${s.name}": missing guide/deny/plugin, skipping`);continue}if(i&&typeof s.guide.say!="string"){t.push(`Hook "${s.name}": guide.say is required and must be string, skipping`);continue}if(a&&typeof s.deny.reason!="string"){t.push(`Hook "${s.name}": deny.reason is required and must be string, skipping`);continue}e.push(s);}return {valid:e,warnings:t}}var Hr=class extends jt{name="@crewx/yaml-hook-plugin";version="0.1.0";capabilities={required:["inject"]};hooks;agentMap;constructor(e){super(),this.hooks=e.hooks,this.agentMap=new Map((e.agents??[]).map(t=>[t.id,t]));}async run(e){let t=[],r=process.env.CREWX_TASK_LOG_PATH,n=process.env.CREWX_HOOK_LOG_VERBOSE==="1";for(let s of this.hooks)if(this.matchEntryLevel(s,e)&&s.guide){if(!this.matchRuleLevel(s.guide,e)){n&&r&&this.appendHookLog(r,{rule:s.name,action:"pass",once:s.guide.once??false,ctx:e,matched:false});continue}s.guide.once&&this.hasFired(e.sessionId,s.name)||(s.guide.once&&this.markFired(e.sessionId,s.name),t.push(s.guide.say),r&&this.appendHookLog(r,{rule:s.name,action:"inject",once:s.guide.once??false,ctx:e,matched:true,message:s.guide.say}));}return t.length?e.inject(t.join(`
137
+ `).map(i=>({date:i.date,agentId:i.agent_id,inputTokens:i.input_tokens,outputTokens:i.output_tokens,cachedInputTokens:i.cached_input_tokens,costUsd:i.cost_usd}))}catch(s){throw new O("DB_ERROR","Failed to get agent usage trend",s)}finally{n.close();}}findTaskForStop(e,t){if(!this.dbExists())return;let r=this.openHandle(false);try{return r.db.select().from(h).where(drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.workspace_id,t))).limit(1).get()??void 0}catch(n){throw new O("DB_ERROR","Failed to find task for stop",n)}finally{r.close();}}markTaskFailed(e,t,r){if(!this.dbExists())return;let n=this.openHandle(true);try{let s=new Date().toISOString(),i=r?drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.status,"running"),drizzleOrm.eq(h.workspace_id,r)):drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.status,"running"));n.db.update(h).set({status:"failed",error:t,completed_at:s}).where(i).run();}catch(s){throw s instanceof O?s:new O("DB_ERROR","Failed to mark task failed",s)}finally{n.close();}}findTasksByPromptHint(e,t){let r=this.resolveDbPaths(),n=new Set,s=[];for(let i of r){if(!fs.existsSync(i))continue;let a=fe(i);try{let d=t?drizzleOrm.and(drizzleOrm.like(h.prompt,`%${e}%`),drizzleOrm.eq(h.workspace_id,t)):drizzleOrm.like(h.prompt,`%${e}%`),c=a.db.select().from(h).where(d).orderBy(drizzleOrm.asc(h.started_at)).all();for(let u of c)n.has(u.id)||(n.add(u.id),s.push(u));}catch(d){throw new O("DB_ERROR","Failed to find tasks by prompt hint",d)}finally{a.close();}}return s}};l();var Fr=class extends He{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=W.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let n=W.dirname(t);fs.existsSync(n)||fs.mkdirSync(n,{recursive:true});}else if(!fs.existsSync(t))throw new O("NOT_FOUND","Database not found");let r=fe(t);if(e)try{Mt(r.db,t);}catch(n){throw r.close(),n}return r}insertSpan(e){let t=this.openHandle(true);try{t.db.insert(Ie).values(e).run();}catch(r){throw r instanceof O?r:new O("DB_ERROR","Failed to insert span",r)}finally{t.close();}}findByTaskId(e){if(!this.dbExists())return [];let t=this.openHandle(false);try{return t.db.select().from(Ie).where(drizzleOrm.eq(Ie.task_id,e)).all()}catch(r){throw new O("DB_ERROR","Failed to find spans by task id",r)}finally{t.close();}}findById(e){if(!this.dbExists())return;let t=this.openHandle(false);try{return t.db.select().from(Ie).where(drizzleOrm.eq(Ie.id,e)).limit(1).get()??void 0}catch(r){throw new O("DB_ERROR","Failed to find span by id",r)}finally{t.close();}}};Cr();Pr();Rr();l();l();var Ut=class{capabilities={required:[]}};l();l();l();var oo=2e3;function so(o){let e=o.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f\u2028\u2029]/g,"");return e.length<=oo?e:e.slice(0,oo-11)+" [redacted]"}var ua=10*1024*1024,pa={b:1,kb:1024,mb:1024*1024,gb:1024*1024*1024};function Hr(o,e){return o===void 0?true:Array.isArray(o)?o.includes(e):o===e}function ga(o,e){return o===void 0?true:Array.isArray(o)?o.some(t=>e.includes(t)):e.includes(o)}function ao(o){if(typeof o=="number")return o;let e=o.match(/^(\d+(?:\.\d+)?)\s*(b|kb|mb|gb)?$/i);if(!e)return 0;let t=parseFloat(e[1]),r=(e[2]??"b").toLowerCase();return Math.floor(t*(pa[r]??1))}function lo(o){return typeof o=="string"}function co(o){try{let e=fs.statSync(o);return e.size>ua?(process.stderr.write(`[YamlHookPlugin] File too large for line count: ${o} (${e.size} bytes)
138
+ `),null):fs.readFileSync(o,"utf8").split(`
139
+ `).length}catch{return null}}function uo(o){try{return fs.statSync(o).size}catch{return null}}function ma(o,e,t){if(!o)return true;let r=e,n=r?.path??r?.file_path??r?.filePath??r?.filename;if(typeof n!="string")return false;if(ie(n,o))return true;if(t&&n.startsWith("/")){let{relative:s,isAbsolute:i}=z("path");if(i(n)){let a=s(t,n);if(a&&!a.startsWith("..")&&ie(a,o))return true}}return false}function fa(o,e){return o?JSON.stringify(e).includes(o):true}function ya(o,e){if(!o)return true;try{let t=new RegExp(o),r=JSON.stringify(e);return t.test(r)}catch{return false}}function ha(o,e){if(!o)return true;try{let t=new RegExp(o),r=JSON.stringify(e);return t.test(r)}catch{return false}}function wa(o,e){if(o.pathSizeMin===void 0&&o.pathSizeMax===void 0)return true;let t=e,r=t?.path??t?.file_path??t?.filePath??t?.filename;if(typeof r!="string")return false;if(o.pathSizeMin!==void 0)if(lo(o.pathSizeMin)){let n=uo(r);if(n===null||n<ao(o.pathSizeMin))return false}else {let n=co(r);if(n===null||n<o.pathSizeMin)return false}if(o.pathSizeMax!==void 0)if(lo(o.pathSizeMax)){let n=uo(r);if(n===null||n>ao(o.pathSizeMax))return false}else {let n=co(r);if(n===null||n>o.pathSizeMax)return false}return true}function xa(o){let e=[],t=[];for(let r=0;r<o.length;r++){let n=o[r];if(!n||typeof n!="object"){t.push(`Hook at index ${r}: not an object, skipping`);continue}let s=n;if(typeof s.name!="string"||!s.name){t.push(`Hook at index ${r}: missing or invalid "name", skipping`);continue}let i=s.guide&&typeof s.guide=="object",a=s.deny&&typeof s.deny=="object",d=typeof s.plugin=="string";if(!i&&!a&&!d){t.push(`Hook "${s.name}": missing guide/deny/plugin, skipping`);continue}if(i&&typeof s.guide.say!="string"){t.push(`Hook "${s.name}": guide.say is required and must be string, skipping`);continue}if(a&&typeof s.deny.reason!="string"){t.push(`Hook "${s.name}": deny.reason is required and must be string, skipping`);continue}e.push(s);}return {valid:e,warnings:t}}var Br=class extends Ut{name="@crewx/yaml-hook-plugin";version="0.1.0";capabilities={required:["inject"]};hooks;agentMap;constructor(e){super(),this.hooks=e.hooks,this.agentMap=new Map((e.agents??[]).map(t=>[t.id,t]));}async run(e){let t=[],r=process.env.CREWX_TASK_LOG_PATH,n=process.env.CREWX_HOOK_LOG_VERBOSE==="1";for(let s of this.hooks)if(this.matchEntryLevel(s,e)&&s.guide){if(!this.matchRuleLevel(s.guide,e)){n&&r&&this.appendHookLog(r,{rule:s.name,action:"pass",once:s.guide.once??false,ctx:e,matched:false});continue}s.guide.once&&this.hasFired(e.sessionId,s.name)||(s.guide.once&&this.markFired(e.sessionId,s.name),t.push(s.guide.say),r&&this.appendHookLog(r,{rule:s.name,action:"inject",once:s.guide.once??false,ctx:e,matched:true,message:s.guide.say}));}return t.length?e.inject(t.join(`
140
140
 
141
- `)):e.pass()}appendHookLog(e,t){try{let r={rule:t.rule,action:t.action,once:t.once,sessionId:t.ctx.sessionId,provider:t.ctx.provider,agent:t.ctx.agent.id,toolName:t.ctx.tool.name,rawToolName:t.ctx.tool.rawName};t.message&&(r.chars=t.message.length,process.env.CREWX_HOOK_LOG_VERBOSE==="1"&&(r.message=ro(t.message).slice(0,500)));let n=`[${new Date().toISOString()}] HOOK: ${JSON.stringify(r)}
142
- `;fs$1.appendFileSync(e,n,{encoding:"utf8",mode:384});}catch{}}matchEntryLevel(e,t){if(e.provider!==void 0){let r=t.provider.replace(/^cli\//,"");if(!jr(e.provider,r))return false}if(e.team!==void 0){let n=this.agentMap.get(t.agent.id)?.team??t.agent.team;if(!jr(e.team,n))return false}if(e.role!==void 0){let n=this.agentMap.get(t.agent.id)?.role??t.agent.role;if(!jr(e.role,n))return false}if(e.tag!==void 0){let n=this.agentMap.get(t.agent.id)?.tags??[];if(!la(e.tag,n))return false}return !(e.agents!==void 0&&!e.agents.includes(t.agent.id))}matchRuleLevel(e,t){return !(e.when!==void 0&&e.when.length>0&&!e.when.includes(t.tool.name)&&!e.when.includes(t.tool.rawName)||!ua(e.pattern,t.tool.input)||!pa(e.regex,t.tool.input)||!ca(e.pathPattern,t.tool.input,t.cwd)||!ma(e,t.tool.input)||!ga(e.whenInputRegex,t.tool.input))}hasFired(e,t){try{let r=this.firedFilePath(e);if(!fs$1.existsSync(r))return !1;let n=JSON.parse(fs$1.readFileSync(r,"utf8"));return Array.isArray(n.fired)&&n.fired.includes(t)}catch{return false}}markFired(e,t){try{let r=this.firedFilePath(e);fs$1.mkdirSync(F.dirname(r),{recursive:!0,mode:448});let n=fs$1.existsSync(r)?JSON.parse(fs$1.readFileSync(r,"utf8")):{fired:[]};Array.isArray(n.fired)||(n.fired=[]),n.fired.includes(t)||(n.fired.push(t),fs$1.writeFileSync(r,JSON.stringify(n),{mode:384}));}catch(r){process.stderr.write(`[YamlHookPlugin] once state write failed: ${r}
143
- `);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return F.join(Ci.homedir(),".crewx","sessions",t,"fired-rules.json")}};l();l();l();function ya(o){let e=o.messages.map(t=>({id:t.id,role:t.isAssistant?"assistant":"user",content:t.text,timestamp:new Date(t.timestamp).toISOString(),metadata:t.metadata??null}));return {getThreadMessages(t){return e}}}l();var Fr=class extends Error{code;kind;retryAfterMs;constructor(e,t,r){super(`AdapterError: ${e}`),this.name="AdapterError",this.code=e,this.kind=t,this.retryAfterMs=r;}};l();function ha(o){return o}function wa(o){return {name:o.name,async attach(e){let t=await o.configFactory(e),n=e.registerChannelAdapter,s=o.instanceId??o.name;n&&await n({adapter:o.adapter,instanceId:s,config:t}),o.onAttach&&await o.onAttach(e);},async detach(e){let r=e.unregisterChannelAdapter;r&&await r(o.instanceId??o.name),o.onDetach&&await o.onDetach(e);}}}yt();exports.AdapterError=Fr;exports.AgentNotFoundError=de;exports.AgentRuntime=at;exports.AgentSkillsSchema=qr;exports.BrowserFsAdapter=Tr;exports.ConfigLoadError=xe;exports.Crewx=Cr;exports.CrewxPlugin=Er;exports.DocumentLoader=Re;exports.LayoutLoadError=V;exports.LayoutLoader=Xe;exports.LayoutRenderer=Ye;exports.NodeFsAdapter=_t;exports.ParallelRunner=it;exports.ParallelRunnerTimeoutError=It;exports.PropsValidationError=ue;exports.PropsValidator=Ge;exports.SdkBoxService=Ir;exports.SpanRepository=$r;exports.TaskRepository=Lr;exports.TemplateEngine=Je;exports.TypedEventEmitter=Qe;exports.YamlHookPlugin=Hr;exports.buildContext=gi;exports.createAdapterContext=ar;exports.createDelegateTool=li;exports.createHandler=lr;exports.createPluginProviderFactory=Sn;exports.createProvider=ce;exports.createRemoteProviderFactory=Cn;exports.createScopedAdapterStore=sr;exports.defaultExtractText=gr;exports.defaultFsAdapter=_e;exports.defaultParseEvent=ne;exports.defineChannelAdapter=ha;exports.defineChannelAdapterPlugin=wa;exports.escapeHandlebarsHelper=er;exports.formatFileSizeHelper=tr;exports.formatTimestamp=or;exports.formatTimestampHelper=rr;exports.generateFingerprint=us;exports.generateId=Ae;exports.getSyncWindowStore=ms;exports.hashWorkspaceId=cr;exports.lengthHelper=Zt;exports.loadYamlFile=ut;exports.materializeWindowsSpawnProgram=We;exports.normalizeWorkspacePath=fn;exports.parseStdoutEvent=Gt;exports.parseUsage=Q;exports.parseYamlContent=ct;exports.queryAcpProviderMeta=Ln;exports.queryAllAcpProviderMetas=di;exports.registerAcpProviders=An;exports.registerApiProviders=wn;exports.registerProviderFactory=le;exports.resolveAgent=gt;exports.resolveAgentSkills=ii;exports.resolveCrewxCli=ci;exports.resolveCrewxWorkspace=ui;exports.resolveDefaultAgentsYaml=Ft;exports.resolveTemplatesPath=Ne;exports.resolveWindowsExecutablePath=zr;exports.resolveWindowsSpawnProgram=Be;exports.runExecutesParallel=Ri;exports.runInSyncWindow=fs;exports.runQueriesParallel=_i;exports.setAuditVerbose=Yo;exports.toTaskReader=ya;exports.toTemplateMessages=dr;exports.truncateHelper=Qt;exports.validateHooksSchema=fa;
141
+ `)):e.pass()}appendHookLog(e,t){try{let r={rule:t.rule,action:t.action,once:t.once,sessionId:t.ctx.sessionId,provider:t.ctx.provider,agent:t.ctx.agent.id,toolName:t.ctx.tool.name,rawToolName:t.ctx.tool.rawName};t.message&&(r.chars=t.message.length,process.env.CREWX_HOOK_LOG_VERBOSE==="1"&&(r.message=so(t.message).slice(0,500)));let n=`[${new Date().toISOString()}] HOOK: ${JSON.stringify(r)}
142
+ `;fs.appendFileSync(e,n,{encoding:"utf8",mode:384});}catch{}}matchEntryLevel(e,t){if(e.provider!==void 0){let r=t.provider.replace(/^cli\//,"");if(!Hr(e.provider,r))return false}if(e.team!==void 0){let n=this.agentMap.get(t.agent.id)?.team??t.agent.team;if(!Hr(e.team,n))return false}if(e.role!==void 0){let n=this.agentMap.get(t.agent.id)?.role??t.agent.role;if(!Hr(e.role,n))return false}if(e.tag!==void 0){let n=this.agentMap.get(t.agent.id)?.tags??[];if(!ga(e.tag,n))return false}return !(e.agents!==void 0&&!e.agents.includes(t.agent.id))}matchRuleLevel(e,t){return !(e.when!==void 0&&e.when.length>0&&!e.when.includes(t.tool.name)&&!e.when.includes(t.tool.rawName)||!fa(e.pattern,t.tool.input)||!ya(e.regex,t.tool.input)||!ma(e.pathPattern,t.tool.input,t.cwd)||!wa(e,t.tool.input)||!ha(e.whenInputRegex,t.tool.input))}hasFired(e,t){try{let r=this.firedFilePath(e);if(!fs.existsSync(r))return !1;let n=JSON.parse(fs.readFileSync(r,"utf8"));return Array.isArray(n.fired)&&n.fired.includes(t)}catch{return false}}markFired(e,t){try{let r=this.firedFilePath(e);fs.mkdirSync(W.dirname(r),{recursive:!0,mode:448});let n=fs.existsSync(r)?JSON.parse(fs.readFileSync(r,"utf8")):{fired:[]};Array.isArray(n.fired)||(n.fired=[]),n.fired.includes(t)||(n.fired.push(t),fs.writeFileSync(r,JSON.stringify(n),{mode:384}));}catch(r){process.stderr.write(`[YamlHookPlugin] once state write failed: ${r}
143
+ `);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return W.join(Si.homedir(),".crewx","sessions",t,"fired-rules.json")}};l();l();l();function ka(o){let e=o.messages.map(t=>({id:t.id,role:t.isAssistant?"assistant":"user",content:t.text,timestamp:new Date(t.timestamp).toISOString(),metadata:t.metadata??null}));return {getThreadMessages(t){return e}}}l();var Wr=class extends Error{code;kind;retryAfterMs;constructor(e,t,r){super(`AdapterError: ${e}`),this.name="AdapterError",this.code=e,this.kind=t,this.retryAfterMs=r;}};l();function va(o){return o}function _a(o){return {name:o.name,async attach(e){let t=await o.configFactory(e),n=e.registerChannelAdapter,s=o.instanceId??o.name;n&&await n({adapter:o.adapter,instanceId:s,config:t}),o.onAttach&&await o.onAttach(e);},async detach(e){let r=e.unregisterChannelAdapter;r&&await r(o.instanceId??o.name),o.onDetach&&await o.onDetach(e);}}}ht();exports.AdapterError=Wr;exports.AgentNotFoundError=ce;exports.AgentRuntime=lt;exports.AgentSkillsSchema=zr;exports.BrowserFsAdapter=Or;exports.ConfigLoadError=ve;exports.Crewx=Er;exports.CrewxPlugin=Ir;exports.DocumentLoader=Pe;exports.LayoutLoadError=J;exports.LayoutLoader=Ge;exports.LayoutRenderer=Qe;exports.NodeFsAdapter=At;exports.ParallelRunner=dt;exports.ParallelRunnerTimeoutError=Ot;exports.PropsValidationError=ge;exports.PropsValidator=Ye;exports.SdkBoxService=Nr;exports.SpanRepository=Fr;exports.TaskRepository=Ur;exports.TemplateEngine=Xe;exports.TypedEventEmitter=Ze;exports.YamlHookPlugin=Br;exports.buildContext=hi;exports.createAdapterContext=lr;exports.createDelegateTool=gi;exports.createHandler=pr;exports.createPluginProviderFactory=Mn;exports.createProvider=pe;exports.createRemoteProviderFactory=En;exports.createScopedAdapterStore=ar;exports.defaultExtractText=yr;exports.defaultFsAdapter=Re;exports.defaultParseEvent=se;exports.defineChannelAdapter=va;exports.defineChannelAdapterPlugin=_a;exports.escapeHandlebarsHelper=rr;exports.formatFileSizeHelper=nr;exports.formatTimestamp=ir;exports.formatTimestampHelper=or;exports.generateFingerprint=ms;exports.generateId=Ce;exports.getSyncWindowStore=hs;exports.hashWorkspaceId=gr;exports.lengthHelper=tr;exports.loadYamlFile=pt;exports.materializeWindowsSpawnProgram=ze;exports.normalizeWorkspacePath=wn;exports.parseStdoutEvent=Qt;exports.parseUsage=ee;exports.parseYamlContent=ut;exports.queryAcpProviderMeta=Un;exports.queryAllAcpProviderMetas=pi;exports.registerAcpProviders=Tn;exports.registerApiProviders=vn;exports.registerProviderFactory=ue;exports.resolveAgent=mt;exports.resolveAgentSkills=ci;exports.resolveCrewxCli=mi;exports.resolveCrewxWorkspace=fi;exports.resolveDefaultAgentsYaml=Bt;exports.resolveTemplatesPath=De;exports.resolveWindowsExecutablePath=Jr;exports.resolveWindowsSpawnProgram=We;exports.runExecutesParallel=Ti;exports.runInSyncWindow=ws;exports.runQueriesParallel=Ci;exports.setAuditVerbose=es;exports.toTaskReader=ka;exports.toTemplateMessages=ur;exports.truncateHelper=er;exports.validateHooksSchema=xa;