@crewx/sdk 0.8.9-rc.33 → 0.8.9-rc.34

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,63 +1,63 @@
1
- 'use strict';var to=require('fs'),V=require('path'),child_process=require('child_process'),string_decoder=require('string_decoder'),sdk=require('@agentclientprotocol/sdk'),jsYaml=require('js-yaml'),zod=require('zod'),module$1=require('module'),pe=require('handlebars'),promises=require('fs/promises'),crypto$1=require('crypto'),events=require('events'),async_hooks=require('async_hooks'),drizzleOrm=require('drizzle-orm'),wi=require('os'),sqliteCore=require('drizzle-orm/sqlite-core'),mcp_js=require('@modelcontextprotocol/sdk/server/mcp.js'),webStandardStreamableHttp_js=require('@modelcontextprotocol/sdk/server/webStandardStreamableHttp.js'),perf_hooks=require('perf_hooks');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 to__namespace=/*#__PURE__*/_interopNamespace(to);var V__namespace=/*#__PURE__*/_interopNamespace(V);var pe__namespace=/*#__PURE__*/_interopNamespace(pe);var wi__default=/*#__PURE__*/_interopDefault(wi);var or=Object.defineProperty;var Vo=Object.getOwnPropertyDescriptor;var Go=Object.getOwnPropertyNames;var Xo=Object.prototype.hasOwnProperty;var J=(n=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(n,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):n)(function(n){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+n+'" is not supported')});var D=(n,e)=>()=>(n&&(e=n(n=0)),e);var Ct=(n,e)=>{for(var t in e)or(n,t,{get:e[t],enumerable:true});},Jo=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Go(e))!Xo.call(n,o)&&o!==t&&or(n,o,{get:()=>e[o],enumerable:!(r=Vo(e,o))||r.enumerable});return n};var yn=n=>Jo(or({},"__esModule",{value:true}),n);var c=D(()=>{});function It(n){return typeof n!="string"?void 0:n.trim()||void 0}function Ot(n){return It(n)?.toLowerCase()??""}function ze(n){try{return to.statSync(n).isFile()}catch{return false}}function kn(n,e){if(n.includes("/")||n.includes("\\")||V__namespace.default.isAbsolute(n))return n;let r=(e.PATH??e.Path??process.env.PATH??process.env.Path??"").split(";").map(a=>a.trim()).filter(Boolean),o=V__namespace.default.extname(n).length>0,s=e.PATHEXT??e.Pathext??process.env.PATHEXT??process.env.Pathext??".EXE;.CMD;.BAT;.COM",i=o?[""]: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 l=Ot(d),u=d.toUpperCase();for(let p of [d,l,u]){let y=V__namespace.default.join(a,`${n}${p}`);if(ze(y))return y}}return n}function ds(n){if(!ze(n))return null;try{let e=to.readFileSync(n,"utf8"),t=V__namespace.default.dirname(n),r=[];for(let a of e.matchAll(/"([^"\r\n]*)"/g)){let u=(a[1]??"").match(/%~?dp0%?\s*[\\/]*(.*)$/i)?.[1]?.trim();if(!u)continue;let p=u.replace(/[\\/]+/g,V__namespace.default.sep).replace(/^[\\/]+/,""),y=V__namespace.default.resolve(t,p);ze(y)&&r.push(y);}let o=[],s=new Map;for(let a of e.matchAll(/SET\s+"(\w+)=%~?dp0%?[\\/]?([^"]+)"/gi)){let d=a[1].toUpperCase(),l=a[2].trim().replace(/[\\/]+/g,V__namespace.default.sep).replace(/^[\\/]+/,"");s.set(d,V__namespace.default.resolve(t,l));}for(let a of e.split(/\r?\n/))if(a.includes("%*"))for(let d of a.matchAll(/"%(\w+)%"/g)){let l=s.get(d[1].toUpperCase());l&&ze(l)&&o.push(l);}let i=a=>a.find(d=>{let l=Ot(V__namespace.default.basename(d));return l!=="node.exe"&&l!=="node"})??null;return i(o)??i(r)}catch{return null}}function ls(n,e){if(typeof e=="string")return It(e)||null;if(!e||typeof e!="object")return null;if(n){let t=e[n],r=typeof t=="string"?It(t):void 0;if(r)return r}for(let t of Object.values(e)){let r=typeof t=="string"?It(t):void 0;if(r)return r}return null}function cs(n,e){if(!e)return null;let t=V__namespace.default.dirname(n),r=[V__namespace.default.resolve(t,"..",e),V__namespace.default.resolve(t,"node_modules",e)];for(let o of r){let s=V__namespace.default.join(o,"package.json");if(ze(s))try{let i=JSON.parse(to.readFileSync(s,"utf8")),a=ls(e,i.bin);if(!a)continue;let d=V__namespace.default.resolve(o,a);if(ze(d))return d}catch{}}return null}function us(n){let e=n.platform??process.platform,t=n.env??process.env,r=n.execPath??process.execPath;if(e!=="win32")return {command:n.command,leadingArgv:[],resolution:"direct"};let o=kn(n.command,t),s=Ot(V__namespace.default.extname(o));if(s===".js"||s===".cjs"||s===".mjs")return {command:r,leadingArgv:[o],resolution:"node-entrypoint",windowsHide:true};if(s===".cmd"||s===".bat"){let i=ds(o)??cs(o,n.packageName);return i?Ot(V__namespace.default.extname(i))===".exe"?{command:i,leadingArgv:[],resolution:"exe-entrypoint",windowsHide:true}:{command:r,leadingArgv:[i],resolution:"node-entrypoint",windowsHide:true}:{command:o,leadingArgv:[],resolution:"unresolved-wrapper"}}return {command:o,leadingArgv:[],resolution:"direct"}}function ps(n){if(n.candidate.resolution!=="unresolved-wrapper")return {command:n.candidate.command,leadingArgv:n.candidate.leadingArgv,resolution:n.candidate.resolution,windowsHide:n.candidate.windowsHide};if(n.allowShellFallback===true)return {command:n.candidate.command,leadingArgv:[],resolution:"shell-fallback",shell:true};throw new Error(`${V__namespace.default.basename(n.candidate.command)} wrapper resolved, but no executable/Node entrypoint could be resolved without shell execution.`)}function tt(n){let e=us(n);return ps({candidate:e,allowShellFallback:n.allowShellFallback})}function rt(n,e){return {command:n.command,argv:[...n.leadingArgv,...e],resolution:n.resolution,shell:n.shell,windowsHide:n.windowsHide}}var Mt=D(()=>{c();});function gs(n){if(n.type!=="usage"||!("input_tokens"in n))return null;let e=Number(n.input_tokens??0),t=Number(n.output_tokens??0),o="cache_read_input_tokens"in n?Number(n.cache_read_input_tokens):void 0,s="cached_input_tokens"in n?Number(n.cached_input_tokens):void 0,i=o!==void 0?o:s??0;return {inputTokens:o!==void 0?e+o:e,outputTokens:t,cachedInputTokens:i}}function ms(n){let e=n.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),o=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:o,cachedInputTokens:d}}function fs(n){if(n.type!=="step_finish")return null;let t=n.part?.tokens;if(!t)return null;let r=Number(t.input??0),o=Number(t.output??0),s=t.cache,i=s?Number(s.read??0):0;return {inputTokens:r+i,outputTokens:o,cachedInputTokens:i}}function fe(n){if(!n||!n.trim())return;let e=null;for(let t of n.split(`
2
- `))if(t.trim())try{let r=JSON.parse(t),o=gs(r)??ms(r)??fs(r);o&&(e=o);}catch{}return e??void 0}var Ke=D(()=>{c();});exports.ProviderError=void 0;var be,nt=D(()=>{c();exports.ProviderError=class extends Error{constructor(t,r,o){super(t);this.providerStr=r;this.name="ProviderError",this.code=o?.code??"UNKNOWN",this.kind=o?.kind??(this.code==="UNKNOWN"?"transient":void 0),this.retryAfterMs=o?.retryAfterMs;}providerStr;code;kind;retryAfterMs},be=class extends exports.ProviderError{constructor(e,t){super(e,t,{code:"TIMEOUT_TOTAL",kind:"permanent"}),this.name="TotalTimeoutError";}};});exports.RateLimitError=void 0;var ir=D(()=>{c();nt();exports.RateLimitError=class extends exports.ProviderError{name="RateLimitError";constructor(e,t="cli/claude"){super(e,t,{code:"QUOTA_EXHAUSTED",kind:"transient"});}};});function oe(n){return /crewx\s+(x|execute)\s/.test(n)}function se(n,e){let t=e.match(/@(\S+)/);return {timestamp:n,type:"agent_call",targetAgent:t?.[1]?.replace(/["']/g,""),toolInput:e}}var Ve=D(()=>{c();});function ie(n){if(typeof n=="string")return n;if(!n||typeof n!="object")return JSON.stringify(n??{});let e=n;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 Ge=D(()=>{c();});function Nt(n){if(!n)return {};let e=n.match(/^(.+?)\[([^\]]+)\]$/);if(e){let t=e[2].toLowerCase();return ys.has(t)?{model:e[1],effort:e[2]}:{model:n}}return {model:n}}function _n(n){switch(n){case "agent-full-access":case "yolo":return ["--dangerously-bypass-approvals-and-sandbox"];case "read-only":case "plan":return ["--sandbox","read-only"];case "agent":return ["--sandbox","workspace-write"];default:return []}}function vn(n){return n?["-c",`model_reasoning_effort=${n}`]:[]}function An(n){if(!n)return [];let e=new Set(["acceptEdits","bypassPermissions","default","delegate","dontAsk","plan"]),t=n==="auto"?"default":n;return e.has(t)?["--permission-mode",t]:[]}var ys,ar=D(()=>{c();ys=new Set(["minimal","low","medium","high","xhigh"]);});function hs(n,e){let t=e.type;if(t==="text"){let r=String(e.text||"");return r?{timestamp:n,type:"text",content:r}:null}if(t==="thinking"){let r=String(e.thinking||"");return {timestamp:n,type:"thinking",content:r||"(thinking)"}}if(t==="tool_use"){let r=String(e.name||""),o=e.id,s=e.input,i=ie(s);return r==="Bash"&&oe(i)?se(n,i):{timestamp:n,type:"tool_use",toolUseId:o,toolName:r,toolInput:i}}if(t==="tool_result"){let r=!!e.is_error,o=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:n,type:"tool_result",toolUseId:o,resultPreview:i,isError:r}}return null}var Rn;exports.claudeAdapter=void 0;var dr=D(()=>{c();ir();Ve();Ge();ar();Rn=false,exports.claudeAdapter={command:"claude",buildArgs(n,e,t){let{model:r,effort:o}=Nt(e.model);(e.effort??o)&&!Rn&&(Rn=true,console.warn("[crewx] claude-cli: effort option has no equivalent CLI flag and will be ignored"));let i=An(e.mode),a=r?["--model",r]:[];if(e.additionalArgs!==void 0){let l=[...e.additionalArgs];return l.indexOf("-p")!==-1?{args:["--output-format","stream-json","--verbose",...i,...a,...l],stdinMessage:n}:{args:["--output-format","stream-json","--verbose",...i,...a,...l],stdinMessage:n}}return {args:["-p","--output-format","stream-json","--verbose",...i,...a],stdinMessage:n}},extractText(n){let e=n.split(`
1
+ 'use strict';var ro=require('fs'),V=require('path'),child_process=require('child_process'),string_decoder=require('string_decoder'),sdk=require('@agentclientprotocol/sdk'),jsYaml=require('js-yaml'),zod=require('zod'),module$1=require('module'),ge=require('handlebars'),promises=require('fs/promises'),crypto$1=require('crypto'),events=require('events'),async_hooks=require('async_hooks'),drizzleOrm=require('drizzle-orm'),xi=require('os'),sqliteCore=require('drizzle-orm/sqlite-core'),mcp_js=require('@modelcontextprotocol/sdk/server/mcp.js'),webStandardStreamableHttp_js=require('@modelcontextprotocol/sdk/server/webStandardStreamableHttp.js'),perf_hooks=require('perf_hooks');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 ro__namespace=/*#__PURE__*/_interopNamespace(ro);var V__namespace=/*#__PURE__*/_interopNamespace(V);var ge__namespace=/*#__PURE__*/_interopNamespace(ge);var xi__default=/*#__PURE__*/_interopDefault(xi);var sr=Object.defineProperty;var Go=Object.getOwnPropertyDescriptor;var Xo=Object.getOwnPropertyNames;var Jo=Object.prototype.hasOwnProperty;var J=(n=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(n,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):n)(function(n){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+n+'" is not supported')});var N=(n,e)=>()=>(n&&(e=n(n=0)),e);var Tt=(n,e)=>{for(var t in e)sr(n,t,{get:e[t],enumerable:true});},Yo=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Xo(e))!Jo.call(n,o)&&o!==t&&sr(n,o,{get:()=>e[o],enumerable:!(r=Go(e,o))||r.enumerable});return n};var hn=n=>Yo(sr({},"__esModule",{value:true}),n);var c=N(()=>{});function Ot(n){return typeof n!="string"?void 0:n.trim()||void 0}function Mt(n){return Ot(n)?.toLowerCase()??""}function Ke(n){try{return ro.statSync(n).isFile()}catch{return false}}function _n(n,e){if(n.includes("/")||n.includes("\\")||V__namespace.default.isAbsolute(n))return n;let r=(e.PATH??e.Path??process.env.PATH??process.env.Path??"").split(";").map(a=>a.trim()).filter(Boolean),o=V__namespace.default.extname(n).length>0,s=e.PATHEXT??e.Pathext??process.env.PATHEXT??process.env.Pathext??".EXE;.CMD;.BAT;.COM",i=o?[""]: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 l=Mt(d),u=d.toUpperCase();for(let p of [d,l,u]){let f=V__namespace.default.join(a,`${n}${p}`);if(Ke(f))return f}}return n}function ls(n){if(!Ke(n))return null;try{let e=ro.readFileSync(n,"utf8"),t=V__namespace.default.dirname(n),r=[];for(let a of e.matchAll(/"([^"\r\n]*)"/g)){let u=(a[1]??"").match(/%~?dp0%?\s*[\\/]*(.*)$/i)?.[1]?.trim();if(!u)continue;let p=u.replace(/[\\/]+/g,V__namespace.default.sep).replace(/^[\\/]+/,""),f=V__namespace.default.resolve(t,p);Ke(f)&&r.push(f);}let o=[],s=new Map;for(let a of e.matchAll(/SET\s+"(\w+)=%~?dp0%?[\\/]?([^"]+)"/gi)){let d=a[1].toUpperCase(),l=a[2].trim().replace(/[\\/]+/g,V__namespace.default.sep).replace(/^[\\/]+/,"");s.set(d,V__namespace.default.resolve(t,l));}for(let a of e.split(/\r?\n/))if(a.includes("%*"))for(let d of a.matchAll(/"%(\w+)%"/g)){let l=s.get(d[1].toUpperCase());l&&Ke(l)&&o.push(l);}let i=a=>a.find(d=>{let l=Mt(V__namespace.default.basename(d));return l!=="node.exe"&&l!=="node"})??null;return i(o)??i(r)}catch{return null}}function cs(n,e){if(typeof e=="string")return Ot(e)||null;if(!e||typeof e!="object")return null;if(n){let t=e[n],r=typeof t=="string"?Ot(t):void 0;if(r)return r}for(let t of Object.values(e)){let r=typeof t=="string"?Ot(t):void 0;if(r)return r}return null}function us(n,e){if(!e)return null;let t=V__namespace.default.dirname(n),r=[V__namespace.default.resolve(t,"..",e),V__namespace.default.resolve(t,"node_modules",e)];for(let o of r){let s=V__namespace.default.join(o,"package.json");if(Ke(s))try{let i=JSON.parse(ro.readFileSync(s,"utf8")),a=cs(e,i.bin);if(!a)continue;let d=V__namespace.default.resolve(o,a);if(Ke(d))return d}catch{}}return null}function ps(n){let e=n.platform??process.platform,t=n.env??process.env,r=n.execPath??process.execPath;if(e!=="win32")return {command:n.command,leadingArgv:[],resolution:"direct"};let o=_n(n.command,t),s=Mt(V__namespace.default.extname(o));if(s===".js"||s===".cjs"||s===".mjs")return {command:r,leadingArgv:[o],resolution:"node-entrypoint",windowsHide:true};if(s===".cmd"||s===".bat"){let i=ls(o)??us(o,n.packageName);return i?Mt(V__namespace.default.extname(i))===".exe"?{command:i,leadingArgv:[],resolution:"exe-entrypoint",windowsHide:true}:{command:r,leadingArgv:[i],resolution:"node-entrypoint",windowsHide:true}:{command:o,leadingArgv:[],resolution:"unresolved-wrapper"}}return {command:o,leadingArgv:[],resolution:"direct"}}function gs(n){if(n.candidate.resolution!=="unresolved-wrapper")return {command:n.candidate.command,leadingArgv:n.candidate.leadingArgv,resolution:n.candidate.resolution,windowsHide:n.candidate.windowsHide};if(n.allowShellFallback===true)return {command:n.candidate.command,leadingArgv:[],resolution:"shell-fallback",shell:true};throw new Error(`${V__namespace.default.basename(n.candidate.command)} wrapper resolved, but no executable/Node entrypoint could be resolved without shell execution.`)}function rt(n){let e=ps(n);return gs({candidate:e,allowShellFallback:n.allowShellFallback})}function nt(n,e){return {command:n.command,argv:[...n.leadingArgv,...e],resolution:n.resolution,shell:n.shell,windowsHide:n.windowsHide}}var Nt=N(()=>{c();});function ms(n){if(n.type!=="usage"||!("input_tokens"in n))return null;let e=Number(n.input_tokens??0),t=Number(n.output_tokens??0),o="cache_read_input_tokens"in n?Number(n.cache_read_input_tokens):void 0,s="cached_input_tokens"in n?Number(n.cached_input_tokens):void 0,i=o!==void 0?o:s??0;return {inputTokens:o!==void 0?e+o:e,outputTokens:t,cachedInputTokens:i}}function fs(n){let e=n.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),o=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:o,cachedInputTokens:d}}function ys(n){if(n.type!=="step_finish")return null;let t=n.part?.tokens;if(!t)return null;let r=Number(t.input??0),o=Number(t.output??0),s=t.cache,i=s?Number(s.read??0):0;return {inputTokens:r+i,outputTokens:o,cachedInputTokens:i}}function ye(n){if(!n||!n.trim())return;let e=null;for(let t of n.split(`
2
+ `))if(t.trim())try{let r=JSON.parse(t),o=ms(r)??fs(r)??ys(r);o&&(e=o);}catch{}return e??void 0}var Ve=N(()=>{c();});exports.ProviderError=void 0;var Se,ot=N(()=>{c();exports.ProviderError=class extends Error{constructor(t,r,o){super(t);this.providerStr=r;this.name="ProviderError",this.code=o?.code??"UNKNOWN",this.kind=o?.kind??(this.code==="UNKNOWN"?"transient":void 0),this.retryAfterMs=o?.retryAfterMs;}providerStr;code;kind;retryAfterMs},Se=class extends exports.ProviderError{constructor(e,t){super(e,t,{code:"TIMEOUT_TOTAL",kind:"permanent"}),this.name="TotalTimeoutError";}};});exports.RateLimitError=void 0;var ar=N(()=>{c();ot();exports.RateLimitError=class extends exports.ProviderError{name="RateLimitError";constructor(e,t="cli/claude"){super(e,t,{code:"QUOTA_EXHAUSTED",kind:"transient"});}};});function se(n){return /crewx\s+(x|execute)\s/.test(n)}function ie(n,e){let t=e.match(/@(\S+)/);return {timestamp:n,type:"agent_call",targetAgent:t?.[1]?.replace(/["']/g,""),toolInput:e}}var Ge=N(()=>{c();});function ae(n){if(typeof n=="string")return n;if(!n||typeof n!="object")return JSON.stringify(n??{});let e=n;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 Xe=N(()=>{c();});function Dt(n){if(!n)return {};let e=n.match(/^(.+?)\[([^\]]+)\]$/);if(e){let t=e[2].toLowerCase();return hs.has(t)?{model:e[1],effort:e[2]}:{model:n}}return {model:n}}function vn(n){switch(n){case "agent-full-access":case "yolo":return ["--dangerously-bypass-approvals-and-sandbox"];case "read-only":case "plan":return ["--sandbox","read-only"];case "agent":return ["--sandbox","workspace-write"];default:return []}}function An(n){return n?["-c",`model_reasoning_effort=${n}`]:[]}function Rn(n){if(!n)return [];let e=new Set(["acceptEdits","bypassPermissions","default","delegate","dontAsk","plan"]),t=n==="auto"?"default":n;return e.has(t)?["--permission-mode",t]:[]}var hs,dr=N(()=>{c();hs=new Set(["minimal","low","medium","high","xhigh"]);});function ws(n,e){let t=e.type;if(t==="text"){let r=String(e.text||"");return r?{timestamp:n,type:"text",content:r}:null}if(t==="thinking"){let r=String(e.thinking||"");return {timestamp:n,type:"thinking",content:r||"(thinking)"}}if(t==="tool_use"){let r=String(e.name||""),o=e.id,s=e.input,i=ae(s);return r==="Bash"&&se(i)?ie(n,i):{timestamp:n,type:"tool_use",toolUseId:o,toolName:r,toolInput:i}}if(t==="tool_result"){let r=!!e.is_error,o=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:n,type:"tool_result",toolUseId:o,resultPreview:i,isError:r}}return null}var En;exports.claudeAdapter=void 0;var lr=N(()=>{c();ar();Ge();Xe();dr();En=false,exports.claudeAdapter={command:"claude",buildArgs(n,e,t){let{model:r,effort:o}=Dt(e.model);(e.effort??o)&&!En&&(En=true,console.warn("[crewx] claude-cli: effort option has no equivalent CLI flag and will be ignored"));let i=Rn(e.mode),a=r?["--model",r]:[];if(e.additionalArgs!==void 0){let l=[...e.additionalArgs];return l.indexOf("-p")!==-1?{args:["--output-format","stream-json","--verbose",...i,...a,...l],stdinMessage:n}:{args:["--output-format","stream-json","--verbose",...i,...a,...l],stdinMessage:n}}return {args:["-p","--output-format","stream-json","--verbose",...i,...a],stdinMessage:n}},extractText(n){let e=n.split(`
4
4
  `).filter(o=>o.trim()),t=[],r=null;for(let o of e)try{let s=JSON.parse(o);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||n.trim()},extractFailure(n){if(n.includes('"rate_limit_event"'))try{let e=JSON.parse(n);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(n){let e=n.split(`
7
- `);for(let t of e)if(t.trim())try{let r=JSON.parse(t);if(r.type==="result"){let o=r.usage,s=o?{inputTokens:Number(o.input_tokens??0)+Number(o.cache_read_input_tokens??0),outputTokens:Number(o.output_tokens??0),cachedInputTokens:Number(o.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(n,e){let t;try{t=JSON.parse(n);}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 l=hs(i,d);l&&a.push(l);}return a}};});exports.copilotAdapter=void 0;var lr=D(()=>{c();Ke();Ve();Ge();exports.copilotAdapter={command:"copilot",buildArgs(n,e,t){let r=e.additionalArgs?[...e.additionalArgs]:[];return e.model&&r.push("--model",e.model),{args:r,stdinMessage:n}},extractText(n){let e=n.split(`
7
+ `);for(let t of e)if(t.trim())try{let r=JSON.parse(t);if(r.type==="result"){let o=r.usage,s=o?{inputTokens:Number(o.input_tokens??0)+Number(o.cache_read_input_tokens??0),outputTokens:Number(o.output_tokens??0),cachedInputTokens:Number(o.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(n,e){let t;try{t=JSON.parse(n);}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 l=ws(i,d);l&&a.push(l);}return a}};});exports.copilotAdapter=void 0;var cr=N(()=>{c();Ve();Ge();Xe();exports.copilotAdapter={command:"copilot",buildArgs(n,e,t){let r=e.additionalArgs?[...e.additionalArgs]:[];return e.model&&r.push("--model",e.model),{args:r,stdinMessage:n}},extractText(n){let e=n.split(`
8
8
  `).filter(o=>o.trim()),t=[],r=null;for(let o of e)try{let s=JSON.parse(o);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(`
9
9
 
10
- `):r||n.trim()},parseResultMeta(n){let e=fe(n);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(n,e){let t;try{t=JSON.parse(n);}catch{return []}let r=t.type;if(!r)return [];if(!r.startsWith("tool.execution")&&!r.startsWith("assistant.")&&r!=="user.message")return [];let o=t.data;if(!o)return [];let s=e??new Date().toISOString(),i=o.toolCallId;if(r==="tool.execution_start"){let a=String(o.toolName||""),d=o.arguments,l=ie(d);return (a==="bash"||a==="Bash")&&oe(l)?[se(s,l)]:[{timestamp:s,type:"tool_use",toolName:a,toolInput:l,...i&&{toolUseId:i}}]}if(r==="tool.execution_complete"){let a=o.error;if(a)return [{timestamp:s,type:"tool_result",isError:true,resultPreview:String(a.message||""),...i&&{toolUseId:i}}];let d=o.result,l=String(d?.content||"");return [{timestamp:s,type:"tool_result",resultPreview:l,isError:false,...i&&{toolUseId:i}}]}if(r==="assistant.message"){let a=String(o.content||"");return a?[{timestamp:s,type:"text",content:a}]:[]}return []}};});function cr(n){return n.replace(/\}\s*\{/g,`}
10
+ `):r||n.trim()},parseResultMeta(n){let e=ye(n);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(n,e){let t;try{t=JSON.parse(n);}catch{return []}let r=t.type;if(!r)return [];if(!r.startsWith("tool.execution")&&!r.startsWith("assistant.")&&r!=="user.message")return [];let o=t.data;if(!o)return [];let s=e??new Date().toISOString(),i=o.toolCallId;if(r==="tool.execution_start"){let a=String(o.toolName||""),d=o.arguments,l=ae(d);return (a==="bash"||a==="Bash")&&se(l)?[ie(s,l)]:[{timestamp:s,type:"tool_use",toolName:a,toolInput:l,...i&&{toolUseId:i}}]}if(r==="tool.execution_complete"){let a=o.error;if(a)return [{timestamp:s,type:"tool_result",isError:true,resultPreview:String(a.message||""),...i&&{toolUseId:i}}];let d=o.result,l=String(d?.content||"");return [{timestamp:s,type:"tool_result",resultPreview:l,isError:false,...i&&{toolUseId:i}}]}if(r==="assistant.message"){let a=String(o.content||"");return a?[{timestamp:s,type:"text",content:a}]:[]}return []}};});function ur(n){return n.replace(/\}\s*\{/g,`}
11
11
  {`).split(`
12
- `).map(e=>e.trim()).filter(Boolean)}function xs(n,e){let t=e.type;if(t==="command_execution"){let r=String(e.command||"");return oe(r)?[se(n,r)]:[{timestamp:n,type:"tool_use",toolName:"Bash",toolInput:r}]}return t==="web_search"?[]:t==="file_change"?[]:[]}function ks(n,e){let t=e.type;if(t==="message"||t==="text"){let r=e.content;if(Array.isArray(r))for(let o of r){let s=_s(n,o);if(s)return s}if(typeof e.text=="string")return {timestamp:n,type:"text",content:e.text}}if(t==="agent_message"&&typeof e.text=="string")return {timestamp:n,type:"text",content:e.text};if(t==="reasoning")return {timestamp:n,type:"text",content:String(e.text||"")};if(t==="command_execution"){let r=String(e.aggregated_output||e.output||""),o=!!e.is_error;return {timestamp:n,type:"tool_result",resultPreview:r,isError:o}}if(t==="tool_use"){let r=String(e.name||e.tool_name||""),o=e.input,s=ie(o);return r==="Bash"&&oe(s)?se(n,s):{timestamp:n,type:"tool_use",toolName:r,toolInput:s}}if(t==="tool_result"){let r=!!e.is_error,o=String(e.output||e.content||"");return {timestamp:n,type:"tool_result",resultPreview:o,isError:r}}if(t==="web_search"){let r=e.action,o;if(r?.type==="search"){let s=r.queries;o=String(r.query||"")||(s?.length?s.join(", "):"")||String(e.query||"");}else o=e.query?"open: "+String(e.query):"";return o?{timestamp:n,type:"tool_use",toolName:"WebSearch",toolInput:o}:null}if(t==="file_change"){let r=e.changes;if(!Array.isArray(r)||r.length===0)return null;let o=r.map(i=>String(i.path||"")).filter(Boolean);if(o.length===0)return null;let s=o.length===1?o[0]:`${o.slice(0,2).join(", ")}${o.length>2?` (+${o.length-2})`:""}`;return {timestamp:n,type:"tool_use",toolName:"Edit",toolInput:s}}return null}function _s(n,e){let t=e.type;if(t==="text")return {timestamp:n,type:"text",content:String(e.text||"")};if(t==="tool_use"){let r=String(e.name||""),o=e.input,s=ie(o);return r==="Bash"&&oe(s)?se(n,s):{timestamp:n,type:"tool_use",toolName:r,toolInput:s}}return null}var ws;exports.codexAdapter=void 0;var ur=D(()=>{c();Ke();Ve();Ge();ar();ws=new Set(["thread.started","turn.started","turn.completed","item.updated"]);exports.codexAdapter={command:"codex",buildArgs(n,e,t){let{model:r,effort:o}=Nt(e.model),s=e.effort??o,i=_n(e.mode),a=vn(s),d=r?["-m",r]:[],l=e.additionalArgs??[];return {args:["exec",...l.includes("--experimental-json")?[]:["--json"],...i,...a,...d,...l],stdinMessage:n}},extractText(n){let e=cr(n),t=[],r=null;for(let o of e)try{let s=JSON.parse(o);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(`
12
+ `).map(e=>e.trim()).filter(Boolean)}function ks(n,e){let t=e.type;if(t==="command_execution"){let r=String(e.command||"");return se(r)?[ie(n,r)]:[{timestamp:n,type:"tool_use",toolName:"Bash",toolInput:r}]}return t==="web_search"?[]:t==="file_change"?[]:[]}function _s(n,e){let t=e.type;if(t==="message"||t==="text"){let r=e.content;if(Array.isArray(r))for(let o of r){let s=vs(n,o);if(s)return s}if(typeof e.text=="string")return {timestamp:n,type:"text",content:e.text}}if(t==="agent_message"&&typeof e.text=="string")return {timestamp:n,type:"text",content:e.text};if(t==="reasoning")return {timestamp:n,type:"text",content:String(e.text||"")};if(t==="command_execution"){let r=String(e.aggregated_output||e.output||""),o=!!e.is_error;return {timestamp:n,type:"tool_result",resultPreview:r,isError:o}}if(t==="tool_use"){let r=String(e.name||e.tool_name||""),o=e.input,s=ae(o);return r==="Bash"&&se(s)?ie(n,s):{timestamp:n,type:"tool_use",toolName:r,toolInput:s}}if(t==="tool_result"){let r=!!e.is_error,o=String(e.output||e.content||"");return {timestamp:n,type:"tool_result",resultPreview:o,isError:r}}if(t==="web_search"){let r=e.action,o;if(r?.type==="search"){let s=r.queries;o=String(r.query||"")||(s?.length?s.join(", "):"")||String(e.query||"");}else o=e.query?"open: "+String(e.query):"";return o?{timestamp:n,type:"tool_use",toolName:"WebSearch",toolInput:o}:null}if(t==="file_change"){let r=e.changes;if(!Array.isArray(r)||r.length===0)return null;let o=r.map(i=>String(i.path||"")).filter(Boolean);if(o.length===0)return null;let s=o.length===1?o[0]:`${o.slice(0,2).join(", ")}${o.length>2?` (+${o.length-2})`:""}`;return {timestamp:n,type:"tool_use",toolName:"Edit",toolInput:s}}return null}function vs(n,e){let t=e.type;if(t==="text")return {timestamp:n,type:"text",content:String(e.text||"")};if(t==="tool_use"){let r=String(e.name||""),o=e.input,s=ae(o);return r==="Bash"&&se(s)?ie(n,s):{timestamp:n,type:"tool_use",toolName:r,toolInput:s}}return null}var xs;exports.codexAdapter=void 0;var pr=N(()=>{c();Ve();Ge();Xe();dr();xs=new Set(["thread.started","turn.started","turn.completed","item.updated"]);exports.codexAdapter={command:"codex",buildArgs(n,e,t){let{model:r,effort:o}=Dt(e.model),s=e.effort??o,i=vn(e.mode),a=An(s),d=r?["-m",r]:[],l=e.additionalArgs??[];return {args:["exec",...l.includes("--experimental-json")?[]:["--json"],...i,...a,...d,...l],stdinMessage:n}},extractText(n){let e=ur(n),t=[],r=null;for(let o of e)try{let s=JSON.parse(o);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||n.trim()},parseResultMeta(n){let e=fe(n);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(n,e){let t=cr(n),r=e??new Date().toISOString(),o=[];for(let s of t){let i;try{i=JSON.parse(s);}catch{continue}let a=i.type;if(!a||!a.startsWith("item.")&&!a.startsWith("turn.")&&!a.startsWith("thread."))continue;let d=i.item;if(d){if(a==="item.started"){o.push(...xs(r,d));continue}if(a==="item.completed"){let l=ks(r,d);l&&o.push(l);continue}}}return o},suppressOutputLine(n){let e=n.trim();if(!e.startsWith("{")||!e.endsWith("}")||cr(e).length!==1)return false;try{let o=JSON.parse(e).type;return o?ws.has(o):!1}catch{return false}}};});function pr(n){return n.replace(/\}\s*\{/g,`}
14
+ `):r||n.trim()},parseResultMeta(n){let e=ye(n);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(n,e){let t=ur(n),r=e??new Date().toISOString(),o=[];for(let s of t){let i;try{i=JSON.parse(s);}catch{continue}let a=i.type;if(!a||!a.startsWith("item.")&&!a.startsWith("turn.")&&!a.startsWith("thread."))continue;let d=i.item;if(d){if(a==="item.started"){o.push(...ks(r,d));continue}if(a==="item.completed"){let l=_s(r,d);l&&o.push(l);continue}}}return o},suppressOutputLine(n){let e=n.trim();if(!e.startsWith("{")||!e.endsWith("}")||ur(e).length!==1)return false;try{let o=JSON.parse(e).type;return o?xs.has(o):!1}catch{return false}}};});function gr(n){return n.replace(/\}\s*\{/g,`}
15
15
  {`).split(`
16
- `).map(e=>e.trim()).filter(Boolean)}var vs;exports.opencodeAdapter=void 0;var gr=D(()=>{c();Ke();Ge();vs=new Set(["step_start","step_finish"]);exports.opencodeAdapter={command:"opencode",buildArgs(n,e,t){let r=e.additionalArgs,o=r!==void 0?[...r]:["run"];return o.includes("--format")||o.push("--format","json"),e.model&&o.push("--model",e.model),{args:o,stdinMessage:n}},extractText(n){let e=pr(n),t=[],r=null;for(let o of e)try{let s=JSON.parse(o);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||n.trim()},parseResultMeta(n){let e=fe(n);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(n,e){let t=pr(n),r=e??new Date().toISOString(),o=[];for(let s of t){let i;try{i=JSON.parse(s);}catch{continue}let a=i.type;if(a){if(a==="text"){let l=i.part?.text;l&&o.push({timestamp:r,type:"text",content:l});continue}if(a==="tool_use"){let d=i.part;if(!d)continue;let l=String(d.tool||""),u=String(d.callID||""),p=d.state,y=String(p?.status||""),g=p?.input,h=ie(g);if(o.push({timestamp:r,type:"tool_use",toolName:l,toolUseId:u,toolInput:h}),y==="completed"&&p?.output!==void 0){let k=p.output,v=typeof k=="string"?k:JSON.stringify(k);o.push({timestamp:r,type:"tool_result",toolUseId:u,resultPreview:v,isError:false});}else y==="error"&&o.push({timestamp:r,type:"tool_result",toolUseId:u,resultPreview:String(p?.error||"tool error"),isError:true});continue}}}return o},suppressOutputLine(n){let e=n.trim();if(!e.startsWith("{")||!e.endsWith("}")||pr(e).length!==1)return false;try{let o=JSON.parse(e).type;return o?vs.has(o):!1}catch{return false}}};});var As,mr,fr=D(()=>{c();nt();As=[{id:"Gemini 3.5 Flash (Medium)",name:"Gemini 3.5 Flash (Medium)"},{id:"Gemini 3.5 Flash (High)",name:"Gemini 3.5 Flash (High)"},{id:"Gemini 3.5 Flash (Low)",name:"Gemini 3.5 Flash (Low)"},{id:"Gemini 3.1 Pro (Low)",name:"Gemini 3.1 Pro (Low)"},{id:"Gemini 3.1 Pro (High)",name:"Gemini 3.1 Pro (High)"},{id:"Claude Sonnet 4.6 (Thinking)",name:"Claude Sonnet 4.6 (Thinking)"},{id:"Claude Opus 4.6 (Thinking)",name:"Claude Opus 4.6 (Thinking)"},{id:"GPT-OSS 120B (Medium)",name:"GPT-OSS 120B (Medium)"}],mr={command:"agy",meta:{displayName:"Antigravity",models:As,defaultTimeoutMs:{query:12e4,execute:3e5}},buildArgs(n,e,t){if(e.additionalArgs!==void 0){let o=[...e.additionalArgs];return o.includes("--print")||o.unshift("--print",n),e.model&&o.push("--model",e.model),o.push("--dangerously-skip-permissions"),{args:o}}let r=["--print",n,"--dangerously-skip-permissions"];return e.model&&r.push("--model",e.model),{args:r}},extractText(n){let e=n.trim();if(!e)throw new exports.ProviderError("Antigravity CLI returned empty output with exit code 0. agy may have hidden an auth/quota/model error in its log file; inspect ~/.gemini/antigravity-cli/log for details.","cli/antigravity",{code:"EMPTY_OUTPUT",kind:"transient"});return e},parseResultMeta(n){return {usage:null,model:null}},parseEvent(n,e){return []}};});var En,Cn=D(()=>{c();Ve();Ge();En={parseEvent(n,e){let t;try{t=JSON.parse(n);}catch{return []}let r=t.type;if(!r)return [];if(r!=="message"&&r!=="tool_use"&&r!=="tool_result")return [];let o=e??new Date().toISOString();if(r==="message"){if(t.role!=="assistant")return [];let i=t.content;return i?[{timestamp:o,type:"text",content:i}]:[]}if(r==="tool_use"){let s=String(t.tool_name||""),i=t.tool_id,a=t.parameters,d=ie(a);return /^bash$/i.test(s)&&oe(d)?[se(o,d)]:[{timestamp:o,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:o,type:"tool_result",toolUseId:s,resultPreview:i,isError:a}]}return []}};});function st(n,e,t){if(t){let r=exports.BUILTIN_ADAPTERS[t];if(r?.parseEvent)return r.parseEvent(e,n);let o=Rs[t];if(o?.parseEvent)return o.parseEvent(e,n)}for(let r of Object.values(exports.BUILTIN_ADAPTERS)){let o=r.parseEvent?.(e,n)??[];if(o.length>0)return o}return []}exports.BUILTIN_ADAPTERS=void 0;var Rs,Ae=D(()=>{c();dr();lr();ur();gr();fr();Cn();dr();lr();ur();gr();fr();Ve();exports.BUILTIN_ADAPTERS={codex:exports.codexAdapter,claude:exports.claudeAdapter,opencode:exports.opencodeAdapter,antigravity:mr,copilot:exports.copilotAdapter},Rs={gemini:En};});function Cs(n){let e=n.split(`
16
+ `).map(e=>e.trim()).filter(Boolean)}var As;exports.opencodeAdapter=void 0;var mr=N(()=>{c();Ve();Xe();As=new Set(["step_start","step_finish"]);exports.opencodeAdapter={command:"opencode",buildArgs(n,e,t){let r=e.additionalArgs,o=r!==void 0?[...r]:["run"];return o.includes("--format")||o.push("--format","json"),e.model&&o.push("--model",e.model),{args:o,stdinMessage:n}},extractText(n){let e=gr(n),t=[],r=null;for(let o of e)try{let s=JSON.parse(o);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||n.trim()},parseResultMeta(n){let e=ye(n);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(n,e){let t=gr(n),r=e??new Date().toISOString(),o=[];for(let s of t){let i;try{i=JSON.parse(s);}catch{continue}let a=i.type;if(a){if(a==="text"){let l=i.part?.text;l&&o.push({timestamp:r,type:"text",content:l});continue}if(a==="tool_use"){let d=i.part;if(!d)continue;let l=String(d.tool||""),u=String(d.callID||""),p=d.state,f=String(p?.status||""),g=p?.input,h=ae(g);if(o.push({timestamp:r,type:"tool_use",toolName:l,toolUseId:u,toolInput:h}),f==="completed"&&p?.output!==void 0){let x=p.output,v=typeof x=="string"?x:JSON.stringify(x);o.push({timestamp:r,type:"tool_result",toolUseId:u,resultPreview:v,isError:false});}else f==="error"&&o.push({timestamp:r,type:"tool_result",toolUseId:u,resultPreview:String(p?.error||"tool error"),isError:true});continue}}}return o},suppressOutputLine(n){let e=n.trim();if(!e.startsWith("{")||!e.endsWith("}")||gr(e).length!==1)return false;try{let o=JSON.parse(e).type;return o?As.has(o):!1}catch{return false}}};});var Rs,fr,yr=N(()=>{c();ot();Rs=[{id:"Gemini 3.5 Flash (Medium)",name:"Gemini 3.5 Flash (Medium)"},{id:"Gemini 3.5 Flash (High)",name:"Gemini 3.5 Flash (High)"},{id:"Gemini 3.5 Flash (Low)",name:"Gemini 3.5 Flash (Low)"},{id:"Gemini 3.1 Pro (Low)",name:"Gemini 3.1 Pro (Low)"},{id:"Gemini 3.1 Pro (High)",name:"Gemini 3.1 Pro (High)"},{id:"Claude Sonnet 4.6 (Thinking)",name:"Claude Sonnet 4.6 (Thinking)"},{id:"Claude Opus 4.6 (Thinking)",name:"Claude Opus 4.6 (Thinking)"},{id:"GPT-OSS 120B (Medium)",name:"GPT-OSS 120B (Medium)"}],fr={command:"agy",meta:{displayName:"Antigravity",models:Rs,defaultTimeoutMs:{query:12e4,execute:3e5}},buildArgs(n,e,t){if(e.additionalArgs!==void 0){let o=[...e.additionalArgs];return o.includes("--print")||o.unshift("--print",n),e.model&&o.push("--model",e.model),o.push("--dangerously-skip-permissions"),{args:o}}let r=["--print",n,"--dangerously-skip-permissions"];return e.model&&r.push("--model",e.model),{args:r}},extractText(n){let e=n.trim();if(!e)throw new exports.ProviderError("Antigravity CLI returned empty output with exit code 0. agy may have hidden an auth/quota/model error in its log file; inspect ~/.gemini/antigravity-cli/log for details.","cli/antigravity",{code:"EMPTY_OUTPUT",kind:"transient"});return e},parseResultMeta(n){return {usage:null,model:null}},parseEvent(n,e){return []}};});var Cn,Tn=N(()=>{c();Ge();Xe();Cn={parseEvent(n,e){let t;try{t=JSON.parse(n);}catch{return []}let r=t.type;if(!r)return [];if(r!=="message"&&r!=="tool_use"&&r!=="tool_result")return [];let o=e??new Date().toISOString();if(r==="message"){if(t.role!=="assistant")return [];let i=t.content;return i?[{timestamp:o,type:"text",content:i}]:[]}if(r==="tool_use"){let s=String(t.tool_name||""),i=t.tool_id,a=t.parameters,d=ae(a);return /^bash$/i.test(s)&&se(d)?[ie(o,d)]:[{timestamp:o,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:o,type:"tool_result",toolUseId:s,resultPreview:i,isError:a}]}return []}};});function it(n,e,t){if(t){let r=exports.BUILTIN_ADAPTERS[t];if(r?.parseEvent)return r.parseEvent(e,n);let o=Es[t];if(o?.parseEvent)return o.parseEvent(e,n)}for(let r of Object.values(exports.BUILTIN_ADAPTERS)){let o=r.parseEvent?.(e,n)??[];if(o.length>0)return o}return []}exports.BUILTIN_ADAPTERS=void 0;var Es,Re=N(()=>{c();lr();cr();pr();mr();yr();Tn();lr();cr();pr();mr();yr();Ge();exports.BUILTIN_ADAPTERS={codex:exports.codexAdapter,claude:exports.claudeAdapter,opencode:exports.opencodeAdapter,antigravity:fr,copilot:exports.copilotAdapter},Es={gemini:Cn};});function Ts(n){let e=n.split(`
17
17
  `).filter(d=>d.trim()),t=[],r=[],o=[],s=[],i=[],a=null;for(let d of e)try{let l=JSON.parse(d);if(l.type==="assistant"&&Array.isArray(l.message?.content))for(let u of l.message.content)u.type==="text"&&typeof u.text=="string"&&u.text.trim()&&t.push(u.text.trim());if(l.type==="message"&&l.role==="assistant"&&l.delta===!0&&typeof l.content=="string"&&r.push(l.content),l.type==="assistant.message"&&typeof l.data?.content=="string"){let u=l.data.content;u.trim()&&o.push(u.trim());}if(l.type==="item.completed"&&(l.item?.type==="message"||l.item?.type==="agent_message")&&typeof l.item?.text=="string"){let u=l.item.text;u.trim()&&s.push(u.trim());}if(l.type==="text"&&typeof l.part?.text=="string"){let u=l.part.text;u.trim()&&i.push(u.trim());}l.type==="result"&&typeof l.result=="string"&&(a=l.result);}catch{}return t.length>0?t.join(`
18
18
 
19
19
  `):r.length>0?r.join(""):o.length>0?o.join(`
20
20
 
21
21
  `):s.length>0?s.join(`
22
22
 
23
- `):i.length>0?i.join(""):a||n.trim()}function Ts(n){let e=fe(n);return e?{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0}:null}function Ps(n,e,t=process.platform){return n==="copilot"&&t==="win32"&&e instanceof exports.ProviderError&&e.message.includes('CLI command "copilot" not found')}function bn(n,e,t,r,o,s,i){return new Promise((a,d)=>{let l=o?.timeoutMs??288e5,u=tt({command:n,allowShellFallback:true}),p=rt(u,e),y=child_process.spawn(p.command,p.argv,{env:{...process.env,...o?.env??{}},cwd:o?.cwd,stdio:["pipe","pipe","pipe"],shell:p.shell??false,windowsHide:p.windowsHide,detached:process.platform!=="win32"});s!==void 0&&y.stdin.write(s),y.stdin.end(),y.pid!==void 0&&o?.onPid?.(y.pid);let g=false,h=false,k=()=>{try{y.kill("SIGKILL");}catch{}},w=setTimeout(()=>{if(!g){h=true;try{y.kill("SIGTERM");}catch{}setTimeout(k,Pn).unref();}},l);w.unref();let _=new string_decoder.StringDecoder("utf8"),x=new string_decoder.StringDecoder("utf8"),I="",P="",z="",H="";y.stdout.on("data",A=>{let U=_.write(A);I+=U,z+=U;let K=z.split(`
24
- `);z=K.pop()??"";for(let B of K)if(B.trim()&&(o?.onOutput?.(B,"stdout"),i?.extractFailure)){let W=i.extractFailure(B);if(W){g=true,clearTimeout(w);try{y.kill("SIGTERM");}catch{}setTimeout(k,Pn).unref(),d(W);return}}}),y.stderr.on("data",A=>{let U=x.write(A);P+=U,H+=U;let K=H.split(`
25
- `);H=K.pop()??"";for(let B of K)B.trim()&&o?.onOutput?.(B,"stderr");}),y.on("error",A=>{g=true,clearTimeout(w),A.code==="ENOENT"?d(new exports.ProviderError(`CLI command "${n}" not found. Is ${t} installed?`,t)):d(new exports.ProviderError(`Spawn error: ${A.message}`,t));}),y.on("close",A=>{if(g)return;g=true,clearTimeout(w);let U=_.end(),K=x.end();U&&(I+=U,z+=U),K&&(P+=K,H+=K),z.trim()&&o?.onOutput?.(z,"stdout"),H.trim()&&o?.onOutput?.(H,"stderr");let B=A??0;if(o?.onExitCode?.(B),h)return d(new be(`Total runtime exceeded ${l}ms; process killed.`,t));if(B!==0){if(i?.interpretExit){let F=i.interpretExit(B,P);if(F){d(F);return}}d(new exports.ProviderError(`Process exited with code ${B}: ${P.slice(0,500)}`,t));return}let W;try{W=i?i.extractText(I):Cs(I);}catch(F){d(F instanceof Error?F:new exports.ProviderError(String(F),t));return}a({stdout:I,parsed:W});});})}function ye(n,e){Sn.set(n,e);}function he(n){let e=n.split("/");if(e.length!==2)throw new exports.ProviderError(`Invalid provider format: "${n}". Expected namespace/id (e.g., cli/claude)`,n);let[t,r]=e,o=Sn.get(t);if(o)return o(r,n);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(", ")}`,n);return new yr(r,s,n)}throw new exports.ProviderError(`Unsupported provider namespace: "${t}". Register a factory with registerProviderFactory('${t}', factory).`,n)}var Pn;exports.ClientToolCallRequiredError=void 0;var Sn,yr,ue=D(()=>{c();Mt();Ke();Ae();nt();nt();Pn=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"},Sn=new Map;yr=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:o,stdinMessage:s}=this.adapter.buildArgs(r,t??{},true);t?.onCommand?.(`${this.adapter.command} ${o.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(o,t,s);return this.handleResultMeta(i,t),a}async query(e,t){let r=this.composeMessage(e,t),{args:o,stdinMessage:s}=this.adapter.buildArgs(r,t??{},false);t?.onCommand?.(`${this.adapter.command} ${o.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(o,t,s);return this.handleResultMeta(i,t),a}composeMessage(e,t){return t?.systemPrompt?`${t.systemPrompt}
23
+ `):i.length>0?i.join(""):a||n.trim()}function Ps(n){let e=ye(n);return e?{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0}:null}function bs(n,e,t=process.platform){return n==="copilot"&&t==="win32"&&e instanceof exports.ProviderError&&e.message.includes('CLI command "copilot" not found')}function Sn(n,e,t,r,o,s,i){return new Promise((a,d)=>{let l=o?.timeoutMs??288e5,u=rt({command:n,allowShellFallback:true}),p=nt(u,e),f=child_process.spawn(p.command,p.argv,{env:{...process.env,...o?.env??{}},cwd:o?.cwd,stdio:["pipe","pipe","pipe"],shell:p.shell??false,windowsHide:p.windowsHide,detached:process.platform!=="win32"});s!==void 0&&f.stdin.write(s),f.stdin.end(),f.pid!==void 0&&o?.onPid?.(f.pid);let g=false,h=false,x=()=>{try{f.kill("SIGKILL");}catch{}},w=setTimeout(()=>{if(!g){h=true;try{f.kill("SIGTERM");}catch{}setTimeout(x,bn).unref();}},l);w.unref();let _=new string_decoder.StringDecoder("utf8"),k=new string_decoder.StringDecoder("utf8"),S="",P="",W="",H="";f.stdout.on("data",A=>{let j=_.write(A);S+=j,W+=j;let z=W.split(`
24
+ `);W=z.pop()??"";for(let B of z)if(B.trim()&&(o?.onOutput?.(B,"stdout"),i?.extractFailure)){let F=i.extractFailure(B);if(F){g=true,clearTimeout(w);try{f.kill("SIGTERM");}catch{}setTimeout(x,bn).unref(),d(F);return}}}),f.stderr.on("data",A=>{let j=k.write(A);P+=j,H+=j;let z=H.split(`
25
+ `);H=z.pop()??"";for(let B of z)B.trim()&&o?.onOutput?.(B,"stderr");}),f.on("error",A=>{g=true,clearTimeout(w),A.code==="ENOENT"?d(new exports.ProviderError(`CLI command "${n}" not found. Is ${t} installed?`,t)):d(new exports.ProviderError(`Spawn error: ${A.message}`,t));}),f.on("close",A=>{if(g)return;g=true,clearTimeout(w);let j=_.end(),z=k.end();j&&(S+=j,W+=j),z&&(P+=z,H+=z),W.trim()&&o?.onOutput?.(W,"stdout"),H.trim()&&o?.onOutput?.(H,"stderr");let B=A??0;if(o?.onExitCode?.(B),h)return d(new Se(`Total runtime exceeded ${l}ms; process killed.`,t));if(B!==0){if(i?.interpretExit){let q=i.interpretExit(B,P);if(q){d(q);return}}d(new exports.ProviderError(`Process exited with code ${B}: ${P.slice(0,500)}`,t));return}let F;try{F=i?i.extractText(S):Ts(S);}catch(q){d(q instanceof Error?q:new exports.ProviderError(String(q),t));return}a({stdout:S,parsed:F});});})}function he(n,e){In.set(n,e);}function we(n){let e=n.split("/");if(e.length!==2)throw new exports.ProviderError(`Invalid provider format: "${n}". Expected namespace/id (e.g., cli/claude)`,n);let[t,r]=e,o=In.get(t);if(o)return o(r,n);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(", ")}`,n);return new hr(r,s,n)}throw new exports.ProviderError(`Unsupported provider namespace: "${t}". Register a factory with registerProviderFactory('${t}', factory).`,n)}var bn;exports.ClientToolCallRequiredError=void 0;var In,hr,pe=N(()=>{c();Nt();Ve();Re();ot();ot();bn=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"},In=new Map;hr=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:o,stdinMessage:s}=this.adapter.buildArgs(r,t??{},true);t?.onCommand?.(`${this.adapter.command} ${o.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(o,t,s);return this.handleResultMeta(i,t),a}async query(e,t){let r=this.composeMessage(e,t),{args:o,stdinMessage:s}=this.adapter.buildArgs(r,t??{},false);t?.onCommand?.(`${this.adapter.command} ${o.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(o,t,s);return this.handleResultMeta(i,t),a}composeMessage(e,t){return t?.systemPrompt?`${t.systemPrompt}
26
26
 
27
27
  ---
28
28
 
29
- ${e}`:e}async runProcess(e,t,r){try{return await bn(this.adapter.command,e,this.providerStr,this.providerId,t,r,this.adapter)}catch(o){if(Ps(this.providerId,o)){let s=e[0]==="copilot"?e:["copilot",...e];return bn("gh",s,this.providerStr,this.providerId,t,r,this.adapter)}throw o}}handleResultMeta(e,t){if(!this.adapter.parseResultMeta){let i=Ts(e);i&&t?.onUsage&&t.onUsage(i);return}let{usage:r,model:o}=this.adapter.parseResultMeta(e);r&&t?.onUsage&&t.onUsage(r);let s=o??(this.providerId==="opencode"?t?.model??null:null);s&&t?.onModel&&t.onModel(s);}};});function Ir(n){let e=n.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 de(n,e){try{let t=JSON.parse(n);if(t!=null&&typeof t=="object"&&typeof t.type=="string"&&fi.has(t.type)){let r=e??new Date().toISOString();return [{...t,timestamp:t.timestamp||r}]}}catch{}return []}var fi,Re=D(()=>{c();fi=new Set(["text","tool_use","tool_result","error","agent_call"]);});var lo,co;exports.VercelProviderRuntime=void 0;var jr=D(()=>{c();ue();lo=10,co=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:o,tool:s}=await import('ai'),i=this.convertTools(r?.tools??[],s),a=this.createModel(r?.model),d=Math.min(r?.maxSteps??this.config.maxSteps??lo,co);try{let l=0,u=await o({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:y=>{if(l++,!!r?.onOutput){if(y.toolCalls&&y.toolCalls.length>0)for(let g of y.toolCalls)r.onOutput(JSON.stringify({type:"assistant",message:{content:[{type:"tool_use",id:g.toolCallId,name:g.toolName,input:g.args}]}}),"stdout");if(y.toolResults&&y.toolResults.length>0)for(let g of y.toolResults){let h=typeof g.result=="string"?g.result:JSON.stringify(g.result);r.onOutput(JSON.stringify({type:"user",message:{content:[{type:"tool_result",tool_use_id:g.toolCallId,output:h,is_error:!1}]}}),"stdout");}}}}),p=new Set((r?.tools??[]).filter(y=>!y.execute).map(y=>y.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let y=u.toolCalls.filter(g=>p.has(g.toolName));if(y.length>0){let g=y[0];throw new exports.ClientToolCallRequiredError({toolCallId:g.toolCallId,toolName:g.toolName,args:g.args},{userMessage:e,responseMessages:u.response?.messages??[],toolDefinitions:r?.tools??[],maxSteps:d,systemPrompt:r?.systemPrompt,modelOverride:r?.model})}}if(r?.onUsage&&u.usage){let y={inputTokens:u.usage.promptTokens??0,outputTokens:u.usage.completionTokens??0,cachedInputTokens:0,costUsd:0};r.onUsage(y);}return r?.onModel&&r.onModel(r.model??this.config.model),u.text??""}catch(l){throw l instanceof exports.ClientToolCallRequiredError?l:l.status===401?new exports.ProviderError(`Authentication failed for ${this.config.provider}. Check your API key.`,this.config.provider):l.status===429?new exports.ProviderError(`Rate limit exceeded for ${this.config.provider}.`,this.config.provider):new exports.ProviderError(`Provider error: ${l.message}`,this.config.provider)}}async continueWithToolResults(e,t,r){let{generateText:o,tool:s}=await import('ai'),i=this.convertTools(e.toolDefinitions,s),a=this.createModel(e.modelOverride),d=Math.min(e.maxSteps??this.config.maxSteps??lo,co),l=[{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 o({model:a,system:e.systemPrompt??void 0,messages:l,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens}}),p=new Set(e.toolDefinitions.filter(y=>!y.execute).map(y=>y.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let y=u.toolCalls.filter(g=>p.has(g.toolName));if(y.length>0){let g=y[0];throw new exports.ClientToolCallRequiredError({toolCallId:g.toolCallId,toolName:g.toolName,args:g.args},{userMessage:e.userMessage,responseMessages:[...e.responseMessages,{role:"tool",content:t.map(h=>({type:"tool-result",toolCallId:h.toolCallId,toolName:h.toolName,result:typeof h.result=="string"?h.result:JSON.stringify(h.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}=J("zod"),o={};for(let s of e){let i=this.jsonSchemaToZod(s.parameters??{},r);s.execute?o[s.name]=t({description:s.description,parameters:i,execute:async a=>s.execute(a)}):o[s.name]=t({description:s.description,parameters:i});}return o}jsonSchemaToZod(e,t){if(!e||!e.properties)return t.object({});let r={},o=e.properties,s=e.required??[];for(let[i,a]of Object.entries(o)){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:o}=this.config,s=e||this.config.model;switch(t){case "api/openrouter":{let{createOpenAI:i}=J("@ai-sdk/openai");return i({apiKey:r||process.env.OPENROUTER_API_KEY,baseURL:o||"https://openrouter.ai/api/v1"})(s)}case "api/openai":{let{createOpenAI:i}=J("@ai-sdk/openai");return i({apiKey:r||process.env.OPENAI_API_KEY,...o&&{baseURL:o}})(s)}case "api/anthropic":{let{createAnthropic:i}=J("@ai-sdk/anthropic");return i({apiKey:r||process.env.ANTHROPIC_API_KEY,...o&&{baseURL:o}})(s)}case "api/google":{let{createGoogleGenerativeAI:i}=J("@ai-sdk/google");return i({apiKey:r||process.env.GOOGLE_API_KEY})(s)}default:throw new exports.ProviderError(`Unsupported API provider: ${t}`,t)}}};});var po={};Ct(po,{registerApiProviders:()=>uo});function uo(n){ye("api",(e,t)=>{let r=n?.apiKeys?.[e];return new exports.VercelProviderRuntime({provider:t,model:"",apiKey:r,maxSteps:n?.defaults?.maxSteps,temperature:n?.defaults?.temperature})});}var Hr=D(()=>{c();ue();jr();});exports.AcpProtocolError=void 0;var Fr=D(()=>{c();exports.AcpProtocolError=class extends Error{constructor(t,r,o){super(t);this.code=r;this.data=o;}code;data;name="AcpProtocolError"};});var la,ca,go,mo,ua;exports.AcpConnection=void 0;var Gt=D(()=>{c();Fr();ue();la=-32e3,ca=2e3,go=3e4,mo=1e4,ua=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),o=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"});o.pid!==void 0&&this.options.onPid?.(o.pid),o.stderr.on("data",g=>{let h=g.toString();this.collectedStderr+=h,this.stderrBuffer+=h;let k=this.stderrBuffer.split(`
30
- `);this.stderrBuffer=k.pop()??"";for(let v of k)v.trim()&&this.options.onStderr?.(v);}),this.proc=o;let s=new WritableStream({write:g=>new Promise((h,k)=>{o.stdin.write(g,v=>{v?k(v):h();});}),close:()=>{o.stdin.end();}}),i=new ReadableStream({start:g=>{o.stdout.on("data",h=>{g.enqueue(new Uint8Array(h));}),o.stdout.on("end",()=>{g.close();}),o.stdout.on("error",h=>{g.error(h);});}}),a=sdk.ndJsonStream(s,i),d=this,l=new sdk.ClientSideConnection(g=>({requestPermission:async h=>{if(d.options.configOptions?.allow_all!==void 0){let k=h.options;if(Array.isArray(k)&&k.length>0)return {outcome:{outcome:"selected",optionId:(k.find(w=>w.kind==="allow_once")??k.find(w=>w.kind?.startsWith("allow_"))??k[0]).optionId}}}return {outcome:{outcome:"cancelled"}}},sessionUpdate:async h=>{d.pendingUpdateCallback?.(h);}}),a);this.sdkConnection=l;let u=new Promise((g,h)=>{o.on("error",k=>{if(k.code==="ENOENT"){let w=t.command==="npx"&&t.args.length>0?`@agentclientprotocol/${t.args[0]}`:t.command;h(new exports.ProviderError(`ACP command "${t.command}" not found. Is the ACP adapter installed? Try: npm install -g ${w}`,"acp"));}else h(new exports.ProviderError(`ACP spawn error: ${k.message}`,"acp"));});}),p=this.doInitialize(l,e),y=new Promise((g,h)=>{setTimeout(()=>{h(new exports.AcpProtocolError(`ACP connect timeout after ${go}ms. The ACP adapter may not be installed or may require interactive setup.`));},go).unref();});await Promise.race([p,y,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((o,s)=>{setTimeout(()=>{s(new exports.AcpProtocolError(`ACP session/new timeout after ${mo}ms`));},mo).unref();});return Promise.race([t,r])}isAuthError(e){return typeof e=="object"&&e!==null&&"code"in e&&e.code===la}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(o=>o.type==="env_var");if(r.length>0){let o=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: ${o.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,o){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=o??ua,d=false,l=s.prompt({sessionId:e,prompt:t}).finally(()=>{d=true;}),u=new Promise((y,g)=>{setTimeout(()=>{s.cancel({sessionId:e}).catch(()=>{}),g(new be(`ACP prompt timeout after ${a}ms`,"acp"));},a).unref();}),p=new Promise((y,g)=>{let h=(_,x,I)=>{if(d)return;let P=x!=null?`signal=${x}`:`code=${String(_)}`;g(new exports.ProviderError(`ACP process terminated unexpectedly (${P}) [${I}]: ${this.collectedStderr.slice(-500)}`,"acp"));},k=(_,x)=>h(_,x,"exit"),v=(_,x)=>h(_,x,"close");i.once("exit",k),i.once("close",v);let w=()=>{i.off("exit",k),i.off("close",v);};l.then(w,w);});try{return await Promise.race([l,u,p])}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=o=>{if(t!==void 0&&process.platform!=="win32")try{process.kill(-t,o);}catch{}else try{e.kill(o);}catch{}};await new Promise(o=>{let s=()=>{clearTimeout(i),o();};e.once("close",s),e.once("error",s);try{r("SIGTERM");}catch{s();return}let i=setTimeout(()=>{r("SIGKILL");},ca);});}get isConnected(){return !this.disposed&&this.sdkConnection!==null&&this.proc!==null}};});function fo(n,e){if(n!=null&&typeof n=="object"){let t=n;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 pa;exports.AcpProviderRuntime=void 0;var qr=D(()=>{c();Re();Gt();pa={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:o}=this.adapter.spawn;t?.onCommand?.(`${r} ${o.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}),l=await a.newSession(d);await this.applySessionOptions(a,l,t);let u=this.composePrompt(e,t),p=[],y=await a.prompt(l,u,g=>this.handleUpdate(g,t,p),t?.timeoutMs);return this.handleUsage(y,t),p.join("")}finally{await a.dispose().catch(()=>{});}}async applySessionOptions(e,t,r){if(r?.model&&r.model!=="default"&&!this.adapter.buildSpawnEnv){let o=this.adapter.buildEffortAction?.(r.effort??"",r.model);try{o?.type==="set_model"?await e.setModel(t,o.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 o=this.adapter.resolveMode?.(r.mode)??r.mode;if(o)try{await e.setMode(t,o);}catch(s){console.warn(`[acp] setMode(${o}) failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.effort){let o=this.adapter.buildEffortAction?.(r.effort,r.model);if(o&&o.type==="set_config_option")try{await e.setConfigOption(t,o.configId,o.value);}catch(s){console.warn(`[acp] setConfigOption(${o.configId}) effort failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.configOptions)for(let[o,s]of Object.entries(r.configOptions))try{await e.setConfigOption(t,o,s);}catch(i){console.warn(`[acp] setConfigOption(${o}) failed, retrying: ${i instanceof Error?i.message:String(i)}`);try{await new Promise(a=>setTimeout(a,500)),await e.setConfigOption(t,o,s);}catch(a){console.warn(`[acp] setConfigOption(${o}) 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(`
29
+ ${e}`:e}async runProcess(e,t,r){try{return await Sn(this.adapter.command,e,this.providerStr,this.providerId,t,r,this.adapter)}catch(o){if(bs(this.providerId,o)){let s=e[0]==="copilot"?e:["copilot",...e];return Sn("gh",s,this.providerStr,this.providerId,t,r,this.adapter)}throw o}}handleResultMeta(e,t){if(!this.adapter.parseResultMeta){let i=Ps(e);i&&t?.onUsage&&t.onUsage(i);return}let{usage:r,model:o}=this.adapter.parseResultMeta(e);r&&t?.onUsage&&t.onUsage(r);let s=o??(this.providerId==="opencode"?t?.model??null:null);s&&t?.onModel&&t.onModel(s);}};});function Or(n){let e=n.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 le(n,e){try{let t=JSON.parse(n);if(t!=null&&typeof t=="object"&&typeof t.type=="string"&&yi.has(t.type)){let r=e??new Date().toISOString();return [{...t,timestamp:t.timestamp||r}]}}catch{}return []}var yi,Ee=N(()=>{c();yi=new Set(["text","tool_use","tool_result","error","agent_call"]);});var co,uo;exports.VercelProviderRuntime=void 0;var Hr=N(()=>{c();pe();co=10,uo=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:o,tool:s}=await import('ai'),i=this.convertTools(r?.tools??[],s),a=this.createModel(r?.model),d=Math.min(r?.maxSteps??this.config.maxSteps??co,uo);try{let l=0,u=await o({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(l++,!!r?.onOutput){if(f.toolCalls&&f.toolCalls.length>0)for(let g of f.toolCalls)r.onOutput(JSON.stringify({type:"assistant",message:{content:[{type:"tool_use",id:g.toolCallId,name:g.toolName,input:g.args}]}}),"stdout");if(f.toolResults&&f.toolResults.length>0)for(let g of f.toolResults){let h=typeof g.result=="string"?g.result:JSON.stringify(g.result);r.onOutput(JSON.stringify({type:"user",message:{content:[{type:"tool_result",tool_use_id:g.toolCallId,output:h,is_error:!1}]}}),"stdout");}}}}),p=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(g=>p.has(g.toolName));if(f.length>0){let g=f[0];throw new exports.ClientToolCallRequiredError({toolCallId:g.toolCallId,toolName:g.toolName,args:g.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(l){throw l instanceof exports.ClientToolCallRequiredError?l:l.status===401?new exports.ProviderError(`Authentication failed for ${this.config.provider}. Check your API key.`,this.config.provider):l.status===429?new exports.ProviderError(`Rate limit exceeded for ${this.config.provider}.`,this.config.provider):new exports.ProviderError(`Provider error: ${l.message}`,this.config.provider)}}async continueWithToolResults(e,t,r){let{generateText:o,tool:s}=await import('ai'),i=this.convertTools(e.toolDefinitions,s),a=this.createModel(e.modelOverride),d=Math.min(e.maxSteps??this.config.maxSteps??co,uo),l=[{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 o({model:a,system:e.systemPrompt??void 0,messages:l,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens}}),p=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(g=>p.has(g.toolName));if(f.length>0){let g=f[0];throw new exports.ClientToolCallRequiredError({toolCallId:g.toolCallId,toolName:g.toolName,args:g.args},{userMessage:e.userMessage,responseMessages:[...e.responseMessages,{role:"tool",content:t.map(h=>({type:"tool-result",toolCallId:h.toolCallId,toolName:h.toolName,result:typeof h.result=="string"?h.result:JSON.stringify(h.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}=J("zod"),o={};for(let s of e){let i=this.jsonSchemaToZod(s.parameters??{},r);s.execute?o[s.name]=t({description:s.description,parameters:i,execute:async a=>s.execute(a)}):o[s.name]=t({description:s.description,parameters:i});}return o}jsonSchemaToZod(e,t){if(!e||!e.properties)return t.object({});let r={},o=e.properties,s=e.required??[];for(let[i,a]of Object.entries(o)){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:o}=this.config,s=e||this.config.model;switch(t){case "api/openrouter":{let{createOpenAI:i}=J("@ai-sdk/openai");return i({apiKey:r||process.env.OPENROUTER_API_KEY,baseURL:o||"https://openrouter.ai/api/v1"})(s)}case "api/openai":{let{createOpenAI:i}=J("@ai-sdk/openai");return i({apiKey:r||process.env.OPENAI_API_KEY,...o&&{baseURL:o}})(s)}case "api/anthropic":{let{createAnthropic:i}=J("@ai-sdk/anthropic");return i({apiKey:r||process.env.ANTHROPIC_API_KEY,...o&&{baseURL:o}})(s)}case "api/google":{let{createGoogleGenerativeAI:i}=J("@ai-sdk/google");return i({apiKey:r||process.env.GOOGLE_API_KEY})(s)}default:throw new exports.ProviderError(`Unsupported API provider: ${t}`,t)}}};});var go={};Tt(go,{registerApiProviders:()=>po});function po(n){he("api",(e,t)=>{let r=n?.apiKeys?.[e];return new exports.VercelProviderRuntime({provider:t,model:"",apiKey:r,maxSteps:n?.defaults?.maxSteps,temperature:n?.defaults?.temperature})});}var Fr=N(()=>{c();pe();Hr();});exports.AcpProtocolError=void 0;var qr=N(()=>{c();exports.AcpProtocolError=class extends Error{constructor(t,r,o){super(t);this.code=r;this.data=o;}code;data;name="AcpProtocolError"};});var ca,ua,mo,fo,pa;exports.AcpConnection=void 0;var Xt=N(()=>{c();qr();pe();ca=-32e3,ua=2e3,mo=3e4,fo=1e4,pa=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),o=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"});o.pid!==void 0&&this.options.onPid?.(o.pid),o.stderr.on("data",g=>{let h=g.toString();this.collectedStderr+=h,this.stderrBuffer+=h;let x=this.stderrBuffer.split(`
30
+ `);this.stderrBuffer=x.pop()??"";for(let v of x)v.trim()&&this.options.onStderr?.(v);}),this.proc=o;let s=new WritableStream({write:g=>new Promise((h,x)=>{o.stdin.write(g,v=>{v?x(v):h();});}),close:()=>{o.stdin.end();}}),i=new ReadableStream({start:g=>{o.stdout.on("data",h=>{g.enqueue(new Uint8Array(h));}),o.stdout.on("end",()=>{g.close();}),o.stdout.on("error",h=>{g.error(h);});}}),a=sdk.ndJsonStream(s,i),d=this,l=new sdk.ClientSideConnection(g=>({requestPermission:async h=>{if(d.options.configOptions?.allow_all!==void 0){let x=h.options;if(Array.isArray(x)&&x.length>0)return {outcome:{outcome:"selected",optionId:(x.find(w=>w.kind==="allow_once")??x.find(w=>w.kind?.startsWith("allow_"))??x[0]).optionId}}}return {outcome:{outcome:"cancelled"}}},sessionUpdate:async h=>{d.pendingUpdateCallback?.(h);}}),a);this.sdkConnection=l;let u=new Promise((g,h)=>{o.on("error",x=>{if(x.code==="ENOENT"){let w=t.command==="npx"&&t.args.length>0?`@agentclientprotocol/${t.args[0]}`:t.command;h(new exports.ProviderError(`ACP command "${t.command}" not found. Is the ACP adapter installed? Try: npm install -g ${w}`,"acp"));}else h(new exports.ProviderError(`ACP spawn error: ${x.message}`,"acp"));});}),p=this.doInitialize(l,e),f=new Promise((g,h)=>{setTimeout(()=>{h(new exports.AcpProtocolError(`ACP connect timeout after ${mo}ms. The ACP adapter may not be installed or may require interactive setup.`));},mo).unref();});await Promise.race([p,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((o,s)=>{setTimeout(()=>{s(new exports.AcpProtocolError(`ACP session/new timeout after ${fo}ms`));},fo).unref();});return Promise.race([t,r])}isAuthError(e){return typeof e=="object"&&e!==null&&"code"in e&&e.code===ca}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(o=>o.type==="env_var");if(r.length>0){let o=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: ${o.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,o){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=o??pa,d=false,l=s.prompt({sessionId:e,prompt:t}).finally(()=>{d=true;}),u=new Promise((f,g)=>{setTimeout(()=>{s.cancel({sessionId:e}).catch(()=>{}),g(new Se(`ACP prompt timeout after ${a}ms`,"acp"));},a).unref();}),p=new Promise((f,g)=>{let h=(_,k,S)=>{if(d)return;let P=k!=null?`signal=${k}`:`code=${String(_)}`;g(new exports.ProviderError(`ACP process terminated unexpectedly (${P}) [${S}]: ${this.collectedStderr.slice(-500)}`,"acp"));},x=(_,k)=>h(_,k,"exit"),v=(_,k)=>h(_,k,"close");i.once("exit",x),i.once("close",v);let w=()=>{i.off("exit",x),i.off("close",v);};l.then(w,w);});try{return await Promise.race([l,u,p])}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=o=>{if(t!==void 0&&process.platform!=="win32")try{process.kill(-t,o);}catch{}else try{e.kill(o);}catch{}};await new Promise(o=>{let s=()=>{clearTimeout(i),o();};e.once("close",s),e.once("error",s);try{r("SIGTERM");}catch{s();return}let i=setTimeout(()=>{r("SIGKILL");},ua);});}get isConnected(){return !this.disposed&&this.sdkConnection!==null&&this.proc!==null}};});function yo(n,e){if(n!=null&&typeof n=="object"){let t=n;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 ga;exports.AcpProviderRuntime=void 0;var Br=N(()=>{c();Ee();Xt();ga={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:o}=this.adapter.spawn;t?.onCommand?.(`${r} ${o.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}),l=await a.newSession(d);await this.applySessionOptions(a,l,t);let u=this.composePrompt(e,t),p=[],f=await a.prompt(l,u,g=>this.handleUpdate(g,t,p),t?.timeoutMs);return this.handleUsage(f,t),p.join("")}finally{await a.dispose().catch(()=>{});}}async applySessionOptions(e,t,r){if(r?.model&&r.model!=="default"&&!this.adapter.buildSpawnEnv){let o=this.adapter.buildEffortAction?.(r.effort??"",r.model);try{o?.type==="set_model"?await e.setModel(t,o.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 o=this.adapter.resolveMode?.(r.mode)??r.mode;if(o)try{await e.setMode(t,o);}catch(s){console.warn(`[acp] setMode(${o}) failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.effort){let o=this.adapter.buildEffortAction?.(r.effort,r.model);if(o&&o.type==="set_config_option")try{await e.setConfigOption(t,o.configId,o.value);}catch(s){console.warn(`[acp] setConfigOption(${o.configId}) effort failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.configOptions)for(let[o,s]of Object.entries(r.configOptions))try{await e.setConfigOption(t,o,s);}catch(i){console.warn(`[acp] setConfigOption(${o}) failed, retrying: ${i instanceof Error?i.message:String(i)}`);try{await new Promise(a=>setTimeout(a,500)),await e.setConfigOption(t,o,s);}catch(a){console.warn(`[acp] setConfigOption(${o}) 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(`
31
31
 
32
- `)}]}handleUpdate(e,t,r){let o=e.update;if(o.sessionUpdate==="agent_message_chunk"){let s=null;this.adapter.extractTextFromUpdate?s=this.adapter.extractTextFromUpdate(e):s=Ir(e),s!==null&&(r.push(s),t?.onOutput?.(s,"stdout"));}else if(o.sessionUpdate==="tool_call"){this.pushBlockBoundary(r);let s=new Date().toISOString(),i=o,a={title:i.title??"",kind:i.kind,rawInput:i.rawInput,rawOutput:i.rawOutput,locations:i.locations,_meta:i._meta},d=this.resolveToolCall(a),l={timestamp:s,type:"tool_use",toolUseId:i.toolCallId,toolName:d.toolName,toolInput:d.toolInput};t?.onTaskLog?.([l]);}else if(o.sessionUpdate==="tool_call_update"){let s=new Date().toISOString(),i=o;if(i.status==="completed"||i.status==="failed"){let d=this.extractResultPreview(i.rawOutput),l={timestamp:s,type:"tool_result",toolUseId:i.toolCallId,resultPreview:d,isError:i.status==="failed"};t?.onTaskLog?.([l]);}else if(i.rawInput!=null&&typeof i.rawInput=="object"&&Object.keys(i.rawInput).length>0){this.pushBlockBoundary(r);let d={title:i.title??"",kind:i.kind,rawInput:i.rawInput,rawOutput:i.rawOutput,locations:i.locations,_meta:i._meta},l=this.resolveToolCall(d),u={timestamp:s,type:"tool_use",toolUseId:i.toolCallId,toolName:l.toolName,toolInput:l.toolInput};t?.onTaskLog?.([u]);}}else o.sessionUpdate;}pushBlockBoundary(e){e.length===0||e[e.length-1].endsWith(`
32
+ `)}]}handleUpdate(e,t,r){let o=e.update;if(o.sessionUpdate==="agent_message_chunk"){let s=null;this.adapter.extractTextFromUpdate?s=this.adapter.extractTextFromUpdate(e):s=Or(e),s!==null&&(r.push(s),t?.onOutput?.(s,"stdout"));}else if(o.sessionUpdate==="tool_call"){this.pushBlockBoundary(r);let s=new Date().toISOString(),i=o,a={title:i.title??"",kind:i.kind,rawInput:i.rawInput,rawOutput:i.rawOutput,locations:i.locations,_meta:i._meta},d=this.resolveToolCall(a),l={timestamp:s,type:"tool_use",toolUseId:i.toolCallId,toolName:d.toolName,toolInput:d.toolInput};t?.onTaskLog?.([l]);}else if(o.sessionUpdate==="tool_call_update"){let s=new Date().toISOString(),i=o;if(i.status==="completed"||i.status==="failed"){let d=this.extractResultPreview(i.rawOutput),l={timestamp:s,type:"tool_result",toolUseId:i.toolCallId,resultPreview:d,isError:i.status==="failed"};t?.onTaskLog?.([l]);}else if(i.rawInput!=null&&typeof i.rawInput=="object"&&Object.keys(i.rawInput).length>0){this.pushBlockBoundary(r);let d={title:i.title??"",kind:i.kind,rawInput:i.rawInput,rawOutput:i.rawOutput,locations:i.locations,_meta:i._meta},l=this.resolveToolCall(d),u={timestamp:s,type:"tool_use",toolUseId:i.toolCallId,toolName:l.toolName,toolInput:l.toolInput};t?.onTaskLog?.([u]);}}else o.sessionUpdate;}pushBlockBoundary(e){e.length===0||e[e.length-1].endsWith(`
33
33
 
34
34
  `)||e.push(`
35
35
 
36
- `);}resolveToolCall(e){let t=e._meta;if(t?.claudeCode?.toolName)return {toolName:t.claudeCode.toolName,toolInput:fo(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=pa[e.kind??""]??e.title??"unknown",o=fo(e.rawInput,e.locations)??(e.title||void 0);return {toolName:r,toolInput:o}}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(`
37
- `)}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 o=this.adapter.extractUsage(e);if(o){t.onUsage(o);return}}let r=e.usage;r&&t.onUsage({inputTokens:r.inputTokens??0,outputTokens:r.outputTokens??0,cachedInputTokens:r.cachedReadTokens??0,costUsd:0});}};});var yo;exports.claudeAcpAdapter=void 0;var Jt=D(()=>{c();Re();yo=[{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(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},extractUsage(n){let e=n.usage;return e?{inputTokens:(e.inputTokens??0)+(e.cachedReadTokens??0),outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"bypassPermissions",buildEffortAction(n){return n?{type:"set_config_option",configId:"effort",value:n}:null},buildSpawnEnv(n){if(!(!n||n==="default"))return {ANTHROPIC_MODEL:n}},resolveMode(n){return {yolo:"bypassPermissions"}[n]??n},parseEvent:de};});exports.codexAcpAdapter=void 0;var Br=D(()=>{c();Re();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(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},extractUsage(n){let e=n.usage;return e?{inputTokens:(e.inputTokens??0)+(e.cachedReadTokens??0),outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"agent-full-access",buildEffortAction(n,e){if(!e)return null;let t=e.match(/^(.+?)\[([^\]]+)\]$/),r=t?t[1]:e,o=t?t[2]:void 0;return {type:"set_model",modelId:`${r}[${n||o||"medium"}]`}},resolveMode(n){return {yolo:"agent-full-access",default:"agent",plan:"read-only"}[n]??n},parseEvent:de};});var Qe;exports.copilotAcpAdapter=void 0;var Wr=D(()=>{c();Re();Qe="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(n){return {cwd:n.cwd?V.resolve(n.cwd):process.cwd(),mcpServers:[]}},yoloModeId:`${Qe}#autopilot`,buildEffortAction(n){return n?{type:"set_config_option",configId:"reasoning_effort",value:n}:null},resolveMode(n){return n.startsWith("https://")?n:{yolo:`${Qe}#autopilot`,default:`${Qe}#agent`,agent:`${Qe}#agent`,plan:`${Qe}#plan`,autopilot:`${Qe}#autopilot`}[n]??null},parseEvent:de};});exports.opencodeAcpAdapter=void 0;var zr=D(()=>{c();Re();exports.opencodeAcpAdapter={spawn:{command:"opencode",args:["acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"OpenCode"},buildSessionParams(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},yoloModeId:void 0,buildEffortAction(n){return null},resolveMode(n){let e={default:"build"};return n==="yolo"?null:e[n]??n},parseEvent:de};});exports.ACP_ADAPTERS=void 0;var er=D(()=>{c();Jt();Br();Wr();zr();Jt();Br();Wr();zr();exports.ACP_ADAPTERS={codex:exports.codexAcpAdapter,claude:exports.claudeAcpAdapter,opencode:exports.opencodeAcpAdapter,copilot:exports.copilotAcpAdapter};});var wo={};Ct(wo,{registerAcpProviders:()=>ho});function ho(n){if(n){ye("acp",n);return}ye("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=D(()=>{c();ue();qr();er();ue();});function ma(n){if(!n)return n;let e=n.trim().replace(/\/+$/,"");return e.toLowerCase().endsWith("/mcp")?e.slice(0,-4):e}exports.McpHttpTransport=void 0;var Vr=D(()=>{c();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=ma(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 o=await fetch(this.endpoint,{method:"POST",headers:this.headers,body:JSON.stringify(e),signal:t.signal});if(clearTimeout(r),!o.ok){let a=await o.text();throw new Error(`HTTP ${o.status}: ${o.statusText}${a?` - ${a}`:""}`)}let s=o.headers.get("content-type");if(s?.includes("application/json"))return await o.json();let i=await o.text();return {jsonrpc:"2.0",id:e.id,error:{code:-32600,message:`Unexpected response content-type: ${s}`,data:i}}}catch(o){throw clearTimeout(r),o instanceof Error&&o.name==="AbortError"?new Error(`MCP-HTTP request timeout after ${this.timeoutMs}ms to ${this.endpoint}`):o}}async close(){}};});exports.RemoteAgentManager=void 0;var Gr=D(()=>{c();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),o=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,o,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),o=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,o,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 o=this.transports.get(e);if(!o)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 o.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,o=typeof r=="string"?r:JSON.stringify(r??e,null,2);return {...t,content:[{type:"text",text:o}]}}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 ko={};Ct(ko,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>xo,resolveFileRemoteAgent:()=>va});function ka(n){let e=to.readFileSync(n,"utf-8"),t=jsYaml.load(e);return {agents:Array.isArray(t?.agents)?t.agents:void 0}}function _a(n){let e=Array.isArray(n.provider)?n.provider[0]:n.provider;return e||(Array.isArray(n.inline?.provider)?n.inline.provider[0]:n.inline?.provider)}function va(n,e=ka,t=to.existsSync){let r=n.location.replace("file://","");if(!t(r))throw new Error(`Remote config file not found: ${r}`);if(!n.external_agent_id)throw new Error(`external_agent_id is required for file:// remote provider "${n.id}"`);let s=e(r).agents?.find(d=>d.id===n.external_agent_id);if(!s)throw new Error(`Agent "${n.external_agent_id}" not found in ${r}`);let i=_a(s);if(!i)throw new Error(`Agent "${n.external_agent_id}" in ${r} has no provider configured`);if(i.startsWith("remote/"))throw new Error(`Chained remotes not allowed: ${n.id} \u2192 ${i}`);let a=V.resolve(V.dirname(r),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function xo(n,e=he){return (t,r)=>{let o=n.get(t);if(!o)throw new Error(`Remote provider "${t}" not found. Available: ${Array.from(n.keys()).join(", ")||"(none)"}`);if(o.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,o,e)}}function Aa(n,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??n}}exports.RemoteProviderRuntime=void 0;var Xr=D(()=>{c();ue();Gr();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,r=he){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let o=Aa(e,t);this.manager.loadConfig(this.agentId,o);}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(o=>o.text).join(`
36
+ `);}resolveToolCall(e){let t=e._meta;if(t?.claudeCode?.toolName)return {toolName:t.claudeCode.toolName,toolInput:yo(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=ga[e.kind??""]??e.title??"unknown",o=yo(e.rawInput,e.locations)??(e.title||void 0);return {toolName:r,toolInput:o}}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(`
37
+ `)}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 o=this.adapter.extractUsage(e);if(o){t.onUsage(o);return}}let r=e.usage;r&&t.onUsage({inputTokens:r.inputTokens??0,outputTokens:r.outputTokens??0,cachedInputTokens:r.cachedReadTokens??0,costUsd:0});}};});var ho;exports.claudeAcpAdapter=void 0;var Yt=N(()=>{c();Ee();ho=[{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(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},extractUsage(n){let e=n.usage;return e?{inputTokens:(e.inputTokens??0)+(e.cachedReadTokens??0),outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"bypassPermissions",buildEffortAction(n){return n?{type:"set_config_option",configId:"effort",value:n}:null},buildSpawnEnv(n){if(!(!n||n==="default"))return {ANTHROPIC_MODEL:n}},resolveMode(n){return {yolo:"bypassPermissions"}[n]??n},parseEvent:le};});exports.codexAcpAdapter=void 0;var Wr=N(()=>{c();Ee();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(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},extractUsage(n){let e=n.usage;return e?{inputTokens:(e.inputTokens??0)+(e.cachedReadTokens??0),outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"agent-full-access",buildEffortAction(n,e){if(!e)return null;let t=e.match(/^(.+?)\[([^\]]+)\]$/),r=t?t[1]:e,o=t?t[2]:void 0;return {type:"set_model",modelId:`${r}[${n||o||"medium"}]`}},resolveMode(n){return {yolo:"agent-full-access",default:"agent",plan:"read-only"}[n]??n},parseEvent:le};});var Ze;exports.copilotAcpAdapter=void 0;var zr=N(()=>{c();Ee();Ze="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(n){return {cwd:n.cwd?V.resolve(n.cwd):process.cwd(),mcpServers:[]}},yoloModeId:`${Ze}#autopilot`,buildEffortAction(n){return n?{type:"set_config_option",configId:"reasoning_effort",value:n}:null},resolveMode(n){return n.startsWith("https://")?n:{yolo:`${Ze}#autopilot`,default:`${Ze}#agent`,agent:`${Ze}#agent`,plan:`${Ze}#plan`,autopilot:`${Ze}#autopilot`}[n]??null},parseEvent:le};});exports.opencodeAcpAdapter=void 0;var Kr=N(()=>{c();Ee();exports.opencodeAcpAdapter={spawn:{command:"opencode",args:["acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"OpenCode"},buildSessionParams(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},yoloModeId:void 0,buildEffortAction(n){return null},resolveMode(n){let e={default:"build"};return n==="yolo"?null:e[n]??n},parseEvent:le};});exports.ACP_ADAPTERS=void 0;var tr=N(()=>{c();Yt();Wr();zr();Kr();Yt();Wr();zr();Kr();exports.ACP_ADAPTERS={codex:exports.codexAcpAdapter,claude:exports.claudeAcpAdapter,opencode:exports.opencodeAcpAdapter,copilot:exports.copilotAcpAdapter};});var xo={};Tt(xo,{registerAcpProviders:()=>wo});function wo(n){if(n){he("acp",n);return}he("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 Vr=N(()=>{c();pe();Br();tr();pe();});function fa(n){if(!n)return n;let e=n.trim().replace(/\/+$/,"");return e.toLowerCase().endsWith("/mcp")?e.slice(0,-4):e}exports.McpHttpTransport=void 0;var Gr=N(()=>{c();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=fa(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 o=await fetch(this.endpoint,{method:"POST",headers:this.headers,body:JSON.stringify(e),signal:t.signal});if(clearTimeout(r),!o.ok){let a=await o.text();throw new Error(`HTTP ${o.status}: ${o.statusText}${a?` - ${a}`:""}`)}let s=o.headers.get("content-type");if(s?.includes("application/json"))return await o.json();let i=await o.text();return {jsonrpc:"2.0",id:e.id,error:{code:-32600,message:`Unexpected response content-type: ${s}`,data:i}}}catch(o){throw clearTimeout(r),o instanceof Error&&o.name==="AbortError"?new Error(`MCP-HTTP request timeout after ${this.timeoutMs}ms to ${this.endpoint}`):o}}async close(){}};});exports.RemoteAgentManager=void 0;var Xr=N(()=>{c();Gr();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),o=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,o,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),o=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,o,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 o=this.transports.get(e);if(!o)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 o.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,o=typeof r=="string"?r:JSON.stringify(r??e,null,2);return {...t,content:[{type:"text",text:o}]}}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 _o={};Tt(_o,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>ko,resolveFileRemoteAgent:()=>Aa});function _a(n){let e=ro.readFileSync(n,"utf-8"),t=jsYaml.load(e);return {agents:Array.isArray(t?.agents)?t.agents:void 0}}function va(n){let e=Array.isArray(n.provider)?n.provider[0]:n.provider;return e||(Array.isArray(n.inline?.provider)?n.inline.provider[0]:n.inline?.provider)}function Aa(n,e=_a,t=ro.existsSync){let r=n.location.replace("file://","");if(!t(r))throw new Error(`Remote config file not found: ${r}`);if(!n.external_agent_id)throw new Error(`external_agent_id is required for file:// remote provider "${n.id}"`);let s=e(r).agents?.find(d=>d.id===n.external_agent_id);if(!s)throw new Error(`Agent "${n.external_agent_id}" not found in ${r}`);let i=va(s);if(!i)throw new Error(`Agent "${n.external_agent_id}" in ${r} has no provider configured`);if(i.startsWith("remote/"))throw new Error(`Chained remotes not allowed: ${n.id} \u2192 ${i}`);let a=V.resolve(V.dirname(r),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function ko(n,e=we){return (t,r)=>{let o=n.get(t);if(!o)throw new Error(`Remote provider "${t}" not found. Available: ${Array.from(n.keys()).join(", ")||"(none)"}`);if(o.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,o,e)}}function Ra(n,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??n}}exports.RemoteProviderRuntime=void 0;var Jr=N(()=>{c();pe();Xr();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,r=we){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let o=Ra(e,t);this.manager.loadConfig(this.agentId,o);}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(o=>o.text).join(`
38
38
  `)}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(o=>o.text).join(`
39
- `)}};});var Ro={};Ct(Ro,{PluginProviderRuntime:()=>exports.PluginProviderRuntime,createPluginProviderFactory:()=>Ao});function Ao(n){return (e,t)=>{let r=n.get(e);if(!r)throw new exports.ProviderError(`Plugin provider "${e}" not found. Available: ${Array.from(n.keys()).join(", ")||"(none)"}`,`plugin/${e}`);return new exports.PluginProviderRuntime(e,r)}}function _o(n,e,t,r){let o=n.map(s=>s.replace(/\{model\}/g,e));return r&&o.push(t),o}function Ea(n){if(!n||typeof n!="string")throw new Error("Plugin provider requires a cli_command")}function vo(n){if(!Array.isArray(n))throw new Error("CLI arguments must be an array");for(let e of n)if(typeof e!="string")throw new Error("Each CLI argument must be a string")}function Ca(n){for(let{pattern:e}of n)if(typeof e!="string")throw new Error("Error pattern must be a string")}function Ta(n){for(let[e,t]of Object.entries(n))if(typeof e!="string"||typeof t!="string")throw new Error("env entries must be string key/value pairs")}exports.PluginProviderRuntime=void 0;var Jr=D(()=>{c();ue();Mt();exports.PluginProviderRuntime=class{constructor(e,t){this.config=t;this.providerStr=`plugin/${e}`,Ea(t.cli_command),vo(t.query_args),vo(t.execute_args),t.error_patterns&&Ca(t.error_patterns),t.env&&Ta(t.env);}config;providerStr;async query(e,t){let r=t?.model??this.config.default_model??"default",o=_o(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} ${o.join(" ")}`);let i=this.config.timeout?.query??6e5;return this.runProcess(o,t,s,i)}async execute(e,t){let r=t?.model??this.config.default_model??"default",o=_o(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} ${o.join(" ")}`);let i=this.config.timeout?.execute??6e5;return this.runProcess(o,t,s,i)}runProcess(e,t,r,o){return new Promise((s,i)=>{let a={...process.env,...this.config.env??{}},d=tt({command:this.config.cli_command,allowShellFallback:true}),l=rt(d,e),u=child_process.spawn(l.command,l.argv,{env:a,shell:l.shell??false,stdio:["pipe","pipe","pipe"],windowsHide:l.windowsHide});r!==void 0&&u.stdin.write(r),u.stdin.end(),u.pid!==void 0&&t?.onPid?.(u.pid);let p="",y="",g="",h="";u.stdout.on("data",v=>{let w=v.toString();p+=w,g+=w;let _=g.split(`
40
- `);g=_.pop()??"";for(let x of _)x.trim()&&t?.onOutput?.(x,"stdout");}),u.stderr.on("data",v=>{let w=v.toString();y+=w,h+=w;let _=h.split(`
41
- `);h=_.pop()??"";for(let x of _)x.trim()&&t?.onOutput?.(x,"stderr");});let k=setTimeout(()=>{u.kill("SIGTERM"),i(new exports.ProviderError(`Plugin provider "${this.providerStr}" timed out after ${o}ms`,this.providerStr));},o);u.on("error",v=>{if(clearTimeout(k),v.code==="ENOENT"){let w=this.config.not_installed_message??`CLI command "${this.config.cli_command}" not found. Is ${this.config.id} installed?`;i(new exports.ProviderError(w,this.providerStr));}else i(new exports.ProviderError(`Spawn error: ${v.message}`,this.providerStr));}),u.on("close",v=>{clearTimeout(k),g.trim()&&t?.onOutput?.(g,"stdout"),h.trim()&&t?.onOutput?.(h,"stderr");let w=v??0;if(t?.onExitCode?.(w),this.config.error_patterns){let _=y||p;for(let x of this.config.error_patterns)if(_.includes(x.pattern)){i(new exports.ProviderError(x.message,this.providerStr));return}}if(v!==0){i(new exports.ProviderError(`Process exited with code ${v}: ${y.slice(0,500)}`,this.providerStr));return}s(p.trim());});})}};});c();c();c();function Yo(n){let e=o=>o.replace(/[.+^${}()|[\]\\]/g,"\\$&"),r=n.split("/").map(o=>o==="**"?".*":o.split("*").map(e).join("[^/]*"));return new RegExp(`^${r.join("\\/")}$`)}function ce(n,e){try{return Yo(e).test(n)}catch{return false}}c();c();var Qo=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()),hn=zod.z.object({include:zod.z.array(zod.z.string()).optional()}).optional(),Zo=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:Qo.optional(),skills:hn}).catchall(zod.z.unknown()),wn=zod.z.object({agents:zod.z.array(Zo).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 Te=class extends Error{constructor(t,r){super(t);this.cause=r;this.name="ConfigLoadError";}cause};function Tt(n){if(!n||typeof n!="string"||!n.trim())throw new Te("YAML content must be a non-empty string");let e;try{e=jsYaml.load(n);}catch(o){throw new Te(`YAML parse error: ${o.message}`,o)}let t=rs(e),r=wn.safeParse(t);if(!r.success)throw new Te(`Config validation error: ${r.error.message}`);return r.data}function Pt(n){let e;try{e=to.readFileSync(n,"utf-8");}catch(t){throw new Te(`Cannot read file: ${n}`,t)}return Tt(e)}function rs(n){if(!n||typeof n!="object")return {agents:[]};let e=n,t;if(e.agents&&typeof e.agents=="object"&&!Array.isArray(e.agents)){let o=e.agents;t=Object.entries(o).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(o=>{if(o.provider===void 0&&o.inline&&typeof o.inline=="object"){let s=o.inline;if(s.provider!==void 0)return {...o,provider:s.provider}}return o});return {...e,agents:r}}c();var Pe=V.join("templates","agents");function ss(){try{let e=(typeof J=="function"?J:module$1.createRequire(typeof __filename<"u"?__filename:process.cwd()+"/")).resolve("@crewx/sdk/package.json");return V.dirname(e)}catch{return null}}function We(n){if(n&&to.existsSync(n))return n;let e=process.env.CREWX_SDK_TEMPLATES_PATH;if(e&&to.existsSync(e))return e;let t=ss();if(t){let o=V.join(t,Pe);if(to.existsSync(o))return o}let r=[V.join(__dirname,"..",Pe),V.join(__dirname,"..","..",Pe),V.join(__dirname,"..","..","..",Pe),V.join(process.cwd(),"packages","sdk",Pe),V.join(process.cwd(),Pe)];for(let o of r)if(to.existsSync(o))return o;throw new Error(`[@crewx/sdk] Templates directory not found.
42
- `+(t?` package anchor: ${V.join(t,Pe)}
39
+ `)}};});var Eo={};Tt(Eo,{PluginProviderRuntime:()=>exports.PluginProviderRuntime,createPluginProviderFactory:()=>Ro});function Ro(n){return (e,t)=>{let r=n.get(e);if(!r)throw new exports.ProviderError(`Plugin provider "${e}" not found. Available: ${Array.from(n.keys()).join(", ")||"(none)"}`,`plugin/${e}`);return new exports.PluginProviderRuntime(e,r)}}function vo(n,e,t,r){let o=n.map(s=>s.replace(/\{model\}/g,e));return r&&o.push(t),o}function Ca(n){if(!n||typeof n!="string")throw new Error("Plugin provider requires a cli_command")}function Ao(n){if(!Array.isArray(n))throw new Error("CLI arguments must be an array");for(let e of n)if(typeof e!="string")throw new Error("Each CLI argument must be a string")}function Ta(n){for(let{pattern:e}of n)if(typeof e!="string")throw new Error("Error pattern must be a string")}function Pa(n){for(let[e,t]of Object.entries(n))if(typeof e!="string"||typeof t!="string")throw new Error("env entries must be string key/value pairs")}exports.PluginProviderRuntime=void 0;var Yr=N(()=>{c();pe();Nt();exports.PluginProviderRuntime=class{constructor(e,t){this.config=t;this.providerStr=`plugin/${e}`,Ca(t.cli_command),Ao(t.query_args),Ao(t.execute_args),t.error_patterns&&Ta(t.error_patterns),t.env&&Pa(t.env);}config;providerStr;async query(e,t){let r=t?.model??this.config.default_model??"default",o=vo(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} ${o.join(" ")}`);let i=this.config.timeout?.query??6e5;return this.runProcess(o,t,s,i)}async execute(e,t){let r=t?.model??this.config.default_model??"default",o=vo(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} ${o.join(" ")}`);let i=this.config.timeout?.execute??6e5;return this.runProcess(o,t,s,i)}runProcess(e,t,r,o){return new Promise((s,i)=>{let a={...process.env,...this.config.env??{}},d=rt({command:this.config.cli_command,allowShellFallback:true}),l=nt(d,e),u=child_process.spawn(l.command,l.argv,{env:a,shell:l.shell??false,stdio:["pipe","pipe","pipe"],windowsHide:l.windowsHide});r!==void 0&&u.stdin.write(r),u.stdin.end(),u.pid!==void 0&&t?.onPid?.(u.pid);let p="",f="",g="",h="";u.stdout.on("data",v=>{let w=v.toString();p+=w,g+=w;let _=g.split(`
40
+ `);g=_.pop()??"";for(let k of _)k.trim()&&t?.onOutput?.(k,"stdout");}),u.stderr.on("data",v=>{let w=v.toString();f+=w,h+=w;let _=h.split(`
41
+ `);h=_.pop()??"";for(let k of _)k.trim()&&t?.onOutput?.(k,"stderr");});let x=setTimeout(()=>{u.kill("SIGTERM"),i(new exports.ProviderError(`Plugin provider "${this.providerStr}" timed out after ${o}ms`,this.providerStr));},o);u.on("error",v=>{if(clearTimeout(x),v.code==="ENOENT"){let w=this.config.not_installed_message??`CLI command "${this.config.cli_command}" not found. Is ${this.config.id} installed?`;i(new exports.ProviderError(w,this.providerStr));}else i(new exports.ProviderError(`Spawn error: ${v.message}`,this.providerStr));}),u.on("close",v=>{clearTimeout(x),g.trim()&&t?.onOutput?.(g,"stdout"),h.trim()&&t?.onOutput?.(h,"stderr");let w=v??0;if(t?.onExitCode?.(w),this.config.error_patterns){let _=f||p;for(let k of this.config.error_patterns)if(_.includes(k.pattern)){i(new exports.ProviderError(k.message,this.providerStr));return}}if(v!==0){i(new exports.ProviderError(`Process exited with code ${v}: ${f.slice(0,500)}`,this.providerStr));return}s(p.trim());});})}};});c();c();c();function Qo(n){let e=o=>o.replace(/[.+^${}()|[\]\\]/g,"\\$&"),r=n.split("/").map(o=>o==="**"?".*":o.split("*").map(e).join("[^/]*"));return new RegExp(`^${r.join("\\/")}$`)}function ue(n,e){try{return Qo(e).test(n)}catch{return false}}c();c();var Zo=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()),wn=zod.z.object({include:zod.z.array(zod.z.string()).optional()}).optional(),es=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:Zo.optional(),skills:wn}).catchall(zod.z.unknown()),xn=zod.z.object({agents:zod.z.array(es).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 Pe=class extends Error{constructor(t,r){super(t);this.cause=r;this.name="ConfigLoadError";}cause};function Pt(n){if(!n||typeof n!="string"||!n.trim())throw new Pe("YAML content must be a non-empty string");let e;try{e=jsYaml.load(n);}catch(o){throw new Pe(`YAML parse error: ${o.message}`,o)}let t=ns(e),r=xn.safeParse(t);if(!r.success)throw new Pe(`Config validation error: ${r.error.message}`);return r.data}function bt(n){let e;try{e=ro.readFileSync(n,"utf-8");}catch(t){throw new Pe(`Cannot read file: ${n}`,t)}return Pt(e)}function ns(n){if(!n||typeof n!="object")return {agents:[]};let e=n,t;if(e.agents&&typeof e.agents=="object"&&!Array.isArray(e.agents)){let o=e.agents;t=Object.entries(o).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(o=>{if(o.provider===void 0&&o.inline&&typeof o.inline=="object"){let s=o.inline;if(s.provider!==void 0)return {...o,provider:s.provider}}return o});return {...e,agents:r}}c();var be=V.join("templates","agents");function is(){try{let e=(typeof J=="function"?J:module$1.createRequire(typeof __filename<"u"?__filename:process.cwd()+"/")).resolve("@crewx/sdk/package.json");return V.dirname(e)}catch{return null}}function ze(n){if(n&&ro.existsSync(n))return n;let e=process.env.CREWX_SDK_TEMPLATES_PATH;if(e&&ro.existsSync(e))return e;let t=is();if(t){let o=V.join(t,be);if(ro.existsSync(o))return o}let r=[V.join(__dirname,"..",be),V.join(__dirname,"..","..",be),V.join(__dirname,"..","..","..",be),V.join(process.cwd(),"packages","sdk",be),V.join(process.cwd(),be)];for(let o of r)if(ro.existsSync(o))return o;throw new Error(`[@crewx/sdk] Templates directory not found.
42
+ `+(t?` package anchor: ${V.join(t,be)}
43
43
  `:` package anchor: (unresolved)
44
44
  `)+r.map(o=>` candidate: ${o}`).join(`
45
45
  `)+`
46
- Set CREWX_SDK_TEMPLATES_PATH or pass options.templatesPath.`)}function sr(){let n=We();return {yamlPath:V.join(n,"default.yaml"),dir:n}}c();var me=class extends Error{constructor(e,t){let r=t.length>0?` Available: ${t.join(", ")}`:"";super(`Agent not found: "${e}".${r}`),this.name="AgentNotFoundError";}},is={claude:{id:"claude",provider:"cli/claude"},copilot:{id:"copilot",provider:"cli/copilot"},codex:{id:"codex",provider:"cli/codex"}};function St(n,e){let t=n.startsWith("@")?n.slice(1):n,r=e.find(s=>s.id===t);if(r)return r;let o=is[t];if(o)return o;throw new me(n,e.map(s=>s.id))}ue();c();function In(n,e){if(n===void 0||n==="")return e;let t=parseInt(n,10);return Number.isNaN(t)?e:t}function On(n=process.env){return {queryMs:In(n.CREWX_TIMEOUT_QUERY,288e5),executeMs:In(n.CREWX_TIMEOUT_EXECUTE,288e5)}}c();var it={"claude-opus-4-8":{input:5,cachedInput:.5,output:25},"claude-opus-4-7":{input:5,cachedInput:.5,output:25},"claude-opus-4-6":{input:5,cachedInput:.5,output:25},"claude-sonnet-4-6":{input:3,cachedInput:.3,output:15},"claude-haiku-4-5":{input:1,cachedInput:.1,output:5},"gpt-5.5":{input:5,cachedInput:1.25,output:15},"gpt-5.4":{input:2.5,cachedInput:.625,output:10},"gpt-5.3-codex":{input:1.5,cachedInput:.375,output:6},"gpt-5-mini":{input:.4,cachedInput:.1,output:1.6},"gpt-4.1":{input:2,cachedInput:.5,output:8},"gpt-4o":{input:2.5,cachedInput:1.25,output:10},"glm-5.1":{input:.5,cachedInput:.05,output:2},copilot:{input:0,cachedInput:0,output:0}},bs={opus:"claude-opus-4-8",sonnet:"claude-sonnet-4-6",haiku:"claude-haiku-4-5","codex-mini":"gpt-5.3-codex",codex:"gpt-5.3-codex"},hr={input:0,cachedInput:0,output:0};function Ss(n){let e=n.toLowerCase().trim();e=e.replace(/\[[^\]]*\]$/g,"");let t=e.lastIndexOf("/");return t>=0&&(e=e.slice(t+1)),e=e.replace(/-\d{8}$/,""),e}function Is(n){if(!n)return hr;let e=Ss(n),t=bs[e];if(t)return it[t]??hr;if(it[e])return it[e];for(let r of Object.keys(it))if(e.includes(r))return it[r];return console.warn(`[pricing] Unknown model: ${n}, cost_usd=0`),hr}function Os(n,e,t,r=0){let o=Is(t),s=Math.min(r,n),a=(n-s)*o.input/1e6,d=s*o.cachedInput/1e6,l=e*o.output/1e6;return a+d+l}function wr(n,e,t,r,o){return n&&n>0?n:!e&&!t?0:Os(e??0,t??0,o,r??0)}c();c();var Ns=[/^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],Ds=/[;|&`$(){}!><\n\r]/,Ls=2,$s=["*","**","*:*","* *","**/*"];function Us(){let n={};for(let[e,t]of Object.entries(process.env))t!==void 0&&(Ns.some(r=>r.test(e))||(n[e]=t));return n}function js(n){if(Ds.test(n))throw new Error(`exec blocked: shell metacharacter detected in "${n}"`)}function Hs(n){return /^npx\s+@crewx\/[\w-]+/.test(n)}function Fs(n){if($s.includes(n.trim()))throw new Error(`exec config error: overly broad pattern "${n}" is not allowed`);if(!/^[\w./@-]/.test(n))throw new Error("exec config error: pattern must start with a command name")}function qs(n,e){let t=e.allow??[],r=e.deny??[];for(let o of [...t,...r])Fs(o);return r.some(o=>ce(n,o))?false:Hs(n)?true:t.some(o=>ce(n,o))}var Mn=false;function Bs(n){Mn=n;}function at(n){if(!Mn)return;let e=JSON.stringify({span:"template_exec",...n,timestamp:new Date().toISOString()});console.error(e);}function Ws(n){let e=[],t="",r=false,o=false;for(let s=0;s<n.length;s++){let i=n[s];i==="'"&&!o?r=!r:i==='"'&&!r?o=!o:i===" "&&!r&&!o?t.length>0&&(e.push(t),t=""):t+=i;}return t.length>0&&e.push(t),e}function Nn(n,e){let t=Date.now(),r=parseInt(process.env.CREWX_EXEC_DEPTH??"0",10);if(isNaN(r)||r>=Ls)return at({command:n,status:"denied",reason:"invalid or max recursion depth"}),"(exec blocked: max recursion depth reached)";try{js(n);}catch{return at({command:n,status:"denied",reason:"shell metacharacter detected"}),`(exec blocked: shell metacharacter detected in "${n}")`}if(!qs(n,e))return at({command:n,status:"denied",reason:"not in allow list"}),`(exec blocked: ${n})`;try{let o=Ws(n),[s,...i]=o;if(!s)return `(exec failed: ${n})`;let a=Us(),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"]}),l=Date.now()-t;return at({command:n,status:"allowed",allowed_by:"policy",duration_ms:l}),`<exec-output cmd="${n}">
46
+ Set CREWX_SDK_TEMPLATES_PATH or pass options.templatesPath.`)}function ir(){let n=ze();return {yamlPath:V.join(n,"default.yaml"),dir:n}}c();var fe=class extends Error{constructor(e,t){let r=t.length>0?` Available: ${t.join(", ")}`:"";super(`Agent not found: "${e}".${r}`),this.name="AgentNotFoundError";}},as={claude:{id:"claude",provider:"cli/claude"},copilot:{id:"copilot",provider:"cli/copilot"},codex:{id:"codex",provider:"cli/codex"}};function It(n,e){let t=n.startsWith("@")?n.slice(1):n,r=e.find(s=>s.id===t);if(r)return r;let o=as[t];if(o)return o;throw new fe(n,e.map(s=>s.id))}pe();c();function On(n,e){if(n===void 0||n==="")return e;let t=parseInt(n,10);return Number.isNaN(t)?e:t}function Mn(n=process.env){return {queryMs:On(n.CREWX_TIMEOUT_QUERY,288e5),executeMs:On(n.CREWX_TIMEOUT_EXECUTE,288e5)}}c();var at={"claude-opus-4-8":{input:5,cachedInput:.5,output:25},"claude-opus-4-7":{input:5,cachedInput:.5,output:25},"claude-opus-4-6":{input:5,cachedInput:.5,output:25},"claude-sonnet-4-6":{input:3,cachedInput:.3,output:15},"claude-haiku-4-5":{input:1,cachedInput:.1,output:5},"gpt-5.5":{input:5,cachedInput:1.25,output:15},"gpt-5.4":{input:2.5,cachedInput:.625,output:10},"gpt-5.3-codex":{input:1.5,cachedInput:.375,output:6},"gpt-5-mini":{input:.4,cachedInput:.1,output:1.6},"gpt-4.1":{input:2,cachedInput:.5,output:8},"gpt-4o":{input:2.5,cachedInput:1.25,output:10},"glm-5.1":{input:.5,cachedInput:.05,output:2},copilot:{input:0,cachedInput:0,output:0}},Ss={opus:"claude-opus-4-8",sonnet:"claude-sonnet-4-6",haiku:"claude-haiku-4-5","codex-mini":"gpt-5.3-codex",codex:"gpt-5.3-codex"},wr={input:0,cachedInput:0,output:0};function Is(n){let e=n.toLowerCase().trim();e=e.replace(/\[[^\]]*\]$/g,"");let t=e.lastIndexOf("/");return t>=0&&(e=e.slice(t+1)),e=e.replace(/-\d{8}$/,""),e}function Os(n){if(!n)return wr;let e=Is(n),t=Ss[e];if(t)return at[t]??wr;if(at[e])return at[e];for(let r of Object.keys(at))if(e.includes(r))return at[r];return console.warn(`[pricing] Unknown model: ${n}, cost_usd=0`),wr}function Ms(n,e,t,r=0){let o=Os(t),s=Math.min(r,n),a=(n-s)*o.input/1e6,d=s*o.cachedInput/1e6,l=e*o.output/1e6;return a+d+l}function xr(n,e,t,r,o){return n&&n>0?n:!e&&!t?0:Ms(e??0,t??0,o,r??0)}c();c();var Ds=[/^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],Ls=/[;|&`$(){}!><\n\r]/,$s=2,Us=["*","**","*:*","* *","**/*"];function js(){let n={};for(let[e,t]of Object.entries(process.env))t!==void 0&&(Ds.some(r=>r.test(e))||(n[e]=t));return n}function Hs(n){if(Ls.test(n))throw new Error(`exec blocked: shell metacharacter detected in "${n}"`)}function Fs(n){return /^npx\s+@crewx\/[\w-]+/.test(n)}function qs(n){if(Us.includes(n.trim()))throw new Error(`exec config error: overly broad pattern "${n}" is not allowed`);if(!/^[\w./@-]/.test(n))throw new Error("exec config error: pattern must start with a command name")}function Bs(n,e){let t=e.allow??[],r=e.deny??[];for(let o of [...t,...r])qs(o);return r.some(o=>ue(n,o))?false:Fs(n)?true:t.some(o=>ue(n,o))}var Nn=false;function Ws(n){Nn=n;}function dt(n){if(!Nn)return;let e=JSON.stringify({span:"template_exec",...n,timestamp:new Date().toISOString()});console.error(e);}function zs(n){let e=[],t="",r=false,o=false;for(let s=0;s<n.length;s++){let i=n[s];i==="'"&&!o?r=!r:i==='"'&&!r?o=!o:i===" "&&!r&&!o?t.length>0&&(e.push(t),t=""):t+=i;}return t.length>0&&e.push(t),e}function Dn(n,e){let t=Date.now(),r=parseInt(process.env.CREWX_EXEC_DEPTH??"0",10);if(isNaN(r)||r>=$s)return dt({command:n,status:"denied",reason:"invalid or max recursion depth"}),"(exec blocked: max recursion depth reached)";try{Hs(n);}catch{return dt({command:n,status:"denied",reason:"shell metacharacter detected"}),`(exec blocked: shell metacharacter detected in "${n}")`}if(!Bs(n,e))return dt({command:n,status:"denied",reason:"not in allow list"}),`(exec blocked: ${n})`;try{let o=zs(n),[s,...i]=o;if(!s)return `(exec failed: ${n})`;let a=js(),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"]}),l=Date.now()-t;return dt({command:n,status:"allowed",allowed_by:"policy",duration_ms:l}),`<exec-output cmd="${n}">
47
47
  ${d.trim()}
48
- </exec-output>`}catch{return at({command:n,status:"error",reason:"execution failed"}),`(exec failed: ${n})`}}c();function Dn(n){return n==null?"":String(n)}c();function Ln(n,e){return `\`\`\`${e?.hash?.lang??""}
48
+ </exec-output>`}catch{return dt({command:n,status:"error",reason:"execution failed"}),`(exec failed: ${n})`}}c();function Ln(n){return n==null?"":String(n)}c();function $n(n,e){return `\`\`\`${e?.hash?.lang??""}
49
49
  ${n??""}
50
- \`\`\``}c();function xr(n,e){if(!n)return "";if(n.length<=e)return n;let t=n.length-e;return `${n.substring(0,e)} (...+${t} chars)`}function kr(n){return Array.isArray(n)||typeof n=="string"?n.length:0}function _r(n){return typeof n!="string"?"":n.replace(/\{\{/g,"&#123;&#123;").replace(/\}\}/g,"&#125;&#125;")}var $n=["B","KB","MB","GB"];function vr(n){if(n===0)return "0 B";let e=Math.min(Math.floor(Math.log(n)/Math.log(1024)),$n.length-1);return `${Math.round(n/Math.pow(1024,e)*100)/100} ${$n[e]}`}function Ar(n){if(!n)return "";try{let e=n instanceof Date?n:new Date(n);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 dt=class{hbs;execPolicy;execEnabled;constructor(e={}){this.hbs=pe__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(o){return typeof o!="string"?"":r?new e.SafeString(Nn(o,t)):"(exec disabled)"}),e.registerHelper("include",function(o){return new e.SafeString(Dn(o))}),e.registerHelper("fenced_code",function(o,s){return new e.SafeString(Ln(o,s))}),e.registerHelper("eq",function(o,s){return o===s}),e.registerHelper("ne",function(o,s){return o!==s}),e.registerHelper("and",function(o,s){return o&&s}),e.registerHelper("or",function(o,s){return o||s}),e.registerHelper("not",function(o){return !o}),e.registerHelper("contains",function(o,s){return Array.isArray(o)&&o.includes(s)}),e.registerHelper("json",function(o){return JSON.stringify(o,null,2)}),e.registerHelper("truncate",function(o,s){return xr(o,s)}),e.registerHelper("length",function(o){return kr(o)}),e.registerHelper("escapeHandlebars",function(o){return new e.SafeString(_r(o))}),e.registerHelper("formatFileSize",function(o){return vr(o)}),e.registerHelper("formatTimestamp",function(o){return Ar(o)});}async render(e,t={}){return this.hbs.compile(e,{noEscape:true})(t)}};c();c();var jt=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?V.resolve(e[0]):V.resolve(V.join(...e))}isAbsolute(e){return V.isAbsolute(e)}async readdir(e){try{return await promises.readdir(e)}catch{return []}}},Se=new jt;var Ie=class{docs=new Map;fs;constructor(e){this.fs=e??Se;}async load(e,t){if(e)for(let[r,o]of Object.entries(e)){let s=o;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 o of t.content.split(`
50
+ \`\`\``}c();function kr(n,e){if(!n)return "";if(n.length<=e)return n;let t=n.length-e;return `${n.substring(0,e)} (...+${t} chars)`}function _r(n){return Array.isArray(n)||typeof n=="string"?n.length:0}function vr(n){return typeof n!="string"?"":n.replace(/\{\{/g,"&#123;&#123;").replace(/\}\}/g,"&#125;&#125;")}var Un=["B","KB","MB","GB"];function Ar(n){if(n===0)return "0 B";let e=Math.min(Math.floor(Math.log(n)/Math.log(1024)),Un.length-1);return `${Math.round(n/Math.pow(1024,e)*100)/100} ${Un[e]}`}function Rr(n){if(!n)return "";try{let e=n instanceof Date?n:new Date(n);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 lt=class{hbs;execPolicy;execEnabled;constructor(e={}){this.hbs=ge__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(o){return typeof o!="string"?"":r?new e.SafeString(Dn(o,t)):"(exec disabled)"}),e.registerHelper("include",function(o){return new e.SafeString(Ln(o))}),e.registerHelper("fenced_code",function(o,s){return new e.SafeString($n(o,s))}),e.registerHelper("eq",function(o,s){return o===s}),e.registerHelper("ne",function(o,s){return o!==s}),e.registerHelper("and",function(o,s){return o&&s}),e.registerHelper("or",function(o,s){return o||s}),e.registerHelper("not",function(o){return !o}),e.registerHelper("contains",function(o,s){return Array.isArray(o)&&o.includes(s)}),e.registerHelper("json",function(o){return JSON.stringify(o,null,2)}),e.registerHelper("truncate",function(o,s){return kr(o,s)}),e.registerHelper("length",function(o){return _r(o)}),e.registerHelper("escapeHandlebars",function(o){return new e.SafeString(vr(o))}),e.registerHelper("formatFileSize",function(o){return Ar(o)}),e.registerHelper("formatTimestamp",function(o){return Rr(o)});}async render(e,t={}){return this.hbs.compile(e,{noEscape:true})(t)}};c();c();var Ht=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?V.resolve(e[0]):V.resolve(V.join(...e))}isAbsolute(e){return V.isAbsolute(e)}async readdir(e){try{return await promises.readdir(e)}catch{return []}}},Ie=new Ht;var Oe=class{docs=new Map;fs;constructor(e){this.fs=e??Ie;}async load(e,t){if(e)for(let[r,o]of Object.entries(e)){let s=o;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 o of t.content.split(`
51
51
  `)){let s=/^(#{1,6})\s+(.+)$/.exec(o.trim());s&&r.push({depth:s[1].length,text:s[2].trim()});}if(r.length!==0)return r.map(({depth:o,text:s})=>`${" ".repeat(o-1)}- ${s}`).join(`
52
- `)}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)??"",o=await this.getToc(t),s=this.getPath(t);e[t]={content:r,toc:o,...s?{path:s}:{}};}return e}async loadFromFile(e,t,r){try{let o=this.resolve(t,r),s=await this.fs.readFile(o);this.docs.set(e,{content:s,path:o});}catch(o){let s=o instanceof Error?o.message:String(o);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)}};c();c();var Q=class extends Error{constructor(t,r,o){super(t);this.layoutId=r;this.cause=o;this.name="LayoutLoadError";}layoutId;cause},we=class extends Error{constructor(t,r=[],o){super(t);this.errors=r;this.cause=o;this.name="PropsValidationError";}errors;cause};var ei={validationMode:"lenient",fallbackLayoutId:"crewx/default"},lt=class{layouts=new Map;options;constructor(e){this.options={...ei,...e,templatesPath:e?.templatesPath??We()},this.loadAllLayouts();}load(e,t){let r=this.layouts.get(e);if(!r){let o=this.normalizeLayoutId(e);r=this.layouts.get(o);}if(!r&&(console.warn(`Layout not found: ${e}, falling back to ${this.options.fallbackLayoutId}`),r=this.layouts.get(this.options.fallbackLayoutId),!r))throw new Q(`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 Q("Layout ID must be a non-empty string",e);let r=typeof t=="string"?{template:t}:t,o=typeof r.template=="string"?r.template:"";if(!o||o.trim().length===0)throw new Q(`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:o,propsSchema:this.parsePropsSchema(s),defaultProps:{...i,...a}},l=this.layouts.get(e),u=l?.template===o&&JSON.stringify(l?.defaultProps??{})===JSON.stringify(d.defaultProps??{})&&JSON.stringify(l?.propsSchema??{})===JSON.stringify(d.propsSchema??{});this.layouts.set(e,d),process.env.CREWX_VERBOSE==="1"&&(l?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(o){console.warn(`Failed to register custom layout ${t}:`,o instanceof Error?o.message:o);}}loadAllLayouts(){let e=this.options.templatesPath;if(!to.existsSync(e))throw new Q(`Templates directory not found: ${e}`,void 0,new Error(`Directory does not exist: ${e}`));try{let t=to.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 o=r.replace(/\.(yaml|yml)$/,""),s=V__namespace.join(e,r);try{let i=this.loadLayoutFile(s,o),a=`crewx/${o}`;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 Q(`Failed to read layouts directory: ${e}`,void 0,t instanceof Error?t:new Error(String(t)))}}loadLayoutFile(e,t){try{let r=to.readFileSync(e,"utf-8");if(!r||r.trim().length===0)throw console.warn(`Empty YAML file: ${e}, will use fallback`),new Q(`Empty YAML file: ${e}`,t,new Error("File content is empty"));let o=jsYaml.load(r);if(!o||typeof o!="object")throw console.warn(`Invalid YAML content in ${e} (parsed as ${typeof o}), will use fallback`),new Q(`Invalid or empty YAML in ${e}`,t,new Error("YAML parsing returned null/undefined or non-object"));if(o.layouts&&typeof o.layouts=="object"){let s=this.resolveLayoutEntry(o.layouts,t);if(!s||s.template.trim().length===0)throw console.warn(`Empty or missing layout template in ${e} for ${t}`),new Q(`Layout template not found or empty in layouts map: ${t}`,t);let i=s.propsSchema||o.propsSchema||{};return {id:`crewx/${t}`,version:o.version||"1.0.0",description:o.description||`CrewX ${t} layout`,template:s.template,propsSchema:this.parsePropsSchema(i),defaultProps:this.extractDefaultProps(i)}}else {if(!o.template||typeof o.template=="string"&&o.template.trim().length===0)throw console.warn(`Empty or missing template field in ${e}`),new Q(`Layout template is missing or empty in ${e}`,t);return {id:o.id||`crewx/${t}`,version:o.version||"1.0.0",description:o.description||"",template:o.template,propsSchema:this.parsePropsSchema(o.propsSchema||{}),defaultProps:this.extractDefaultProps(o.propsSchema||{})}}}catch(r){throw new Q(`Failed to load layout file: ${e}`,t,r instanceof Error?r:new Error(String(r)))}}parsePropsSchema(e){let t={};for(let[r,o]of Object.entries(e))typeof o=="object"&&o!==null&&(t[r]=o);return t}extractDefaultProps(e){let t={};for(let[r,o]of Object.entries(e))o&&typeof o=="object"&&("defaultValue"in o?t[r]=o.defaultValue:"default"in o&&(t[r]=o.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 o=t.split("/"),s=o[o.length-1];s&&r.add(s);}else r.add(`crewx/${t}`);r.add("default");for(let o of r){let s=e[o];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 o of Object.values(e)){if(typeof o=="string"&&o.trim().length>0)return {template:o};let s=o;if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}}};c();c();c();function Oe(n){return String(Math.floor(Math.abs(n))).padStart(2,"0")}function ct(n){if(!(n instanceof Date)||Number.isNaN(n.getTime()))return "";let e=-n.getTimezoneOffset(),t=e>=0?"+":"-";return `${n.getFullYear()}-${Oe(n.getMonth()+1)}-${Oe(n.getDate())}T${Oe(n.getHours())}:${Oe(n.getMinutes())}:${Oe(n.getSeconds())}${t}${Oe(e/60)}:${Oe(e%60)}`}function ti(n){return n.map(e=>{let t=typeof e?.timestamp=="number"?e.timestamp:null;return t===null?e:{...e,created_at:ct(new Date(t))}})}function ri(n){let e=[];for(let t of n)t?.isAssistant&&t?.metadata?.agent_id?e.push(String(t.metadata.agent_id)):!t?.isAssistant&&t?.metadata?.caller_agent_id&&e.push(String(t.metadata.caller_agent_id));return Array.from(new Set(e))}function Fn(...n){let e=n[n.length-1],t=n[0],r=n[1],o=typeof n[2]=="string"?n[2]:"",s=typeof n[3]=="string"?n[3]:"";if(!Array.isArray(t)||t.length===0||!(e&&typeof e.fn=="function"))return "";let a=ri(t),d=a.length>0?a[0]:"",l=Date.now(),u={messages:ti(t),platform:typeof r=="string"?r:"",messagesCount:t.length,agentIds:a,primaryAgentId:d,currentAgentId:o,threadId:s,now:ct(new Date(l))};return e.fn(u)}c();var ut=class{defaultMode;constructor(e={}){this.defaultMode=e.defaultMode??"lenient";}validate(e,t,r=this.defaultMode){let o=[],s=this.validateObject(e??{},t,r,["props"],o);if(o.length>0&&r==="strict")throw new we("Props validation failed in strict mode",o);return {valid:o.length===0,props:s,errors:o}}validateObject(e,t,r,o,s){let i={};if(r==="strict")for(let a of Object.keys(e))t[a]||s.push({path:this.buildPath([...o,a]),message:`Unknown prop '${a}'`,value:e[a]});for(let[a,d]of Object.entries(t)){let l=[...o,a],u=e[a],p=this.resolveProp(u,d,l,r,s);p.shouldAssign&&(i[a]=p.value);}return i}resolveProp(e,t,r,o,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,o,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,o,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,o,s);case "object":return this.validatePlainObject(e);case "shape":return this.validateShape(e,t,r,o,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,o,s){let i=this.validateArray(e,t);if(!i.valid)return i;let a=[],d=t.itemType,l=t.itemOneOf,u=s.length;return i.value.forEach((p,y)=>{let g=[...r,String(y)];if(d){let h=this.validateType(p,{type:d},g,o,s);h.valid?a.push(h.value):s.push({path:this.buildPath(g),message:h.error??"Invalid array item",value:p});}else a.push(p);l&&!l.includes(p)&&s.push({path:this.buildPath(g),message:`Array item must be one of: ${l.join(", ")}`,value:p});}),{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,o,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??{},o,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,o]of Object.entries(e)){if(o.defaultValue!==void 0){t[r]=this.cloneValue(o.defaultValue);continue}if(o.type==="shape"&&o.shape){let s=this.applyDefaults(o.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,o]of Object.entries(e))t[r]=this.cloneValue(o);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 pt=class{handlebars;propsValidator;constructor(e){this.handlebars=pe__namespace.default.create(),this.propsValidator=e??new ut,this.registerHelpers();}render(e,t,r={}){try{let o=this.prepareRenderContext(e,t,r);return this.handlebars.compile(e.template,{noEscape:!0})(o)}catch(o){throw o instanceof Error?new Error(`Template rendering failed for layout '${e.id}': ${o.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 o=this.mergeProps(e.defaultProps,t);return !e.propsSchema||Object.keys(e.propsSchema).length===0?{valid:true,props:o,errors:[]}:this.executeValidation(o,e.propsSchema,r)}prepareRenderContext(e,t,r){let{validationMode:o="lenient",skipValidation:s=false}=r,i=s?this.mergeProps(e.defaultProps,t.props):this.resolveProps(e,t.props,o).props;return {...t,vars:this.sanitizeVars(t.vars),props:i}}registerHelpers(){this.handlebars.registerHelper("formatConversation",Fn),pe__namespace.default.helpers.each&&this.handlebars.registerHelper("each",pe__namespace.default.helpers.each),pe__namespace.default.helpers.if&&this.handlebars.registerHelper("if",pe__namespace.default.helpers.if),pe__namespace.default.helpers.unless&&this.handlebars.registerHelper("unless",pe__namespace.default.helpers.unless),pe__namespace.default.helpers.with&&this.handlebars.registerHelper("with",pe__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 pe__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(o){if(o instanceof we&&o.errors&&o.errors.length>0){let s=o.errors[0];if(s)throw new we(s.message,o.errors)}throw o}}mergeProps(e,t){let r=this.cloneDeep(e??{});return t?this.deepMerge(r,t):r}deepMerge(e,t){for(let[r,o]of Object.entries(t)){if(this.isPlainObject(o)){let s=e[r];e[r]=this.deepMerge(this.isPlainObject(s)?s:{},o);continue}if(Array.isArray(o)){e[r]=this.cloneDeep(o);continue}e[r]=o;}return e}cloneDeep(e){if(Array.isArray(e))return e.map(t=>this.cloneDeep(t));if(this.isPlainObject(e)){let t={};for(let[r,o]of Object.entries(e))t[r]=this.cloneDeep(o);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}};c();var Rr="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function ni(n){let e=crypto$1.randomBytes(n*2),t="";for(let r=0;r<e.length&&t.length<n;r++){let o=e[r];o<248&&(t+=Rr[o%62]);}for(;t.length<n;)t+=Rr[crypto$1.randomBytes(1)[0]%62];return t}function Me(n){return `${n}_${ni(8)}`}function oi(n,e){let{createHash:t}=J("crypto"),r=t("sha256").update(e).digest(),o=Buffer.alloc(8);for(let i=0;i<32;i++)o[i%8]^=r[i];let s="";for(let i of o)s+=Rr[i%62];return `${n}_${s}`}c();function Er(n){let e=t=>String(t).padStart(2,"0");return `${n.getFullYear()}${e(n.getMonth()+1)}${e(n.getDate())}T${e(n.getHours())}${e(n.getMinutes())}${e(n.getSeconds())}`}c();function Bn(n,e){return t=>{try{let r=e(t);r instanceof Promise&&r.catch(o=>{console.error(`[crewx] event listener error (${n}): ${o instanceof Error?o.message:String(o)}`);});}catch(r){console.error(`[crewx] event listener error (${n}): ${r instanceof Error?r.message:String(r)}`);}}}var gt=class{_emitter=new events.EventEmitter;on(e,t){let r=Bn(e,t);return this._emitter.on(e,r),()=>this._emitter.off(e,r)}once(e,t){let r=Bn(e,t);return this._emitter.once(e,r),()=>this._emitter.off(e,r)}emit(e,t){this._emitter.emit(e,t);}};c();function Cr(n){let e=new Map,t=r=>r.startsWith(`${n}::`)?r:`${n}::${r}`;return {async get(r){let o=e.get(t(r));return o?o.value:void 0},async set(r,o){e.set(t(r),{value:o});},async delete(r){return e.delete(t(r))},async list(r){let o=r?t(r):`${n}::`,s=[];for(let i of e.keys())i.startsWith(o)&&s.push(i.slice(n.length+2));return s}}}c();var Tr=new async_hooks.AsyncLocalStorage;function ai(){return Tr}function di(n,e){return Tr.run(n,e)}function Pr(n){let e=n.log??n.logger??{debug:()=>{},info:()=>{},warn:()=>{},error:()=>{}},t=n.agentRunner??{run:async()=>({output:""})},r=n.db??{get:async()=>{},set:async()=>{},delete:async()=>false,list:async()=>[]},o=n.storage??{put:async()=>"",get:async()=>{},delete:async()=>false},s=n.audit??{log:async()=>{}},i=n.onInbound??(async()=>({accepted:true})),a=n.onEmitEvent??(async()=>({accepted:true})),d=n.onUpdateMessage??(async()=>{}),l=n.onResolveUser??(async y=>({userId:y,displayName:y})),u=async y=>{let g=Tr.getStore();if(!g){e.warn("respondSync called outside sync window \u2014 graceful degradation (no-op)",{textPreview:typeof y=="object"&&"text"in y?y.text.slice(0,80):void 0});return}let h="text"in y?y.text:"";g.res.status(200).json({text:h});},p=n.httpRouter??{registerRoute:()=>{e.warn("httpRouter not configured \u2014 registerRoute is a no-op");}};return {instanceId:n.instanceId,config:n.config,capabilities:n.capabilities,log:e,agentRunner:t,db:r,storage:o,audit:s,abortSignal:n.abortSignal??new AbortController().signal,httpRouter:p,inbound:i,emitEvent:a,updateMessage:d,resolveUser:l,respondSync:u}}Ae();c();var li=/^-\s*Status:\s*active/m,ci=/^---\n([\s\S]*?)\n---/,ui=/^type:\s*goal\s*$/m;async function Wn(n,e=Se,t){let r=typeof t=="string"?[t]:Array.isArray(t)?t:void 0;if(r){let a=[];for(let d of r){let l=e.resolvePath(n,d);await e.exists(l)&&a.push(await e.readFile(l));}return a.join(`
52
+ `)}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)??"",o=await this.getToc(t),s=this.getPath(t);e[t]={content:r,toc:o,...s?{path:s}:{}};}return e}async loadFromFile(e,t,r){try{let o=this.resolve(t,r),s=await this.fs.readFile(o);this.docs.set(e,{content:s,path:o});}catch(o){let s=o instanceof Error?o.message:String(o);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)}};c();c();var Q=class extends Error{constructor(t,r,o){super(t);this.layoutId=r;this.cause=o;this.name="LayoutLoadError";}layoutId;cause},xe=class extends Error{constructor(t,r=[],o){super(t);this.errors=r;this.cause=o;this.name="PropsValidationError";}errors;cause};var ti={validationMode:"lenient",fallbackLayoutId:"crewx/default"},ct=class{layouts=new Map;options;constructor(e){this.options={...ti,...e,templatesPath:e?.templatesPath??ze()},this.loadAllLayouts();}load(e,t){let r=this.layouts.get(e);if(!r){let o=this.normalizeLayoutId(e);r=this.layouts.get(o);}if(!r&&(console.warn(`Layout not found: ${e}, falling back to ${this.options.fallbackLayoutId}`),r=this.layouts.get(this.options.fallbackLayoutId),!r))throw new Q(`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 Q("Layout ID must be a non-empty string",e);let r=typeof t=="string"?{template:t}:t,o=typeof r.template=="string"?r.template:"";if(!o||o.trim().length===0)throw new Q(`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:o,propsSchema:this.parsePropsSchema(s),defaultProps:{...i,...a}},l=this.layouts.get(e),u=l?.template===o&&JSON.stringify(l?.defaultProps??{})===JSON.stringify(d.defaultProps??{})&&JSON.stringify(l?.propsSchema??{})===JSON.stringify(d.propsSchema??{});this.layouts.set(e,d),process.env.CREWX_VERBOSE==="1"&&(l?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(o){console.warn(`Failed to register custom layout ${t}:`,o instanceof Error?o.message:o);}}loadAllLayouts(){let e=this.options.templatesPath;if(!ro.existsSync(e))throw new Q(`Templates directory not found: ${e}`,void 0,new Error(`Directory does not exist: ${e}`));try{let t=ro.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 o=r.replace(/\.(yaml|yml)$/,""),s=V__namespace.join(e,r);try{let i=this.loadLayoutFile(s,o),a=`crewx/${o}`;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 Q(`Failed to read layouts directory: ${e}`,void 0,t instanceof Error?t:new Error(String(t)))}}loadLayoutFile(e,t){try{let r=ro.readFileSync(e,"utf-8");if(!r||r.trim().length===0)throw console.warn(`Empty YAML file: ${e}, will use fallback`),new Q(`Empty YAML file: ${e}`,t,new Error("File content is empty"));let o=jsYaml.load(r);if(!o||typeof o!="object")throw console.warn(`Invalid YAML content in ${e} (parsed as ${typeof o}), will use fallback`),new Q(`Invalid or empty YAML in ${e}`,t,new Error("YAML parsing returned null/undefined or non-object"));if(o.layouts&&typeof o.layouts=="object"){let s=this.resolveLayoutEntry(o.layouts,t);if(!s||s.template.trim().length===0)throw console.warn(`Empty or missing layout template in ${e} for ${t}`),new Q(`Layout template not found or empty in layouts map: ${t}`,t);let i=s.propsSchema||o.propsSchema||{};return {id:`crewx/${t}`,version:o.version||"1.0.0",description:o.description||`CrewX ${t} layout`,template:s.template,propsSchema:this.parsePropsSchema(i),defaultProps:this.extractDefaultProps(i)}}else {if(!o.template||typeof o.template=="string"&&o.template.trim().length===0)throw console.warn(`Empty or missing template field in ${e}`),new Q(`Layout template is missing or empty in ${e}`,t);return {id:o.id||`crewx/${t}`,version:o.version||"1.0.0",description:o.description||"",template:o.template,propsSchema:this.parsePropsSchema(o.propsSchema||{}),defaultProps:this.extractDefaultProps(o.propsSchema||{})}}}catch(r){throw new Q(`Failed to load layout file: ${e}`,t,r instanceof Error?r:new Error(String(r)))}}parsePropsSchema(e){let t={};for(let[r,o]of Object.entries(e))typeof o=="object"&&o!==null&&(t[r]=o);return t}extractDefaultProps(e){let t={};for(let[r,o]of Object.entries(e))o&&typeof o=="object"&&("defaultValue"in o?t[r]=o.defaultValue:"default"in o&&(t[r]=o.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 o=t.split("/"),s=o[o.length-1];s&&r.add(s);}else r.add(`crewx/${t}`);r.add("default");for(let o of r){let s=e[o];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 o of Object.values(e)){if(typeof o=="string"&&o.trim().length>0)return {template:o};let s=o;if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}}};c();c();c();function Me(n){return String(Math.floor(Math.abs(n))).padStart(2,"0")}function ut(n){if(!(n instanceof Date)||Number.isNaN(n.getTime()))return "";let e=-n.getTimezoneOffset(),t=e>=0?"+":"-";return `${n.getFullYear()}-${Me(n.getMonth()+1)}-${Me(n.getDate())}T${Me(n.getHours())}:${Me(n.getMinutes())}:${Me(n.getSeconds())}${t}${Me(e/60)}:${Me(e%60)}`}function ri(n){return n.map(e=>{let t=typeof e?.timestamp=="number"?e.timestamp:null;return t===null?e:{...e,created_at:ut(new Date(t))}})}function ni(n){let e=[];for(let t of n)t?.isAssistant&&t?.metadata?.agent_id?e.push(String(t.metadata.agent_id)):!t?.isAssistant&&t?.metadata?.caller_agent_id&&e.push(String(t.metadata.caller_agent_id));return Array.from(new Set(e))}function qn(...n){let e=n[n.length-1],t=n[0],r=n[1],o=typeof n[2]=="string"?n[2]:"",s=typeof n[3]=="string"?n[3]:"";if(!Array.isArray(t)||t.length===0||!(e&&typeof e.fn=="function"))return "";let a=ni(t),d=a.length>0?a[0]:"",l=Date.now(),u={messages:ri(t),platform:typeof r=="string"?r:"",messagesCount:t.length,agentIds:a,primaryAgentId:d,currentAgentId:o,threadId:s,now:ut(new Date(l))};return e.fn(u)}c();var pt=class{defaultMode;constructor(e={}){this.defaultMode=e.defaultMode??"lenient";}validate(e,t,r=this.defaultMode){let o=[],s=this.validateObject(e??{},t,r,["props"],o);if(o.length>0&&r==="strict")throw new xe("Props validation failed in strict mode",o);return {valid:o.length===0,props:s,errors:o}}validateObject(e,t,r,o,s){let i={};if(r==="strict")for(let a of Object.keys(e))t[a]||s.push({path:this.buildPath([...o,a]),message:`Unknown prop '${a}'`,value:e[a]});for(let[a,d]of Object.entries(t)){let l=[...o,a],u=e[a],p=this.resolveProp(u,d,l,r,s);p.shouldAssign&&(i[a]=p.value);}return i}resolveProp(e,t,r,o,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,o,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,o,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,o,s);case "object":return this.validatePlainObject(e);case "shape":return this.validateShape(e,t,r,o,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,o,s){let i=this.validateArray(e,t);if(!i.valid)return i;let a=[],d=t.itemType,l=t.itemOneOf,u=s.length;return i.value.forEach((p,f)=>{let g=[...r,String(f)];if(d){let h=this.validateType(p,{type:d},g,o,s);h.valid?a.push(h.value):s.push({path:this.buildPath(g),message:h.error??"Invalid array item",value:p});}else a.push(p);l&&!l.includes(p)&&s.push({path:this.buildPath(g),message:`Array item must be one of: ${l.join(", ")}`,value:p});}),{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,o,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??{},o,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,o]of Object.entries(e)){if(o.defaultValue!==void 0){t[r]=this.cloneValue(o.defaultValue);continue}if(o.type==="shape"&&o.shape){let s=this.applyDefaults(o.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,o]of Object.entries(e))t[r]=this.cloneValue(o);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 gt=class{handlebars;propsValidator;constructor(e){this.handlebars=ge__namespace.default.create(),this.propsValidator=e??new pt,this.registerHelpers();}render(e,t,r={}){try{let o=this.prepareRenderContext(e,t,r);return this.handlebars.compile(e.template,{noEscape:!0})(o)}catch(o){throw o instanceof Error?new Error(`Template rendering failed for layout '${e.id}': ${o.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 o=this.mergeProps(e.defaultProps,t);return !e.propsSchema||Object.keys(e.propsSchema).length===0?{valid:true,props:o,errors:[]}:this.executeValidation(o,e.propsSchema,r)}prepareRenderContext(e,t,r){let{validationMode:o="lenient",skipValidation:s=false}=r,i=s?this.mergeProps(e.defaultProps,t.props):this.resolveProps(e,t.props,o).props;return {...t,vars:this.sanitizeVars(t.vars),props:i}}registerHelpers(){this.handlebars.registerHelper("formatConversation",qn),ge__namespace.default.helpers.each&&this.handlebars.registerHelper("each",ge__namespace.default.helpers.each),ge__namespace.default.helpers.if&&this.handlebars.registerHelper("if",ge__namespace.default.helpers.if),ge__namespace.default.helpers.unless&&this.handlebars.registerHelper("unless",ge__namespace.default.helpers.unless),ge__namespace.default.helpers.with&&this.handlebars.registerHelper("with",ge__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 ge__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(o){if(o instanceof xe&&o.errors&&o.errors.length>0){let s=o.errors[0];if(s)throw new xe(s.message,o.errors)}throw o}}mergeProps(e,t){let r=this.cloneDeep(e??{});return t?this.deepMerge(r,t):r}deepMerge(e,t){for(let[r,o]of Object.entries(t)){if(this.isPlainObject(o)){let s=e[r];e[r]=this.deepMerge(this.isPlainObject(s)?s:{},o);continue}if(Array.isArray(o)){e[r]=this.cloneDeep(o);continue}e[r]=o;}return e}cloneDeep(e){if(Array.isArray(e))return e.map(t=>this.cloneDeep(t));if(this.isPlainObject(e)){let t={};for(let[r,o]of Object.entries(e))t[r]=this.cloneDeep(o);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}};c();var Er="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function oi(n){let e=crypto$1.randomBytes(n*2),t="";for(let r=0;r<e.length&&t.length<n;r++){let o=e[r];o<248&&(t+=Er[o%62]);}for(;t.length<n;)t+=Er[crypto$1.randomBytes(1)[0]%62];return t}function Ne(n){return `${n}_${oi(8)}`}function si(n,e){let{createHash:t}=J("crypto"),r=t("sha256").update(e).digest(),o=Buffer.alloc(8);for(let i=0;i<32;i++)o[i%8]^=r[i];let s="";for(let i of o)s+=Er[i%62];return `${n}_${s}`}c();function Cr(n){let e=t=>String(t).padStart(2,"0");return `${n.getFullYear()}${e(n.getMonth()+1)}${e(n.getDate())}T${e(n.getHours())}${e(n.getMinutes())}${e(n.getSeconds())}`}c();function Wn(n,e){return t=>{try{let r=e(t);r instanceof Promise&&r.catch(o=>{console.error(`[crewx] event listener error (${n}): ${o instanceof Error?o.message:String(o)}`);});}catch(r){console.error(`[crewx] event listener error (${n}): ${r instanceof Error?r.message:String(r)}`);}}}var mt=class{_emitter=new events.EventEmitter;on(e,t){let r=Wn(e,t);return this._emitter.on(e,r),()=>this._emitter.off(e,r)}once(e,t){let r=Wn(e,t);return this._emitter.once(e,r),()=>this._emitter.off(e,r)}emit(e,t){this._emitter.emit(e,t);}};c();function Tr(n){let e=new Map,t=r=>r.startsWith(`${n}::`)?r:`${n}::${r}`;return {async get(r){let o=e.get(t(r));return o?o.value:void 0},async set(r,o){e.set(t(r),{value:o});},async delete(r){return e.delete(t(r))},async list(r){let o=r?t(r):`${n}::`,s=[];for(let i of e.keys())i.startsWith(o)&&s.push(i.slice(n.length+2));return s}}}c();var Pr=new async_hooks.AsyncLocalStorage;function di(){return Pr}function li(n,e){return Pr.run(n,e)}function br(n){let e=n.log??n.logger??{debug:()=>{},info:()=>{},warn:()=>{},error:()=>{}},t=n.agentRunner??{run:async()=>({output:""})},r=n.db??{get:async()=>{},set:async()=>{},delete:async()=>false,list:async()=>[]},o=n.storage??{put:async()=>"",get:async()=>{},delete:async()=>false},s=n.audit??{log:async()=>{}},i=n.onInbound??(async()=>({accepted:true})),a=n.onEmitEvent??(async()=>({accepted:true})),d=n.onUpdateMessage??(async()=>{}),l=n.onResolveUser??(async f=>({userId:f,displayName:f})),u=async f=>{let g=Pr.getStore();if(!g){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 h="text"in f?f.text:"";g.res.status(200).json({text:h});},p=n.httpRouter??{registerRoute:()=>{e.warn("httpRouter not configured \u2014 registerRoute is a no-op");}};return {instanceId:n.instanceId,config:n.config,capabilities:n.capabilities,log:e,agentRunner:t,db:r,storage:o,audit:s,abortSignal:n.abortSignal??new AbortController().signal,httpRouter:p,inbound:i,emitEvent:a,updateMessage:d,resolveUser:l,respondSync:u}}Re();c();var ci=/^-\s*Status:\s*active/m,ui=/^---\n([\s\S]*?)\n---/,pi=/^type:\s*goal\s*$/m;async function zn(n,e=Ie,t){let r=typeof t=="string"?[t]:Array.isArray(t)?t:void 0;if(r){let a=[];for(let d of r){let l=e.resolvePath(n,d);await e.exists(l)&&a.push(await e.readFile(l));}return a.join(`
53
53
  ---
54
- `)}let s=(await e.readdir(n)).filter(a=>a.endsWith(".md"));if(s.length===0)return "";let i=[];for(let a of s){let d=e.resolvePath(n,a),l=await e.readFile(d),u=ci.exec(l);!u||!ui.test(u[1])||li.test(l)&&i.push(l);}return i.join(`
54
+ `)}let s=(await e.readdir(n)).filter(a=>a.endsWith(".md"));if(s.length===0)return "";let i=[];for(let a of s){let d=e.resolvePath(n,a),l=await e.readFile(d),u=ui.exec(l);!u||!pi.test(u[1])||ci.test(l)&&i.push(l);}return i.join(`
55
55
  ---
56
- `)}c();function pi(){let n=new Date,e=n.getFullYear(),t=String(n.getMonth()+1).padStart(2,"0"),r=String(n.getDate()).padStart(2,"0");return `${e}-${t}-${r}`}async function zn(n,e=Se){let t=e.resolvePath(n,`${pi()}.md`);return await e.exists(t)?e.readFile(t):""}Ae();c();var mt=new async_hooks.AsyncLocalStorage;function br(n){if(n)return {parentTaskId:n.parentTaskId??null,rootTraceId:n.rootTraceId,callerAgentId:n.callerAgentId??null}}c();function mi(n){return typeof n!="string"?"":n.replace(/</g,"&lt;").replace(/>/g,"&gt;")}function Sr(n){return n.messages.map(e=>({text:mi(e.text),isAssistant:e.isAssistant,timestamp:e.timestamp,metadata:e.metadata,files:void 0}))}c();Ae();Re();c();c();var Xe=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:V.join(wi__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 to.existsSync(e??this.resolveDbPath())}};c();function xe(n){let e=J("better-sqlite3"),{drizzle:t}=J("drizzle-orm/better-sqlite3"),r=new e(n);return r.exec("PRAGMA journal_mode = WAL"),r.exec("PRAGMA busy_timeout = 5000"),r.exec("PRAGMA foreign_keys = ON"),{db:t(r),runRaw:(o,s=[])=>r.prepare(o).run(...s),close:()=>r.close()}}c();var Kn=new Set,xi={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 Or(n,e){return (n.get(`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='${e}'`)?.cnt??0)>0}function ki(n,e){if(e>0||!Or(n,"tasks"))return;let t=n.all("PRAGMA table_info(tasks)"),r=new Set(t.map(o=>o.name));for(let[o,s]of Object.entries(xi))r.has(o)||n.run(`ALTER TABLE tasks ADD COLUMN ${o} ${s}`);}var _i={"0002_normalize_task_names":{workspace_name:"TEXT",project_name:"TEXT"}};function vi(n,e,t){if(!Or(n,"__drizzle_migrations")||!Or(n,"tasks"))return;let r=n.all(t`SELECT hash FROM __drizzle_migrations`),o=new Set(r.map(i=>i.hash)),s=JSON.parse(to.readFileSync(V__namespace.default.join(e,"meta/_journal.json"),"utf-8"));for(let i of s.entries){let a=_i[i.tag];if(!a)continue;let d=V__namespace.default.join(e,`${i.tag}.sql`);if(!to.existsSync(d))continue;let l=to.readFileSync(d,"utf-8"),u=crypto$1.createHash("sha256").update(l).digest("hex");if(o.has(u))continue;let p=n.all("PRAGMA table_info(tasks)"),y=new Set(p.map(g=>g.name));for(let[g,h]of Object.entries(a))y.has(g)||(n.run(`ALTER TABLE tasks ADD COLUMN ${g} ${h}`),y.add(g));}}function Ai(n,e,t){let r=n.all(t`SELECT hash FROM __drizzle_migrations`),o=new Set(r.map(i=>i.hash)),s=JSON.parse(to.readFileSync(V__namespace.default.join(e,"meta/_journal.json"),"utf-8"));for(let i of s.entries){let a=V__namespace.default.join(e,`${i.tag}.sql`);if(!to.existsSync(a))continue;let d=to.readFileSync(a,"utf-8"),l=crypto$1.createHash("sha256").update(d).digest("hex");if(o.has(l))continue;let u=/ALTER\s+TABLE\s+[`"]?(\w+)[`"]?\s+ADD\s+[`"]?(\w+)[`"]?/gi,p=[],y;for(;(y=u.exec(d))!==null;)p.push({table:y[1],column:y[2]});if(p.length===0||!d.split(/-->\s*statement-breakpoint/).map(k=>k.trim()).filter(Boolean).every(k=>/^ALTER\s+TABLE\s+.+\s+ADD\s+/i.test(k)))continue;p.every(({table:k,column:v})=>n.all(`PRAGMA table_info("${k}")`).some(_=>_.name===v))&&n.run(t`INSERT INTO __drizzle_migrations (hash, created_at) VALUES (${l}, ${i.when})`);}}function Ri(n){let{migrate:e}=J("drizzle-orm/better-sqlite3/migrator"),{sql:t}=J("drizzle-orm"),r=[V__namespace.default.join(__dirname,"../migrations"),V__namespace.default.join(__dirname,"migrations"),V__namespace.default.join(__dirname,"../../../../drizzle/migrations"),V__namespace.default.join(process.cwd(),"drizzle/migrations")],o=r.find(l=>to.existsSync(V__namespace.default.join(l,"meta/_journal.json")));if(!o)throw new Error(`migrations folder not found. Searched:
56
+ `)}c();function gi(){let n=new Date,e=n.getFullYear(),t=String(n.getMonth()+1).padStart(2,"0"),r=String(n.getDate()).padStart(2,"0");return `${e}-${t}-${r}`}async function Kn(n,e=Ie){let t=e.resolvePath(n,`${gi()}.md`);return await e.exists(t)?e.readFile(t):""}Re();c();var ft=new async_hooks.AsyncLocalStorage;function Sr(n){if(n)return {parentTaskId:n.parentTaskId??null,rootTraceId:n.rootTraceId,callerAgentId:n.callerAgentId??null}}c();function fi(n){return typeof n!="string"?"":n.replace(/</g,"&lt;").replace(/>/g,"&gt;")}function Ir(n){return n.messages.map(e=>({text:fi(e.text),isAssistant:e.isAssistant,timestamp:e.timestamp,metadata:e.metadata,files:void 0}))}c();Re();Ee();c();c();var Je=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:V.join(xi__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 ro.existsSync(e??this.resolveDbPath())}};c();function ke(n){let e=J("better-sqlite3"),{drizzle:t}=J("drizzle-orm/better-sqlite3"),r=new e(n);return r.exec("PRAGMA journal_mode = WAL"),r.exec("PRAGMA busy_timeout = 5000"),r.exec("PRAGMA foreign_keys = ON"),{db:t(r),runRaw:(o,s=[])=>r.prepare(o).run(...s),close:()=>r.close()}}c();var Vn=new Set,ki={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 Mr(n,e){return (n.get(`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='${e}'`)?.cnt??0)>0}function _i(n,e){if(e>0||!Mr(n,"tasks"))return;let t=n.all("PRAGMA table_info(tasks)"),r=new Set(t.map(o=>o.name));for(let[o,s]of Object.entries(ki))r.has(o)||n.run(`ALTER TABLE tasks ADD COLUMN ${o} ${s}`);}var vi={"0002_normalize_task_names":{workspace_name:"TEXT",project_name:"TEXT"}};function Ai(n,e,t){if(!Mr(n,"__drizzle_migrations")||!Mr(n,"tasks"))return;let r=n.all(t`SELECT hash FROM __drizzle_migrations`),o=new Set(r.map(i=>i.hash)),s=JSON.parse(ro.readFileSync(V__namespace.default.join(e,"meta/_journal.json"),"utf-8"));for(let i of s.entries){let a=vi[i.tag];if(!a)continue;let d=V__namespace.default.join(e,`${i.tag}.sql`);if(!ro.existsSync(d))continue;let l=ro.readFileSync(d,"utf-8"),u=crypto$1.createHash("sha256").update(l).digest("hex");if(o.has(u))continue;let p=n.all("PRAGMA table_info(tasks)"),f=new Set(p.map(g=>g.name));for(let[g,h]of Object.entries(a))f.has(g)||(n.run(`ALTER TABLE tasks ADD COLUMN ${g} ${h}`),f.add(g));}}function Ri(n,e,t){let r=n.all(t`SELECT hash FROM __drizzle_migrations`),o=new Set(r.map(i=>i.hash)),s=JSON.parse(ro.readFileSync(V__namespace.default.join(e,"meta/_journal.json"),"utf-8"));for(let i of s.entries){let a=V__namespace.default.join(e,`${i.tag}.sql`);if(!ro.existsSync(a))continue;let d=ro.readFileSync(a,"utf-8"),l=crypto$1.createHash("sha256").update(d).digest("hex");if(o.has(l))continue;let u=/ALTER\s+TABLE\s+[`"]?(\w+)[`"]?\s+ADD\s+[`"]?(\w+)[`"]?/gi,p=[],f;for(;(f=u.exec(d))!==null;)p.push({table:f[1],column:f[2]});if(p.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;p.every(({table:x,column:v})=>n.all(`PRAGMA table_info("${x}")`).some(_=>_.name===v))&&n.run(t`INSERT INTO __drizzle_migrations (hash, created_at) VALUES (${l}, ${i.when})`);}}function Ei(n){let{migrate:e}=J("drizzle-orm/better-sqlite3/migrator"),{sql:t}=J("drizzle-orm"),r=[V__namespace.default.join(__dirname,"../migrations"),V__namespace.default.join(__dirname,"migrations"),V__namespace.default.join(__dirname,"../../../../drizzle/migrations"),V__namespace.default.join(process.cwd(),"drizzle/migrations")],o=r.find(l=>ro.existsSync(V__namespace.default.join(l,"meta/_journal.json")));if(!o)throw new Error(`migrations folder not found. Searched:
57
57
  ${r.join(`
58
- `)}`);let s=n.get(t`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='__drizzle_migrations'`),i=0;s?.cnt&&(i=n.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0),ki(n,i),s?.cnt&&(Ai(n,o,t),vi(n,o,t)),e(n,{migrationsFolder:o});let d=(n.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0)-i;if(d>0){let l=s?.cnt?"Database migrated":"Database initialized";console.log(`[crewx] ${l} (${d} migration${d>1?"s":""} applied).`);}}function Ft(n,e){Kn.has(e)||(Ri(n),Kn.add(e));}c();var N=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);}};c();c();var Gn=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()});c();var m=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)},n=>({idx_tasks_agent_id:sqliteCore.index("idx_tasks_agent_id").on(n.agent_id),idx_tasks_status:sqliteCore.index("idx_tasks_status").on(n.status),idx_tasks_started_at:sqliteCore.index("idx_tasks_started_at").on(n.started_at),idx_tasks_trace_id:sqliteCore.index("idx_tasks_trace_id").on(n.trace_id),idx_tasks_parent_task_id:sqliteCore.index("idx_tasks_parent_task_id").on(n.parent_task_id),idx_tasks_crewx_version:sqliteCore.index("idx_tasks_crewx_version").on(n.crewx_version),idx_tasks_pid:sqliteCore.index("idx_tasks_pid").on(n.pid),idx_tasks_thread_id:sqliteCore.index("idx_tasks_thread_id").on(n.thread_id),idx_tasks_workspace_id:sqliteCore.index("idx_tasks_workspace_id").on(n.workspace_id),idx_tasks_workspace_ref:sqliteCore.index("idx_tasks_workspace_ref").on(n.workspace_ref),idx_tasks_project_id:sqliteCore.index("idx_tasks_project_id").on(n.project_id),idx_tasks_ws_started:sqliteCore.index("idx_tasks_ws_started").on(n.workspace_id,n.started_at)}));c();var Jn=sqliteCore.sqliteTable("threads",{id:sqliteCore.text("id").primaryKey(),workspace_id:sqliteCore.text("workspace_id").references(()=>Gn.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)},n=>({idx_threads_updated_at:sqliteCore.index("idx_threads_updated_at").on(n.updated_at),idx_threads_workspace_id:sqliteCore.index("idx_threads_workspace_id").on(n.workspace_id)}));c();var De=sqliteCore.sqliteTable("spans",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>m.id,{onDelete:"set null"}),parent_span_id:sqliteCore.text("parent_span_id").references(()=>De.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")},n=>({idx_spans_task_id:sqliteCore.index("idx_spans_task_id").on(n.task_id),idx_spans_parent_span_id:sqliteCore.index("idx_spans_parent_span_id").on(n.parent_span_id)}));c();sqliteCore.sqliteTable("tool_calls",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>m.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()},n=>({idx_tool_calls_task_id:sqliteCore.index("idx_tool_calls_task_id").on(n.task_id),idx_tool_calls_tool_name:sqliteCore.index("idx_tool_calls_tool_name").on(n.tool_name),idx_tool_calls_timestamp:sqliteCore.index("idx_tool_calls_timestamp").on(n.timestamp)}));c();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()},n=>({idx_thread_boxes_thread_id:sqliteCore.index("idx_thread_boxes_thread_id").on(n.thread_id),idx_thread_boxes_seq:sqliteCore.index("idx_thread_boxes_seq").on(n.thread_id,n.seq),uniq_thread_boxes_thread_seq:sqliteCore.unique().on(n.thread_id,n.seq)}));c();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")},n=>({idx_request_logs_timestamp:sqliteCore.index("idx_request_logs_timestamp").on(n.timestamp),idx_request_logs_path:sqliteCore.index("idx_request_logs_path").on(n.path),idx_request_logs_status_code:sqliteCore.index("idx_request_logs_status_code").on(n.status_code),idx_request_logs_partition_key:sqliteCore.index("idx_request_logs_partition_key").on(n.partition_key)}));var Ue="2026-05-09",Bi="0.8.9-rc.13",je=10,He=parseInt(Bi.split("rc.")[1]),ft=class extends Xe{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=V.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let o=V.dirname(t);to.existsSync(o)||to.mkdirSync(o,{recursive:true});}else if(!to.existsSync(t))throw new N("NOT_FOUND","Database not found");let r=xe(t);if(e)try{Ft(r.db,t);}catch(o){throw r.close(),o}return r}startTask(e){let t=this.openHandle(true);try{t.db.insert(m).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 N?r:new N("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=?,
58
+ `)}`);let s=n.get(t`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='__drizzle_migrations'`),i=0;s?.cnt&&(i=n.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0),_i(n,i),s?.cnt&&(Ri(n,o,t),Ai(n,o,t)),e(n,{migrationsFolder:o});let d=(n.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0)-i;if(d>0){let l=s?.cnt?"Database migrated":"Database initialized";console.log(`[crewx] ${l} (${d} migration${d>1?"s":""} applied).`);}}function qt(n,e){Vn.has(e)||(Ei(n),Vn.add(e));}c();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);}};c();c();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()});c();var m=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)},n=>({idx_tasks_agent_id:sqliteCore.index("idx_tasks_agent_id").on(n.agent_id),idx_tasks_status:sqliteCore.index("idx_tasks_status").on(n.status),idx_tasks_started_at:sqliteCore.index("idx_tasks_started_at").on(n.started_at),idx_tasks_trace_id:sqliteCore.index("idx_tasks_trace_id").on(n.trace_id),idx_tasks_parent_task_id:sqliteCore.index("idx_tasks_parent_task_id").on(n.parent_task_id),idx_tasks_crewx_version:sqliteCore.index("idx_tasks_crewx_version").on(n.crewx_version),idx_tasks_pid:sqliteCore.index("idx_tasks_pid").on(n.pid),idx_tasks_thread_id:sqliteCore.index("idx_tasks_thread_id").on(n.thread_id),idx_tasks_workspace_id:sqliteCore.index("idx_tasks_workspace_id").on(n.workspace_id),idx_tasks_workspace_ref:sqliteCore.index("idx_tasks_workspace_ref").on(n.workspace_ref),idx_tasks_project_id:sqliteCore.index("idx_tasks_project_id").on(n.project_id),idx_tasks_ws_started:sqliteCore.index("idx_tasks_ws_started").on(n.workspace_id,n.started_at)}));c();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)},n=>({idx_threads_updated_at:sqliteCore.index("idx_threads_updated_at").on(n.updated_at),idx_threads_workspace_id:sqliteCore.index("idx_threads_workspace_id").on(n.workspace_id)}));c();var Le=sqliteCore.sqliteTable("spans",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>m.id,{onDelete:"set null"}),parent_span_id:sqliteCore.text("parent_span_id").references(()=>Le.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")},n=>({idx_spans_task_id:sqliteCore.index("idx_spans_task_id").on(n.task_id),idx_spans_parent_span_id:sqliteCore.index("idx_spans_parent_span_id").on(n.parent_span_id)}));c();sqliteCore.sqliteTable("tool_calls",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>m.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()},n=>({idx_tool_calls_task_id:sqliteCore.index("idx_tool_calls_task_id").on(n.task_id),idx_tool_calls_tool_name:sqliteCore.index("idx_tool_calls_tool_name").on(n.tool_name),idx_tool_calls_timestamp:sqliteCore.index("idx_tool_calls_timestamp").on(n.timestamp)}));c();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()},n=>({idx_thread_boxes_thread_id:sqliteCore.index("idx_thread_boxes_thread_id").on(n.thread_id),idx_thread_boxes_seq:sqliteCore.index("idx_thread_boxes_seq").on(n.thread_id,n.seq),uniq_thread_boxes_thread_seq:sqliteCore.unique().on(n.thread_id,n.seq)}));c();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")},n=>({idx_request_logs_timestamp:sqliteCore.index("idx_request_logs_timestamp").on(n.timestamp),idx_request_logs_path:sqliteCore.index("idx_request_logs_path").on(n.path),idx_request_logs_status_code:sqliteCore.index("idx_request_logs_status_code").on(n.status_code),idx_request_logs_partition_key:sqliteCore.index("idx_request_logs_partition_key").on(n.partition_key)}));var je="2026-05-09",Wi="0.8.9-rc.13",He=10,Fe=parseInt(Wi.split("rc.")[1]),yt=class extends Je{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=V.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let o=V.dirname(t);ro.existsSync(o)||ro.mkdirSync(o,{recursive:true});}else if(!ro.existsSync(t))throw new M("NOT_FOUND","Database not found");let r=ke(t);if(e)try{qt(r.db,t);}catch(o){throw r.close(),o}return r}startTask(e){let t=this.openHandle(true);try{t.db.insert(m).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=?,
59
59
  exit_code=?, input_tokens=?, output_tokens=?, cached_input_tokens=?, cost_usd=?,
60
- model=COALESCE(?, model) WHERE id=? AND status='running'`,[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 N?r:new N("DB_ERROR","Failed to finish task",r)}finally{t.close();}}appendLog(e,t){let r=this.openHandle(true);try{r.db.transaction(o=>{let s=o.select({logs:m.logs}).from(m).where(drizzleOrm.eq(m.id,e)).limit(1).get(),i=s?.logs?JSON.parse(s.logs):[];i.push(t),o.update(m).set({logs:JSON.stringify(i)}).where(drizzleOrm.eq(m.id,e)).run();},{behavior:"immediate"});}catch(o){throw o instanceof N?o:new N("DB_ERROR","Failed to append log",o)}finally{r.close();}}getRunningTasks(){if(!this.dbExists())return [];let e=this.openHandle(false);try{return e.db.select().from(m).where(drizzleOrm.eq(m.status,"running")).orderBy(drizzleOrm.desc(m.started_at)).all()}catch(t){throw new N("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(m).orderBy(drizzleOrm.desc(m.started_at)).limit(100).all()}catch(t){throw new N("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(m).where(drizzleOrm.eq(m.id,e)).limit(1).get()??void 0}catch(r){throw new N("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:m.id,status:m.status,pid:m.pid}).from(m).where(drizzleOrm.eq(m.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(m).set({status:"failed",error:"Killed by user",completed_at:new Date().toISOString()}).where(drizzleOrm.and(drizzleOrm.eq(m.id,e),drizzleOrm.eq(m.status,"running"))).run(),{killed:!0,pid:r.pid??void 0}}catch(r){throw r instanceof N?r:new N("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:m.id,pid:m.pid}).from(m).where(drizzleOrm.eq(m.status,"running")).all(),r=0;for(let o of t){if(!o.pid)continue;let s=!1;try{process.kill(o.pid,0),s=!0;}catch{}s||(e.db.update(m).set({status:"failed",error:"Reaped: process not found (orphaned task)",completed_at:new Date().toISOString()}).where(drizzleOrm.and(drizzleOrm.eq(m.id,o.id),drizzleOrm.eq(m.status,"running"))).run(),r++);}return r}finally{e.close();}}findTaskStatus(e,t){let r=this.resolveDbPaths();for(let o of r){if(!to.existsSync(o))continue;let s=xe(o);try{let i=t?drizzleOrm.eq(m.workspace_id,t):void 0,a=i?drizzleOrm.and(drizzleOrm.eq(m.id,e),i):drizzleOrm.eq(m.id,e),d=s.db.select().from(m).where(a).limit(1).get()??void 0;if(!d){let l=drizzleOrm.or(drizzleOrm.eq(m.thread_id,e),drizzleOrm.and(drizzleOrm.isNull(m.thread_id),drizzleOrm.like(m.command,`%--thread=${e}%`))),u=i?drizzleOrm.and(l,i):l;d=s.db.select().from(m).where(u).orderBy(drizzleOrm.desc(m.started_at)).limit(1).get()??void 0;}if(d)return d}catch(i){throw new N("DB_ERROR","Failed to find task status",i)}finally{s.close();}}}findChildTasks(e,t){let r=this.resolveDbPaths(),o=new Set,s=[];for(let i of r){if(!to.existsSync(i))continue;let a=xe(i);try{let d=t?drizzleOrm.and(drizzleOrm.eq(m.parent_task_id,e),drizzleOrm.eq(m.workspace_id,t)):drizzleOrm.eq(m.parent_task_id,e),l=a.db.select().from(m).where(d).orderBy(drizzleOrm.asc(m.started_at)).all();for(let u of l)o.has(u.id)||(o.add(u.id),s.push(u));}catch(d){throw new N("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`
60
+ model=COALESCE(?, model) WHERE id=? AND status='running'`,[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(o=>{let s=o.select({logs:m.logs}).from(m).where(drizzleOrm.eq(m.id,e)).limit(1).get(),i=s?.logs?JSON.parse(s.logs):[];i.push(t),o.update(m).set({logs:JSON.stringify(i)}).where(drizzleOrm.eq(m.id,e)).run();},{behavior:"immediate"});}catch(o){throw o instanceof M?o:new M("DB_ERROR","Failed to append log",o)}finally{r.close();}}getRunningTasks(){if(!this.dbExists())return [];let e=this.openHandle(false);try{return e.db.select().from(m).where(drizzleOrm.eq(m.status,"running")).orderBy(drizzleOrm.desc(m.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(m).orderBy(drizzleOrm.desc(m.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(m).where(drizzleOrm.eq(m.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:m.id,status:m.status,pid:m.pid}).from(m).where(drizzleOrm.eq(m.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(m).set({status:"failed",error:"Killed by user",completed_at:new Date().toISOString()}).where(drizzleOrm.and(drizzleOrm.eq(m.id,e),drizzleOrm.eq(m.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:m.id,pid:m.pid}).from(m).where(drizzleOrm.eq(m.status,"running")).all(),r=0;for(let o of t){if(!o.pid)continue;let s=!1;try{process.kill(o.pid,0),s=!0;}catch{}s||(e.db.update(m).set({status:"failed",error:"Reaped: process not found (orphaned task)",completed_at:new Date().toISOString()}).where(drizzleOrm.and(drizzleOrm.eq(m.id,o.id),drizzleOrm.eq(m.status,"running"))).run(),r++);}return r}finally{e.close();}}findTaskStatus(e,t){let r=this.resolveDbPaths();for(let o of r){if(!ro.existsSync(o))continue;let s=ke(o);try{let i=t?drizzleOrm.eq(m.workspace_id,t):void 0,a=i?drizzleOrm.and(drizzleOrm.eq(m.id,e),i):drizzleOrm.eq(m.id,e),d=s.db.select().from(m).where(a).limit(1).get()??void 0;if(!d){let l=drizzleOrm.or(drizzleOrm.eq(m.thread_id,e),drizzleOrm.and(drizzleOrm.isNull(m.thread_id),drizzleOrm.like(m.command,`%--thread=${e}%`))),u=i?drizzleOrm.and(l,i):l;d=s.db.select().from(m).where(u).orderBy(drizzleOrm.desc(m.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(),o=new Set,s=[];for(let i of r){if(!ro.existsSync(i))continue;let a=ke(i);try{let d=t?drizzleOrm.and(drizzleOrm.eq(m.parent_task_id,e),drizzleOrm.eq(m.workspace_id,t)):drizzleOrm.eq(m.parent_task_id,e),l=a.db.select().from(m).where(d).orderBy(drizzleOrm.asc(m.started_at)).all();for(let u of l)o.has(u.id)||(o.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`
61
61
  SELECT
62
62
  COALESCE(workspace_id, 'unknown') AS workspace_id,
63
63
  COALESCE(SUM(input_tokens), 0) AS input_tokens,
@@ -78,7 +78,7 @@ ${r.join(`
78
78
  FROM tasks
79
79
  GROUP BY workspace_id
80
80
  ORDER BY (COALESCE(SUM(input_tokens), 0) + COALESCE(SUM(output_tokens), 0)) DESC
81
- `)}catch(r){throw new N("DB_ERROR","Failed to get workspace usage summary",r)}finally{t.close();}}getThreadTokenUsage(e,t){let r=this.resolveDbPaths(),o=new Set,s=0,i=0,a=0;for(let d of r){if(!to.existsSync(d))continue;let l=xe(d);try{let u=drizzleOrm.or(drizzleOrm.eq(m.thread_id,e),drizzleOrm.and(drizzleOrm.isNull(m.thread_id),drizzleOrm.like(m.command,`%--thread=${e}%`))),p=t?drizzleOrm.and(u,drizzleOrm.eq(m.workspace_id,t)):u,y=l.db.select({id:m.id,input_tokens:m.input_tokens,output_tokens:m.output_tokens,cost_usd:m.cost_usd}).from(m).where(p).all();for(let g of y)o.has(g.id)||(o.add(g.id),s+=g.input_tokens??0,i+=g.output_tokens??0,a+=g.cost_usd??0);}catch(u){throw new N("DB_ERROR","Failed to get thread token usage",u)}finally{l.close();}}return {inputTokens:s,outputTokens:i,costUsd:a}}findTasksByThread(e,t){let r=this.resolveDbPaths(),o=new Set,s=[];for(let i of r){if(!to.existsSync(i))continue;let a=xe(i);try{let d=drizzleOrm.or(drizzleOrm.eq(m.thread_id,e),drizzleOrm.and(drizzleOrm.isNull(m.thread_id),drizzleOrm.like(m.command,`%--thread=${e}%`))),l=t?drizzleOrm.and(d,drizzleOrm.eq(m.workspace_id,t)):d,u=a.db.select().from(m).where(l).orderBy(drizzleOrm.asc(m.started_at)).all();for(let p of u)o.has(p.id)||(o.add(p.id),s.push(p));}catch(d){throw new N("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(m.workspace_id,e.workspaceId));let o=e.agents&&e.agents.length>0?e.agents:e.agentId?[e.agentId]:null;o&&r.push(drizzleOrm.inArray(m.agent_id,o));let s=e.statuses&&e.statuses.length>0?e.statuses:e.status?[e.status]:null;s&&r.push(drizzleOrm.inArray(m.status,s));let i=e.q??e.search;i&&r.push(drizzleOrm.like(m.prompt,`%${i}%`)),e.from&&r.push(drizzleOrm.gte(m.started_at,e.from)),e.to&&r.push(drizzleOrm.lt(m.started_at,e.to));let a=r.length>0?drizzleOrm.and(...r):void 0,d=t.db.select({count:drizzleOrm.sql`count(*)`}).from(m).where(a).get(),l=(e.sortDir??"DESC")==="ASC"?drizzleOrm.asc(m.started_at):drizzleOrm.desc(m.started_at);return {rows:t.db.select().from(m).where(a).orderBy(l).limit(e.limit).offset(e.offset).all(),total:d?.count??0}}catch(r){throw new N("DB_ERROR","Failed to find all tasks",r)}finally{t.close();}}getAgentUsage(e,t,r){if(!this.dbExists())return [];let o=this.openHandle(false);try{return o.db.all(r?drizzleOrm.sql`
81
+ `)}catch(r){throw new M("DB_ERROR","Failed to get workspace usage summary",r)}finally{t.close();}}getThreadTokenUsage(e,t){let r=this.resolveDbPaths(),o=new Set,s=0,i=0,a=0;for(let d of r){if(!ro.existsSync(d))continue;let l=ke(d);try{let u=drizzleOrm.or(drizzleOrm.eq(m.thread_id,e),drizzleOrm.and(drizzleOrm.isNull(m.thread_id),drizzleOrm.like(m.command,`%--thread=${e}%`))),p=t?drizzleOrm.and(u,drizzleOrm.eq(m.workspace_id,t)):u,f=l.db.select({id:m.id,input_tokens:m.input_tokens,output_tokens:m.output_tokens,cost_usd:m.cost_usd}).from(m).where(p).all();for(let g of f)o.has(g.id)||(o.add(g.id),s+=g.input_tokens??0,i+=g.output_tokens??0,a+=g.cost_usd??0);}catch(u){throw new M("DB_ERROR","Failed to get thread token usage",u)}finally{l.close();}}return {inputTokens:s,outputTokens:i,costUsd:a}}findTasksByThread(e,t){let r=this.resolveDbPaths(),o=new Set,s=[];for(let i of r){if(!ro.existsSync(i))continue;let a=ke(i);try{let d=drizzleOrm.or(drizzleOrm.eq(m.thread_id,e),drizzleOrm.and(drizzleOrm.isNull(m.thread_id),drizzleOrm.like(m.command,`%--thread=${e}%`))),l=t?drizzleOrm.and(d,drizzleOrm.eq(m.workspace_id,t)):d,u=a.db.select().from(m).where(l).orderBy(drizzleOrm.asc(m.started_at)).all();for(let p of u)o.has(p.id)||(o.add(p.id),s.push(p));}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(m.workspace_id,e.workspaceId));let o=e.agents&&e.agents.length>0?e.agents:e.agentId?[e.agentId]:null;o&&r.push(drizzleOrm.inArray(m.agent_id,o));let s=e.statuses&&e.statuses.length>0?e.statuses:e.status?[e.status]:null;s&&r.push(drizzleOrm.inArray(m.status,s));let i=e.q??e.search;i&&r.push(drizzleOrm.like(m.prompt,`%${i}%`)),e.from&&r.push(drizzleOrm.gte(m.started_at,e.from)),e.to&&r.push(drizzleOrm.lt(m.started_at,e.to));let a=r.length>0?drizzleOrm.and(...r):void 0,d=t.db.select({count:drizzleOrm.sql`count(*)`}).from(m).where(a).get(),l=(e.sortDir??"DESC")==="ASC"?drizzleOrm.asc(m.started_at):drizzleOrm.desc(m.started_at);return {rows:t.db.select().from(m).where(a).orderBy(l).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 o=this.openHandle(false);try{return o.db.all(r?drizzleOrm.sql`
82
82
  SELECT
83
83
  t.agent_id,
84
84
  t.workspace_id,
@@ -86,11 +86,11 @@ ${r.join(`
86
86
  COALESCE(SUM(
87
87
  COALESCE(t.input_tokens, 0)
88
88
  + CASE
89
- WHEN t.started_at >= ${Ue}
89
+ WHEN t.started_at >= ${je}
90
90
  AND (
91
91
  t.crewx_version IS NULL
92
92
  OR (t.crewx_version LIKE '0.8.%' AND t.crewx_version NOT LIKE '0.8.9%')
93
- OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${je}) AS INTEGER) < ${He})
93
+ OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${He}) AS INTEGER) < ${Fe})
94
94
  )
95
95
  THEN COALESCE(t.cached_input_tokens, 0)
96
96
  ELSE 0
@@ -109,11 +109,11 @@ ${r.join(`
109
109
  COALESCE(SUM(
110
110
  COALESCE(t.input_tokens, 0)
111
111
  + CASE
112
- WHEN t.started_at >= ${Ue}
112
+ WHEN t.started_at >= ${je}
113
113
  AND (
114
114
  t.crewx_version IS NULL
115
115
  OR (t.crewx_version LIKE '0.8.%' AND t.crewx_version NOT LIKE '0.8.9%')
116
- OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${je}) AS INTEGER) < ${He})
116
+ OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${He}) AS INTEGER) < ${Fe})
117
117
  )
118
118
  THEN COALESCE(t.cached_input_tokens, 0)
119
119
  ELSE 0
@@ -129,11 +129,11 @@ ${r.join(`
129
129
  COALESCE(SUM(
130
130
  COALESCE(t.input_tokens, 0)
131
131
  + CASE
132
- WHEN t.started_at >= ${Ue}
132
+ WHEN t.started_at >= ${je}
133
133
  AND (
134
134
  t.crewx_version IS NULL
135
135
  OR (t.crewx_version LIKE '0.8.%' AND t.crewx_version NOT LIKE '0.8.9%')
136
- OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${je}) AS INTEGER) < ${He})
136
+ OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${He}) AS INTEGER) < ${Fe})
137
137
  )
138
138
  THEN COALESCE(t.cached_input_tokens, 0)
139
139
  ELSE 0
@@ -151,11 +151,11 @@ ${r.join(`
151
151
  COALESCE(SUM(
152
152
  COALESCE(t.input_tokens, 0)
153
153
  + CASE
154
- WHEN t.started_at >= ${Ue}
154
+ WHEN t.started_at >= ${je}
155
155
  AND (
156
156
  t.crewx_version IS NULL
157
157
  OR (t.crewx_version LIKE '0.8.%' AND t.crewx_version NOT LIKE '0.8.9%')
158
- OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${je}) AS INTEGER) < ${He})
158
+ OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${He}) AS INTEGER) < ${Fe})
159
159
  )
160
160
  THEN COALESCE(t.cached_input_tokens, 0)
161
161
  ELSE 0
@@ -163,18 +163,18 @@ ${r.join(`
163
163
  ), 0)
164
164
  + COALESCE(SUM(t.output_tokens), 0)
165
165
  ) DESC
166
- `).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,totalTokens:i.input_tokens+i.output_tokens}))}catch(s){throw new N("DB_ERROR","Failed to get agent usage",s)}finally{o.close();}}getAgentUsageTrendRaw(e,t,r){if(!this.dbExists())return [];let o=this.openHandle(false);try{return o.db.all(r?drizzleOrm.sql`
166
+ `).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,totalTokens:i.input_tokens+i.output_tokens}))}catch(s){throw new M("DB_ERROR","Failed to get agent usage",s)}finally{o.close();}}getAgentUsageTrendRaw(e,t,r){if(!this.dbExists())return [];let o=this.openHandle(false);try{return o.db.all(r?drizzleOrm.sql`
167
167
  SELECT
168
168
  date(t.started_at) AS date,
169
169
  t.agent_id,
170
170
  COALESCE(SUM(
171
171
  COALESCE(t.input_tokens, 0)
172
172
  + CASE
173
- WHEN t.started_at >= ${Ue}
173
+ WHEN t.started_at >= ${je}
174
174
  AND (
175
175
  t.crewx_version IS NULL
176
176
  OR (t.crewx_version LIKE '0.8.%' AND t.crewx_version NOT LIKE '0.8.9%')
177
- OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${je}) AS INTEGER) < ${He})
177
+ OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${He}) AS INTEGER) < ${Fe})
178
178
  )
179
179
  THEN COALESCE(t.cached_input_tokens, 0)
180
180
  ELSE 0
@@ -197,11 +197,11 @@ ${r.join(`
197
197
  COALESCE(SUM(
198
198
  COALESCE(t.input_tokens, 0)
199
199
  + CASE
200
- WHEN t.started_at >= ${Ue}
200
+ WHEN t.started_at >= ${je}
201
201
  AND (
202
202
  t.crewx_version IS NULL
203
203
  OR (t.crewx_version LIKE '0.8.%' AND t.crewx_version NOT LIKE '0.8.9%')
204
- OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${je}) AS INTEGER) < ${He})
204
+ OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${He}) AS INTEGER) < ${Fe})
205
205
  )
206
206
  THEN COALESCE(t.cached_input_tokens, 0)
207
207
  ELSE 0
@@ -216,7 +216,7 @@ ${r.join(`
216
216
  AND t.started_at < ${t}
217
217
  GROUP BY date(t.started_at), t.agent_id
218
218
  ORDER BY date(t.started_at) ASC
219
- `).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,totalTokens:i.input_tokens+i.output_tokens}))}catch(s){throw new N("DB_ERROR","Failed to get agent usage trend",s)}finally{o.close();}}findTaskForStop(e,t){if(!this.dbExists())return;let r=this.openHandle(false);try{return r.db.select().from(m).where(drizzleOrm.and(drizzleOrm.eq(m.id,e),drizzleOrm.eq(m.workspace_id,t))).limit(1).get()??void 0}catch(o){throw new N("DB_ERROR","Failed to find task for stop",o)}finally{r.close();}}markTaskFailed(e,t,r){if(!this.dbExists())return;let o=this.openHandle(true);try{let s=new Date().toISOString(),i=r?drizzleOrm.and(drizzleOrm.eq(m.id,e),drizzleOrm.eq(m.status,"running"),drizzleOrm.eq(m.workspace_id,r)):drizzleOrm.and(drizzleOrm.eq(m.id,e),drizzleOrm.eq(m.status,"running"));o.db.update(m).set({status:"failed",error:t,completed_at:s}).where(i).run();}catch(s){throw s instanceof N?s:new N("DB_ERROR","Failed to mark task failed",s)}finally{o.close();}}findTasksByPromptHint(e,t){let r=this.resolveDbPaths(),o=new Set,s=[];for(let i of r){if(!to.existsSync(i))continue;let a=xe(i);try{let d=t?drizzleOrm.and(drizzleOrm.like(m.prompt,`%${e}%`),drizzleOrm.eq(m.workspace_id,t)):drizzleOrm.like(m.prompt,`%${e}%`),l=a.db.select().from(m).where(d).orderBy(drizzleOrm.asc(m.started_at)).all();for(let u of l)o.has(u.id)||(o.add(u.id),s.push(u));}catch(d){throw new N("DB_ERROR","Failed to find tasks by prompt hint",d)}finally{a.close();}}return s}getProviderUsage(e,t,r){if(!this.dbExists())return [];let o=this.openHandle(false);try{let s=drizzleOrm.sql`
219
+ `).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,totalTokens:i.input_tokens+i.output_tokens}))}catch(s){throw new M("DB_ERROR","Failed to get agent usage trend",s)}finally{o.close();}}findTaskForStop(e,t){if(!this.dbExists())return;let r=this.openHandle(false);try{return r.db.select().from(m).where(drizzleOrm.and(drizzleOrm.eq(m.id,e),drizzleOrm.eq(m.workspace_id,t))).limit(1).get()??void 0}catch(o){throw new M("DB_ERROR","Failed to find task for stop",o)}finally{r.close();}}markTaskFailed(e,t,r){if(!this.dbExists())return;let o=this.openHandle(true);try{let s=new Date().toISOString(),i=r?drizzleOrm.and(drizzleOrm.eq(m.id,e),drizzleOrm.eq(m.status,"running"),drizzleOrm.eq(m.workspace_id,r)):drizzleOrm.and(drizzleOrm.eq(m.id,e),drizzleOrm.eq(m.status,"running"));o.db.update(m).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{o.close();}}findTasksByPromptHint(e,t){let r=this.resolveDbPaths(),o=new Set,s=[];for(let i of r){if(!ro.existsSync(i))continue;let a=ke(i);try{let d=t?drizzleOrm.and(drizzleOrm.like(m.prompt,`%${e}%`),drizzleOrm.eq(m.workspace_id,t)):drizzleOrm.like(m.prompt,`%${e}%`),l=a.db.select().from(m).where(d).orderBy(drizzleOrm.asc(m.started_at)).all();for(let u of l)o.has(u.id)||(o.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}getProviderUsage(e,t,r){if(!this.dbExists())return [];let o=this.openHandle(false);try{let s=drizzleOrm.sql`
220
220
  CASE
221
221
  WHEN ${m.model} LIKE 'claude-%' OR ${m.model} IN ('opus', 'sonnet', 'haiku', 'opus[1m]', 'sonnet[1m]') THEN 'claude'
222
222
  WHEN ${m.model} LIKE 'gpt-%' OR ${m.model} LIKE 'codex-%' THEN 'codex'
@@ -229,11 +229,11 @@ ${r.join(`
229
229
  `,i=drizzleOrm.sql`
230
230
  COALESCE(${m.input_tokens}, 0)
231
231
  + CASE
232
- WHEN ${m.started_at} >= ${Ue}
232
+ WHEN ${m.started_at} >= ${je}
233
233
  AND (
234
234
  ${m.crewx_version} IS NULL
235
235
  OR (${m.crewx_version} LIKE '0.8.%' AND ${m.crewx_version} NOT LIKE '0.8.9%')
236
- OR (${m.crewx_version} LIKE '0.8.9-rc.%' AND CAST(SUBSTR(${m.crewx_version}, ${je}) AS INTEGER) < ${He})
236
+ OR (${m.crewx_version} LIKE '0.8.9-rc.%' AND CAST(SUBSTR(${m.crewx_version}, ${He}) AS INTEGER) < ${Fe})
237
237
  )
238
238
  THEN COALESCE(${m.cached_input_tokens}, 0)
239
239
  ELSE 0
@@ -252,15 +252,15 @@ ${r.join(`
252
252
  ${a}
253
253
  GROUP BY provider
254
254
  ORDER BY (COALESCE(SUM(${i}), 0) + COALESCE(SUM(${m.output_tokens}), 0)) DESC
255
- `).map(l=>({provider:l.provider,totalTasks:l.total_tasks,inputTokens:l.input_tokens,outputTokens:l.output_tokens,cachedInputTokens:l.cached_input_tokens,costUsd:l.cost_usd,totalTokens:l.input_tokens+l.output_tokens,activeDurationMs:l.active_duration_ms??0,lastActiveAt:l.last_active_at??null}))}catch(s){throw new N("DB_ERROR","Failed to get provider usage",s)}finally{o.close();}}};var Wi=new Set(["Read","Grep","Find","Glob"]),zi=["git status","git log","git branch","git diff --stat","git show","git remote","git rev-parse","git ls-files","pwd","ls ","echo ","cat ","head ","tail ","npx crewx memory index","npx crewx memory find","npx crewx memory get","npx crewx doc toc","npx crewx doc section","npx crewx doc status","npx crewx search","npx skill tsserver find","npx skill tsserver refs","npx skill tsserver type","crewx memory index","crewx memory find","crewx memory get","crewx doc toc","crewx doc section","crewx doc status","crewx search","crewx agent ls","crewx agent list"],Ki=[/\bgit\s+(commit|push|pull|merge|rebase|reset|checkout|switch|add|rm)\b/,/\bnpm\s+(install|ci|publish|run\s+(test|lint|build))\b/,/\bnpx\s+tsc\b/,/\bpnpm\s+(install|run)\b/,/\bvitest\b/,/\bjest\b/];function Vi(n){let e=n.toLowerCase();return e==="bash"||e==="terminal"?"Bash":e==="read"||e==="view"?"Read":e==="edit"||e==="apply_patch"?"Edit":e==="write"?"Write":e==="grep"||e==="rg"?"Grep":e==="glob"||e==="find"?"Find":n}function Gi(n,e){if(Wi.has(n))return true;if(n!=="Bash"||!e)return false;let t=e.split(`
256
- `)[0].trimStart();return Ki.some(r=>r.test(t))?false:zi.some(r=>t.startsWith(r))}function Vt(n){return n.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;")}function Xi(n,e,t){if(n!=="Read"||!e)return "ok";let o=e.split(`
257
- `).find(s=>s.trim()&&!s.startsWith("Read "))?.trim()??e.trim();if(!o)return "unknown";try{let s=to__namespace.statSync(o);if(t){let i=Date.parse(t);if(!Number.isNaN(i)&&s.mtimeMs>i)return "stale"}return "ok"}catch{return "unknown"}}function Ji(n){let e=new Set;for(let t of n)try{let r=JSON.parse(t);r.type&&e.add(r.type);}catch{}return e.has("turn.started")||e.has("thread.started")?"codex":e.has("assistant.message_delta")?"copilot":e.has("step_start")&&e.has("step_finish")?"opencode":e.has("system")&&e.has("result")?"claude":e.has("init")&&e.has("message")?"gemini":e.has("result")&&e.has("assistant")?"claude":null}function Yi(n){if(!Array.isArray(n))return [];let e=n,t=e.filter(a=>a.level==="stdout"&&a.message).map(a=>a.message),r=Ji(t),o=[];for(let a of e)a.level==="info"&&a.message?o.push(...de(a.message,a.timestamp)):a.level==="stdout"&&a.message&&r&&o.push(...st("",a.message,r));let s=new Map,i=[];for(let a of o)if(a.type==="tool_use"){let d={tool:Vi(a.toolName??""),input:a.toolInput??null,result:null,isError:false},l=a.toolUseId;if(l){if(s.has(l)){s.get(l).input=d.input;continue}s.set(l,d);}i.push(d);}else if(a.type==="tool_result"){if(a.toolUseId&&s.has(a.toolUseId)){let d=s.get(a.toolUseId);d.isError=a.isError===true,d.result=a.resultPreview??null;}else for(let d=i.length-1;d>=0;d--)if(i[d].result===null){i[d].isError=a.isError===true,i[d].result=a.resultPreview??null;break}}return i}function Qi(n,e){let t=Yi(n),r=[];for(let o of t){let s=o.tool==="Bash"?o.input?.split(`
258
- `)[0]?.slice(0,150)??null:o.input?.slice(0,150)??null,i=Gi(o.tool,o.input)&&!o.isError;r.push({tool:o.tool,cmd:s,result:o.result,status:Xi(o.tool,o.input,e),reusable:i});}return r}function Zi(n,e,t){let r=["<activity_log>"];if(n.length===0&&e===0)r.push(" <!-- no activity found in previous tasks -->");else {r.push(" <!-- tool activity from previous tasks -->"),e>0&&r.push(` <!-- ${e} entries omitted (cap) -->`);for(let o of n){let s=`tool="${Vt(o.tool)}"`,i=o.cmd?` cmd="${Vt(o.cmd)}"`:"",a="";if(o.reusable&&(a=o.status==="stale"?' reused="stale"':' reused="ok"'),o.reusable&&o.status==="stale")r.push(` <entry ${s}${i}${a}>\u26A0\uFE0F changed since \u2014 re-read</entry>`);else if(o.result){r.push(` <entry ${s}${i}${a}>`);let d=t&&t>0?t:8e3,l=o.result;l.length>d?r.push(Vt(l.slice(0,d))+` \u2026 [truncated, ${d}/${l.length} chars shown]`):r.push(Vt(l)),r.push(" </entry>");}else r.push(` <entry ${s}${i}${a} />`);}}return r.push("</activity_log>"),r}function ro(n){let{threadId:e,agentId:t,lookback:r,maxEntryChars:o}=n;if(!r||!e||!t)return new Map;let s;try{s=new ft().findTasksByThread(e).filter(l=>!l.parent_task_id&&l.agent_id===t).sort((l,u)=>u.started_at>l.started_at?1:-1).slice(0,Math.min(r,5));}catch{return new Map}if(!s.length)return new Map;let i=[];for(let d of s){let l=[];try{let u=JSON.parse(d.logs??"[]");Array.isArray(u)&&(l=u);}catch{}i.push({taskId:d.id,entries:Qi(l,d.completed_at)});}let a=new Map;for(let{taskId:d,entries:l}of i){if(l.length===0)continue;let u=Math.max(0,l.length-200),p=u>0?l.slice(u):l,y=Zi(p,u,o);a.set(d,y.join(`
259
- `));}return a}c();c();var ea={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")},ta={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 no(n,e,t){n.tool("crewx_listAgents","List available CrewX agents exposed by this server",async()=>{let r=[];for(let o of t){let s=e.agents.get(o);s&&r.push({id:s.id,name:s.name??s.id,description:s.description??""});}return {content:[{type:"text",text:JSON.stringify(r,null,2)}]}}),n.tool("crewx_queryAgent","Query a CrewX agent with a read-only question",ea,async({agentId:r,query:o,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,o,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Query failed"}],isError:true}}),n.tool("crewx_executeAgent","Execute a task on a CrewX agent (may modify state)",ta,async({agentId:r,task:o,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,o,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Execute failed"}],isError:true}});}c();function oo(n){return n.headers.get("Origin")?null:new Response(JSON.stringify({error:"Forbidden: Origin header required"}),{status:403,headers:{"Content-Type":"application/json"}})}async function so(n,e){return e?await e(n)?null:new Response(JSON.stringify({error:"Unauthorized"}),{status:401,headers:{"Content-Type":"application/json"}}):null}function oa(n,e){let t=new mcp_js.McpServer({name:"crewx-mcp-server",version:"1.0.0"},{capabilities:{tools:{}}});return no(t,n,e),t}function $r(n,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 o=>{let s=oo(o);if(s)return s;let i=await so(o,e.auth);if(i)return i;let a=o.headers.get("mcp-session-id");if(a&&r.has(a))return r.get(a).transport.handleRequest(o);let d=oa(n,t),l=new webStandardStreamableHttp_js.WebStandardStreamableHTTPServerTransport({sessionIdGenerator:()=>crypto.randomUUID(),onsessioninitialized:u=>{r.set(u,{transport:l,server:d});},onsessionclosed:u=>{r.delete(u);},enableJsonResponse:true});return await d.connect(l),l.handleRequest(o)}}c();function ao(n){let e=V__namespace.resolve(n);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 Ur(n){let e=ao(n);return crypto$1.createHash("sha256").update(e).digest("hex")}function Ia(n){return n?n.settings?.template?.exec:void 0}function Oa(){try{let n=new Uint8Array(8);return globalThis.crypto.getRandomValues(n),Array.from(n,e=>e.toString(16).padStart(2,"0")).join("")}catch{let{randomBytes:n}=J("crypto");return n(8).toString("hex")}}var Zr=class n extends gt{_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,o,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=Ur(i),this._workspaceName=V.basename(i);let a=Ia(r);this._templateEngine=new dt({execPolicy:t.execPolicy??a}),this._documentLoader=o??new Ie,this._layoutLoader=new lt({templatesPath:We()}),this._layoutRenderer=new pt,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 o=r.slice(7),s=this.getRemoteProviderConfig(o);if(!s?.location?.startsWith("file://"))return null;let i=V.resolve(s.location.replace("file://","")),a=s.external_agent_id??e.replace(/^@/,""),d=this._remoteTargets.get(i);d||(d=(this._remoteFactory??(g=>n.loadYaml(g)))(i),this._remoteTargets.set(i,d),d.catch(()=>this._remoteTargets.delete(i)));let l=await d,u=l.getAgent("@"+a),p=Array.isArray(u?.provider)?u?.provider[0]:u?.provider;if(p?.startsWith("remote/"))throw new Error(`Chained remotes not allowed: "${o}" \u2192 "${p}"`);return {target:l,agentRef:"@"+a}}static async loadBuiltInConfig(e){let{yamlPath:t,dir:r}=sr(),o;try{o=to.readFileSync(t,"utf-8");}catch(i){throw new Error(`[@crewx/sdk] Cannot read built-in config: ${t}
260
- ${i.message}`)}let s=Tt(o);if(s.documents&&typeof s.documents=="object"){let i={};for(let[a,d]of Object.entries(s.documents))if(d&&typeof d=="object"){let l=d;typeof l.path=="string"&&!V.isAbsolute(l.path)?i[a]={...l,path:V.resolve(r,l.path)}:i[a]=l;}else i[a]=d;return {...s,documents:i}}return s}static mergeCrewxConfig(e,t){let r=new Map;for(let _ of e.agents??[])r.set(_.id,_);for(let _ of t.agents??[])r.has(_.id)&&console.warn(`[agent-loader] User agent "${_.id}" overrides built-in`),r.set(_.id,_);let o=Array.from(r.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,d=t,l=Co(a.vars,d.vars),u=Co(a.settings,d.settings),p;e.skills&&t.skills&&typeof e.skills=="object"&&typeof t.skills=="object"&&!Array.isArray(e.skills)&&!Array.isArray(t.skills)?p={...e.skills,...t.skills}:p=t.skills??e.skills;let y=[...e.hooks??[],...t.hooks??[]],g=Ma(a.providers,d.providers),h={...e},k={...t};for(let _ of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete h[_],delete k[_];let w={...{...h,...k},agents:o,layouts:s,documents:i,skills:p};return y.length>0&&(w.hooks=y),l!==void 0&&(w.vars=l),u!==void 0&&(w.settings=u),g!==void 0&&(w.providers=g),w}static async loadYaml(e,t,r){let o=t?.includeBuiltIns!==false,s,i;if(o){let u=await n.loadBuiltInConfig(r);if(e!==void 0){let p=Pt(e);s=n.mergeCrewxConfig(u,p),i=V.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=V.dirname(e);}let a=new Ie(r);await a.load(s.documents,i);let d=s.agents??[];return await To(d,s,t),new n(d,t??{},s,a,i)}static async fromConfig(e,t,r,o){let s=t?.includeBuiltIns===true,i=e;if(s){let u=await n.loadBuiltInConfig(o);i=n.mergeCrewxConfig(u,e);}let a=new Ie(o);await a.load(i.documents,r??(typeof process<"u"?process.cwd():"/"));let d=i.agents??[];return await To(d,i,t),new n(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(o=>o.type==="remote"&&o.id===e):void 0}computeTaskLogPath(e,t){let r=Er(t);return V.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 $r(this,e)}async registerChannelAdapter(e){let{adapter:t,instanceId:r,config:o}=e;if(this._activeAdapters.has(r))throw new Error(`Adapter instance already registered: ${r}`);let s=new Set(t.manifest.capabilities),i=e.store??Cr(r),a=e.defaultMode??"query",d=t.manifest.platform,l=e.agentRunner??{run:async(g,h,k)=>{let w=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${g}`,h,{threadId:k?.threadId,platform:d});return {output:w.ok?w.data:w.error?.message??""}}},u=e.onInbound??(async g=>{let h=g.routingHints?.agentId??e.defaultAgent;if(!h)return {accepted:false,reason:"no_agent"};let{output:k}=await l.run(h,g.text,{threadId:g.threadId});return {accepted:true,output:k}}),p=Pr({instanceId:r,config:o,capabilities:s,db:i,agentRunner:l,onInbound:u}),y={adapter:t,ctx:p,state:"starting"};this._activeAdapters.set(r,y),this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"starting",timestamp:new Date});try{await t.start(p),y.state="started",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"started",timestamp:new Date});}catch(g){throw y.state="failed",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"failed",error:g instanceof Error?g:new Error(String(g)),timestamp:new Date}),this._activeAdapters.delete(r),g}}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()),o=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<o.length;s++)o[s].status==="rejected"&&console.error(`[crewx] adapter stop error (${r[s]}): ${o[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(o){console.error(`[crewx] remote target close error: ${o instanceof Error?o.message:String(o)}`);}}));let t=[...this._plugins].reverse();for(let r of t)try{await r.detach(this);}catch(o){console.error(`[crewx] plugin ${r.name} detach error: ${o instanceof Error?o.message:String(o)}`);}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),o=t(e.team),s=t(e.provider),i=Array.from(this._agents.values());return r&&(i=i.filter(a=>a.role&&r.some(d=>ce(a.role.toLowerCase(),d)))),o&&(i=i.filter(a=>a.team&&o.some(d=>ce(a.team.toLowerCase(),d)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(l=>s.some(u=>ce(l.toLowerCase(),u))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,r=this._agents.get(t);if(!r)throw new me(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 o={...await this._documentLoader.buildContext(),...t?.documents??{}},s={...t,documents:o};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,o=this._agents.get(r);if(!o)throw new me(r,Array.from(this._agents.keys()));let s=this._resolveLayoutSpec(o,t?.layout),i=this._extractLayoutId(s),a=this._extractLayoutProps(o,s,t?.layout),d=this._layoutLoader.load(i,a),l=o.inline?.prompt??o.inline?.system_prompt??o.description??`You are an expert ${r}.`,u=await this._documentLoader.buildContext(),p=t?.env??(typeof process<"u"?process.env:{}),y=t?.vars?.security_key??Oa(),g={...t?.vars??{},documents:u,env:p,agent:{id:o.id,name:o.name??o.id,role:o.role??"",team:o.team??"",description:o.description??""}},h=await this._templateEngine.render(l,g),k={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},v=o.provider,w=Array.isArray(v)?v:typeof v=="string"&&v.length>0?[v]:[],_=w.join(", ")||(typeof v=="string"?v:""),x=o.options,I=["goals","daily"],P={goals:false,daily:false},z;if(!Array.isArray(x)&&typeof x=="object"&&x!==null){let S=x;if("goals"in S){let le=S.goals;typeof le=="string"||Array.isArray(le)?P.goals=le:P.goals=!!le;}"daily"in S&&(P.daily=!!S.daily);let q={};for(let[le,Ze]of Object.entries(S))I.includes(le)||(q[le]=Ze);if(Object.keys(q).length>0){let le=w.some(nr=>nr.startsWith("cli/")),Ze={};for(let[nr,et]of Object.entries(q)){let Be={};if(Array.isArray(et))le&&(Be.rawArgs=et);else if(typeof et=="object"&&et!==null){let fn=et;Object.keys(fn).length>0&&(Be.named=fn);}(Be.named||Be.rawArgs&&Be.rawArgs.length>0)&&(Ze[nr]=Be);}z=Object.keys(Ze).length>0?Ze:void 0;}}let H=Array.isArray(x)?x:void 0,A={};for(let[S,q]of Object.entries(u))A[S]={content:q.content??"",toc:q.toc,summary:q.summary,path:q.path};if(P.goals){let S=V.join(this._projectRoot,"docs","goal"),q=await Wn(S,void 0,P.goals);q&&(A.active_goals={content:q});}if(P.daily){let S=V.join(this._projectRoot,"docs","daily"),q=await zn(S);q&&(A.today_daily={content:q});}let U=t?.vars?.user_input??void 0,W=this._config?.settings?.dreaming?.continuity,F=W?.reuseReadOnly!==false,G=typeof W?.lookback=="number"?W.lookback:5,E=typeof W?.maxEntryChars=="number"?W.maxEntryChars:8e3,b=t?.threadId??"",O=o.id,R=F&&G>0&&b&&t?.messages&&t.messages.length>0?ro({threadId:b,agentId:O,lookback:G,maxEntryChars:E}):new Map,j=(t?.messages??[]).map(S=>{if(!S.isAssistant)return S;let q=S.metadata?.task_id;return !q||!R.has(q)?S:{...S,activity_log:R.get(q)}}),X={user_input:U,agent:{id:o.id,name:o.name??o.id,role:o.role??"",team:o.team??"",description:o.description??"",provider:_,providerList:w,model:o.inline?.model,workingDirectory:o.working_directory??o.workingDirectory??".",inline:{...o.inline??{},prompt:h},specialties:o.specialties??[],capabilities:o.capabilities??[],remote:o.remote??null,optionsByMode:z,optionsArray:H},agentMetadata:{specialties:o.specialties??[],capabilities:o.capabilities??[],description:o.description??""},contextOptions:P,documents:A,skills:t?.skills??[],session:k,env:p,vars:{security_key:y,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:k.platform,mode:k.mode,thread_id:b,now:ct(new Date),has_activity_log:R.size>0,messages:j,tools:this._tools.size>0?{list:Array.from(this._tools.values()).map(S=>({name:S.name,description:S.description,parameters:S.parameters})),json:JSON.stringify(Array.from(this._tools.values()).map(S=>({name:S.name,description:S.description,parameters:S.parameters})),null,2),count:this._tools.size}:null,metadata:{}};return this._layoutRenderer.render(d,X)}_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 o=this._config?.layouts?.default;return typeof o=="string"&&o?o:"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 o=e.inline?.layout,s=o&&typeof o=="object"&&"props"in o?o.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 o=this._getConversationProvider();if(o)try{let s=await o.fetchHistory(e,{currentTraceId:t});return s.messages.length===0?void 0:Sr(s)}catch{return}}_resolveTimeout(e,t){let r=e==="query"?"CREWX_TIMEOUT_QUERY":"CREWX_TIMEOUT_EXECUTE";if(process.env[r]!=null&&process.env[r]!==""){let o=On();return e==="query"?o.queryMs:o.executeMs}if(t?.meta?.defaultTimeoutMs){let o=e==="query"?t.meta.defaultTimeoutMs.query:t.meta.defaultTimeoutMs.execute;if(o!==void 0)return o}return 8*36e5}_lookupCliAdapter(e){if(e.startsWith("cli/"))return exports.BUILTIN_ADAPTERS[e.slice(4)]}_resolveEffectiveCwd(e,t){return t?.cwd??(e.working_directory?V.resolve(this._projectRoot,e.working_directory):this._projectRoot)}_buildFileRemoteOptions(e,t){let r={path:this._projectRoot,id:this._workspaceId,name:this._workspaceName,agentRef:e};return {...t,cwd:void 0,metadata:{...t?.metadata??{},crewx:{...t?.metadata?.crewx??{},callerWorkspace:r}},vars:{...t?.vars??{},crewx_caller_workspace_path:r.path,crewx_caller_workspace_id:r.id,crewx_caller_workspace_name:r.name}}}emitToolEvents(e,t,r,o,s,i,a){try{let l=exports.BUILTIN_ADAPTERS[r]?.parseEvent?.(o)??st(new Date().toISOString(),o);for(let u of l)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,o,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:o,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:o,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 o=await this.resolveFileRemoteTarget(e);if(o)return o.target.query(o.agentRef,t,this._buildFileRemoteOptions(e,r));let s=mt.getStore()??br(r?.trace),i=r?.taskId??Me("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return mt.run(d,async()=>{let l=Date.now(),u=new Date,p;try{p=St(e,Array.from(this._agents.values()));}catch(E){if(E instanceof me){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 b=Date.now()-l,O={code:"AGENT_NOT_FOUND",message:E.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:b,error:O,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:O,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:b}}}throw E}d.callerAgentId=p.id;let y=Array.isArray(p.provider)?p.provider[0]??"cli/claude":p.provider,g=r?.provider??y,h=r?.model??p.inline?.model;h&&h.includes("{{")&&(h=await this._templateEngine.render(h,{...r?.vars??{}}));let k;try{k=he(g);}catch(E){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 b=Date.now()-l,O={code:"PROVIDER_ERROR",message:E.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:b,error:O,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:O,meta:{agentId:p.id,provider:g,model:h,durationMs:b}}}let v=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),w;try{w=await this.renderAgentPromptFull(e,{session:{mode:"query",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:v,threadId:r?.threadId});}catch(E){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${E instanceof Error?E.message:String(E)}`);}let _,x,I,P=h,z=false,H=E=>{z||(z=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",pid:E,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:P,provider:g,codingAgentCommand:_,renderedPrompt:w,metadata:{...r?.metadata??{},provider:g},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},A=p.options,U=Array.isArray(A?.query?.tools)?A.query.tools:void 0,K=this._tools.size>0?this._filterToolsByMode(U):[],B=(()=>{let E=A?.query;if(!E||Array.isArray(E))return;let{tools:b,effort:O,mode:R,...j}=E,X=Object.entries(j).filter(([,S])=>S!=null);if(X.length!==0)return Object.fromEntries(X.map(([S,q])=>[S,String(q)]))})(),W=p.inline?.max_steps;g.startsWith("api/")&&H();let F=false,G=0;try{let E=await k.query(t,{model:h,effort:A?.query?.effort,mode:A?.query?.mode,context:r?.context,systemPrompt:w??p.inline?.system_prompt??p.inline?.prompt??p.description??`You are ${p.id}.`,additionalArgs:Array.isArray(A?.query)?A.query:void 0,tools:K.length>0?K:void 0,maxSteps:W,configOptions:B,timeoutMs:this._resolveTimeout("query",this._lookupCliAdapter(g)),cwd:this._resolveEffectiveCwd(p,r),env:{CREWX_AGENT_ID:p.id,CREWX_AGENT_ROLE:p.role??"",CREWX_AGENT_TEAM:p.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:g,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,u)},onPid:R=>H(R),onOutput:(R,j)=>{let X=exports.BUILTIN_ADAPTERS[g];j==="stdout"&&X?.suppressOutputLine?.(R)===!0||this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:R,level:j}),j==="stdout"&&this.emitToolEvents(i,e,g,R,p.id,r?.threadId??"","");},onTaskLog:R=>{this.emitTaskLogEntries(i,e,p.id,r?.threadId??"","",g,R);for(let j of R)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(j),level:"info"});},onCommand:R=>{_=R;},onUsage:R=>{x=R;},onExitCode:R=>{I=R;},onModel:R=>{P||(P=R);}});G=wr(x?.costUsd,x?.inputTokens,x?.outputTokens,x?.cachedInputTokens,P),H();let b=Date.now()-l,O={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:E,durationMs:b,exitCode:I,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:G,model:P,metadata:Object.keys(O).length>0?O:void 0}),F=!0,{ok:!0,data:E,meta:{agentId:p.id,provider:g,model:h,durationMs:b,taskId:i}}}catch(E){if(E instanceof exports.ClientToolCallRequiredError){let R=Me("thd");return this._pendingThreads.set(R,{agentRef:p.id,providerStr:g,continuationState:E.continuationState,toolCall:E.toolCall,traceId:i,startMs:l,model:h}),F=true,{ok:true,status:"requires_action",data:"",toolCall:E.toolCall,threadId:R,meta:{agentId:p.id,provider:g,model:h,durationMs:Date.now()-l,taskId:i}}}H();let b=Date.now()-l,O={code:"QUERY_FAILED",message:E.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:b,error:O,exitCode:I,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:G,model:P,metadata:r?.metadata?{...r.metadata}:void 0}),F=true,{ok:false,data:"",error:O,meta:{agentId:p.id,provider:g,model:h,durationMs:b,taskId:i}}}finally{F||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:Date.now()-l,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:I??-1,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:G,model:P});}})}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 o=he(r.providerStr);if(!o.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 o.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 o=await this.resolveFileRemoteTarget(e);if(o)return o.target.execute(o.agentRef,t,this._buildFileRemoteOptions(e,r));let s=mt.getStore()??br(r?.trace),i=r?.taskId??Me("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return mt.run(d,async()=>{let l=Date.now(),u=new Date,p;try{p=St(e,Array.from(this._agents.values()));}catch(E){if(E instanceof me){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 b=Date.now()-l,O={code:"AGENT_NOT_FOUND",message:E.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:b,error:O,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:O,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:b}}}throw E}d.callerAgentId=p.id;let y=Array.isArray(p.provider)?p.provider[0]??"cli/claude":p.provider,g=r?.provider??y,h=r?.model??p.inline?.model;h&&h.includes("{{")&&(h=await this._templateEngine.render(h,{...r?.vars??{}}));let k;try{k=he(g);}catch(E){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 b=Date.now()-l,O={code:"PROVIDER_ERROR",message:E.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:b,error:O,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:O,meta:{agentId:p.id,provider:g,model:h,durationMs:b}}}let v=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),w;try{w=await this.renderAgentPromptFull(e,{session:{mode:"execute",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:v,threadId:r?.threadId});}catch(E){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${E instanceof Error?E.message:String(E)}`);}let _,x,I,P=h,z=false,H=E=>{z||(z=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",pid:E,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:P,provider:g,codingAgentCommand:_,renderedPrompt:w,metadata:{...r?.metadata??{},provider:g},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},A=p.options,U=Array.isArray(A?.execute?.tools)?A.execute.tools:void 0,K=this._tools.size>0?this._filterToolsByMode(U):[],B=(()=>{let E=A?.execute;if(!E||Array.isArray(E))return;let{tools:b,effort:O,mode:R,...j}=E,X=Object.entries(j).filter(([,S])=>S!=null);if(X.length!==0)return Object.fromEntries(X.map(([S,q])=>[S,String(q)]))})(),W=p.inline?.max_steps;g.startsWith("api/")&&H();let F=false,G=0;try{let E=await k.execute(t,{model:h,effort:A?.execute?.effort,mode:A?.execute?.mode,context:r?.context,systemPrompt:w??p.inline?.system_prompt??p.inline?.prompt??p.description??`You are ${p.id}.`,additionalArgs:Array.isArray(A?.execute)?A.execute:void 0,tools:K.length>0?K:void 0,maxSteps:W,configOptions:B,timeoutMs:this._resolveTimeout("execute",this._lookupCliAdapter(g)),cwd:this._resolveEffectiveCwd(p,r),env:{CREWX_AGENT_ID:p.id,CREWX_AGENT_ROLE:p.role??"",CREWX_AGENT_TEAM:p.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:g,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,u)},onPid:R=>H(R),onOutput:(R,j)=>{let X=exports.BUILTIN_ADAPTERS[g];j==="stdout"&&X?.suppressOutputLine?.(R)===!0||this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:R,level:j}),j==="stdout"&&this.emitToolEvents(i,e,g,R,p.id,r?.threadId??"","");},onTaskLog:R=>{this.emitTaskLogEntries(i,e,p.id,r?.threadId??"","",g,R);for(let j of R)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(j),level:"info"});},onCommand:R=>{_=R;},onUsage:R=>{x=R;},onExitCode:R=>{I=R;},onModel:R=>{P||(P=R);}});G=wr(x?.costUsd,x?.inputTokens,x?.outputTokens,x?.cachedInputTokens,P),H();let b=Date.now()-l,O={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:E,durationMs:b,exitCode:I,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:G,model:P,metadata:Object.keys(O).length>0?O:void 0}),F=!0,{ok:!0,data:E,meta:{agentId:p.id,provider:g,model:h,durationMs:b,taskId:i}}}catch(E){H();let b=Date.now()-l,O={code:"EXECUTE_FAILED",message:E.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:b,error:O,exitCode:I,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:G,model:P,metadata:r?.metadata?{...r.metadata}:void 0}),F=true,{ok:false,data:"",error:O,meta:{agentId:p.id,provider:g,model:h,durationMs:b}}}finally{F||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:Date.now()-l,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:I??-1,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:G,model:P});}})}};function Co(n,e){let t=en(n)?n:void 0,r=en(e)?e:void 0;if(!(!t&&!r))return {...t??{},...r??{}}}function en(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function Ma(n,e){let t=Array.isArray(n)?n:void 0,r=Array.isArray(e)?e:void 0;if(!t&&!r)return;let o=a=>{if(!en(a))return;let d=a.id;if(typeof d=="string")return `id:${d}`;let l=a.name;if(typeof l=="string")return `name:${l}`},s=new Set;for(let a of r??[]){let d=o(a);d&&s.add(d);}let i=[];for(let a of t??[]){let d=o(a);d&&s.has(d)||i.push(a);}for(let a of r??[])i.push(a);return i}async function To(n,e,t){if(n.some(o=>(Array.isArray(o.provider)?o.provider:[o.provider]).some(i=>i.startsWith("api/")))){let{registerApiProviders:o}=await Promise.resolve().then(()=>(Hr(),po));o(t?.api);}await Da(n,e),La(n,e),Na(n);}function Na(n){if(!n.some(r=>(Array.isArray(r.provider)?r.provider:[r.provider]).some(s=>s.startsWith("acp/"))))return;let{registerAcpProviders:t}=(Kr(),yn(wo));t();}async function Da(n,e){if(!n.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:o}=await Promise.resolve().then(()=>(Xr(),ko)),s=new Map;for(let i of r)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&ye("remote",o(s,he));}function La(n,e){if(!n.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:o}=(Jr(),yn(Ro)),s=new Map;for(let i of r)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&ye("plugin",o(s));}c();var tn=class{detach(e){}};c();var $a="crewx:fs:",rn=class{prefix;store;constructor(e){this.prefix=e?.prefix??$a,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("/"),o=[];for(let i of r)i==="."||i===""||(i===".."?o.pop():o.push(i));let s=o.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+"/"),o=[];for(let s of this.store.keys())if(s.startsWith(r)){let a=s.slice(r.length).split("/")[0];a&&!o.includes(a)&&o.push(a);}return o}toKey(e){return `${this.prefix}${e.replace(/\\/g,"/")}`}};c();function Ua(n,e){let t=n.skills?.include;if(t===void 0)return [...e];if(t.length===0)return [];let r=new Set(t);return e.filter(o=>r.has(o))}c();var nn=["codex","claude","opencode","antigravity","copilot"];function ja(n){let e=n.indexOf("/");return e===-1?n:n.slice(e+1)}function on(n){let e=ja(n),t=nn.indexOf(e);return t===-1?nn.length:t}function vt(n,e){return on(n)-on(e)}ue();jr();Hr();c();Fr();Re();c();Gt();er();Jt();var Ha="model",Fa="mode",qa="thought_level";function sn(n){if(n.length===0)return [];if(n[0]?.group!=null){let e=[];for(let t of n)for(let r of t.options??[])e.push(r);return e}return n}function Ba(n,e){let t=new Map;for(let r of [...n,...e]){let o=t.get(r.id);(!o||!o.name&&r.name)&&t.set(r.id,r);}return Array.from(t.values())}function Wa(n,e){let t=new Map;for(let r of [...n,...e])t.has(r.id)||t.set(r.id,r);return Array.from(t.values())}function za(n,e,t,r){let o=t.agentInfo?.name,s=e??o??n,i=r.configOptions??[],d=(r.modes?.availableModes??[]).map(w=>({id:w.id,name:w.name,...w.description!=null?{description:w.description}:{}})),l=[];for(let w of i)if(w.category?.trim().toLowerCase()===Fa&&w.options!=null)for(let _ of sn(w.options))_.value!=null&&l.push({id:_.value,name:_.name??_.value});let u=Wa(d,l),p=[];for(let w of i)if(w.category?.trim().toLowerCase()===qa&&w.type==="select")for(let _ of sn(w.options??[]))_.value!=null&&p.push(_.value);if(n==="claude"){let w=yo.map(x=>({id:x.id,name:x.name})),_=Po(t);return bo(n,{models:w,modes:u,availableModelsCount:0,configModelsCount:0,skipModelWarn:true}),{id:`acp/${n}`,name:s,modes:u,effort:p,models:w,capabilities:_}}let g=(r.models?.availableModels??[]).map(w=>({id:w.modelId})),h=[];for(let w of i)if(w.category?.trim().toLowerCase()===Ha&&w.options!=null)for(let _ of sn(w.options))_.value!=null&&h.push({id:_.value,..._.name!=null?{name:_.name}:{}});let k=Ba(g,h);bo(n,{models:k,modes:u,availableModelsCount:g.length,configModelsCount:h.length,skipModelWarn:false});let v=Po(t);return {id:`acp/${n}`,name:s,modes:u,effort:p,models:k,capabilities:v}}function Po(n){let e=n.agentCapabilities??{};return {loadSession:e.loadSession??false,image:e.promptCapabilities?.image??false,audio:e.promptCapabilities?.audio??false,mcp:e.mcpCapabilities!=null}}function bo(n,e){!e.skipModelWarn&&e.models.length===0&&console.warn(`[acp] ${n} meta: models empty (availableModels=${e.availableModelsCount}, configOptions[model]=${e.configModelsCount})`),e.modes.length===0&&console.warn(`[acp] ${n} meta: modes empty`);}async function So(n){let e=exports.ACP_ADAPTERS[n];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 o=r.initResponse;if(!o)return null;let s=e.buildSessionParams({cwd:process.cwd()}),i=await r.newSessionRaw(s);return za(n,t,o,i)}catch(o){return console.warn(`[acp] ${n} meta query failed: ${o instanceof Error?o.message:String(o)}`),null}finally{await r.dispose();}}async function Ka(){let n=Object.keys(exports.ACP_ADAPTERS),e=await Promise.allSettled(n.map(r=>So(r))),t=[];for(let r of e)r.status==="fulfilled"&&r.value!==null&&t.push(r.value);return t.sort((r,o)=>vt(r.id,o.id))}Gt();qr();er();Kr();ir();Ae();c();Ae();function Va(n){return n.charAt(0).toUpperCase()+n.slice(1)}function Ga(){let n=[];for(let[e,t]of Object.entries(exports.BUILTIN_ADAPTERS))t.meta&&n.push({id:`cli/${e}`,name:t.meta.displayName??Va(e),modes:[],effort:[],models:t.meta.models??[],capabilities:{loadSession:false,image:false,audio:false,mcp:false}});return n.sort((e,t)=>vt(e.id,t.id))}c();var an=0;function Xa(n){let e=Array.from(n.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(an>=3)return "Error: Maximum delegation depth (3) reached. Cannot delegate further.";let r=t.agent,o=t.message,s=t.mode??"query";if(!e.includes(r))return `Error: Unknown agent "${r}". Available: ${e.join(", ")}`;an++;try{if(s==="execute"){let a=await n.execute(r,o);return a.ok?a.data:`Error: ${a.error?.message??"Unknown error"}`}let i=await n.query(r,o);return i.ok?i.data:`Error: ${i.error?.message??"Unknown error"}`}finally{an--;}}}}c();var Io=typeof process<"u"?process.env:{};function Ja(){return Io.CREWX_CLI||"npx crewx"}function Ya(){return Io.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}c();var Qa=/^[a-zA-Z0-9._-]+$/,dn=class{constructor(e){this.storage=e;}storage;listBoxes(e){this.validateId(e);let r=this.storage.listBoxes(e).map(o=>this.toBoxResponse(o));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(),o=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:o});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(!Qa.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return Me("box")}};c();function Za(n,e,t,r,o){let{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}=r,d=s*i,l=s*a,u=d+l,p=e.getThreadMessages(n),y=[],g=0,h=false,k=[];for(let _=0;_<p.length;_+=2){let x=p[_],I=p[_+1],P=x?.content||"",z=I?.content||"",H=o.countTokens(P+z),A=[];x&&A.push(x),I&&A.push(I),k.push({messages:A,tokens:H});}for(let _=k.length-1;_>=0;_--){let x=k[_];if(g+x.tokens>d){h=true;break}g+=x.tokens,y.unshift(...x.messages);}let v=[],w=0;if(h&&l>0)try{let{boxes:_}=t.listBoxes(n);for(let x=_.length-1;x>=0;x--){let I=_[x],P=I.summaryTokens??I.sourceTokens;if(w+P>l)break;w+=P,v.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(_){if(_ instanceof Error&&!/not found/i.test(_.message))throw _}return {hot:y,warm:v,hotTokens:g,warmTokens:w,hotOverflow:h,totalBudget:u,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}Ae();Ke();c();var tr=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},Rt=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),o=Math.max(1,r.maxConcurrency??5),s=r.timeoutMs,i=r.failFast??false,a=r.callbacks,d=r.evaluateTaskSuccess??(()=>true),l=[],u=0,p=0,y=0,g=false,h=0,k=perf_hooks.performance.now(),v=async A=>{a?.onTaskStart&&await a.onTaskStart(A),y+=1;let U=new AbortController,K={signal:U.signal},B,W;typeof s=="number"&&Number.isFinite(s)&&s>0&&(W=new Promise((b,O)=>{B=setTimeout(()=>{let R=new tr(A.id,s);U.abort(R),O(R);},s);}));let F=perf_hooks.performance.now(),G=A.run(K),E=W?Promise.race([G,W]):G;try{let b=await E,O=perf_hooks.performance.now(),R=O-F,j=d(b,A),X={taskId:A.id,success:j,value:b,durationMs:R,startedAt:F,finishedAt:O,metadata:A.metadata,aborted:!1};l.push(X),j?u+=1:p+=1,a?.onTaskComplete&&await a.onTaskComplete(X),i&&!j&&(g=!0);}catch(b){let O=perf_hooks.performance.now(),R=O-F,j=b instanceof Error?b:new Error(String(b)),X={taskId:A.id,success:false,error:j,durationMs:R,startedAt:F,finishedAt:O,metadata:A.metadata,aborted:U.signal.aborted};l.push(X),p+=1,a?.onError&&await a.onError(A,j,R),i&&(g=true);}finally{B&&clearTimeout(B),W&&G.catch(()=>{});}},w=async()=>{for(;!g;){let A=h;if(A>=e.length)break;h+=1;let U=e[A];if(!U||(await v(U),g))break}},_=Math.min(o,e.length),x=[];for(let A=0;A<_;A++)x.push(w());await Promise.all(x);let P=perf_hooks.performance.now()-k,z=l.length?l.reduce((A,U)=>A+U.durationMs,0)/l.length:0,H=P>0?l.length/(P/1e3):l.length;return this.metrics={totalTasks:e.length,startedTasks:y,completedTasks:l.length,successCount:u,failureCount:p,totalDurationMs:P,averageDurationMs:z,throughput:H},l}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,o,s)=>{e?.onError&&await e.onError(r,o,s),t?.onError&&await t.onError(r,o,s);}}}};c();c();var Et=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 Oo=3,Mo=3e4,No=500,ed=n=>{if(typeof n!="number"||Number.isNaN(n)||!Number.isFinite(n))return Oo;let e=Math.floor(n);return e>0?e:Oo},td=n=>n===void 0||typeof n!="number"||Number.isNaN(n)||n<=0?Mo:n,rd=n=>{if(!n)return {maxRetries:0,retryDelay:No};let e=Number.isInteger(n.maxRetries)&&n.maxRetries>=0?n.maxRetries:0,t=typeof n.retryDelay=="number"&&n.retryDelay>=0?n.retryDelay:No;return {maxRetries:e,retryDelay:t}},ln=n=>{let e=n.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},nd=(n,e)=>n<=0?Promise.resolve():new Promise((t,r)=>{let o=setTimeout(()=>{e.removeEventListener("abort",s),t();},n),s=()=>{clearTimeout(o),r(ln(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),od=async(n,e,t)=>{let r,o;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw ln(t);try{let i=await n();if(r=i,i.success||s===e.maxRetries)return i}catch(i){if(o=i,t.aborted)throw ln(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await nd(e.retryDelay,t);}if(r)return r;throw o?o instanceof Error?o:new Error(String(o)):new Error("Parallel helper encountered an unexpected state")},Do=(n,e,t)=>{e.completed+=1,t?e.success+=1:e.failure+=1;try{n.onProgress?.(e.completed,e.total);}catch(r){process.env.NODE_ENV!=="production"&&console.warn("Parallel helper onProgress callback threw an error:",r);}},sd=n=>n.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 o=r.error??new Error("Unknown error");return {agentId:t.request.agentId,content:o.message,success:false,metadata:{error:o.message,aborted:r.aborted??false,requestIndex:t.index,mode:t.mode}}}),id=n=>n.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")}}),ad=(n,e)=>({onTaskComplete:async t=>{Do(e,n,t.success);},onError:async()=>{Do(e,n,false);}}),Lo=async(n,e,t={})=>{if(!Array.isArray(n))throw new TypeError("Parallel helpers expect an array of requests");if(n.length===0){let v={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?.(v),[]}let r=ed(t.concurrency),o=td(t.timeout),s=rd(t.retryPolicy),i=new Rt,a=new Et,d=n.map((k,v)=>({id:`${e}:${k.agentId??"anonymous"}:${v}`,metadata:{index:v,mode:e,request:k},run:w=>od(()=>e==="query"?a.query(k):a.execute(k),s,w.signal)})),l={completed:0,success:0,failure:0,total:n.length},u=await i.run(d,{maxConcurrency:r,timeoutMs:o,evaluateTaskSuccess:k=>k.success,callbacks:ad(l,t)}),p=sd(u),y=id(u),g=i.getMetrics(),h={total:n.length,completed:n.length,successCount:p.filter(k=>k.success).length,failureCount:p.filter(k=>!k.success).length,results:p,errors:y,metrics:g};return t.onComplete?.(h),p},dd=(n,e)=>Lo(n,"query",e),ld=(n,e)=>Lo(n,"execute",e);Jr();c();var cn=class extends Xe{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=V.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let o=V.dirname(t);to.existsSync(o)||to.mkdirSync(o,{recursive:true});}else if(!to.existsSync(t))throw new N("NOT_FOUND","Database not found");let r=xe(t);if(e)try{Ft(r.db,t);}catch(o){throw r.close(),o}return r}insertSpan(e){let t=this.openHandle(true);try{t.db.insert(De).values(e).run();}catch(r){throw r instanceof N?r:new N("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(De).where(drizzleOrm.eq(De.task_id,e)).all()}catch(r){throw new N("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(De).where(drizzleOrm.eq(De.id,e)).limit(1).get()??void 0}catch(r){throw new N("DB_ERROR","Failed to find span by id",r)}finally{t.close();}}};Xr();Gr();Vr();c();c();var rr=class{capabilities={required:[]}};c();c();c();var jo=2e3;function Ho(n){let e=n.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f\u2028\u2029]/g,"");return e.length<=jo?e:e.slice(0,jo-11)+" [redacted]"}var kd=10*1024*1024,_d={b:1,kb:1024,mb:1024*1024,gb:1024*1024*1024};function un(n,e){return n===void 0?true:Array.isArray(n)?n.includes(e):n===e}function vd(n,e){return n===void 0?true:Array.isArray(n)?n.some(t=>e.includes(t)):e.includes(n)}function qo(n){if(typeof n=="number")return n;let e=n.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*(_d[r]??1))}function Bo(n){return typeof n=="string"}function Wo(n){try{let e=to.statSync(n);return e.size>kd?(process.stderr.write(`[YamlHookPlugin] File too large for line count: ${n} (${e.size} bytes)
261
- `),null):to.readFileSync(n,"utf8").split(`
262
- `).length}catch{return null}}function zo(n){try{return to.statSync(n).size}catch{return null}}function Ad(n,e,t){if(!n)return true;let r=e,o=r?.path??r?.file_path??r?.filePath??r?.filename;if(typeof o!="string")return false;if(ce(o,n))return true;if(t&&o.startsWith("/")){let{relative:s,isAbsolute:i}=J("path");if(i(o)){let a=s(t,o);if(a&&!a.startsWith("..")&&ce(a,n))return true}}return false}function Rd(n,e){return n?JSON.stringify(e).includes(n):true}function Ed(n,e){if(!n)return true;try{let t=new RegExp(n),r=JSON.stringify(e);return t.test(r)}catch{return false}}function Cd(n,e){if(!n)return true;try{let t=new RegExp(n),r=JSON.stringify(e);return t.test(r)}catch{return false}}function Td(n,e){if(n.pathSizeMin===void 0&&n.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(n.pathSizeMin!==void 0)if(Bo(n.pathSizeMin)){let o=zo(r);if(o===null||o<qo(n.pathSizeMin))return false}else {let o=Wo(r);if(o===null||o<n.pathSizeMin)return false}if(n.pathSizeMax!==void 0)if(Bo(n.pathSizeMax)){let o=zo(r);if(o===null||o>qo(n.pathSizeMax))return false}else {let o=Wo(r);if(o===null||o>n.pathSizeMax)return false}return true}function Pd(n){let e=[],t=[];for(let r=0;r<n.length;r++){let o=n[r];if(!o||typeof o!="object"){t.push(`Hook at index ${r}: not an object, skipping`);continue}let s=o;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 gn=class extends rr{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,o=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)){o&&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(`
255
+ `).map(l=>({provider:l.provider,totalTasks:l.total_tasks,inputTokens:l.input_tokens,outputTokens:l.output_tokens,cachedInputTokens:l.cached_input_tokens,costUsd:l.cost_usd,totalTokens:l.input_tokens+l.output_tokens,activeDurationMs:l.active_duration_ms??0,lastActiveAt:l.last_active_at??null}))}catch(s){throw new M("DB_ERROR","Failed to get provider usage",s)}finally{o.close();}}};var zi=new Set(["Read","Grep","Find","Glob"]),Ki=["git status","git log","git branch","git diff --stat","git show","git remote","git rev-parse","git ls-files","pwd","ls ","echo ","cat ","head ","tail ","npx crewx memory index","npx crewx memory find","npx crewx memory get","npx crewx doc toc","npx crewx doc section","npx crewx doc status","npx crewx search","npx skill tsserver find","npx skill tsserver refs","npx skill tsserver type","crewx memory index","crewx memory find","crewx memory get","crewx doc toc","crewx doc section","crewx doc status","crewx search","crewx agent ls","crewx agent list"],Vi=[/\bgit\s+(commit|push|pull|merge|rebase|reset|checkout|switch|add|rm)\b/,/\bnpm\s+(install|ci|publish|run\s+(test|lint|build))\b/,/\bnpx\s+tsc\b/,/\bpnpm\s+(install|run)\b/,/\bvitest\b/,/\bjest\b/];function Gi(n){let e=n.toLowerCase();return e==="bash"||e==="terminal"?"Bash":e==="read"||e==="view"?"Read":e==="edit"||e==="apply_patch"?"Edit":e==="write"?"Write":e==="grep"||e==="rg"?"Grep":e==="glob"||e==="find"?"Find":n}function Xi(n,e){if(zi.has(n))return true;if(n!=="Bash"||!e)return false;let t=e.split(`
256
+ `)[0].trimStart();return Vi.some(r=>r.test(t))?false:Ki.some(r=>t.startsWith(r))}function Gt(n){return n.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;")}function Ji(n,e,t){if(n!=="Read"||!e)return "ok";let o=e.split(`
257
+ `).find(s=>s.trim()&&!s.startsWith("Read "))?.trim()??e.trim();if(!o)return "unknown";try{let s=ro__namespace.statSync(o);if(t){let i=Date.parse(t);if(!Number.isNaN(i)&&s.mtimeMs>i)return "stale"}return "ok"}catch{return "unknown"}}function Yi(n){let e=new Set;for(let t of n)try{let r=JSON.parse(t);r.type&&e.add(r.type);}catch{}return e.has("turn.started")||e.has("thread.started")?"codex":e.has("assistant.message_delta")?"copilot":e.has("step_start")&&e.has("step_finish")?"opencode":e.has("system")&&e.has("result")?"claude":e.has("init")&&e.has("message")?"gemini":e.has("result")&&e.has("assistant")?"claude":null}function Qi(n){if(!Array.isArray(n))return [];let e=n,t=e.filter(a=>a.level==="stdout"&&a.message).map(a=>a.message),r=Yi(t),o=[];for(let a of e)a.level==="info"&&a.message?o.push(...le(a.message,a.timestamp)):a.level==="stdout"&&a.message&&r&&o.push(...it("",a.message,r));let s=new Map,i=[];for(let a of o)if(a.type==="tool_use"){let d={tool:Gi(a.toolName??""),input:a.toolInput??null,result:null,isError:false},l=a.toolUseId;if(l){if(s.has(l)){s.get(l).input=d.input;continue}s.set(l,d);}i.push(d);}else if(a.type==="tool_result"){if(a.toolUseId&&s.has(a.toolUseId)){let d=s.get(a.toolUseId);d.isError=a.isError===true,d.result=a.resultPreview??null;}else for(let d=i.length-1;d>=0;d--)if(i[d].result===null){i[d].isError=a.isError===true,i[d].result=a.resultPreview??null;break}}return i}function Zi(n,e){let t=Qi(n),r=[];for(let o of t){let s=o.tool==="Bash"?o.input?.split(`
258
+ `)[0]?.slice(0,150)??null:o.input?.slice(0,150)??null,i=Xi(o.tool,o.input)&&!o.isError;r.push({tool:o.tool,cmd:s,result:o.result,status:Ji(o.tool,o.input,e),reusable:i});}return r}function ea(n,e,t){let r=["<activity_log>"];if(n.length===0&&e===0)r.push(" <!-- no activity found in previous tasks -->");else {r.push(" <!-- tool activity from previous tasks -->"),e>0&&r.push(` <!-- ${e} entries omitted (cap) -->`);for(let o of n){let s=`tool="${Gt(o.tool)}"`,i=o.cmd?` cmd="${Gt(o.cmd)}"`:"",a="";if(o.reusable&&(a=o.status==="stale"?' reused="stale"':' reused="ok"'),o.reusable&&o.status==="stale")r.push(` <entry ${s}${i}${a}>\u26A0\uFE0F changed since \u2014 re-read</entry>`);else if(o.result){r.push(` <entry ${s}${i}${a}>`);let d=t&&t>0?t:8e3,l=o.result;l.length>d?r.push(Gt(l.slice(0,d))+` \u2026 [truncated, ${d}/${l.length} chars shown]`):r.push(Gt(l)),r.push(" </entry>");}else r.push(` <entry ${s}${i}${a} />`);}}return r.push("</activity_log>"),r}function no(n){let{threadId:e,agentId:t,lookback:r,maxEntryChars:o,decayRate:s}=n;if(!r||!e||!t)return new Map;let i;try{i=new yt().findTasksByThread(e).filter(f=>!f.parent_task_id&&f.agent_id===t).sort((f,g)=>g.started_at>f.started_at?1:-1).slice(0,Math.min(r,5));}catch{return new Map}if(!i.length)return new Map;let a=[];for(let p of i){let f=[];try{let g=JSON.parse(p.logs??"[]");Array.isArray(g)&&(f=g);}catch{}a.push({taskId:p.id,entries:Zi(f,p.completed_at)});}let d=new Map,l=typeof s=="number"&&s>0&&s<=1?s:1,u=1e3;for(let p=0;p<a.length;p++){let{taskId:f,entries:g}=a[p];if(g.length===0)continue;let h=Math.max(Math.floor((o??8e3)*Math.pow(l,p)),u),x=Math.max(0,g.length-200),v=x>0?g.slice(x):g,w=ea(v,x,h);d.set(f,w.join(`
259
+ `));}return d}c();c();var ta={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")},ra={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 oo(n,e,t){n.tool("crewx_listAgents","List available CrewX agents exposed by this server",async()=>{let r=[];for(let o of t){let s=e.agents.get(o);s&&r.push({id:s.id,name:s.name??s.id,description:s.description??""});}return {content:[{type:"text",text:JSON.stringify(r,null,2)}]}}),n.tool("crewx_queryAgent","Query a CrewX agent with a read-only question",ta,async({agentId:r,query:o,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,o,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Query failed"}],isError:true}}),n.tool("crewx_executeAgent","Execute a task on a CrewX agent (may modify state)",ra,async({agentId:r,task:o,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,o,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Execute failed"}],isError:true}});}c();function so(n){return n.headers.get("Origin")?null:new Response(JSON.stringify({error:"Forbidden: Origin header required"}),{status:403,headers:{"Content-Type":"application/json"}})}async function io(n,e){return e?await e(n)?null:new Response(JSON.stringify({error:"Unauthorized"}),{status:401,headers:{"Content-Type":"application/json"}}):null}function sa(n,e){let t=new mcp_js.McpServer({name:"crewx-mcp-server",version:"1.0.0"},{capabilities:{tools:{}}});return oo(t,n,e),t}function Ur(n,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 o=>{let s=so(o);if(s)return s;let i=await io(o,e.auth);if(i)return i;let a=o.headers.get("mcp-session-id");if(a&&r.has(a))return r.get(a).transport.handleRequest(o);let d=sa(n,t),l=new webStandardStreamableHttp_js.WebStandardStreamableHTTPServerTransport({sessionIdGenerator:()=>crypto.randomUUID(),onsessioninitialized:u=>{r.set(u,{transport:l,server:d});},onsessionclosed:u=>{r.delete(u);},enableJsonResponse:true});return await d.connect(l),l.handleRequest(o)}}c();function lo(n){let e=V__namespace.resolve(n);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 jr(n){let e=lo(n);return crypto$1.createHash("sha256").update(e).digest("hex")}function Oa(n){return n?n.settings?.template?.exec:void 0}function Ma(){try{let n=new Uint8Array(8);return globalThis.crypto.getRandomValues(n),Array.from(n,e=>e.toString(16).padStart(2,"0")).join("")}catch{let{randomBytes:n}=J("crypto");return n(8).toString("hex")}}var en=class n extends mt{_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,o,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=jr(i),this._workspaceName=V.basename(i);let a=Oa(r);this._templateEngine=new lt({execPolicy:t.execPolicy??a}),this._documentLoader=o??new Oe,this._layoutLoader=new ct({templatesPath:ze()}),this._layoutRenderer=new gt,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 o=r.slice(7),s=this.getRemoteProviderConfig(o);if(!s?.location?.startsWith("file://"))return null;let i=V.resolve(s.location.replace("file://","")),a=s.external_agent_id??e.replace(/^@/,""),d=this._remoteTargets.get(i);d||(d=(this._remoteFactory??(g=>n.loadYaml(g)))(i),this._remoteTargets.set(i,d),d.catch(()=>this._remoteTargets.delete(i)));let l=await d,u=l.getAgent("@"+a),p=Array.isArray(u?.provider)?u?.provider[0]:u?.provider;if(p?.startsWith("remote/"))throw new Error(`Chained remotes not allowed: "${o}" \u2192 "${p}"`);return {target:l,agentRef:"@"+a}}static async loadBuiltInConfig(e){let{yamlPath:t,dir:r}=ir(),o;try{o=ro.readFileSync(t,"utf-8");}catch(i){throw new Error(`[@crewx/sdk] Cannot read built-in config: ${t}
260
+ ${i.message}`)}let s=Pt(o);if(s.documents&&typeof s.documents=="object"){let i={};for(let[a,d]of Object.entries(s.documents))if(d&&typeof d=="object"){let l=d;typeof l.path=="string"&&!V.isAbsolute(l.path)?i[a]={...l,path:V.resolve(r,l.path)}:i[a]=l;}else i[a]=d;return {...s,documents:i}}return s}static mergeCrewxConfig(e,t){let r=new Map;for(let _ of e.agents??[])r.set(_.id,_);for(let _ of t.agents??[])r.has(_.id)&&console.warn(`[agent-loader] User agent "${_.id}" overrides built-in`),r.set(_.id,_);let o=Array.from(r.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,d=t,l=To(a.vars,d.vars),u=To(a.settings,d.settings),p;e.skills&&t.skills&&typeof e.skills=="object"&&typeof t.skills=="object"&&!Array.isArray(e.skills)&&!Array.isArray(t.skills)?p={...e.skills,...t.skills}:p=t.skills??e.skills;let f=[...e.hooks??[],...t.hooks??[]],g=Na(a.providers,d.providers),h={...e},x={...t};for(let _ of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete h[_],delete x[_];let w={...{...h,...x},agents:o,layouts:s,documents:i,skills:p};return f.length>0&&(w.hooks=f),l!==void 0&&(w.vars=l),u!==void 0&&(w.settings=u),g!==void 0&&(w.providers=g),w}static async loadYaml(e,t,r){let o=t?.includeBuiltIns!==false,s,i;if(o){let u=await n.loadBuiltInConfig(r);if(e!==void 0){let p=bt(e);s=n.mergeCrewxConfig(u,p),i=V.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=bt(e),i=V.dirname(e);}let a=new Oe(r);await a.load(s.documents,i);let d=s.agents??[];return await Po(d,s,t),new n(d,t??{},s,a,i)}static async fromConfig(e,t,r,o){let s=t?.includeBuiltIns===true,i=e;if(s){let u=await n.loadBuiltInConfig(o);i=n.mergeCrewxConfig(u,e);}let a=new Oe(o);await a.load(i.documents,r??(typeof process<"u"?process.cwd():"/"));let d=i.agents??[];return await Po(d,i,t),new n(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(o=>o.type==="remote"&&o.id===e):void 0}computeTaskLogPath(e,t){let r=Cr(t);return V.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 Ur(this,e)}async registerChannelAdapter(e){let{adapter:t,instanceId:r,config:o}=e;if(this._activeAdapters.has(r))throw new Error(`Adapter instance already registered: ${r}`);let s=new Set(t.manifest.capabilities),i=e.store??Tr(r),a=e.defaultMode??"query",d=t.manifest.platform,l=e.agentRunner??{run:async(g,h,x)=>{let w=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${g}`,h,{threadId:x?.threadId,platform:d});return {output:w.ok?w.data:w.error?.message??""}}},u=e.onInbound??(async g=>{let h=g.routingHints?.agentId??e.defaultAgent;if(!h)return {accepted:false,reason:"no_agent"};let{output:x}=await l.run(h,g.text,{threadId:g.threadId});return {accepted:true,output:x}}),p=br({instanceId:r,config:o,capabilities:s,db:i,agentRunner:l,onInbound:u}),f={adapter:t,ctx:p,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(p),f.state="started",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"started",timestamp:new Date});}catch(g){throw f.state="failed",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"failed",error:g instanceof Error?g:new Error(String(g)),timestamp:new Date}),this._activeAdapters.delete(r),g}}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()),o=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<o.length;s++)o[s].status==="rejected"&&console.error(`[crewx] adapter stop error (${r[s]}): ${o[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(o){console.error(`[crewx] remote target close error: ${o instanceof Error?o.message:String(o)}`);}}));let t=[...this._plugins].reverse();for(let r of t)try{await r.detach(this);}catch(o){console.error(`[crewx] plugin ${r.name} detach error: ${o instanceof Error?o.message:String(o)}`);}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),o=t(e.team),s=t(e.provider),i=Array.from(this._agents.values());return r&&(i=i.filter(a=>a.role&&r.some(d=>ue(a.role.toLowerCase(),d)))),o&&(i=i.filter(a=>a.team&&o.some(d=>ue(a.team.toLowerCase(),d)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(l=>s.some(u=>ue(l.toLowerCase(),u))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,r=this._agents.get(t);if(!r)throw new fe(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 o={...await this._documentLoader.buildContext(),...t?.documents??{}},s={...t,documents:o};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,o=this._agents.get(r);if(!o)throw new fe(r,Array.from(this._agents.keys()));let s=this._resolveLayoutSpec(o,t?.layout),i=this._extractLayoutId(s),a=this._extractLayoutProps(o,s,t?.layout),d=this._layoutLoader.load(i,a),l=o.inline?.prompt??o.inline?.system_prompt??o.description??`You are an expert ${r}.`,u=await this._documentLoader.buildContext(),p=t?.env??(typeof process<"u"?process.env:{}),f=t?.vars?.security_key??Ma(),g={...t?.vars??{},documents:u,env:p,agent:{id:o.id,name:o.name??o.id,role:o.role??"",team:o.team??"",description:o.description??""}},h=await this._templateEngine.render(l,g),x={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},v=o.provider,w=Array.isArray(v)?v:typeof v=="string"&&v.length>0?[v]:[],_=w.join(", ")||(typeof v=="string"?v:""),k=o.options,S=["goals","daily"],P={goals:false,daily:false},W;if(!Array.isArray(k)&&typeof k=="object"&&k!==null){let L=k;if("goals"in L){let ce=L.goals;typeof ce=="string"||Array.isArray(ce)?P.goals=ce:P.goals=!!ce;}"daily"in L&&(P.daily=!!L.daily);let K={};for(let[ce,et]of Object.entries(L))S.includes(ce)||(K[ce]=et);if(Object.keys(K).length>0){let ce=w.some(or=>or.startsWith("cli/")),et={};for(let[or,tt]of Object.entries(K)){let We={};if(Array.isArray(tt))ce&&(We.rawArgs=tt);else if(typeof tt=="object"&&tt!==null){let yn=tt;Object.keys(yn).length>0&&(We.named=yn);}(We.named||We.rawArgs&&We.rawArgs.length>0)&&(et[or]=We);}W=Object.keys(et).length>0?et:void 0;}}let H=Array.isArray(k)?k:void 0,A={};for(let[L,K]of Object.entries(u))A[L]={content:K.content??"",toc:K.toc,summary:K.summary,path:K.path};if(P.goals){let L=V.join(this._projectRoot,"docs","goal"),K=await zn(L,void 0,P.goals);K&&(A.active_goals={content:K});}if(P.daily){let L=V.join(this._projectRoot,"docs","daily"),K=await Kn(L);K&&(A.today_daily={content:K});}let j=t?.vars?.user_input??void 0,F=this._config?.settings?.dreaming?.continuity,q=F?.reuseReadOnly!==false,G=typeof F?.lookback=="number"?F.lookback:5,R=typeof F?.maxEntryChars=="number"?F.maxEntryChars:8e3,I=typeof F?.decayRate=="number"?F.decayRate:.5,b=t?.threadId??"",E=o.id,$=q&&G>0&&b&&t?.messages&&t.messages.length>0?no({threadId:b,agentId:E,lookback:G,maxEntryChars:R,decayRate:I}):new Map,X=(t?.messages??[]).map(L=>{if(!L.isAssistant)return L;let K=L.metadata?.task_id;return !K||!$.has(K)?L:{...L,activity_log:$.get(K)}}),ee={user_input:j,agent:{id:o.id,name:o.name??o.id,role:o.role??"",team:o.team??"",description:o.description??"",provider:_,providerList:w,model:o.inline?.model,workingDirectory:o.working_directory??o.workingDirectory??".",inline:{...o.inline??{},prompt:h},specialties:o.specialties??[],capabilities:o.capabilities??[],remote:o.remote??null,optionsByMode:W,optionsArray:H},agentMetadata:{specialties:o.specialties??[],capabilities:o.capabilities??[],description:o.description??""},contextOptions:P,documents:A,skills:t?.skills??[],session:x,env:p,vars:{security_key:f,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:x.platform,mode:x.mode,thread_id:b,now:ut(new Date),has_activity_log:$.size>0,messages:X,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,ee)}_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 o=this._config?.layouts?.default;return typeof o=="string"&&o?o:"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 o=e.inline?.layout,s=o&&typeof o=="object"&&"props"in o?o.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 o=this._getConversationProvider();if(o)try{let s=await o.fetchHistory(e,{currentTraceId:t});return s.messages.length===0?void 0:Ir(s)}catch{return}}_resolveTimeout(e,t){let r=e==="query"?"CREWX_TIMEOUT_QUERY":"CREWX_TIMEOUT_EXECUTE";if(process.env[r]!=null&&process.env[r]!==""){let o=Mn();return e==="query"?o.queryMs:o.executeMs}if(t?.meta?.defaultTimeoutMs){let o=e==="query"?t.meta.defaultTimeoutMs.query:t.meta.defaultTimeoutMs.execute;if(o!==void 0)return o}return 8*36e5}_lookupCliAdapter(e){if(e.startsWith("cli/"))return exports.BUILTIN_ADAPTERS[e.slice(4)]}_resolveEffectiveCwd(e,t){return t?.cwd??(e.working_directory?V.resolve(this._projectRoot,e.working_directory):this._projectRoot)}_buildFileRemoteOptions(e,t){let r={path:this._projectRoot,id:this._workspaceId,name:this._workspaceName,agentRef:e};return {...t,cwd:void 0,metadata:{...t?.metadata??{},crewx:{...t?.metadata?.crewx??{},callerWorkspace:r}},vars:{...t?.vars??{},crewx_caller_workspace_path:r.path,crewx_caller_workspace_id:r.id,crewx_caller_workspace_name:r.name}}}emitToolEvents(e,t,r,o,s,i,a){try{let l=exports.BUILTIN_ADAPTERS[r]?.parseEvent?.(o)??it(new Date().toISOString(),o);for(let u of l)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,o,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:o,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:o,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 o=await this.resolveFileRemoteTarget(e);if(o)return o.target.query(o.agentRef,t,this._buildFileRemoteOptions(e,r));let s=ft.getStore()??Sr(r?.trace),i=r?.taskId??Ne("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return ft.run(d,async()=>{let l=Date.now(),u=new Date,p;try{p=It(e,Array.from(this._agents.values()));}catch(R){if(R instanceof fe){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 I=Date.now()-l,b={code:"AGENT_NOT_FOUND",message:R.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:I,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:I}}}throw R}d.callerAgentId=p.id;let f=Array.isArray(p.provider)?p.provider[0]??"cli/claude":p.provider,g=r?.provider??f,h=r?.model??p.inline?.model;h&&h.includes("{{")&&(h=await this._templateEngine.render(h,{...r?.vars??{}}));let x;try{x=we(g);}catch(R){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 I=Date.now()-l,b={code:"PROVIDER_ERROR",message:R.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:I,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:p.id,provider:g,model:h,durationMs:I}}}let v=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),w;try{w=await this.renderAgentPromptFull(e,{session:{mode:"query",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:v,threadId:r?.threadId});}catch(R){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${R instanceof Error?R.message:String(R)}`);}let _,k,S,P=h,W=false,H=R=>{W||(W=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",pid:R,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:P,provider:g,codingAgentCommand:_,renderedPrompt:w,metadata:{...r?.metadata??{},provider:g},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},A=p.options,j=Array.isArray(A?.query?.tools)?A.query.tools:void 0,z=this._tools.size>0?this._filterToolsByMode(j):[],B=(()=>{let R=A?.query;if(!R||Array.isArray(R))return;let{tools:I,effort:b,mode:E,...$}=R,X=Object.entries($).filter(([,ee])=>ee!=null);if(X.length!==0)return Object.fromEntries(X.map(([ee,L])=>[ee,String(L)]))})(),F=p.inline?.max_steps;g.startsWith("api/")&&H();let q=false,G=0;try{let R=await x.query(t,{model:h,effort:A?.query?.effort,mode:A?.query?.mode,context:r?.context,systemPrompt:w??p.inline?.system_prompt??p.inline?.prompt??p.description??`You are ${p.id}.`,additionalArgs:Array.isArray(A?.query)?A.query:void 0,tools:z.length>0?z:void 0,maxSteps:F,configOptions:B,timeoutMs:this._resolveTimeout("query",this._lookupCliAdapter(g)),cwd:this._resolveEffectiveCwd(p,r),env:{CREWX_AGENT_ID:p.id,CREWX_AGENT_ROLE:p.role??"",CREWX_AGENT_TEAM:p.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:g,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,u)},onPid:E=>H(E),onOutput:(E,$)=>{let X=exports.BUILTIN_ADAPTERS[g];$==="stdout"&&X?.suppressOutputLine?.(E)===!0||this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:E,level:$}),$==="stdout"&&this.emitToolEvents(i,e,g,E,p.id,r?.threadId??"","");},onTaskLog:E=>{this.emitTaskLogEntries(i,e,p.id,r?.threadId??"","",g,E);for(let $ of E)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify($),level:"info"});},onCommand:E=>{_=E;},onUsage:E=>{k=E;},onExitCode:E=>{S=E;},onModel:E=>{P||(P=E);}});G=xr(k?.costUsd,k?.inputTokens,k?.outputTokens,k?.cachedInputTokens,P),H();let I=Date.now()-l,b={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:R,durationMs:I,exitCode:S,inputTokens:k?.inputTokens,outputTokens:k?.outputTokens,cachedInputTokens:k?.cachedInputTokens,costUsd:G,model:P,metadata:Object.keys(b).length>0?b:void 0}),q=!0,{ok:!0,data:R,meta:{agentId:p.id,provider:g,model:h,durationMs:I,taskId:i}}}catch(R){if(R instanceof exports.ClientToolCallRequiredError){let E=Ne("thd");return this._pendingThreads.set(E,{agentRef:p.id,providerStr:g,continuationState:R.continuationState,toolCall:R.toolCall,traceId:i,startMs:l,model:h}),q=true,{ok:true,status:"requires_action",data:"",toolCall:R.toolCall,threadId:E,meta:{agentId:p.id,provider:g,model:h,durationMs:Date.now()-l,taskId:i}}}H();let I=Date.now()-l,b={code:"QUERY_FAILED",message:R.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:I,error:b,exitCode:S,inputTokens:k?.inputTokens,outputTokens:k?.outputTokens,cachedInputTokens:k?.cachedInputTokens,costUsd:G,model:P,metadata:r?.metadata?{...r.metadata}:void 0}),q=true,{ok:false,data:"",error:b,meta:{agentId:p.id,provider:g,model:h,durationMs:I,taskId:i}}}finally{q||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:Date.now()-l,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:S??-1,inputTokens:k?.inputTokens,outputTokens:k?.outputTokens,cachedInputTokens:k?.cachedInputTokens,costUsd:G,model:P});}})}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 o=we(r.providerStr);if(!o.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 o.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 o=await this.resolveFileRemoteTarget(e);if(o)return o.target.execute(o.agentRef,t,this._buildFileRemoteOptions(e,r));let s=ft.getStore()??Sr(r?.trace),i=r?.taskId??Ne("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return ft.run(d,async()=>{let l=Date.now(),u=new Date,p;try{p=It(e,Array.from(this._agents.values()));}catch(R){if(R instanceof fe){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 I=Date.now()-l,b={code:"AGENT_NOT_FOUND",message:R.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:I,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:I}}}throw R}d.callerAgentId=p.id;let f=Array.isArray(p.provider)?p.provider[0]??"cli/claude":p.provider,g=r?.provider??f,h=r?.model??p.inline?.model;h&&h.includes("{{")&&(h=await this._templateEngine.render(h,{...r?.vars??{}}));let x;try{x=we(g);}catch(R){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 I=Date.now()-l,b={code:"PROVIDER_ERROR",message:R.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:I,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:p.id,provider:g,model:h,durationMs:I}}}let v=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),w;try{w=await this.renderAgentPromptFull(e,{session:{mode:"execute",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:v,threadId:r?.threadId});}catch(R){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${R instanceof Error?R.message:String(R)}`);}let _,k,S,P=h,W=false,H=R=>{W||(W=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",pid:R,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:P,provider:g,codingAgentCommand:_,renderedPrompt:w,metadata:{...r?.metadata??{},provider:g},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},A=p.options,j=Array.isArray(A?.execute?.tools)?A.execute.tools:void 0,z=this._tools.size>0?this._filterToolsByMode(j):[],B=(()=>{let R=A?.execute;if(!R||Array.isArray(R))return;let{tools:I,effort:b,mode:E,...$}=R,X=Object.entries($).filter(([,ee])=>ee!=null);if(X.length!==0)return Object.fromEntries(X.map(([ee,L])=>[ee,String(L)]))})(),F=p.inline?.max_steps;g.startsWith("api/")&&H();let q=false,G=0;try{let R=await x.execute(t,{model:h,effort:A?.execute?.effort,mode:A?.execute?.mode,context:r?.context,systemPrompt:w??p.inline?.system_prompt??p.inline?.prompt??p.description??`You are ${p.id}.`,additionalArgs:Array.isArray(A?.execute)?A.execute:void 0,tools:z.length>0?z:void 0,maxSteps:F,configOptions:B,timeoutMs:this._resolveTimeout("execute",this._lookupCliAdapter(g)),cwd:this._resolveEffectiveCwd(p,r),env:{CREWX_AGENT_ID:p.id,CREWX_AGENT_ROLE:p.role??"",CREWX_AGENT_TEAM:p.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:g,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,u)},onPid:E=>H(E),onOutput:(E,$)=>{let X=exports.BUILTIN_ADAPTERS[g];$==="stdout"&&X?.suppressOutputLine?.(E)===!0||this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:E,level:$}),$==="stdout"&&this.emitToolEvents(i,e,g,E,p.id,r?.threadId??"","");},onTaskLog:E=>{this.emitTaskLogEntries(i,e,p.id,r?.threadId??"","",g,E);for(let $ of E)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify($),level:"info"});},onCommand:E=>{_=E;},onUsage:E=>{k=E;},onExitCode:E=>{S=E;},onModel:E=>{P||(P=E);}});G=xr(k?.costUsd,k?.inputTokens,k?.outputTokens,k?.cachedInputTokens,P),H();let I=Date.now()-l,b={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:R,durationMs:I,exitCode:S,inputTokens:k?.inputTokens,outputTokens:k?.outputTokens,cachedInputTokens:k?.cachedInputTokens,costUsd:G,model:P,metadata:Object.keys(b).length>0?b:void 0}),q=!0,{ok:!0,data:R,meta:{agentId:p.id,provider:g,model:h,durationMs:I,taskId:i}}}catch(R){H();let I=Date.now()-l,b={code:"EXECUTE_FAILED",message:R.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:I,error:b,exitCode:S,inputTokens:k?.inputTokens,outputTokens:k?.outputTokens,cachedInputTokens:k?.cachedInputTokens,costUsd:G,model:P,metadata:r?.metadata?{...r.metadata}:void 0}),q=true,{ok:false,data:"",error:b,meta:{agentId:p.id,provider:g,model:h,durationMs:I}}}finally{q||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:Date.now()-l,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:S??-1,inputTokens:k?.inputTokens,outputTokens:k?.outputTokens,cachedInputTokens:k?.cachedInputTokens,costUsd:G,model:P});}})}};function To(n,e){let t=tn(n)?n:void 0,r=tn(e)?e:void 0;if(!(!t&&!r))return {...t??{},...r??{}}}function tn(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function Na(n,e){let t=Array.isArray(n)?n:void 0,r=Array.isArray(e)?e:void 0;if(!t&&!r)return;let o=a=>{if(!tn(a))return;let d=a.id;if(typeof d=="string")return `id:${d}`;let l=a.name;if(typeof l=="string")return `name:${l}`},s=new Set;for(let a of r??[]){let d=o(a);d&&s.add(d);}let i=[];for(let a of t??[]){let d=o(a);d&&s.has(d)||i.push(a);}for(let a of r??[])i.push(a);return i}async function Po(n,e,t){if(n.some(o=>(Array.isArray(o.provider)?o.provider:[o.provider]).some(i=>i.startsWith("api/")))){let{registerApiProviders:o}=await Promise.resolve().then(()=>(Fr(),go));o(t?.api);}await La(n,e),$a(n,e),Da(n);}function Da(n){if(!n.some(r=>(Array.isArray(r.provider)?r.provider:[r.provider]).some(s=>s.startsWith("acp/"))))return;let{registerAcpProviders:t}=(Vr(),hn(xo));t();}async function La(n,e){if(!n.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:o}=await Promise.resolve().then(()=>(Jr(),_o)),s=new Map;for(let i of r)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&he("remote",o(s,we));}function $a(n,e){if(!n.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:o}=(Yr(),hn(Eo)),s=new Map;for(let i of r)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&he("plugin",o(s));}c();var rn=class{detach(e){}};c();var Ua="crewx:fs:",nn=class{prefix;store;constructor(e){this.prefix=e?.prefix??Ua,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("/"),o=[];for(let i of r)i==="."||i===""||(i===".."?o.pop():o.push(i));let s=o.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+"/"),o=[];for(let s of this.store.keys())if(s.startsWith(r)){let a=s.slice(r.length).split("/")[0];a&&!o.includes(a)&&o.push(a);}return o}toKey(e){return `${this.prefix}${e.replace(/\\/g,"/")}`}};c();function ja(n,e){let t=n.skills?.include;if(t===void 0)return [...e];if(t.length===0)return [];let r=new Set(t);return e.filter(o=>r.has(o))}c();var on=["codex","claude","opencode","antigravity","copilot"];function Ha(n){let e=n.indexOf("/");return e===-1?n:n.slice(e+1)}function sn(n){let e=Ha(n),t=on.indexOf(e);return t===-1?on.length:t}function At(n,e){return sn(n)-sn(e)}pe();Hr();Fr();c();qr();Ee();c();Xt();tr();Yt();var Fa="model",qa="mode",Ba="thought_level";function an(n){if(n.length===0)return [];if(n[0]?.group!=null){let e=[];for(let t of n)for(let r of t.options??[])e.push(r);return e}return n}function Wa(n,e){let t=new Map;for(let r of [...n,...e]){let o=t.get(r.id);(!o||!o.name&&r.name)&&t.set(r.id,r);}return Array.from(t.values())}function za(n,e){let t=new Map;for(let r of [...n,...e])t.has(r.id)||t.set(r.id,r);return Array.from(t.values())}function Ka(n,e,t,r){let o=t.agentInfo?.name,s=e??o??n,i=r.configOptions??[],d=(r.modes?.availableModes??[]).map(w=>({id:w.id,name:w.name,...w.description!=null?{description:w.description}:{}})),l=[];for(let w of i)if(w.category?.trim().toLowerCase()===qa&&w.options!=null)for(let _ of an(w.options))_.value!=null&&l.push({id:_.value,name:_.name??_.value});let u=za(d,l),p=[];for(let w of i)if(w.category?.trim().toLowerCase()===Ba&&w.type==="select")for(let _ of an(w.options??[]))_.value!=null&&p.push(_.value);if(n==="claude"){let w=ho.map(k=>({id:k.id,name:k.name})),_=bo(t);return So(n,{models:w,modes:u,availableModelsCount:0,configModelsCount:0,skipModelWarn:true}),{id:`acp/${n}`,name:s,modes:u,effort:p,models:w,capabilities:_}}let g=(r.models?.availableModels??[]).map(w=>({id:w.modelId})),h=[];for(let w of i)if(w.category?.trim().toLowerCase()===Fa&&w.options!=null)for(let _ of an(w.options))_.value!=null&&h.push({id:_.value,..._.name!=null?{name:_.name}:{}});let x=Wa(g,h);So(n,{models:x,modes:u,availableModelsCount:g.length,configModelsCount:h.length,skipModelWarn:false});let v=bo(t);return {id:`acp/${n}`,name:s,modes:u,effort:p,models:x,capabilities:v}}function bo(n){let e=n.agentCapabilities??{};return {loadSession:e.loadSession??false,image:e.promptCapabilities?.image??false,audio:e.promptCapabilities?.audio??false,mcp:e.mcpCapabilities!=null}}function So(n,e){!e.skipModelWarn&&e.models.length===0&&console.warn(`[acp] ${n} meta: models empty (availableModels=${e.availableModelsCount}, configOptions[model]=${e.configModelsCount})`),e.modes.length===0&&console.warn(`[acp] ${n} meta: modes empty`);}async function Io(n){let e=exports.ACP_ADAPTERS[n];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 o=r.initResponse;if(!o)return null;let s=e.buildSessionParams({cwd:process.cwd()}),i=await r.newSessionRaw(s);return Ka(n,t,o,i)}catch(o){return console.warn(`[acp] ${n} meta query failed: ${o instanceof Error?o.message:String(o)}`),null}finally{await r.dispose();}}async function Va(){let n=Object.keys(exports.ACP_ADAPTERS),e=await Promise.allSettled(n.map(r=>Io(r))),t=[];for(let r of e)r.status==="fulfilled"&&r.value!==null&&t.push(r.value);return t.sort((r,o)=>At(r.id,o.id))}Xt();Br();tr();Vr();ar();Re();c();Re();function Ga(n){return n.charAt(0).toUpperCase()+n.slice(1)}function Xa(){let n=[];for(let[e,t]of Object.entries(exports.BUILTIN_ADAPTERS))t.meta&&n.push({id:`cli/${e}`,name:t.meta.displayName??Ga(e),modes:[],effort:[],models:t.meta.models??[],capabilities:{loadSession:false,image:false,audio:false,mcp:false}});return n.sort((e,t)=>At(e.id,t.id))}c();var dn=0;function Ja(n){let e=Array.from(n.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(dn>=3)return "Error: Maximum delegation depth (3) reached. Cannot delegate further.";let r=t.agent,o=t.message,s=t.mode??"query";if(!e.includes(r))return `Error: Unknown agent "${r}". Available: ${e.join(", ")}`;dn++;try{if(s==="execute"){let a=await n.execute(r,o);return a.ok?a.data:`Error: ${a.error?.message??"Unknown error"}`}let i=await n.query(r,o);return i.ok?i.data:`Error: ${i.error?.message??"Unknown error"}`}finally{dn--;}}}}c();var Oo=typeof process<"u"?process.env:{};function Ya(){return Oo.CREWX_CLI||"npx crewx"}function Qa(){return Oo.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}c();var Za=/^[a-zA-Z0-9._-]+$/,ln=class{constructor(e){this.storage=e;}storage;listBoxes(e){this.validateId(e);let r=this.storage.listBoxes(e).map(o=>this.toBoxResponse(o));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(),o=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:o});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(!Za.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return Ne("box")}};c();function ed(n,e,t,r,o){let{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}=r,d=s*i,l=s*a,u=d+l,p=e.getThreadMessages(n),f=[],g=0,h=false,x=[];for(let _=0;_<p.length;_+=2){let k=p[_],S=p[_+1],P=k?.content||"",W=S?.content||"",H=o.countTokens(P+W),A=[];k&&A.push(k),S&&A.push(S),x.push({messages:A,tokens:H});}for(let _=x.length-1;_>=0;_--){let k=x[_];if(g+k.tokens>d){h=true;break}g+=k.tokens,f.unshift(...k.messages);}let v=[],w=0;if(h&&l>0)try{let{boxes:_}=t.listBoxes(n);for(let k=_.length-1;k>=0;k--){let S=_[k],P=S.summaryTokens??S.sourceTokens;if(w+P>l)break;w+=P,v.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(_){if(_ instanceof Error&&!/not found/i.test(_.message))throw _}return {hot:f,warm:v,hotTokens:g,warmTokens:w,hotOverflow:h,totalBudget:u,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}Re();Ve();c();var rr=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},Et=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),o=Math.max(1,r.maxConcurrency??5),s=r.timeoutMs,i=r.failFast??false,a=r.callbacks,d=r.evaluateTaskSuccess??(()=>true),l=[],u=0,p=0,f=0,g=false,h=0,x=perf_hooks.performance.now(),v=async A=>{a?.onTaskStart&&await a.onTaskStart(A),f+=1;let j=new AbortController,z={signal:j.signal},B,F;typeof s=="number"&&Number.isFinite(s)&&s>0&&(F=new Promise((I,b)=>{B=setTimeout(()=>{let E=new rr(A.id,s);j.abort(E),b(E);},s);}));let q=perf_hooks.performance.now(),G=A.run(z),R=F?Promise.race([G,F]):G;try{let I=await R,b=perf_hooks.performance.now(),E=b-q,$=d(I,A),X={taskId:A.id,success:$,value:I,durationMs:E,startedAt:q,finishedAt:b,metadata:A.metadata,aborted:!1};l.push(X),$?u+=1:p+=1,a?.onTaskComplete&&await a.onTaskComplete(X),i&&!$&&(g=!0);}catch(I){let b=perf_hooks.performance.now(),E=b-q,$=I instanceof Error?I:new Error(String(I)),X={taskId:A.id,success:false,error:$,durationMs:E,startedAt:q,finishedAt:b,metadata:A.metadata,aborted:j.signal.aborted};l.push(X),p+=1,a?.onError&&await a.onError(A,$,E),i&&(g=true);}finally{B&&clearTimeout(B),F&&G.catch(()=>{});}},w=async()=>{for(;!g;){let A=h;if(A>=e.length)break;h+=1;let j=e[A];if(!j||(await v(j),g))break}},_=Math.min(o,e.length),k=[];for(let A=0;A<_;A++)k.push(w());await Promise.all(k);let P=perf_hooks.performance.now()-x,W=l.length?l.reduce((A,j)=>A+j.durationMs,0)/l.length:0,H=P>0?l.length/(P/1e3):l.length;return this.metrics={totalTasks:e.length,startedTasks:f,completedTasks:l.length,successCount:u,failureCount:p,totalDurationMs:P,averageDurationMs:W,throughput:H},l}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,o,s)=>{e?.onError&&await e.onError(r,o,s),t?.onError&&await t.onError(r,o,s);}}}};c();c();var Ct=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 Mo=3,No=3e4,Do=500,td=n=>{if(typeof n!="number"||Number.isNaN(n)||!Number.isFinite(n))return Mo;let e=Math.floor(n);return e>0?e:Mo},rd=n=>n===void 0||typeof n!="number"||Number.isNaN(n)||n<=0?No:n,nd=n=>{if(!n)return {maxRetries:0,retryDelay:Do};let e=Number.isInteger(n.maxRetries)&&n.maxRetries>=0?n.maxRetries:0,t=typeof n.retryDelay=="number"&&n.retryDelay>=0?n.retryDelay:Do;return {maxRetries:e,retryDelay:t}},cn=n=>{let e=n.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},od=(n,e)=>n<=0?Promise.resolve():new Promise((t,r)=>{let o=setTimeout(()=>{e.removeEventListener("abort",s),t();},n),s=()=>{clearTimeout(o),r(cn(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),sd=async(n,e,t)=>{let r,o;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw cn(t);try{let i=await n();if(r=i,i.success||s===e.maxRetries)return i}catch(i){if(o=i,t.aborted)throw cn(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await od(e.retryDelay,t);}if(r)return r;throw o?o instanceof Error?o:new Error(String(o)):new Error("Parallel helper encountered an unexpected state")},Lo=(n,e,t)=>{e.completed+=1,t?e.success+=1:e.failure+=1;try{n.onProgress?.(e.completed,e.total);}catch(r){process.env.NODE_ENV!=="production"&&console.warn("Parallel helper onProgress callback threw an error:",r);}},id=n=>n.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 o=r.error??new Error("Unknown error");return {agentId:t.request.agentId,content:o.message,success:false,metadata:{error:o.message,aborted:r.aborted??false,requestIndex:t.index,mode:t.mode}}}),ad=n=>n.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")}}),dd=(n,e)=>({onTaskComplete:async t=>{Lo(e,n,t.success);},onError:async()=>{Lo(e,n,false);}}),$o=async(n,e,t={})=>{if(!Array.isArray(n))throw new TypeError("Parallel helpers expect an array of requests");if(n.length===0){let v={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?.(v),[]}let r=td(t.concurrency),o=rd(t.timeout),s=nd(t.retryPolicy),i=new Et,a=new Ct,d=n.map((x,v)=>({id:`${e}:${x.agentId??"anonymous"}:${v}`,metadata:{index:v,mode:e,request:x},run:w=>sd(()=>e==="query"?a.query(x):a.execute(x),s,w.signal)})),l={completed:0,success:0,failure:0,total:n.length},u=await i.run(d,{maxConcurrency:r,timeoutMs:o,evaluateTaskSuccess:x=>x.success,callbacks:dd(l,t)}),p=id(u),f=ad(u),g=i.getMetrics(),h={total:n.length,completed:n.length,successCount:p.filter(x=>x.success).length,failureCount:p.filter(x=>!x.success).length,results:p,errors:f,metrics:g};return t.onComplete?.(h),p},ld=(n,e)=>$o(n,"query",e),cd=(n,e)=>$o(n,"execute",e);Yr();c();var un=class extends Je{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=V.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let o=V.dirname(t);ro.existsSync(o)||ro.mkdirSync(o,{recursive:true});}else if(!ro.existsSync(t))throw new M("NOT_FOUND","Database not found");let r=ke(t);if(e)try{qt(r.db,t);}catch(o){throw r.close(),o}return r}insertSpan(e){let t=this.openHandle(true);try{t.db.insert(Le).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(Le).where(drizzleOrm.eq(Le.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(Le).where(drizzleOrm.eq(Le.id,e)).limit(1).get()??void 0}catch(r){throw new M("DB_ERROR","Failed to find span by id",r)}finally{t.close();}}};Jr();Xr();Gr();c();c();var nr=class{capabilities={required:[]}};c();c();c();var Ho=2e3;function Fo(n){let e=n.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f\u2028\u2029]/g,"");return e.length<=Ho?e:e.slice(0,Ho-11)+" [redacted]"}var _d=10*1024*1024,vd={b:1,kb:1024,mb:1024*1024,gb:1024*1024*1024};function pn(n,e){return n===void 0?true:Array.isArray(n)?n.includes(e):n===e}function Ad(n,e){return n===void 0?true:Array.isArray(n)?n.some(t=>e.includes(t)):e.includes(n)}function Bo(n){if(typeof n=="number")return n;let e=n.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*(vd[r]??1))}function Wo(n){return typeof n=="string"}function zo(n){try{let e=ro.statSync(n);return e.size>_d?(process.stderr.write(`[YamlHookPlugin] File too large for line count: ${n} (${e.size} bytes)
261
+ `),null):ro.readFileSync(n,"utf8").split(`
262
+ `).length}catch{return null}}function Ko(n){try{return ro.statSync(n).size}catch{return null}}function Rd(n,e,t){if(!n)return true;let r=e,o=r?.path??r?.file_path??r?.filePath??r?.filename;if(typeof o!="string")return false;if(ue(o,n))return true;if(t&&o.startsWith("/")){let{relative:s,isAbsolute:i}=J("path");if(i(o)){let a=s(t,o);if(a&&!a.startsWith("..")&&ue(a,n))return true}}return false}function Ed(n,e){return n?JSON.stringify(e).includes(n):true}function Cd(n,e){if(!n)return true;try{let t=new RegExp(n),r=JSON.stringify(e);return t.test(r)}catch{return false}}function Td(n,e){if(!n)return true;try{let t=new RegExp(n),r=JSON.stringify(e);return t.test(r)}catch{return false}}function Pd(n,e){if(n.pathSizeMin===void 0&&n.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(n.pathSizeMin!==void 0)if(Wo(n.pathSizeMin)){let o=Ko(r);if(o===null||o<Bo(n.pathSizeMin))return false}else {let o=zo(r);if(o===null||o<n.pathSizeMin)return false}if(n.pathSizeMax!==void 0)if(Wo(n.pathSizeMax)){let o=Ko(r);if(o===null||o>Bo(n.pathSizeMax))return false}else {let o=zo(r);if(o===null||o>n.pathSizeMax)return false}return true}function bd(n){let e=[],t=[];for(let r=0;r<n.length;r++){let o=n[r];if(!o||typeof o!="object"){t.push(`Hook at index ${r}: not an object, skipping`);continue}let s=o;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 mn=class extends nr{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,o=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)){o&&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(`
263
263
 
264
- `)):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=Ho(t.message).slice(0,500)));let o=`[${new Date().toISOString()}] HOOK: ${JSON.stringify(r)}
265
- `;to.appendFileSync(e,o,{encoding:"utf8",mode:384});}catch{}}matchEntryLevel(e,t){if(e.provider!==void 0){let r=t.provider.replace(/^cli\//,"");if(!un(e.provider,r))return false}if(e.team!==void 0){let o=this.agentMap.get(t.agent.id)?.team??t.agent.team;if(!un(e.team,o))return false}if(e.role!==void 0){let o=this.agentMap.get(t.agent.id)?.role??t.agent.role;if(!un(e.role,o))return false}if(e.tag!==void 0){let o=this.agentMap.get(t.agent.id)?.tags??[];if(!vd(e.tag,o))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)||!Rd(e.pattern,t.tool.input)||!Ed(e.regex,t.tool.input)||!Ad(e.pathPattern,t.tool.input,t.cwd)||!Td(e,t.tool.input)||!Cd(e.whenInputRegex,t.tool.input))}hasFired(e,t){try{let r=this.firedFilePath(e);if(!to.existsSync(r))return !1;let o=JSON.parse(to.readFileSync(r,"utf8"));return Array.isArray(o.fired)&&o.fired.includes(t)}catch{return false}}markFired(e,t){try{let r=this.firedFilePath(e);to.mkdirSync(V.dirname(r),{recursive:!0,mode:448});let o=to.existsSync(r)?JSON.parse(to.readFileSync(r,"utf8")):{fired:[]};Array.isArray(o.fired)||(o.fired=[]),o.fired.includes(t)||(o.fired.push(t),to.writeFileSync(r,JSON.stringify(o),{mode:384}));}catch(r){process.stderr.write(`[YamlHookPlugin] once state write failed: ${r}
266
- `);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return V.join(wi.homedir(),".crewx","sessions",t,"fired-rules.json")}};c();c();c();function bd(n){let e=n.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}}}c();var mn=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;}};c();function Sd(n){return n}function Id(n){return {name:n.name,async attach(e){let t=await n.configFactory(e),o=e.registerChannelAdapter,s=n.instanceId??n.name;o&&await o({adapter:n.adapter,instanceId:s,config:t}),n.onAttach&&await n.onAttach(e);},async detach(e){let r=e.unregisterChannelAdapter;r&&await r(n.instanceId??n.name),n.onDetach&&await n.onDetach(e);}}}Mt();exports.AdapterError=mn;exports.AgentNotFoundError=me;exports.AgentRuntime=Et;exports.AgentSkillsSchema=hn;exports.BrowserFsAdapter=rn;exports.ConfigLoadError=Te;exports.Crewx=Zr;exports.CrewxPlugin=tn;exports.DocumentLoader=Ie;exports.LayoutLoadError=Q;exports.LayoutLoader=lt;exports.LayoutRenderer=pt;exports.NodeFsAdapter=jt;exports.PROVIDER_ORDER=nn;exports.ParallelRunner=Rt;exports.ParallelRunnerTimeoutError=tr;exports.PropsValidationError=we;exports.PropsValidator=ut;exports.SdkBoxService=dn;exports.SpanRepository=cn;exports.TaskRepository=ft;exports.TemplateEngine=dt;exports.TypedEventEmitter=gt;exports.YamlHookPlugin=gn;exports.buildContext=Za;exports.compareProviders=vt;exports.createAdapterContext=Pr;exports.createDelegateTool=Xa;exports.createHandler=$r;exports.createPluginProviderFactory=Ao;exports.createProvider=he;exports.createRemoteProviderFactory=xo;exports.createScopedAdapterStore=Cr;exports.defaultExtractText=Ir;exports.defaultFsAdapter=Se;exports.defaultParseEvent=de;exports.defineChannelAdapter=Sd;exports.defineChannelAdapterPlugin=Id;exports.escapeHandlebarsHelper=_r;exports.formatFileSizeHelper=vr;exports.formatTimestamp=Er;exports.formatTimestampHelper=Ar;exports.generateFingerprint=oi;exports.generateId=Me;exports.getSyncWindowStore=ai;exports.hashWorkspaceId=Ur;exports.lengthHelper=kr;exports.loadYamlFile=Pt;exports.materializeWindowsSpawnProgram=rt;exports.normalizeWorkspacePath=ao;exports.parseStdoutEvent=st;exports.parseUsage=fe;exports.parseYamlContent=Tt;exports.providerRank=on;exports.queryAcpProviderMeta=So;exports.queryAllAcpProviderMetas=Ka;exports.queryAllCliProviderMetas=Ga;exports.registerAcpProviders=ho;exports.registerApiProviders=uo;exports.registerProviderFactory=ye;exports.resolveAgent=St;exports.resolveAgentSkills=Ua;exports.resolveCrewxCli=Ja;exports.resolveCrewxWorkspace=Ya;exports.resolveDefaultAgentsYaml=sr;exports.resolveTemplatesPath=We;exports.resolveWindowsExecutablePath=kn;exports.resolveWindowsSpawnProgram=tt;exports.runExecutesParallel=ld;exports.runInSyncWindow=di;exports.runQueriesParallel=dd;exports.setAuditVerbose=Bs;exports.toTaskReader=bd;exports.toTemplateMessages=Sr;exports.truncateHelper=xr;exports.validateHooksSchema=Pd;
264
+ `)):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=Fo(t.message).slice(0,500)));let o=`[${new Date().toISOString()}] HOOK: ${JSON.stringify(r)}
265
+ `;ro.appendFileSync(e,o,{encoding:"utf8",mode:384});}catch{}}matchEntryLevel(e,t){if(e.provider!==void 0){let r=t.provider.replace(/^cli\//,"");if(!pn(e.provider,r))return false}if(e.team!==void 0){let o=this.agentMap.get(t.agent.id)?.team??t.agent.team;if(!pn(e.team,o))return false}if(e.role!==void 0){let o=this.agentMap.get(t.agent.id)?.role??t.agent.role;if(!pn(e.role,o))return false}if(e.tag!==void 0){let o=this.agentMap.get(t.agent.id)?.tags??[];if(!Ad(e.tag,o))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)||!Ed(e.pattern,t.tool.input)||!Cd(e.regex,t.tool.input)||!Rd(e.pathPattern,t.tool.input,t.cwd)||!Pd(e,t.tool.input)||!Td(e.whenInputRegex,t.tool.input))}hasFired(e,t){try{let r=this.firedFilePath(e);if(!ro.existsSync(r))return !1;let o=JSON.parse(ro.readFileSync(r,"utf8"));return Array.isArray(o.fired)&&o.fired.includes(t)}catch{return false}}markFired(e,t){try{let r=this.firedFilePath(e);ro.mkdirSync(V.dirname(r),{recursive:!0,mode:448});let o=ro.existsSync(r)?JSON.parse(ro.readFileSync(r,"utf8")):{fired:[]};Array.isArray(o.fired)||(o.fired=[]),o.fired.includes(t)||(o.fired.push(t),ro.writeFileSync(r,JSON.stringify(o),{mode:384}));}catch(r){process.stderr.write(`[YamlHookPlugin] once state write failed: ${r}
266
+ `);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return V.join(xi.homedir(),".crewx","sessions",t,"fired-rules.json")}};c();c();c();function Sd(n){let e=n.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}}}c();var fn=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;}};c();function Id(n){return n}function Od(n){return {name:n.name,async attach(e){let t=await n.configFactory(e),o=e.registerChannelAdapter,s=n.instanceId??n.name;o&&await o({adapter:n.adapter,instanceId:s,config:t}),n.onAttach&&await n.onAttach(e);},async detach(e){let r=e.unregisterChannelAdapter;r&&await r(n.instanceId??n.name),n.onDetach&&await n.onDetach(e);}}}Nt();exports.AdapterError=fn;exports.AgentNotFoundError=fe;exports.AgentRuntime=Ct;exports.AgentSkillsSchema=wn;exports.BrowserFsAdapter=nn;exports.ConfigLoadError=Pe;exports.Crewx=en;exports.CrewxPlugin=rn;exports.DocumentLoader=Oe;exports.LayoutLoadError=Q;exports.LayoutLoader=ct;exports.LayoutRenderer=gt;exports.NodeFsAdapter=Ht;exports.PROVIDER_ORDER=on;exports.ParallelRunner=Et;exports.ParallelRunnerTimeoutError=rr;exports.PropsValidationError=xe;exports.PropsValidator=pt;exports.SdkBoxService=ln;exports.SpanRepository=un;exports.TaskRepository=yt;exports.TemplateEngine=lt;exports.TypedEventEmitter=mt;exports.YamlHookPlugin=mn;exports.buildContext=ed;exports.compareProviders=At;exports.createAdapterContext=br;exports.createDelegateTool=Ja;exports.createHandler=Ur;exports.createPluginProviderFactory=Ro;exports.createProvider=we;exports.createRemoteProviderFactory=ko;exports.createScopedAdapterStore=Tr;exports.defaultExtractText=Or;exports.defaultFsAdapter=Ie;exports.defaultParseEvent=le;exports.defineChannelAdapter=Id;exports.defineChannelAdapterPlugin=Od;exports.escapeHandlebarsHelper=vr;exports.formatFileSizeHelper=Ar;exports.formatTimestamp=Cr;exports.formatTimestampHelper=Rr;exports.generateFingerprint=si;exports.generateId=Ne;exports.getSyncWindowStore=di;exports.hashWorkspaceId=jr;exports.lengthHelper=_r;exports.loadYamlFile=bt;exports.materializeWindowsSpawnProgram=nt;exports.normalizeWorkspacePath=lo;exports.parseStdoutEvent=it;exports.parseUsage=ye;exports.parseYamlContent=Pt;exports.providerRank=sn;exports.queryAcpProviderMeta=Io;exports.queryAllAcpProviderMetas=Va;exports.queryAllCliProviderMetas=Xa;exports.registerAcpProviders=wo;exports.registerApiProviders=po;exports.registerProviderFactory=he;exports.resolveAgent=It;exports.resolveAgentSkills=ja;exports.resolveCrewxCli=Ya;exports.resolveCrewxWorkspace=Qa;exports.resolveDefaultAgentsYaml=ir;exports.resolveTemplatesPath=ze;exports.resolveWindowsExecutablePath=_n;exports.resolveWindowsSpawnProgram=rt;exports.runExecutesParallel=cd;exports.runInSyncWindow=li;exports.runQueriesParallel=ld;exports.setAuditVerbose=Ws;exports.toTaskReader=Sd;exports.toTemplateMessages=Ir;exports.truncateHelper=kr;exports.validateHooksSchema=bd;