@crewx/sdk 0.8.9-rc.2 → 0.8.9-rc.21
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/activity-log/builder.d.ts +21 -0
- package/dist/config/pricing.d.ts +9 -0
- package/dist/esm/index.js +162 -44
- package/dist/esm/plugins/index.js +137 -23
- package/dist/esm/repository/index.js +133 -19
- package/dist/facade/Crewx.d.ts +1 -0
- package/dist/index.js +162 -44
- package/dist/plugins/index.js +137 -23
- package/dist/provider/acp/meta.d.ts +3 -0
- package/dist/provider/cli/adapters/claude.d.ts +1 -0
- package/dist/provider/cli/adapters/cli-knob.util.d.ts +7 -0
- package/dist/repository/index.d.ts +1 -1
- package/dist/repository/index.js +133 -19
- package/dist/repository/task.repository.d.ts +14 -0
- package/package.json +1 -1
- package/templates/agents/default.yaml +18 -129
package/dist/index.js
CHANGED
|
@@ -1,63 +1,62 @@
|
|
|
1
|
-
'use strict';var
|
|
2
|
-
`))if(t.trim())try{let r=JSON.parse(t),o
|
|
3
|
-
`):i=JSON.stringify(s),{timestamp:n,type:"tool_result",toolUseId:o,resultPreview:i,isError:r}}return null}exports.claudeAdapter=void 0;var
|
|
1
|
+
'use strict';var Jn=require('fs'),B=require('path'),child_process=require('child_process'),sdk=require('@agentclientprotocol/sdk'),jsYaml=require('js-yaml'),zod=require('zod'),module$1=require('module'),ce=require('handlebars'),promises=require('fs/promises'),crypto$1=require('crypto'),events=require('events'),async_hooks=require('async_hooks'),drizzleOrm=require('drizzle-orm'),di=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 Jn__namespace=/*#__PURE__*/_interopNamespace(Jn);var B__namespace=/*#__PURE__*/_interopNamespace(B);var ce__namespace=/*#__PURE__*/_interopNamespace(ce);var di__default=/*#__PURE__*/_interopDefault(di);var rr=Object.defineProperty;var Fo=Object.getOwnPropertyDescriptor;var qo=Object.getOwnPropertyNames;var Bo=Object.prototype.hasOwnProperty;var K=(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 At=(n,e)=>{for(var t in e)rr(n,t,{get:e[t],enumerable:true});},Wo=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of qo(e))!Bo.call(n,o)&&o!==t&&rr(n,o,{get:()=>e[o],enumerable:!(r=Fo(e,o))||r.enumerable});return n};var gn=n=>Wo(rr({},"__esModule",{value:true}),n);var c=D(()=>{});function bt(n){return typeof n!="string"?void 0:n.trim()||void 0}function Pt(n){return bt(n)?.toLowerCase()??""}function We(n){try{return Jn.statSync(n).isFile()}catch{return false}}function hn(n,e){if(n.includes("/")||n.includes("\\")||B__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=B__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=Pt(d),u=d.toUpperCase();for(let p of [d,l,u]){let y=B__namespace.default.join(a,`${n}${p}`);if(We(y))return y}}return n}function rs(n){if(!We(n))return null;try{let e=Jn.readFileSync(n,"utf8"),t=B__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,B__namespace.default.sep).replace(/^[\\/]+/,""),y=B__namespace.default.resolve(t,p);We(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,B__namespace.default.sep).replace(/^[\\/]+/,"");s.set(d,B__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&&We(l)&&o.push(l);}let i=a=>a.find(d=>{let l=Pt(B__namespace.default.basename(d));return l!=="node.exe"&&l!=="node"})??null;return i(o)??i(r)}catch{return null}}function ns(n,e){if(typeof e=="string")return bt(e)||null;if(!e||typeof e!="object")return null;if(n){let t=e[n],r=typeof t=="string"?bt(t):void 0;if(r)return r}for(let t of Object.values(e)){let r=typeof t=="string"?bt(t):void 0;if(r)return r}return null}function os(n,e){if(!e)return null;let t=B__namespace.default.dirname(n),r=[B__namespace.default.resolve(t,"..",e),B__namespace.default.resolve(t,"node_modules",e)];for(let o of r){let s=B__namespace.default.join(o,"package.json");if(We(s))try{let i=JSON.parse(Jn.readFileSync(s,"utf8")),a=ns(e,i.bin);if(!a)continue;let d=B__namespace.default.resolve(o,a);if(We(d))return d}catch{}}return null}function ss(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=hn(n.command,t),s=Pt(B__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=rs(o)??os(o,n.packageName);return i?Pt(B__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 is(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(`${B__namespace.default.basename(n.candidate.command)} wrapper resolved, but no executable/Node entrypoint could be resolved without shell execution.`)}function Ze(n){let e=ss(n);return is({candidate:e,allowShellFallback:n.allowShellFallback})}function et(n,e){return {command:n.command,argv:[...n.leadingArgv,...e],resolution:n.resolution,shell:n.shell,windowsHide:n.windowsHide}}var St=D(()=>{c();});function as(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 ds(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 ls(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 ne(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=as(r)??ds(r)??ls(r);o&&(e=o);}catch{}return e??void 0}var Te=D(()=>{c();});exports.RateLimitError=void 0;var or=D(()=>{c();exports.RateLimitError=class extends Error{name="RateLimitError";constructor(e){super(e);}};});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 ze=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 Ke=D(()=>{c();});function It(n){if(!n)return {};let e=n.match(/^(.+?)\[([^\]]+)\]$/);if(e){let t=e[2].toLowerCase();return cs.has(t)?{model:e[1],effort:e[2]}:{model:n}}return {model:n}}function wn(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 xn(n){return n?["-c",`model_reasoning_effort=${n}`]:[]}function kn(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 cs,sr=D(()=>{c();cs=new Set(["minimal","low","medium","high","xhigh"]);});function us(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 _n;exports.claudeAdapter=void 0;var ir=D(()=>{c();or();ze();Ke();sr();_n=false,exports.claudeAdapter={command:"claude",buildArgs(n,e,t){let{model:r,effort:o}=It(e.model);(e.effort??o)&&!_n&&(_n=true,console.warn("[crewx] claude-cli: effort option has no equivalent CLI flag and will be ignored"));let i=kn(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
|
|
8
|
-
`).filter(o=>o.trim()),t=[],r=null;for(let o of e)try{let s=JSON.parse(o);s.type==="message"&&s.role==="assistant"&&s.delta===!0&&typeof s.content=="string"&&t.push(s.content),s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(""):r||n.trim()},parseResultMeta(n){let e=
|
|
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=us(i,d);l&&a.push(l);}return a}};});exports.geminiAdapter=void 0;var ar=D(()=>{c();Te();ze();Ke();exports.geminiAdapter={command:"gemini",buildArgs(n,e,t){if(e.additionalArgs!==void 0){let o=[...e.additionalArgs],s=o.indexOf("-p");return s!==-1?(o.splice(s+1,0,n),e.model&&o.push("--model",e.model),{args:o}):(e.model&&o.push("--model",e.model),{args:o,stdinMessage:n})}let r=["-p",n,"--output-format","stream-json","--verbose"];return e.model&&r.push("--model",e.model),{args:r}},extractText(n){let e=n.split(`
|
|
8
|
+
`).filter(o=>o.trim()),t=[],r=null;for(let o of e)try{let s=JSON.parse(o);s.type==="message"&&s.role==="assistant"&&s.delta===!0&&typeof s.content=="string"&&t.push(s.content),s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(""):r||n.trim()},parseResultMeta(n){let e=ne(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!=="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 []}};});exports.copilotAdapter=void 0;var dr=D(()=>{c();Te();ze();Ke();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(`
|
|
9
9
|
`).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(`
|
|
10
10
|
|
|
11
|
-
`):r||n.trim()},parseResultMeta(n){let e=
|
|
11
|
+
`):r||n.trim()},parseResultMeta(n){let e=ne(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 ps(n,e){if(e.type==="command_execution"){let r=String(e.command||"");return oe(r)?[se(n,r)]:[{timestamp:n,type:"tool_use",toolName:"Bash",toolInput:r}]}return []}function gs(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=ms(n,o);if(s)return s}if(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}}return null}function ms(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}exports.codexAdapter=void 0;var lr=D(()=>{c();Te();ze();Ke();sr();exports.codexAdapter={command:"codex",buildArgs(n,e,t){let{model:r,effort:o}=It(e.model),s=e.effort??o,i=wn(e.mode),a=xn(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=n.split(`
|
|
12
12
|
`).filter(o=>o.trim()),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=
|
|
15
|
-
`).filter(o=>o.trim()),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=
|
|
16
|
-
`).filter(d=>d.trim()),t=[],r=[],o=[],s=[],i=[],a=null;for(let d of e)try{let
|
|
14
|
+
`):r||n.trim()},parseResultMeta(n){let e=ne(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("item.")&&!r.startsWith("turn.")&&!r.startsWith("thread."))return [];let o=t.item;if(!o)return [];let s=e??new Date().toISOString();if(r==="item.started")return ps(s,o);if(r==="item.completed"){let i=gs(s,o);return i?[i]:[]}return []}};});exports.opencodeAdapter=void 0;var cr=D(()=>{c();Te();Ke();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=n.split(`
|
|
15
|
+
`).filter(o=>o.trim()),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=ne(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 [];let o=e??new Date().toISOString();if(r==="text"){let i=t.part?.text;return i?[{timestamp:o,type:"text",content:i}]:[]}if(r==="tool_use"){let s=t.part;if(!s)return [];let i=String(s.tool||""),a=String(s.callID||""),d=s.state,l=String(d?.status||""),u=d?.input,p=ie(u),y=[{timestamp:o,type:"tool_use",toolName:i,toolUseId:a,toolInput:p}];if(l==="completed"&&d?.output!==void 0){let g=d.output,h=typeof g=="string"?g:JSON.stringify(g);y.push({timestamp:o,type:"tool_result",toolUseId:a,resultPreview:h,isError:false});}else l==="error"&&y.push({timestamp:o,type:"tool_result",toolUseId:a,resultPreview:String(d?.error||"tool error"),isError:true});return y}return []}};});var ur,pr=D(()=>{c();ur={command:"agy",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){return n.trim()},parseResultMeta(n){return {usage:null,model:null}},parseEvent(n,e){return []}};});function rt(n,e,t){if(t){let r=exports.BUILTIN_ADAPTERS[t];if(r?.parseEvent)return r.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 be=D(()=>{c();ir();ar();dr();lr();cr();pr();ir();ar();dr();lr();cr();pr();ze();exports.BUILTIN_ADAPTERS={claude:exports.claudeAdapter,gemini:exports.geminiAdapter,copilot:exports.copilotAdapter,codex:exports.codexAdapter,opencode:exports.opencodeAdapter,antigravity:ur};});function ys(n){let e=n.split(`
|
|
16
|
+
`).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(`
|
|
17
17
|
|
|
18
18
|
`):r.length>0?r.join(""):o.length>0?o.join(`
|
|
19
19
|
|
|
20
20
|
`):s.length>0?s.join(`
|
|
21
21
|
|
|
22
|
-
`):i.length>0?i.join(""):a||n.trim()}function
|
|
23
|
-
`);S=
|
|
24
|
-
`);T=
|
|
22
|
+
`):i.length>0?i.join(""):a||n.trim()}function hs(n){let e=ne(n);return e?{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0}:null}function ws(n,e,t=process.platform){return n==="copilot"&&t==="win32"&&e instanceof exports.ProviderError&&e.message.includes('CLI command "copilot" not found')}function An(n,e,t,r,o,s,i){return new Promise((a,d)=>{let l=o?.timeoutMs??288e5,u=Ze({command:n,allowShellFallback:true}),p=et(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});s!==void 0&&y.stdin.write(s),y.stdin.end(),y.pid!==void 0&&o?.onPid?.(y.pid);let g=false,h=false,_=()=>{try{y.kill("SIGKILL");}catch{}},w=setTimeout(()=>{if(!g){h=true;try{y.kill("SIGTERM");}catch{}setTimeout(_,vn).unref();}},l);w.unref();let k="",x="",S="",T="";y.stdout.on("data",F=>{let j=F.toString();k+=j,S+=j;let R=S.split(`
|
|
23
|
+
`);S=R.pop()??"";for(let H of R)if(H.trim()&&(o?.onOutput?.(H,"stdout"),i?.extractFailure)){let re=i.extractFailure(H);if(re){g=true,clearTimeout(w);try{y.kill("SIGTERM");}catch{}setTimeout(_,vn).unref(),d(re);return}}}),y.stderr.on("data",F=>{let j=F.toString();x+=j,T+=j;let R=T.split(`
|
|
24
|
+
`);T=R.pop()??"";for(let H of R)H.trim()&&o?.onOutput?.(H,"stderr");}),y.on("error",F=>{g=true,clearTimeout(w),F.code==="ENOENT"?d(new exports.ProviderError(`CLI command "${n}" not found. Is ${t} installed?`,t)):d(new exports.ProviderError(`Spawn error: ${F.message}`,t));}),y.on("close",F=>{if(g)return;g=true,clearTimeout(w),S.trim()&&o?.onOutput?.(S,"stdout"),T.trim()&&o?.onOutput?.(T,"stderr");let j=F??0;if(o?.onExitCode?.(j),h&&F!==0)return d(new nt(`Total runtime exceeded ${l}ms; process killed.`,t));if(j!==0){if(i?.interpretExit){let H=i.interpretExit(j,x);if(H){d(H);return}}d(new exports.ProviderError(`Process exited with code ${j}: ${x.slice(0,500)}`,t));return}let R=i?i.extractText(k):ys(k);a({stdout:k,parsed:R});});})}function ge(n,e){Rn.set(n,e);}function me(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=Rn.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 gr(r,s,n)}throw new exports.ProviderError(`Unsupported provider namespace: "${t}". Register a factory with registerProviderFactory('${t}', factory).`,n)}exports.ProviderError=void 0;var nt,vn;exports.ClientToolCallRequiredError=void 0;var Rn,gr,le=D(()=>{c();St();Te();be();exports.ProviderError=class extends Error{constructor(t,r){super(t);this.providerStr=r;this.name="ProviderError";}providerStr},nt=class extends exports.ProviderError{constructor(e,t){super(e,t),this.name="TotalTimeoutError";}};vn=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"},Rn=new Map;gr=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}
|
|
25
25
|
|
|
26
26
|
---
|
|
27
27
|
|
|
28
|
-
${e}`:e}async runProcess(e,t,r){try{return await
|
|
29
|
-
`);this.stderrBuffer=
|
|
28
|
+
${e}`:e}async runProcess(e,t,r){try{return await An(this.adapter.command,e,this.providerStr,this.providerId,t,r,this.adapter)}catch(o){if(ws(this.providerId,o)){let s=e[0]==="copilot"?e:["copilot",...e];return An("gh",s,this.providerStr,this.providerId,t,r,this.adapter)}throw o}}handleResultMeta(e,t){if(!this.adapter.parseResultMeta){let i=hs(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 br(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 Y(n,e){try{let t=JSON.parse(n);if(t!=null&&typeof t=="object"&&typeof t.type=="string"&&si.has(t.type)){let r=e??new Date().toISOString();return [{...t,timestamp:t.timestamp||r}]}}catch{}return []}var si,ye=D(()=>{c();si=new Set(["text","tool_use","tool_result","error","agent_call"]);});var ro,no;exports.VercelProviderRuntime=void 0;var $r=D(()=>{c();le();ro=10,no=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??ro,no);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??ro,no),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}=K("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}=K("@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}=K("@ai-sdk/openai");return i({apiKey:r||process.env.OPENAI_API_KEY,...o&&{baseURL:o}})(s)}case "api/anthropic":{let{createAnthropic:i}=K("@ai-sdk/anthropic");return i({apiKey:r||process.env.ANTHROPIC_API_KEY,...o&&{baseURL:o}})(s)}case "api/google":{let{createGoogleGenerativeAI:i}=K("@ai-sdk/google");return i({apiKey:r||process.env.GOOGLE_API_KEY})(s)}default:throw new exports.ProviderError(`Unsupported API provider: ${t}`,t)}}};});var so={};At(so,{registerApiProviders:()=>oo});function oo(n){ge("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 jr=D(()=>{c();le();$r();});exports.AcpProtocolError=void 0;var Ur=D(()=>{c();exports.AcpProtocolError=class extends Error{constructor(t,r,o){super(t);this.code=r;this.data=o;}code;data;name="AcpProtocolError"};});var Zi,ea,io,ao,ta;exports.AcpConnection=void 0;var zt=D(()=>{c();Ur();le();Zi=-32e3,ea=2e3,io=3e4,ao=1e4,ta=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 _=this.stderrBuffer.split(`
|
|
29
|
+
`);this.stderrBuffer=_.pop()??"";for(let A of _)A.trim()&&this.options.onStderr?.(A);}),this.proc=o;let s=new WritableStream({write:g=>new Promise((h,_)=>{o.stdin.write(g,A=>{A?_(A):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 _=h.options;if(Array.isArray(_)&&_.length>0)return {outcome:{outcome:"selected",optionId:(_.find(w=>w.kind==="allow_once")??_.find(w=>w.kind?.startsWith("allow_"))??_[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",_=>{if(_.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: ${_.message}`,"acp"));});}),p=this.doInitialize(l,e),y=new Promise((g,h)=>{setTimeout(()=>{h(new exports.AcpProtocolError(`ACP connect timeout after ${io}ms. The ACP adapter may not be installed or may require interactive setup.`));},io).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 ${ao}ms`));},ao).unref();});return Promise.race([t,r])}isAuthError(e){return typeof e=="object"&&e!==null&&"code"in e&&e.code===Zi}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??ta,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 nt(`ACP prompt timeout after ${a}ms`,"acp"));},a).unref();}),p=new Promise((y,g)=>{let h=(k,x,S)=>{if(d)return;let T=x!=null?`signal=${x}`:`code=${String(k)}`;g(new exports.ProviderError(`ACP process terminated unexpectedly (${T}) [${S}]: ${this.collectedStderr.slice(-500)}`,"acp"));},_=(k,x)=>h(k,x,"exit"),A=(k,x)=>h(k,x,"close");i.once("exit",_),i.once("close",A);let w=()=>{i.off("exit",_),i.off("close",A);};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");},ea);});}get isConnected(){return !this.disposed&&this.sdkConnection!==null&&this.proc!==null}};});function lo(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 ra;exports.AcpProviderRuntime=void 0;var Hr=D(()=>{c();ye();zt();ra={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(`
|
|
30
30
|
|
|
31
|
-
`)}]}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=
|
|
31
|
+
`)}]}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=br(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
32
|
|
|
33
33
|
`)||e.push(`
|
|
34
34
|
|
|
35
|
-
`);}resolveToolCall(e){let t=e._meta;if(t?.claudeCode?.toolName)return {toolName:t.claudeCode.toolName,toolInput:
|
|
36
|
-
`)}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 En;exports.claudeAcpAdapter=void 0;var bt=N(()=>{l();xe();En=[{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,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:se};});exports.codexAcpAdapter=void 0;var kr=N(()=>{l();xe();exports.codexAcpAdapter={spawn:{command:"npx",args:["-y","@agentclientprotocol/codex-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/codex-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Codex",defaultMode:"agent"},buildSessionParams(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},extractUsage(n){let e=n.usage;return e?{inputTokens:e.inputTokens??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:se};});exports.geminiAcpAdapter=void 0;var vr=N(()=>{l();xe();exports.geminiAcpAdapter={spawn:{command:"gemini",args:["--acp","--skip-trust"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Gemini"},buildSessionParams(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},yoloModeId:"yolo",buildEffortAction(n){return null},resolveMode(n){return {acceptEdits:"autoEdit"}[n]??n},parseEvent:se};});var He;exports.copilotAcpAdapter=void 0;var _r=N(()=>{l();xe();He="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?W.resolve(n.cwd):process.cwd(),mcpServers:[]}},yoloModeId:`${He}#autopilot`,buildEffortAction(n){return n?{type:"set_config_option",configId:"reasoning_effort",value:n}:null},resolveMode(n){return n.startsWith("https://")?n:{yolo:`${He}#autopilot`,default:`${He}#agent`,agent:`${He}#agent`,plan:`${He}#plan`,autopilot:`${He}#autopilot`}[n]??null},parseEvent:se};});exports.opencodeAcpAdapter=void 0;var Ar=N(()=>{l();xe();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:se};});exports.ACP_ADAPTERS=void 0;var Mt=N(()=>{l();bt();kr();vr();_r();Ar();bt();kr();vr();_r();Ar();exports.ACP_ADAPTERS={claude:exports.claudeAcpAdapter,codex:exports.codexAcpAdapter,gemini:exports.geminiAcpAdapter,copilot:exports.copilotAcpAdapter,opencode:exports.opencodeAcpAdapter};});var In={};pt(In,{registerAcpProviders:()=>Sn});function Sn(n){if(n){ue("acp",n);return}ue("acp",(e,t)=>{let r=exports.ACP_ADAPTERS[e];if(!r)throw new exports.ProviderError(`Unknown ACP provider id: "${e}". Supported: ${Object.keys(exports.ACP_ADAPTERS).join(", ")}`,t);return new exports.AcpProviderRuntime(e,r,t)});}var Rr=N(()=>{l();ae();xr();Mt();ae();});function Ws(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 Pr=N(()=>{l();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=Ws(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 Cr=N(()=>{l();Pr();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 Mn={};pt(Mn,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>On,resolveFileRemoteAgent:()=>Qs});function Gs(n){let e=fs$1.readFileSync(n,"utf-8"),t=jsYaml.load(e);return {agents:Array.isArray(t?.agents)?t.agents:void 0}}function Ys(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 Qs(n,e=Gs,t=fs$1.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=Ys(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=W.resolve(W.dirname(r),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function On(n,e=pe){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 Zs(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 Tr=N(()=>{l();ae();Cr();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,r=pe){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let o=Zs(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(`
|
|
35
|
+
`);}resolveToolCall(e){let t=e._meta;if(t?.claudeCode?.toolName)return {toolName:t.claudeCode.toolName,toolInput:lo(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=ra[e.kind??""]??e.title??"unknown",o=lo(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(`
|
|
36
|
+
`)}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 co;exports.claudeAcpAdapter=void 0;var Vt=D(()=>{c();ye();co=[{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:Y};});exports.codexAcpAdapter=void 0;var Fr=D(()=>{c();ye();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:Y};});exports.geminiAcpAdapter=void 0;var qr=D(()=>{c();ye();exports.geminiAcpAdapter={spawn:{command:"gemini",args:["--acp","--skip-trust"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Gemini"},buildSessionParams(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},yoloModeId:"yolo",buildEffortAction(n){return null},resolveMode(n){return {acceptEdits:"autoEdit"}[n]??n},parseEvent:Y};});var Xe;exports.copilotAcpAdapter=void 0;var Br=D(()=>{c();ye();Xe="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?B.resolve(n.cwd):process.cwd(),mcpServers:[]}},yoloModeId:`${Xe}#autopilot`,buildEffortAction(n){return n?{type:"set_config_option",configId:"reasoning_effort",value:n}:null},resolveMode(n){return n.startsWith("https://")?n:{yolo:`${Xe}#autopilot`,default:`${Xe}#agent`,agent:`${Xe}#agent`,plan:`${Xe}#plan`,autopilot:`${Xe}#autopilot`}[n]??null},parseEvent:Y};});exports.opencodeAcpAdapter=void 0;var Wr=D(()=>{c();ye();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:Y};});exports.ACP_ADAPTERS=void 0;var Qt=D(()=>{c();Vt();Fr();qr();Br();Wr();Vt();Fr();qr();Br();Wr();exports.ACP_ADAPTERS={claude:exports.claudeAcpAdapter,codex:exports.codexAcpAdapter,gemini:exports.geminiAcpAdapter,copilot:exports.copilotAcpAdapter,opencode:exports.opencodeAcpAdapter};});var po={};At(po,{registerAcpProviders:()=>uo});function uo(n){if(n){ge("acp",n);return}ge("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 zr=D(()=>{c();le();Hr();Qt();le();});function oa(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 Kr=D(()=>{c();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=oa(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 Vr=D(()=>{c();Kr();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 mo={};At(mo,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>go,resolveFileRemoteAgent:()=>pa});function ca(n){let e=Jn.readFileSync(n,"utf-8"),t=jsYaml.load(e);return {agents:Array.isArray(t?.agents)?t.agents:void 0}}function ua(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 pa(n,e=ca,t=Jn.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=ua(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=B.resolve(B.dirname(r),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function go(n,e=me){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 ga(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 Gr=D(()=>{c();le();Vr();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,r=me){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let o=ga(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(`
|
|
37
37
|
`)}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(`
|
|
38
|
-
`)}};});var
|
|
39
|
-
`);
|
|
40
|
-
`);
|
|
41
|
-
`+(t?` package anchor: ${
|
|
38
|
+
`)}};});var wo={};At(wo,{PluginProviderRuntime:()=>exports.PluginProviderRuntime,createPluginProviderFactory:()=>ho});function ho(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 fo(n,e,t,r){let o=n.map(s=>s.replace(/\{model\}/g,e));return r&&o.push(t),o}function fa(n){if(!n||typeof n!="string")throw new Error("Plugin provider requires a cli_command")}function yo(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 ya(n){for(let{pattern:e}of n)if(typeof e!="string")throw new Error("Error pattern must be a string")}function ha(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();le();St();exports.PluginProviderRuntime=class{constructor(e,t){this.config=t;this.providerStr=`plugin/${e}`,fa(t.cli_command),yo(t.query_args),yo(t.execute_args),t.error_patterns&&ya(t.error_patterns),t.env&&ha(t.env);}config;providerStr;async query(e,t){let r=t?.model??this.config.default_model??"default",o=fo(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=fo(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=Ze({command:this.config.cli_command,allowShellFallback:true}),l=et(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",A=>{let w=A.toString();p+=w,g+=w;let k=g.split(`
|
|
39
|
+
`);g=k.pop()??"";for(let x of k)x.trim()&&t?.onOutput?.(x,"stdout");}),u.stderr.on("data",A=>{let w=A.toString();y+=w,h+=w;let k=h.split(`
|
|
40
|
+
`);h=k.pop()??"";for(let x of k)x.trim()&&t?.onOutput?.(x,"stderr");});let _=setTimeout(()=>{u.kill("SIGTERM"),i(new exports.ProviderError(`Plugin provider "${this.providerStr}" timed out after ${o}ms`,this.providerStr));},o);u.on("error",A=>{if(clearTimeout(_),A.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: ${A.message}`,this.providerStr));}),u.on("close",A=>{clearTimeout(_),g.trim()&&t?.onOutput?.(g,"stdout"),h.trim()&&t?.onOutput?.(h,"stderr");let w=A??0;if(t?.onExitCode?.(w),this.config.error_patterns){let k=y||p;for(let x of this.config.error_patterns)if(k.includes(x.pattern)){i(new exports.ProviderError(x.message,this.providerStr));return}}if(A!==0){i(new exports.ProviderError(`Process exited with code ${A}: ${y.slice(0,500)}`,this.providerStr));return}s(p.trim());});})}};});c();c();c();function zo(n){let e=o=>o.replace(/[.+^${}()|[\]\\]/g,"\\$&"),r=n.split("/").map(o=>o==="**"?".*":o.split("*").map(e).join("[^/]*"));return new RegExp(`^${r.join("\\/")}$`)}function de(n,e){try{return zo(e).test(n)}catch{return false}}c();c();var Ko=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()),mn=zod.z.object({include:zod.z.array(zod.z.string()).optional()}).optional(),Vo=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:Ko.optional(),skills:mn}).catchall(zod.z.unknown()),fn=zod.z.object({agents:zod.z.array(Vo).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 Ee=class extends Error{constructor(t,r){super(t);this.cause=r;this.name="ConfigLoadError";}cause};function Rt(n){if(!n||typeof n!="string"||!n.trim())throw new Ee("YAML content must be a non-empty string");let e;try{e=jsYaml.load(n);}catch(o){throw new Ee(`YAML parse error: ${o.message}`,o)}let t=Xo(e),r=fn.safeParse(t);if(!r.success)throw new Ee(`Config validation error: ${r.error.message}`);return r.data}function Et(n){let e;try{e=Jn.readFileSync(n,"utf-8");}catch(t){throw new Ee(`Cannot read file: ${n}`,t)}return Rt(e)}function Xo(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 Ce=B.join("templates","agents");function Zo(){try{let e=(typeof K=="function"?K:module$1.createRequire(typeof __filename<"u"?__filename:process.cwd()+"/")).resolve("@crewx/sdk/package.json");return B.dirname(e)}catch{return null}}function Be(n){if(n&&Jn.existsSync(n))return n;let e=process.env.CREWX_SDK_TEMPLATES_PATH;if(e&&Jn.existsSync(e))return e;let t=Zo();if(t){let o=B.join(t,Ce);if(Jn.existsSync(o))return o}let r=[B.join(__dirname,"..",Ce),B.join(__dirname,"..","..",Ce),B.join(__dirname,"..","..","..",Ce),B.join(process.cwd(),"packages","sdk",Ce),B.join(process.cwd(),Ce)];for(let o of r)if(Jn.existsSync(o))return o;throw new Error(`[@crewx/sdk] Templates directory not found.
|
|
41
|
+
`+(t?` package anchor: ${B.join(t,Ce)}
|
|
42
42
|
`:` package anchor: (unresolved)
|
|
43
43
|
`)+r.map(o=>` candidate: ${o}`).join(`
|
|
44
44
|
`)+`
|
|
45
|
-
Set CREWX_SDK_TEMPLATES_PATH or pass options.templatesPath.`)}function
|
|
45
|
+
Set CREWX_SDK_TEMPLATES_PATH or pass options.templatesPath.`)}function nr(){let n=Be();return {yamlPath:B.join(n,"default.yaml"),dir:n}}c();var pe=class extends Error{constructor(e,t){let r=t.length>0?` Available: ${t.join(", ")}`:"";super(`Agent not found: "${e}".${r}`),this.name="AgentNotFoundError";}},es={claude:{id:"claude",provider:"cli/claude"},gemini:{id:"gemini",provider:"cli/gemini"},copilot:{id:"copilot",provider:"cli/copilot"},codex:{id:"codex",provider:"cli/codex"}};function Tt(n,e){let t=n.startsWith("@")?n.slice(1):n,r=e.find(s=>s.id===t);if(r)return r;let o=es[t];if(o)return o;throw new pe(n,e.map(s=>s.id))}le();c();function En(n,e){if(n===void 0||n==="")return e;let t=parseInt(n,10);return Number.isNaN(t)?e:t}function Cn(n=process.env){return {queryMs:En(n.CREWX_TIMEOUT_QUERY,288e5),executeMs:En(n.CREWX_TIMEOUT_EXECUTE,288e5)}}c();var ot={"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},"gemini-2.5-pro":{input:1.25,cachedInput:.3125,output:10},"gemini-2.5-flash":{input:.075,cachedInput:.01875,output:.3},"glm-5.1":{input:.5,cachedInput:.05,output:2},copilot:{input:0,cachedInput:0,output:0}},xs={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","gemini-flash":"gemini-2.5-flash","gemini-pro":"gemini-2.5-pro"},mr={input:0,cachedInput:0,output:0};function ks(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 _s(n){if(!n)return mr;let e=ks(n),t=xs[e];if(t)return ot[t]??mr;if(ot[e])return ot[e];for(let r of Object.keys(ot))if(e.includes(r))return ot[r];return console.warn(`[pricing] Unknown model: ${n}, cost_usd=0`),mr}function vs(n,e,t,r=0){let o=_s(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 fr(n,e,t,r,o){return n&&n>0?n:!e&&!t?0:vs(e??0,t??0,o,r??0)}c();c();var Rs=[/^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],Es=/[;|&`$(){}!><\n\r]/,Cs=2,Ts=["*","**","*:*","* *","**/*"];function bs(){let n={};for(let[e,t]of Object.entries(process.env))t!==void 0&&(Rs.some(r=>r.test(e))||(n[e]=t));return n}function Ps(n){if(Es.test(n))throw new Error(`exec blocked: shell metacharacter detected in "${n}"`)}function Ss(n){return /^npx\s+@crewx\/[\w-]+/.test(n)}function Is(n){if(Ts.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 Os(n,e){let t=e.allow??[],r=e.deny??[];for(let o of [...t,...r])Is(o);return r.some(o=>de(n,o))?false:Ss(n)?true:t.some(o=>de(n,o))}var Tn=false;function Ms(n){Tn=n;}function st(n){if(!Tn)return;let e=JSON.stringify({span:"template_exec",...n,timestamp:new Date().toISOString()});console.error(e);}function Ns(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 bn(n,e){let t=Date.now(),r=parseInt(process.env.CREWX_EXEC_DEPTH??"0",10);if(isNaN(r)||r>=Cs)return st({command:n,status:"denied",reason:"invalid or max recursion depth"}),"(exec blocked: max recursion depth reached)";try{Ps(n);}catch{return st({command:n,status:"denied",reason:"shell metacharacter detected"}),`(exec blocked: shell metacharacter detected in "${n}")`}if(!Os(n,e))return st({command:n,status:"denied",reason:"not in allow list"}),`(exec blocked: ${n})`;try{let o=Ns(n),[s,...i]=o;if(!s)return `(exec failed: ${n})`;let a=bs(),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 st({command:n,status:"allowed",allowed_by:"policy",duration_ms:l}),`<exec-output cmd="${n}">
|
|
46
46
|
${d.trim()}
|
|
47
|
-
</exec-output>`}catch{return
|
|
47
|
+
</exec-output>`}catch{return st({command:n,status:"error",reason:"execution failed"}),`(exec failed: ${n})`}}c();function Pn(n){return n==null?"":String(n)}c();function Sn(n,e){return `\`\`\`${e?.hash?.lang??""}
|
|
48
48
|
${n??""}
|
|
49
|
-
\`\`\``}
|
|
49
|
+
\`\`\``}c();function yr(n,e){if(!n)return "";if(n.length<=e)return n;let t=n.length-e;return `${n.substring(0,e)} (...+${t} chars)`}function hr(n){return Array.isArray(n)||typeof n=="string"?n.length:0}function wr(n){return typeof n!="string"?"":n.replace(/\{\{/g,"{{").replace(/\}\}/g,"}}")}var In=["B","KB","MB","GB"];function xr(n){if(n===0)return "0 B";let e=Math.min(Math.floor(Math.log(n)/Math.log(1024)),In.length-1);return `${Math.round(n/Math.pow(1024,e)*100)/100} ${In[e]}`}function kr(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 it=class{hbs;execPolicy;execEnabled;constructor(e={}){this.hbs=ce__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(bn(o,t)):"(exec disabled)"}),e.registerHelper("include",function(o){return new e.SafeString(Pn(o))}),e.registerHelper("fenced_code",function(o,s){return new e.SafeString(Sn(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 yr(o,s)}),e.registerHelper("length",function(o){return hr(o)}),e.registerHelper("escapeHandlebars",function(o){return new e.SafeString(wr(o))}),e.registerHelper("formatFileSize",function(o){return xr(o)}),e.registerHelper("formatTimestamp",function(o){return kr(o)});}async render(e,t={}){return this.hbs.compile(e,{noEscape:true})(t)}};c();c();var $t=class{async readFile(e){return promises.readFile(e,"utf-8")}async exists(e){try{return await promises.access(e),!0}catch{return false}}resolvePath(...e){return e.length===1?B.resolve(e[0]):B.resolve(B.join(...e))}isAbsolute(e){return B.isAbsolute(e)}async readdir(e){try{return await promises.readdir(e)}catch{return []}}},Pe=new $t;var Se=class{docs=new Map;fs;constructor(e){this.fs=e??Pe;}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
50
|
`)){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(`
|
|
51
|
-
`)}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)}};l();l();var J=class extends Error{constructor(t,r,o){super(t);this.layoutId=r;this.cause=o;this.name="LayoutLoadError";}layoutId;cause},ge=class extends Error{constructor(t,r=[],o){super(t);this.errors=r;this.cause=o;this.name="PropsValidationError";}errors;cause};var ms={validationMode:"lenient",fallbackLayoutId:"crewx/default"},Ye=class{layouts=new Map;options;constructor(e){this.options={...ms,...e,templatesPath:e?.templatesPath??$e()},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 J(`Fallback layout not found: ${this.options.fallbackLayoutId}`,this.options.fallbackLayoutId);return t&&Object.keys(t).length>0?{...r,defaultProps:{...r.defaultProps,...t}}:r}getLayoutIds(){return Array.from(this.layouts.keys())}hasLayout(e){if(this.layouts.has(e))return true;let t=this.normalizeLayoutId(e);return this.layouts.has(t)}reload(){this.layouts.clear(),this.loadAllLayouts();}registerLayout(e,t){if(!e||typeof e!="string")throw new J("Layout ID must be a non-empty string",e);let r=typeof t=="string"?{template:t}:t,o=typeof r.template=="string"?r.template:"";if(!o||o.trim().length===0)throw new J(`Custom layout template is empty for ${e}`,e);let s=r.propsSchema||{},i=this.extractDefaultProps(s),a=r.defaultProps||{},d={id:e,version:r.version||"1.0.0",description:r.description||`Custom layout ${e}`,template:o,propsSchema:this.parsePropsSchema(s),defaultProps:{...i,...a}},c=this.layouts.get(e),u=c?.template===o&&JSON.stringify(c?.defaultProps??{})===JSON.stringify(d.defaultProps??{})&&JSON.stringify(c?.propsSchema??{})===JSON.stringify(d.propsSchema??{});this.layouts.set(e,d),process.env.CREWX_VERBOSE==="1"&&(c?u||console.error(`Updated custom layout: ${e}`):console.error(`Registered custom layout: ${e}`));}registerLayouts(e){for(let[t,r]of Object.entries(e))try{this.registerLayout(t,r);}catch(o){console.warn(`Failed to register custom layout ${t}:`,o instanceof Error?o.message:o);}}loadAllLayouts(){let e=this.options.templatesPath;if(!fs$1.existsSync(e))throw new J(`Templates directory not found: ${e}`,void 0,new Error(`Directory does not exist: ${e}`));try{let t=fs$1.readdirSync(e).filter(r=>r.endsWith(".yaml")||r.endsWith(".yml"));t.length===0&&console.warn(`No layout files found in ${e}`);for(let r of t){let o=r.replace(/\.(yaml|yml)$/,""),s=W__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 J(`Failed to read layouts directory: ${e}`,void 0,t instanceof Error?t:new Error(String(t)))}}loadLayoutFile(e,t){try{let r=fs$1.readFileSync(e,"utf-8");if(!r||r.trim().length===0)throw console.warn(`Empty YAML file: ${e}, will use fallback`),new J(`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 J(`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 J(`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 J(`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 J(`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}}}};l();l();l();function Ce(n){return String(Math.floor(Math.abs(n))).padStart(2,"0")}function Qe(n){if(!(n instanceof Date)||Number.isNaN(n.getTime()))return "";let e=-n.getTimezoneOffset(),t=e>=0?"+":"-";return `${n.getFullYear()}-${Ce(n.getMonth()+1)}-${Ce(n.getDate())}T${Ce(n.getHours())}:${Ce(n.getMinutes())}:${Ce(n.getSeconds())}${t}${Ce(e/60)}:${Ce(e%60)}`}function un(n){if(!Number.isFinite(n))return "";let e=Math.floor(n/1e3);if(e<=0)return "just now";if(e<60)return `${e}s ago`;let t=Math.floor(e/60);if(t<60)return `${t}m ago`;let r=Math.floor(t/60);return r<24?`${r}h ago`:`${Math.floor(r/24)}d ago`}function fs(n,e){return n.map(t=>{let r=typeof t?.timestamp=="number"?t.timestamp:null;return r===null?t:{...t,created_at:Qe(new Date(r)),relative_time:un(e-r)}})}function ys(n){return Array.from(new Set(n.filter(e=>e?.isAssistant&&e?.metadata?.agent_id).map(e=>String(e.metadata.agent_id))))}function pn(...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=ys(t),d=a.length>0?a[0]:"",c=Date.now(),u={messages:fs(t,c),platform:typeof r=="string"?r:"",messagesCount:t.length,agentIds:a,primaryAgentId:d,currentAgentId:o,threadId:s,now:Qe(new Date(c))};return e.fn(u)}l();var Ze=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 ge("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 c=[...o,a],u=e[a],g=this.resolveProp(u,d,c,r,s);g.shouldAssign&&(i[a]=g.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,c=t.itemOneOf,u=s.length;return i.value.forEach((g,y)=>{let p=[...r,String(y)];if(d){let m=this.validateType(g,{type:d},p,o,s);m.valid?a.push(m.value):s.push({path:this.buildPath(p),message:m.error??"Invalid array item",value:g});}else a.push(g);c&&!c.includes(g)&&s.push({path:this.buildPath(p),message:`Array item must be one of: ${c.join(", ")}`,value:g});}),{valid:s.length===u,value:a}}validatePlainObject(e){return this.isPlainObject(e)?{valid:true,value:{...e}}:{valid:false,error:`Expected object, got ${this.describeType(e)}`}}validateFunction(e){return typeof e!="function"?{valid:false,error:`Expected function, got ${this.describeType(e)}`}:{valid:true,value:e}}validateShape(e,t,r,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 et=class{handlebars;propsValidator;constructor(e){this.handlebars=de__namespace.default.create(),this.propsValidator=e??new Ze,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",pn),de__namespace.default.helpers.each&&this.handlebars.registerHelper("each",de__namespace.default.helpers.each),de__namespace.default.helpers.if&&this.handlebars.registerHelper("if",de__namespace.default.helpers.if),de__namespace.default.helpers.unless&&this.handlebars.registerHelper("unless",de__namespace.default.helpers.unless),de__namespace.default.helpers.with&&this.handlebars.registerHelper("with",de__namespace.default.helpers.with),this.handlebars.registerHelper("eq",function(e,t){return e===t}),this.handlebars.registerHelper("ne",function(e,t){return e!==t}),this.handlebars.registerHelper("gt",function(e,t){return e>t}),this.handlebars.registerHelper("lt",function(e,t){return e<t}),this.handlebars.registerHelper("json",function(e){return new de__namespace.default.SafeString(JSON.stringify(e))}),this.handlebars.registerHelper("raw",function(e){return typeof e?.fn=="function"?e.fn(this):""}),this.handlebars.registerHelper("escapeHandlebars",function(e){return typeof e!="string"?"":e.replace(/\{\{/g,"{{").replace(/\}\}/g,"}}")}),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 ge&&o.errors&&o.errors.length>0){let s=o.errors[0];if(s)throw new ge(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,"{{{").replace(/\}\}\}/g,"}}}").replace(/\{\{/g,"{{").replace(/\}\}/g,"}}");t.user_input=this.handlebars.escapeExpression(r);}return t}};l();var ir="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function hs(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+=ir[o%62]);}for(;t.length<n;)t+=ir[crypto$1.randomBytes(1)[0]%62];return t}function Te(n){return `${n}_${hs(8)}`}function ws(n,e){let{createHash:t}=z("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+=ir[i%62];return `${n}_${s}`}l();function ar(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())}`}l();function mn(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 tt=class{_emitter=new events.EventEmitter;on(e,t){let r=mn(e,t);return this._emitter.on(e,r),()=>this._emitter.off(e,r)}once(e,t){let r=mn(e,t);return this._emitter.once(e,r),()=>this._emitter.off(e,r)}emit(e,t){this._emitter.emit(e,t);}};l();function dr(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}}}l();var lr=new async_hooks.AsyncLocalStorage;function vs(){return lr}function _s(n,e){return lr.run(n,e)}function cr(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()=>{}),c=n.onResolveUser??(async y=>({userId:y,displayName:y})),u=async y=>{let p=lr.getStore();if(!p){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 m="text"in y?y.text:"";p.res.status(200).json({text:m});},g=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:g,inbound:i,emitEvent:a,updateMessage:d,resolveUser:c,respondSync:u}}Fe();l();var As=/^-\s*Status:\s*active/m,Rs=/^---\n([\s\S]*?)\n---/,Ps=/^type:\s*goal\s*$/m;async function fn(n,e=Re,t){let r=typeof t=="string"?[t]:Array.isArray(t)?t:void 0;if(r){let a=[];for(let d of r){let c=e.resolvePath(n,d);await e.exists(c)&&a.push(await e.readFile(c));}return a.join(`
|
|
51
|
+
`)}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 J=class extends Error{constructor(t,r,o){super(t);this.layoutId=r;this.cause=o;this.name="LayoutLoadError";}layoutId;cause},fe=class extends Error{constructor(t,r=[],o){super(t);this.errors=r;this.cause=o;this.name="PropsValidationError";}errors;cause};var Ws={validationMode:"lenient",fallbackLayoutId:"crewx/default"},at=class{layouts=new Map;options;constructor(e){this.options={...Ws,...e,templatesPath:e?.templatesPath??Be()},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 J(`Fallback layout not found: ${this.options.fallbackLayoutId}`,this.options.fallbackLayoutId);return t&&Object.keys(t).length>0?{...r,defaultProps:{...r.defaultProps,...t}}:r}getLayoutIds(){return Array.from(this.layouts.keys())}hasLayout(e){if(this.layouts.has(e))return true;let t=this.normalizeLayoutId(e);return this.layouts.has(t)}reload(){this.layouts.clear(),this.loadAllLayouts();}registerLayout(e,t){if(!e||typeof e!="string")throw new J("Layout ID must be a non-empty string",e);let r=typeof t=="string"?{template:t}:t,o=typeof r.template=="string"?r.template:"";if(!o||o.trim().length===0)throw new J(`Custom layout template is empty for ${e}`,e);let s=r.propsSchema||{},i=this.extractDefaultProps(s),a=r.defaultProps||{},d={id:e,version:r.version||"1.0.0",description:r.description||`Custom layout ${e}`,template: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(!Jn.existsSync(e))throw new J(`Templates directory not found: ${e}`,void 0,new Error(`Directory does not exist: ${e}`));try{let t=Jn.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=B__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 J(`Failed to read layouts directory: ${e}`,void 0,t instanceof Error?t:new Error(String(t)))}}loadLayoutFile(e,t){try{let r=Jn.readFileSync(e,"utf-8");if(!r||r.trim().length===0)throw console.warn(`Empty YAML file: ${e}, will use fallback`),new J(`Empty YAML file: ${e}`,t,new Error("File content is empty"));let 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 J(`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 J(`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 J(`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 J(`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 Ie(n){return String(Math.floor(Math.abs(n))).padStart(2,"0")}function dt(n){if(!(n instanceof Date)||Number.isNaN(n.getTime()))return "";let e=-n.getTimezoneOffset(),t=e>=0?"+":"-";return `${n.getFullYear()}-${Ie(n.getMonth()+1)}-${Ie(n.getDate())}T${Ie(n.getHours())}:${Ie(n.getMinutes())}:${Ie(n.getSeconds())}${t}${Ie(e/60)}:${Ie(e%60)}`}function zs(n){return n.map(e=>{let t=typeof e?.timestamp=="number"?e.timestamp:null;return t===null?e:{...e,created_at:dt(new Date(t))}})}function Ks(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 Dn(...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=Ks(t),d=a.length>0?a[0]:"",l=Date.now(),u={messages:zs(t),platform:typeof r=="string"?r:"",messagesCount:t.length,agentIds:a,primaryAgentId:d,currentAgentId:o,threadId:s,now:dt(new Date(l))};return e.fn(u)}c();var lt=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 fe("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 ct=class{handlebars;propsValidator;constructor(e){this.handlebars=ce__namespace.default.create(),this.propsValidator=e??new lt,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",Dn),ce__namespace.default.helpers.each&&this.handlebars.registerHelper("each",ce__namespace.default.helpers.each),ce__namespace.default.helpers.if&&this.handlebars.registerHelper("if",ce__namespace.default.helpers.if),ce__namespace.default.helpers.unless&&this.handlebars.registerHelper("unless",ce__namespace.default.helpers.unless),ce__namespace.default.helpers.with&&this.handlebars.registerHelper("with",ce__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 ce__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,"{{").replace(/\}\}/g,"}}")}),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 fe&&o.errors&&o.errors.length>0){let s=o.errors[0];if(s)throw new fe(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,"{{{").replace(/\}\}\}/g,"}}}").replace(/\{\{/g,"{{").replace(/\}\}/g,"}}");t.user_input=this.handlebars.escapeExpression(r);}return t}};c();var _r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function Vs(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+=_r[o%62]);}for(;t.length<n;)t+=_r[crypto$1.randomBytes(1)[0]%62];return t}function Oe(n){return `${n}_${Vs(8)}`}function Gs(n,e){let{createHash:t}=K("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+=_r[i%62];return `${n}_${s}`}c();function vr(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 $n(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 ut=class{_emitter=new events.EventEmitter;on(e,t){let r=$n(e,t);return this._emitter.on(e,r),()=>this._emitter.off(e,r)}once(e,t){let r=$n(e,t);return this._emitter.once(e,r),()=>this._emitter.off(e,r)}emit(e,t){this._emitter.emit(e,t);}};c();function Ar(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 Rr=new async_hooks.AsyncLocalStorage;function Ys(){return Rr}function Qs(n,e){return Rr.run(n,e)}function Er(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=Rr.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}}be();c();var Zs=/^-\s*Status:\s*active/m,ei=/^---\n([\s\S]*?)\n---/,ti=/^type:\s*goal\s*$/m;async function jn(n,e=Pe,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
52
|
---
|
|
53
|
-
`)}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),
|
|
53
|
+
`)}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=ei.exec(l);!u||!ti.test(u[1])||Zs.test(l)&&i.push(l);}return i.join(`
|
|
54
54
|
---
|
|
55
|
-
`)}
|
|
56
|
-
${i.message}`)}let s=gt(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 c=d;typeof c.path=="string"&&!W.isAbsolute(c.path)?i[a]={...c,path:W.resolve(r,c.path)}:i[a]=c;}else i[a]=d;return {...s,documents:i}}return s}static mergeCrewxConfig(e,t){let r=new Map;for(let k of e.agents??[])r.set(k.id,k);for(let k of t.agents??[])r.has(k.id)&&console.warn(`[agent-loader] User agent "${k.id}" overrides built-in`),r.set(k.id,k);let o=Array.from(r.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,d=t,c=Fn(a.vars,d.vars),u=Fn(a.settings,d.settings),g;e.skills&&t.skills&&typeof e.skills=="object"&&typeof t.skills=="object"&&!Array.isArray(e.skills)&&!Array.isArray(t.skills)?g={...e.skills,...t.skills}:g=t.skills??e.skills;let y=[...e.hooks??[],...t.hooks??[]],p=li(a.providers,d.providers),m={...e},w={...t};for(let k of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete m[k],delete w[k];let v={...{...m,...w},agents:o,layouts:s,documents:i,skills:g};return y.length>0&&(v.hooks=y),c!==void 0&&(v.vars=c),u!==void 0&&(v.settings=u),p!==void 0&&(v.providers=p),v}static async loadYaml(e,t,r){let o=t?.includeBuiltIns!==false,s,i;if(o){let u=await n.loadBuiltInConfig(r);if(e!==void 0){let g=mt(e);s=n.mergeCrewxConfig(u,g),i=W.dirname(e);}else s=u,i=process.cwd();}else {if(e===void 0)throw new Error("[@crewx/sdk] loadYaml: path is required when includeBuiltIns is false");s=mt(e),i=W.dirname(e);}let a=new Pe(r);await a.load(s.documents,i);let d=s.agents??[];return await Hn(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 Pe(o);await a.load(i.documents,r??(typeof process<"u"?process.cwd():"/"));let d=i.agents??[];return await Hn(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=ar(t);return W.join(this._projectRoot,".crewx","logs",`${r}_${e}.log`)}registerTool(e,t){this._tools.set(e,{name:e,...t});}async use(e){this._plugins.includes(e)||(await e.attach(this),this._plugins.push(e));}handler(e){return gr(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??dr(r),a=e.defaultMode??"query",d=t.manifest.platform,c=e.agentRunner??{run:async(p,m,w)=>{let v=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${p}`,m,{threadId:w?.threadId,platform:d});return {output:v.ok?v.data:v.error?.message??""}}},u=e.onInbound??(async p=>{let m=p.routingHints?.agentId??e.defaultAgent;if(!m)return {accepted:false,reason:"no_agent"};let{output:w}=await c.run(m,p.text,{threadId:p.threadId});return {accepted:true,output:w}}),g=cr({instanceId:r,config:o,capabilities:s,db:i,agentRunner:c,onInbound:u}),y={adapter:t,ctx:g,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(g),y.state="started",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"started",timestamp:new Date});}catch(p){throw y.state="failed",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"failed",error:p instanceof Error?p:new Error(String(p)),timestamp:new Date}),this._activeAdapters.delete(r),p}}async unregisterChannelAdapter(e){let t=this._activeAdapters.get(e);if(t){t.state="stopping",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopping",timestamp:new Date});try{await t.adapter.stop(t.ctx),t.state="stopped",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopped",timestamp:new Date});}catch(r){t.state="failed",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"failed",error:r instanceof Error?r:new Error(String(r)),timestamp:new Date});}finally{this._activeAdapters.delete(e);}}}async stopAllAdapters(e={}){let t=e.timeoutMs??1e4,r=Array.from(this._activeAdapters.keys()),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=>ie(a.role.toLowerCase(),d)))),o&&(i=i.filter(a=>a.team&&o.some(d=>ie(a.team.toLowerCase(),d)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(c=>s.some(u=>ie(c.toLowerCase(),u))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,r=this._agents.get(t);if(!r)throw new ce(t,Array.from(this._agents.keys()));return r.inline?.prompt??r.inline?.system_prompt??r.description??`You are an expert ${t}.`}async renderPrompt(e,t){let 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 ce(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),c=o.inline?.prompt??o.inline?.system_prompt??o.description??`You are an expert ${r}.`,u=await this._documentLoader.buildContext(),g=t?.env??(typeof process<"u"?process.env:{}),y=t?.vars?.security_key??di(),p={...t?.vars??{},documents:u,env:g,agent:{id:o.id,name:o.name??o.id,role:o.role??"",team:o.team??"",description:o.description??""}},m=await this._templateEngine.render(c,p),w={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},A=o.provider,v=Array.isArray(A)?A:typeof A=="string"&&A.length>0?[A]:[],k=v.join(", ")||(typeof A=="string"?A:""),x=o.options,S=["goals","daily"],T={goals:false,daily:false},B;if(!Array.isArray(x)&&typeof x=="object"&&x!==null){let $=x;if("goals"in $){let U=$.goals;typeof U=="string"||Array.isArray(U)?T.goals=U:T.goals=!!U;}"daily"in $&&(T.daily=!!$.daily);let q={};for(let[U,_]of Object.entries($))S.includes(U)||(q[U]=_);if(Object.keys(q).length>0){let U=v.some(M=>M.startsWith("cli/")),_={};for(let[M,b]of Object.entries(q)){let R={};if(Array.isArray(b))U&&(R.rawArgs=b);else if(typeof b=="object"&&b!==null){let F=b;Object.keys(F).length>0&&(R.named=F);}(R.named||R.rawArgs&&R.rawArgs.length>0)&&(_[M]=R);}B=Object.keys(_).length>0?_:void 0;}}let L=Array.isArray(x)?x:void 0,P={};for(let[$,q]of Object.entries(u))P[$]={content:q.content??"",toc:q.toc,summary:q.summary,path:q.path};if(T.goals){let $=W.join(this._projectRoot,"docs","goal"),q=await fn($,void 0,T.goals);q&&(P.active_goals={content:q});}if(T.daily){let $=W.join(this._projectRoot,"docs","daily"),q=await yn($);q&&(P.today_daily={content:q});}let G={user_input:t?.vars?.user_input??void 0,agent:{id:o.id,name:o.name??o.id,role:o.role??"",team:o.team??"",description:o.description??"",provider:k,providerList:v,model:o.inline?.model,workingDirectory:o.working_directory??o.workingDirectory??".",inline:{...o.inline??{},prompt:m},specialties:o.specialties??[],capabilities:o.capabilities??[],remote:o.remote??null,optionsByMode:B,optionsArray:L},agentMetadata:{specialties:o.specialties??[],capabilities:o.capabilities??[],description:o.description??""},contextOptions:T,documents:P,skills:t?.skills??[],session:w,env:g,vars:{security_key:y,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:w.platform,mode:w.mode,thread_id:t?.threadId??"",now:Qe(new Date),messages:t?.messages??[],tools:this._tools.size>0?{list:Array.from(this._tools.values()).map($=>({name:$.name,description:$.description,parameters:$.parameters})),json:JSON.stringify(Array.from(this._tools.values()).map($=>({name:$.name,description:$.description,parameters:$.parameters})),null,2),count:this._tools.size}:null,metadata:{}};return this._layoutRenderer.render(d,G)}_filterToolsByMode(e){return e?e.map(t=>this._tools.get(t)).filter(t=>t!==void 0):Array.from(this._tools.values())}_resolveLayoutSpec(e,t){if(t!==void 0)return t;let r=e.inline?.layout;if(r!==void 0)return r;let 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:pr(s)}catch{return}}_resolveTimeout(e){let t=tn();return e==="query"?t.queryMs:t.executeMs}_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 c=exports.BUILTIN_ADAPTERS[r]?.parseEvent?.(o)??Zt(new Date().toISOString(),o);for(let u of c)u.type==="tool_use"&&u.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName,rawName:u.toolName,input:u.toolInput?this.tryParseJson(u.toolInput):void 0,toolUseId:u.toolUseId}}),u.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName??"unknown",rawName:u.toolName??"unknown",toolUseId:u.toolUseId,result:u.resultPreview,isError:u.isError}});}catch{}}emitTaskLogEntries(e,t,r,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=rt.getStore()??ur(r?.trace),i=r?.taskId??Te("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return rt.run(d,async()=>{let c=Date.now(),u=new Date,g;try{g=yt(e,Array.from(this._agents.values()));}catch(_){if(_ instanceof ce){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"AGENT_NOT_FOUND",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:M}}}throw _}d.callerAgentId=g.id;let y=Array.isArray(g.provider)?g.provider[0]??"cli/claude":g.provider,p=r?.provider??y,m=r?.model??g.inline?.model;m&&m.includes("{{")&&(m=await this._templateEngine.render(m,{...r?.vars??{}}));let w;try{w=pe(p);}catch(_){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"PROVIDER_ERROR",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M}}}let A=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),v;try{v=await this.renderAgentPromptFull(e,{session:{mode:"query",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:A,threadId:r?.threadId});}catch(_){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${_ instanceof Error?_.message:String(_)}`);}let k,x,S,T=m,B=false,L=_=>{B||(B=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",pid:_,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:T,provider:p,codingAgentCommand:k,renderedPrompt:v,metadata:{...r?.metadata??{},provider:p},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},P=g.options,H=Array.isArray(P?.query?.tools)?P.query.tools:void 0,G=this._tools.size>0?this._filterToolsByMode(H):[],$=(()=>{let _=P?.query;if(!_||Array.isArray(_))return;let{tools:M,effort:b,mode:R,...F}=_,Y=Object.entries(F).filter(([,K])=>K!=null);if(Y.length!==0)return Object.fromEntries(Y.map(([K,qt])=>[K,String(qt)]))})(),q=g.inline?.max_steps;p.startsWith("api/")&&L();let U=false;try{let _=await w.query(t,{model:m,effort:P?.query?.effort,mode:P?.query?.mode,context:r?.context,systemPrompt:v??g.inline?.system_prompt??g.inline?.prompt??g.description??`You are ${g.id}.`,additionalArgs:Array.isArray(P?.query)?P.query:void 0,tools:G.length>0?G:void 0,maxSteps:q,configOptions:$,timeoutMs:this._resolveTimeout("query"),cwd:r?.cwd,env:{CREWX_AGENT_ID:g.id,CREWX_AGENT_ROLE:g.role??"",CREWX_AGENT_TEAM:g.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:p,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,u)},onPid:R=>L(R),onOutput:(R,F)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:R,level:F}),F==="stdout"&&this.emitToolEvents(i,e,p,R,g.id,r?.threadId??"","");},onTaskLog:R=>{this.emitTaskLogEntries(i,e,g.id,r?.threadId??"","",p,R);for(let F of R)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(F),level:"info"});},onCommand:R=>{k=R;},onUsage:R=>{x=R;},onExitCode:R=>{S=R;},onModel:R=>{T||(T=R);}});L();let M=Date.now()-c,b={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:_,durationMs:M,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:Object.keys(b).length>0?b:void 0}),U=!0,{ok:!0,data:_,meta:{agentId:g.id,provider:p,model:m,durationMs:M,taskId:i}}}catch(_){if(_ instanceof exports.ClientToolCallRequiredError){let R=Te("thd");return this._pendingThreads.set(R,{agentRef:g.id,providerStr:p,continuationState:_.continuationState,toolCall:_.toolCall,traceId:i,startMs:c,model:m}),U=true,{ok:true,status:"requires_action",data:"",toolCall:_.toolCall,threadId:R,meta:{agentId:g.id,provider:p,model:m,durationMs:Date.now()-c,taskId:i}}}L();let M=Date.now()-c,b={code:"QUERY_FAILED",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:M,error:b,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:r?.metadata?{...r.metadata}:void 0}),U=true,{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M,taskId:i}}}finally{U||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:Date.now()-c,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:S??-1,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T});}})}async continueQuery(e,t){let r=this._pendingThreads.get(e);if(!r)return {ok:false,data:"",error:{code:"THREAD_NOT_FOUND",message:`No pending thread: ${e}`},meta:{agentId:"",provider:"",durationMs:0}};this._pendingThreads.delete(e);let o=pe(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=rt.getStore()??ur(r?.trace),i=r?.taskId??Te("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return rt.run(d,async()=>{let c=Date.now(),u=new Date,g;try{g=yt(e,Array.from(this._agents.values()));}catch(_){if(_ instanceof ce){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"AGENT_NOT_FOUND",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:M}}}throw _}d.callerAgentId=g.id;let y=Array.isArray(g.provider)?g.provider[0]??"cli/claude":g.provider,p=r?.provider??y,m=r?.model??g.inline?.model;m&&m.includes("{{")&&(m=await this._templateEngine.render(m,{...r?.vars??{}}));let w;try{w=pe(p);}catch(_){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"PROVIDER_ERROR",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M}}}let A=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),v;try{v=await this.renderAgentPromptFull(e,{session:{mode:"execute",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:A,threadId:r?.threadId});}catch(_){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${_ instanceof Error?_.message:String(_)}`);}let k,x,S,T=m,B=false,L=_=>{B||(B=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",pid:_,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:T,provider:p,codingAgentCommand:k,renderedPrompt:v,metadata:{...r?.metadata??{},provider:p},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},P=g.options,H=Array.isArray(P?.execute?.tools)?P.execute.tools:void 0,G=this._tools.size>0?this._filterToolsByMode(H):[],$=(()=>{let _=P?.execute;if(!_||Array.isArray(_))return;let{tools:M,effort:b,mode:R,...F}=_,Y=Object.entries(F).filter(([,K])=>K!=null);if(Y.length!==0)return Object.fromEntries(Y.map(([K,qt])=>[K,String(qt)]))})(),q=g.inline?.max_steps;p.startsWith("api/")&&L();let U=false;try{let _=await w.execute(t,{model:m,effort:P?.execute?.effort,mode:P?.execute?.mode,context:r?.context,systemPrompt:v??g.inline?.system_prompt??g.inline?.prompt??g.description??`You are ${g.id}.`,additionalArgs:Array.isArray(P?.execute)?P.execute:void 0,tools:G.length>0?G:void 0,maxSteps:q,configOptions:$,timeoutMs:this._resolveTimeout("execute"),cwd:r?.cwd,env:{CREWX_AGENT_ID:g.id,CREWX_AGENT_ROLE:g.role??"",CREWX_AGENT_TEAM:g.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:p,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,u)},onPid:R=>L(R),onOutput:(R,F)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:R,level:F}),F==="stdout"&&this.emitToolEvents(i,e,p,R,g.id,r?.threadId??"","");},onTaskLog:R=>{this.emitTaskLogEntries(i,e,g.id,r?.threadId??"","",p,R);for(let F of R)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(F),level:"info"});},onCommand:R=>{k=R;},onUsage:R=>{x=R;},onExitCode:R=>{S=R;},onModel:R=>{T||(T=R);}});L();let M=Date.now()-c,b={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:_,durationMs:M,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:Object.keys(b).length>0?b:void 0}),U=!0,{ok:!0,data:_,meta:{agentId:g.id,provider:p,model:m,durationMs:M,taskId:i}}}catch(_){L();let M=Date.now()-c,b={code:"EXECUTE_FAILED",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:M,error:b,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:r?.metadata?{...r.metadata}:void 0}),U=true,{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M}}}finally{U||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:Date.now()-c,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:S??-1,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T});}})}};function Fn(n,e){let t=Ir(n)?n:void 0,r=Ir(e)?e:void 0;if(!(!t&&!r))return {...t??{},...r??{}}}function Ir(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function li(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(!Ir(a))return;let d=a.id;if(typeof d=="string")return `id:${d}`;let c=a.name;if(typeof c=="string")return `name:${c}`},s=new Set;for(let a of r??[]){let d=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 Hn(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(()=>(yr(),Pn));o(t?.api);}await ui(n,e),pi(n,e),ci(n);}function ci(n){if(!n.some(r=>(Array.isArray(r.provider)?r.provider:[r.provider]).some(s=>s.startsWith("acp/"))))return;let{registerAcpProviders:t}=(Rr(),Vr(In));t();}async function ui(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(()=>(Tr(),Mn)),s=new Map;for(let i of r)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&ue("remote",o(s,pe));}function pi(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}=(br(),Vr(Ln)),s=new Map;for(let i of r)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&ue("plugin",o(s));}l();var Or=class{detach(e){}};l();var gi="crewx:fs:",Mr=class{prefix;store;constructor(e){this.prefix=e?.prefix??gi,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,"/")}`}};l();function mi(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))}ae();fr();yr();l();wr();xe();l();Ct();Mt();bt();function fi(n,e,t,r){let o=t.agentInfo?.name,s=e??o??n,a=(r.modes?.availableModes??[]).map(m=>({id:m.id,name:m.name,...m.description!=null?{description:m.description}:{}})),d=[],c=r.configOptions??[];for(let m of c)if(m.category==="thought_level"&&m.type==="select"){let w=m.options??[];if(w.length>0&&w[0]?.group!=null)for(let A of w)for(let v of A.options??[])d.push(v.value);else for(let A of w)A.value!=null&&d.push(A.value);}let u=r.models?.availableModels??[],g=n==="claude"?En.map(m=>({id:m.id,name:m.name})):u.map(m=>({id:m.modelId})),y=t.agentCapabilities??{},p={loadSession:y.loadSession??false,image:y.promptCapabilities?.image??false,audio:y.promptCapabilities?.audio??false,mcp:y.mcpCapabilities!=null};return {id:`acp/${n}`,name:s,modes:a,effort:d,models:g,capabilities:p}}async function qn(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 fi(n,t,o,i)}catch{return null}finally{await r.dispose();}}async function yi(){let n=Object.keys(exports.ACP_ADAPTERS),e=await Promise.allSettled(n.map(r=>qn(r))),t=[];for(let r of e)r.status==="fulfilled"&&r.value!==null&&t.push(r.value);return t}Ct();xr();Mt();Rr();zt();Fe();l();var Nr=0;function hi(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(Nr>=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(", ")}`;Nr++;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{Nr--;}}}}l();var Bn=typeof process<"u"?process.env:{};function wi(){return Bn.CREWX_CLI||"npx crewx"}function xi(){return Bn.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}l();var ki=/^[a-zA-Z0-9._-]+$/,Dr=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(!ki.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return Te("box")}};l();function vi(n,e,t,r,o){let{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}=r,d=s*i,c=s*a,u=d+c,g=e.getThreadMessages(n),y=[],p=0,m=false,w=[];for(let k=0;k<g.length;k+=2){let x=g[k],S=g[k+1],T=x?.content||"",B=S?.content||"",L=o.countTokens(T+B),P=[];x&&P.push(x),S&&P.push(S),w.push({messages:P,tokens:L});}for(let k=w.length-1;k>=0;k--){let x=w[k];if(p+x.tokens>d){m=true;break}p+=x.tokens,y.unshift(...x.messages);}let A=[],v=0;if(m&&c>0)try{let{boxes:k}=t.listBoxes(n);for(let x=k.length-1;x>=0;x--){let S=k[x],T=S.summaryTokens??S.sourceTokens;if(v+T>c)break;v+=T,A.unshift({boxId:S.id,seq:S.seq,taskCount:S.taskCount,sourceTokens:S.sourceTokens,summary:S.summary,previewFirst:S.previewFirst,previewMid:S.previewMid,previewLast:S.previewLast,createdAt:S.createdAt});}}catch(k){if(k instanceof Error&&!/not found/i.test(k.message))throw k}return {hot:y,warm:A,hotTokens:p,warmTokens:v,hotOverflow:m,totalBudget:u,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}Fe();Ae();l();var Nt=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},ct=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),c=[],u=0,g=0,y=0,p=false,m=0,w=perf_hooks.performance.now(),A=async P=>{a?.onTaskStart&&await a.onTaskStart(P),y+=1;let H=new AbortController,G={signal:H.signal},$,q;typeof s=="number"&&Number.isFinite(s)&&s>0&&(q=new Promise((b,R)=>{$=setTimeout(()=>{let F=new Nt(P.id,s);H.abort(F),R(F);},s);}));let U=perf_hooks.performance.now(),_=P.run(G),M=q?Promise.race([_,q]):_;try{let b=await M,R=perf_hooks.performance.now(),F=R-U,Y=d(b,P),K={taskId:P.id,success:Y,value:b,durationMs:F,startedAt:U,finishedAt:R,metadata:P.metadata,aborted:!1};c.push(K),Y?u+=1:g+=1,a?.onTaskComplete&&await a.onTaskComplete(K),i&&!Y&&(p=!0);}catch(b){let R=perf_hooks.performance.now(),F=R-U,Y=b instanceof Error?b:new Error(String(b)),K={taskId:P.id,success:false,error:Y,durationMs:F,startedAt:U,finishedAt:R,metadata:P.metadata,aborted:H.signal.aborted};c.push(K),g+=1,a?.onError&&await a.onError(P,Y,F),i&&(p=true);}finally{$&&clearTimeout($),q&&_.catch(()=>{});}},v=async()=>{for(;!p;){let P=m;if(P>=e.length)break;m+=1;let H=e[P];if(!H||(await A(H),p))break}},k=Math.min(o,e.length),x=[];for(let P=0;P<k;P++)x.push(v());await Promise.all(x);let T=perf_hooks.performance.now()-w,B=c.length?c.reduce((P,H)=>P+H.durationMs,0)/c.length:0,L=T>0?c.length/(T/1e3):c.length;return this.metrics={totalTasks:e.length,startedTasks:y,completedTasks:c.length,successCount:u,failureCount:g,totalDurationMs:T,averageDurationMs:B,throughput:L},c}getMetrics(){return this.metrics}mergeOptions(e){return {maxConcurrency:e.maxConcurrency??this.defaults.maxConcurrency,timeoutMs:e.timeoutMs??this.defaults.timeoutMs,failFast:e.failFast??this.defaults.failFast,evaluateTaskSuccess:e.evaluateTaskSuccess??this.defaults.evaluateTaskSuccess,callbacks:this.mergeCallbacks(this.defaults.callbacks,e.callbacks)}}mergeCallbacks(e,t){if(!(!e&&!t))return {onTaskStart:async r=>{e?.onTaskStart&&await e.onTaskStart(r),t?.onTaskStart&&await t.onTaskStart(r);},onTaskComplete:async r=>{e?.onTaskComplete&&await e.onTaskComplete(r),t?.onTaskComplete&&await t.onTaskComplete(r);},onError:async(r,o,s)=>{e?.onError&&await e.onError(r,o,s),t?.onError&&await t.onError(r,o,s);}}}};l();l();var ut=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 Wn=3,zn=3e4,Vn=500,_i=n=>{if(typeof n!="number"||Number.isNaN(n)||!Number.isFinite(n))return Wn;let e=Math.floor(n);return e>0?e:Wn},Ai=n=>n===void 0||typeof n!="number"||Number.isNaN(n)||n<=0?zn:n,Ri=n=>{if(!n)return {maxRetries:0,retryDelay:Vn};let e=Number.isInteger(n.maxRetries)&&n.maxRetries>=0?n.maxRetries:0,t=typeof n.retryDelay=="number"&&n.retryDelay>=0?n.retryDelay:Vn;return {maxRetries:e,retryDelay:t}},$r=n=>{let e=n.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},Pi=(n,e)=>n<=0?Promise.resolve():new Promise((t,r)=>{let o=setTimeout(()=>{e.removeEventListener("abort",s),t();},n),s=()=>{clearTimeout(o),r($r(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),Ci=async(n,e,t)=>{let r,o;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw $r(t);try{let i=await n();if(r=i,i.success||s===e.maxRetries)return i}catch(i){if(o=i,t.aborted)throw $r(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await Pi(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")},Kn=(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);}},Ti=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}}}),bi=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")}}),Ei=(n,e)=>({onTaskComplete:async t=>{Kn(e,n,t.success);},onError:async()=>{Kn(e,n,false);}}),Jn=async(n,e,t={})=>{if(!Array.isArray(n))throw new TypeError("Parallel helpers expect an array of requests");if(n.length===0){let A={total:0,completed:0,successCount:0,failureCount:0,results:[],errors:[],metrics:{totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0}};return t.onComplete?.(A),[]}let r=_i(t.concurrency),o=Ai(t.timeout),s=Ri(t.retryPolicy),i=new ct,a=new ut,d=n.map((w,A)=>({id:`${e}:${w.agentId??"anonymous"}:${A}`,metadata:{index:A,mode:e,request:w},run:v=>Ci(()=>e==="query"?a.query(w):a.execute(w),s,v.signal)})),c={completed:0,success:0,failure:0,total:n.length},u=await i.run(d,{maxConcurrency:r,timeoutMs:o,evaluateTaskSuccess:w=>w.success,callbacks:Ei(c,t)}),g=Ti(u),y=bi(u),p=i.getMetrics(),m={total:n.length,completed:n.length,successCount:g.filter(w=>w.success).length,failureCount:g.filter(w=>!w.success).length,results:g,errors:y,metrics:p};return t.onComplete?.(m),g},Si=(n,e)=>Jn(n,"query",e),Ii=(n,e)=>Jn(n,"execute",e);br();l();l();var qe=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:W.join(Ni__default.default.homedir(),".crewx","crewx.db")}resolveDbPaths(){return [this.resolveDbPath()]}isMissingTableError(e){return e instanceof Error&&/no such table:/i.test(e.message)}dbExists(e){return fs$1.existsSync(e??this.resolveDbPath())}};l();function fe(n){let e=z("better-sqlite3"),{drizzle:t}=z("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()}}l();var Gn=new Set,$i={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 Li(n,e){return (n.get(`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='${e}'`)?.cnt??0)>0}function ji(n,e){if(e>0||!Li(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($i))r.has(o)||n.run(`ALTER TABLE tasks ADD COLUMN ${o} ${s}`);}function Ui(n,e,t){let r=n.all(t`SELECT hash FROM __drizzle_migrations`),o=new Set(r.map(i=>i.hash)),s=JSON.parse(fs$1.readFileSync(W__namespace.default.join(e,"meta/_journal.json"),"utf-8"));for(let i of s.entries){let a=W__namespace.default.join(e,`${i.tag}.sql`);if(!fs$1.existsSync(a))continue;let d=fs$1.readFileSync(a,"utf-8"),c=crypto$1.createHash("sha256").update(d).digest("hex");if(o.has(c))continue;let u=/ALTER\s+TABLE\s+[`"]?(\w+)[`"]?\s+ADD\s+[`"]?(\w+)[`"]?/gi,g=[],y;for(;(y=u.exec(d))!==null;)g.push({table:y[1],column:y[2]});if(g.length===0||!d.split(/-->\s*statement-breakpoint/).map(w=>w.trim()).filter(Boolean).every(w=>/^ALTER\s+TABLE\s+.+\s+ADD\s+/i.test(w)))continue;g.every(({table:w,column:A})=>n.all(`PRAGMA table_info("${w}")`).some(k=>k.name===A))&&n.run(t`INSERT INTO __drizzle_migrations (hash, created_at) VALUES (${c}, ${i.when})`);}}function Fi(n){let{migrate:e}=z("drizzle-orm/better-sqlite3/migrator"),{sql:t}=z("drizzle-orm"),r=[W__namespace.default.join(__dirname,"../migrations"),W__namespace.default.join(__dirname,"migrations"),W__namespace.default.join(__dirname,"../../../../drizzle/migrations"),W__namespace.default.join(process.cwd(),"drizzle/migrations")],o=r.find(c=>fs$1.existsSync(W__namespace.default.join(c,"meta/_journal.json")));if(!o)throw new Error(`migrations folder not found. Searched:
|
|
55
|
+
`)}c();function ri(){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 Un(n,e=Pe){let t=e.resolvePath(n,`${ri()}.md`);return await e.exists(t)?e.readFile(t):""}be();c();var pt=new async_hooks.AsyncLocalStorage;function Cr(n){if(n)return {parentTaskId:n.parentTaskId??null,rootTraceId:n.rootTraceId,callerAgentId:n.callerAgentId??null}}c();function oi(n){return typeof n!="string"?"":n.replace(/</g,"<").replace(/>/g,">")}function Tr(n){return n.messages.map(e=>({text:oi(e.text),isAssistant:e.isAssistant,timestamp:e.timestamp,metadata:e.metadata,files:void 0}))}c();be();ye();c();c();var Ve=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:B.join(di__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 Jn.existsSync(e??this.resolveDbPath())}};c();function he(n){let e=K("better-sqlite3"),{drizzle:t}=K("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 Hn=new Set,li={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 Pr(n,e){return (n.get(`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='${e}'`)?.cnt??0)>0}function ci(n,e){if(e>0||!Pr(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(li))r.has(o)||n.run(`ALTER TABLE tasks ADD COLUMN ${o} ${s}`);}var ui={"0002_normalize_task_names":{workspace_name:"TEXT",project_name:"TEXT"}};function pi(n,e,t){if(!Pr(n,"__drizzle_migrations")||!Pr(n,"tasks"))return;let r=n.all(t`SELECT hash FROM __drizzle_migrations`),o=new Set(r.map(i=>i.hash)),s=JSON.parse(Jn.readFileSync(B__namespace.default.join(e,"meta/_journal.json"),"utf-8"));for(let i of s.entries){let a=ui[i.tag];if(!a)continue;let d=B__namespace.default.join(e,`${i.tag}.sql`);if(!Jn.existsSync(d))continue;let l=Jn.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 gi(n,e,t){let r=n.all(t`SELECT hash FROM __drizzle_migrations`),o=new Set(r.map(i=>i.hash)),s=JSON.parse(Jn.readFileSync(B__namespace.default.join(e,"meta/_journal.json"),"utf-8"));for(let i of s.entries){let a=B__namespace.default.join(e,`${i.tag}.sql`);if(!Jn.existsSync(a))continue;let d=Jn.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(_=>_.trim()).filter(Boolean).every(_=>/^ALTER\s+TABLE\s+.+\s+ADD\s+/i.test(_)))continue;p.every(({table:_,column:A})=>n.all(`PRAGMA table_info("${_}")`).some(k=>k.name===A))&&n.run(t`INSERT INTO __drizzle_migrations (hash, created_at) VALUES (${l}, ${i.when})`);}}function mi(n){let{migrate:e}=K("drizzle-orm/better-sqlite3/migrator"),{sql:t}=K("drizzle-orm"),r=[B__namespace.default.join(__dirname,"../migrations"),B__namespace.default.join(__dirname,"migrations"),B__namespace.default.join(__dirname,"../../../../drizzle/migrations"),B__namespace.default.join(process.cwd(),"drizzle/migrations")],o=r.find(l=>Jn.existsSync(B__namespace.default.join(l,"meta/_journal.json")));if(!o)throw new Error(`migrations folder not found. Searched:
|
|
57
56
|
${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),
|
|
57
|
+
`)}`);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),ci(n,i),s?.cnt&&(gi(n,o,t),pi(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 Ut(n,e){Hn.has(e)||(mi(n),Hn.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 qn=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 Wn=sqliteCore.sqliteTable("threads",{id:sqliteCore.text("id").primaryKey(),workspace_id:sqliteCore.text("workspace_id").references(()=>qn.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 Ne=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(()=>Ne.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(()=>Wn.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 $e="2026-05-09",Mi="0.8.9-rc.13",je=10,Ue=parseInt(Mi.split("rc.")[1]),gt=class extends Ve{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=B.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let o=B.dirname(t);Jn.existsSync(o)||Jn.mkdirSync(o,{recursive:true});}else if(!Jn.existsSync(t))throw new N("NOT_FOUND","Database not found");let r=he(t);if(e)try{Ut(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=?,
|
|
59
58
|
exit_code=?, input_tokens=?, output_tokens=?, cached_input_tokens=?, cost_usd=?,
|
|
60
|
-
model=COALESCE(?, model) WHERE id=?`,[e.status,e.result??null,e.error??null,e.completedAt,e.durationMs??null,e.exitCode??null,e.inputTokens??0,e.outputTokens??0,e.cachedInputTokens??0,e.costUsd??0,e.model??null,e.id]);}catch(r){throw r instanceof
|
|
59
|
+
model=COALESCE(?, model) WHERE id=?`,[e.status,e.result??null,e.error??null,e.completedAt,e.durationMs??null,e.exitCode??null,e.inputTokens??0,e.outputTokens??0,e.cachedInputTokens??0,e.costUsd??0,e.model??null,e.id]);}catch(r){throw r instanceof 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(!Jn.existsSync(o))continue;let s=he(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(!Jn.existsSync(i))continue;let a=he(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`
|
|
61
60
|
SELECT
|
|
62
61
|
COALESCE(workspace_id, 'unknown') AS workspace_id,
|
|
63
62
|
COALESCE(SUM(input_tokens), 0) AS input_tokens,
|
|
@@ -78,12 +77,24 @@ ${r.join(`
|
|
|
78
77
|
FROM tasks
|
|
79
78
|
GROUP BY workspace_id
|
|
80
79
|
ORDER BY (COALESCE(SUM(input_tokens), 0) + COALESCE(SUM(output_tokens), 0)) DESC
|
|
81
|
-
`)}catch(r){throw new
|
|
80
|
+
`)}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(!Jn.existsSync(d))continue;let l=he(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(!Jn.existsSync(i))continue;let a=he(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`
|
|
82
81
|
SELECT
|
|
83
82
|
t.agent_id,
|
|
84
83
|
t.workspace_id,
|
|
85
84
|
COUNT(*) AS total_tasks,
|
|
86
|
-
COALESCE(SUM(
|
|
85
|
+
COALESCE(SUM(
|
|
86
|
+
COALESCE(t.input_tokens, 0)
|
|
87
|
+
+ CASE
|
|
88
|
+
WHEN t.started_at >= ${$e}
|
|
89
|
+
AND (
|
|
90
|
+
t.crewx_version IS NULL
|
|
91
|
+
OR (t.crewx_version LIKE '0.8.%' AND t.crewx_version NOT LIKE '0.8.9%')
|
|
92
|
+
OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${je}) AS INTEGER) < ${Ue})
|
|
93
|
+
)
|
|
94
|
+
THEN COALESCE(t.cached_input_tokens, 0)
|
|
95
|
+
ELSE 0
|
|
96
|
+
END
|
|
97
|
+
), 0) AS input_tokens,
|
|
87
98
|
COALESCE(SUM(t.output_tokens), 0) AS output_tokens,
|
|
88
99
|
COALESCE(SUM(t.cached_input_tokens), 0) AS cached_input_tokens,
|
|
89
100
|
COALESCE(SUM(t.cost_usd), 0) AS cost_usd
|
|
@@ -93,13 +104,40 @@ ${r.join(`
|
|
|
93
104
|
AND t.started_at < ${t}
|
|
94
105
|
AND t.workspace_id = ${r}
|
|
95
106
|
GROUP BY t.agent_id, t.workspace_id
|
|
96
|
-
ORDER BY (
|
|
107
|
+
ORDER BY (
|
|
108
|
+
COALESCE(SUM(
|
|
109
|
+
COALESCE(t.input_tokens, 0)
|
|
110
|
+
+ CASE
|
|
111
|
+
WHEN t.started_at >= ${$e}
|
|
112
|
+
AND (
|
|
113
|
+
t.crewx_version IS NULL
|
|
114
|
+
OR (t.crewx_version LIKE '0.8.%' AND t.crewx_version NOT LIKE '0.8.9%')
|
|
115
|
+
OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${je}) AS INTEGER) < ${Ue})
|
|
116
|
+
)
|
|
117
|
+
THEN COALESCE(t.cached_input_tokens, 0)
|
|
118
|
+
ELSE 0
|
|
119
|
+
END
|
|
120
|
+
), 0)
|
|
121
|
+
+ COALESCE(SUM(t.output_tokens), 0)
|
|
122
|
+
) DESC
|
|
97
123
|
`:drizzleOrm.sql`
|
|
98
124
|
SELECT
|
|
99
125
|
t.agent_id,
|
|
100
126
|
t.workspace_id,
|
|
101
127
|
COUNT(*) AS total_tasks,
|
|
102
|
-
COALESCE(SUM(
|
|
128
|
+
COALESCE(SUM(
|
|
129
|
+
COALESCE(t.input_tokens, 0)
|
|
130
|
+
+ CASE
|
|
131
|
+
WHEN t.started_at >= ${$e}
|
|
132
|
+
AND (
|
|
133
|
+
t.crewx_version IS NULL
|
|
134
|
+
OR (t.crewx_version LIKE '0.8.%' AND t.crewx_version NOT LIKE '0.8.9%')
|
|
135
|
+
OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${je}) AS INTEGER) < ${Ue})
|
|
136
|
+
)
|
|
137
|
+
THEN COALESCE(t.cached_input_tokens, 0)
|
|
138
|
+
ELSE 0
|
|
139
|
+
END
|
|
140
|
+
), 0) AS input_tokens,
|
|
103
141
|
COALESCE(SUM(t.output_tokens), 0) AS output_tokens,
|
|
104
142
|
COALESCE(SUM(t.cached_input_tokens), 0) AS cached_input_tokens,
|
|
105
143
|
COALESCE(SUM(t.cost_usd), 0) AS cost_usd
|
|
@@ -108,12 +146,39 @@ ${r.join(`
|
|
|
108
146
|
AND t.started_at >= ${e}
|
|
109
147
|
AND t.started_at < ${t}
|
|
110
148
|
GROUP BY t.agent_id, t.workspace_id
|
|
111
|
-
ORDER BY (
|
|
112
|
-
|
|
149
|
+
ORDER BY (
|
|
150
|
+
COALESCE(SUM(
|
|
151
|
+
COALESCE(t.input_tokens, 0)
|
|
152
|
+
+ CASE
|
|
153
|
+
WHEN t.started_at >= ${$e}
|
|
154
|
+
AND (
|
|
155
|
+
t.crewx_version IS NULL
|
|
156
|
+
OR (t.crewx_version LIKE '0.8.%' AND t.crewx_version NOT LIKE '0.8.9%')
|
|
157
|
+
OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${je}) AS INTEGER) < ${Ue})
|
|
158
|
+
)
|
|
159
|
+
THEN COALESCE(t.cached_input_tokens, 0)
|
|
160
|
+
ELSE 0
|
|
161
|
+
END
|
|
162
|
+
), 0)
|
|
163
|
+
+ COALESCE(SUM(t.output_tokens), 0)
|
|
164
|
+
) DESC
|
|
165
|
+
`).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`
|
|
113
166
|
SELECT
|
|
114
167
|
date(t.started_at) AS date,
|
|
115
168
|
t.agent_id,
|
|
116
|
-
COALESCE(SUM(
|
|
169
|
+
COALESCE(SUM(
|
|
170
|
+
COALESCE(t.input_tokens, 0)
|
|
171
|
+
+ CASE
|
|
172
|
+
WHEN t.started_at >= ${$e}
|
|
173
|
+
AND (
|
|
174
|
+
t.crewx_version IS NULL
|
|
175
|
+
OR (t.crewx_version LIKE '0.8.%' AND t.crewx_version NOT LIKE '0.8.9%')
|
|
176
|
+
OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${je}) AS INTEGER) < ${Ue})
|
|
177
|
+
)
|
|
178
|
+
THEN COALESCE(t.cached_input_tokens, 0)
|
|
179
|
+
ELSE 0
|
|
180
|
+
END
|
|
181
|
+
), 0) AS input_tokens,
|
|
117
182
|
COALESCE(SUM(t.output_tokens), 0) AS output_tokens,
|
|
118
183
|
COALESCE(SUM(t.cached_input_tokens), 0) AS cached_input_tokens,
|
|
119
184
|
COALESCE(SUM(t.cost_usd), 0) AS cost_usd
|
|
@@ -128,7 +193,19 @@ ${r.join(`
|
|
|
128
193
|
SELECT
|
|
129
194
|
date(t.started_at) AS date,
|
|
130
195
|
t.agent_id,
|
|
131
|
-
COALESCE(SUM(
|
|
196
|
+
COALESCE(SUM(
|
|
197
|
+
COALESCE(t.input_tokens, 0)
|
|
198
|
+
+ CASE
|
|
199
|
+
WHEN t.started_at >= ${$e}
|
|
200
|
+
AND (
|
|
201
|
+
t.crewx_version IS NULL
|
|
202
|
+
OR (t.crewx_version LIKE '0.8.%' AND t.crewx_version NOT LIKE '0.8.9%')
|
|
203
|
+
OR (t.crewx_version LIKE '0.8.9-rc.%' AND CAST(SUBSTR(t.crewx_version, ${je}) AS INTEGER) < ${Ue})
|
|
204
|
+
)
|
|
205
|
+
THEN COALESCE(t.cached_input_tokens, 0)
|
|
206
|
+
ELSE 0
|
|
207
|
+
END
|
|
208
|
+
), 0) AS input_tokens,
|
|
132
209
|
COALESCE(SUM(t.output_tokens), 0) AS output_tokens,
|
|
133
210
|
COALESCE(SUM(t.cached_input_tokens), 0) AS cached_input_tokens,
|
|
134
211
|
COALESCE(SUM(t.cost_usd), 0) AS cost_usd
|
|
@@ -138,10 +215,51 @@ ${r.join(`
|
|
|
138
215
|
AND t.started_at < ${t}
|
|
139
216
|
GROUP BY date(t.started_at), t.agent_id
|
|
140
217
|
ORDER BY date(t.started_at) ASC
|
|
141
|
-
`).map(i=>({date:i.date,agentId:i.agent_id,inputTokens:i.input_tokens,outputTokens:i.output_tokens,cachedInputTokens:i.cached_input_tokens,costUsd:i.cost_usd}))}catch(s){throw new
|
|
142
|
-
|
|
143
|
-
|
|
218
|
+
`).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(!Jn.existsSync(i))continue;let a=he(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
|
+
CASE
|
|
220
|
+
WHEN ${m.model} LIKE 'claude-%' OR ${m.model} IN ('opus', 'sonnet', 'haiku', 'opus[1m]', 'sonnet[1m]') THEN 'claude'
|
|
221
|
+
WHEN ${m.model} LIKE 'gpt-%' OR ${m.model} LIKE 'codex-%' THEN 'codex'
|
|
222
|
+
WHEN ${m.model} LIKE 'gemini-%' THEN 'gemini'
|
|
223
|
+
WHEN ${m.model} LIKE 'zai-%' OR ${m.model} LIKE 'openrouter/z-ai/%' THEN 'opencode'
|
|
224
|
+
WHEN ${m.model} LIKE 'minimax/%' THEN 'minimax'
|
|
225
|
+
WHEN ${m.model} LIKE 'qwen%' THEN 'qwen'
|
|
226
|
+
ELSE 'unknown'
|
|
227
|
+
END
|
|
228
|
+
`,i=drizzleOrm.sql`
|
|
229
|
+
COALESCE(${m.input_tokens}, 0)
|
|
230
|
+
+ CASE
|
|
231
|
+
WHEN ${m.started_at} >= ${$e}
|
|
232
|
+
AND (
|
|
233
|
+
${m.crewx_version} IS NULL
|
|
234
|
+
OR (${m.crewx_version} LIKE '0.8.%' AND ${m.crewx_version} NOT LIKE '0.8.9%')
|
|
235
|
+
OR (${m.crewx_version} LIKE '0.8.9-rc.%' AND CAST(SUBSTR(${m.crewx_version}, ${je}) AS INTEGER) < ${Ue})
|
|
236
|
+
)
|
|
237
|
+
THEN COALESCE(${m.cached_input_tokens}, 0)
|
|
238
|
+
ELSE 0
|
|
239
|
+
END
|
|
240
|
+
`,a=r?drizzleOrm.sql`WHERE ${m.status} IN ('completed', 'success') AND ${m.started_at} >= ${e} AND ${m.started_at} < ${t} AND ${m.workspace_id} = ${r}`:drizzleOrm.sql`WHERE ${m.status} IN ('completed', 'success') AND ${m.started_at} >= ${e} AND ${m.started_at} < ${t}`;return o.db.all(drizzleOrm.sql`
|
|
241
|
+
SELECT
|
|
242
|
+
${s} AS provider,
|
|
243
|
+
COUNT(*) AS total_tasks,
|
|
244
|
+
COALESCE(SUM(${i}), 0) AS input_tokens,
|
|
245
|
+
COALESCE(SUM(${m.output_tokens}), 0) AS output_tokens,
|
|
246
|
+
COALESCE(SUM(${m.cached_input_tokens}), 0) AS cached_input_tokens,
|
|
247
|
+
COALESCE(SUM(${m.cost_usd}), 0) AS cost_usd,
|
|
248
|
+
COALESCE(SUM(${m.duration_ms}), 0) AS active_duration_ms,
|
|
249
|
+
MAX(${m.completed_at}) AS last_active_at
|
|
250
|
+
FROM ${m}
|
|
251
|
+
${a}
|
|
252
|
+
GROUP BY provider
|
|
253
|
+
ORDER BY (COALESCE(SUM(${i}), 0) + COALESCE(SUM(${m.output_tokens}), 0)) DESC
|
|
254
|
+
`).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 Ni=new Set(["Read","Grep","Find","Glob"]),Di=["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"],Li=[/\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 $i(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 ji(n,e){if(Ni.has(n))return true;if(n!=="Bash"||!e)return false;let t=e.split(`
|
|
255
|
+
`)[0].trimStart();return Li.some(r=>r.test(t))?false:Di.some(r=>t.startsWith(r))}function Nr(n){return n.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""")}function Ui(n,e,t){if(n!=="Read"||!e)return "ok";let o=e.split(`
|
|
256
|
+
`).find(s=>s.trim()&&!s.startsWith("Read "))?.trim()??e.trim();if(!o)return "unknown";try{let s=Jn__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 Hi(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 Fi(n){if(!Array.isArray(n))return [];let e=n,t=e.filter(a=>a.level==="stdout"&&a.message).map(a=>a.message),r=Hi(t),o=[];for(let a of e)a.level==="info"&&a.message?o.push(...Y(a.message,a.timestamp)):a.level==="stdout"&&a.message&&r&&o.push(...rt("",a.message,r));let s=new Map,i=[];for(let a of o)if(a.type==="tool_use"){let d={tool:$i(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=Fi(n),r=[];for(let o of t){let s=o.tool==="Bash"?o.input?.split(`
|
|
257
|
+
`)[0]?.slice(0,150)??null:o.input?.slice(0,150)??null,i=ji(o.tool,o.input)&&!o.isError;r.push({tool:o.tool,cmd:s,result:o.result,status:Ui(o.tool,o.input,e),reusable:i});}return r}function Bi(n,e){let t=["<activity_log>"];if(n.length===0&&e===0)t.push(" <!-- no activity found in previous tasks -->");else {t.push(" <!-- tool activity from previous tasks -->"),e>0&&t.push(` <!-- ${e} entries omitted (cap) -->`);for(let r of n){let o=`tool="${Nr(r.tool)}"`,s=r.cmd?` cmd="${Nr(r.cmd)}"`:"",i="";r.reusable&&(i=r.status==="stale"?' reused="stale"':' reused="ok"'),r.reusable&&r.status==="stale"?t.push(` <entry ${o}${s}${i}>\u26A0\uFE0F changed since \u2014 re-read</entry>`):r.result?(t.push(` <entry ${o}${s}${i}>`),t.push(Nr(r.result)),t.push(" </entry>")):t.push(` <entry ${o}${s}${i} />`);}}return t.push("</activity_log>"),t}function Xn(n){let{threadId:e,agentId:t,lookback:r}=n;if(!r||!e||!t)return new Map;let o;try{o=new gt().findTasksByThread(e).filter(d=>!d.parent_task_id&&d.agent_id===t).sort((d,l)=>l.started_at>d.started_at?1:-1).slice(0,Math.min(r,5));}catch{return new Map}if(!o.length)return new Map;let s=[];for(let a of o){let d=[];try{let l=JSON.parse(a.logs??"[]");Array.isArray(l)&&(d=l);}catch{}s.push({taskId:a.id,entries:qi(d,a.completed_at)});}let i=new Map;for(let{taskId:a,entries:d}of s){if(d.length===0)continue;let l=Math.max(0,d.length-200),u=l>0?d.slice(l):d,p=Bi(u,l);i.set(a,p.join(`
|
|
258
|
+
`));}return i}c();c();var Wi={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")},zi={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 Yn(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",Wi,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)",zi,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 Qn(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 Zn(n,e){return e?await e(n)?null:new Response(JSON.stringify({error:"Unauthorized"}),{status:401,headers:{"Content-Type":"application/json"}}):null}function Gi(n,e){let t=new mcp_js.McpServer({name:"crewx-mcp-server",version:"1.0.0"},{capabilities:{tools:{}}});return Yn(t,n,e),t}function Dr(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=Qn(o);if(s)return s;let i=await Zn(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=Gi(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 to(n){let e=B__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 Lr(n){let e=to(n);return crypto$1.createHash("sha256").update(e).digest("hex")}function _a(n){return n?n.settings?.template?.exec:void 0}function va(){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}=K("crypto");return n(8).toString("hex")}}var Qr=class n extends ut{_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=Lr(i),this._workspaceName=B.basename(i);let a=_a(r);this._templateEngine=new it({execPolicy:t.execPolicy??a}),this._documentLoader=o??new Se,this._layoutLoader=new at({templatesPath:Be()}),this._layoutRenderer=new ct,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=B.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}=nr(),o;try{o=Jn.readFileSync(t,"utf-8");}catch(i){throw new Error(`[@crewx/sdk] Cannot read built-in config: ${t}
|
|
259
|
+
${i.message}`)}let s=Rt(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"&&!B.isAbsolute(l.path)?i[a]={...l,path:B.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 k of e.agents??[])r.set(k.id,k);for(let k of t.agents??[])r.has(k.id)&&console.warn(`[agent-loader] User agent "${k.id}" overrides built-in`),r.set(k.id,k);let o=Array.from(r.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,d=t,l=ko(a.vars,d.vars),u=ko(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=Aa(a.providers,d.providers),h={...e},_={...t};for(let k of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete h[k],delete _[k];let w={...{...h,..._},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=Et(e);s=n.mergeCrewxConfig(u,p),i=B.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=Et(e),i=B.dirname(e);}let a=new Se(r);await a.load(s.documents,i);let d=s.agents??[];return await _o(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 Se(o);await a.load(i.documents,r??(typeof process<"u"?process.cwd():"/"));let d=i.agents??[];return await _o(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=vr(t);return B.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 Dr(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??Ar(r),a=e.defaultMode??"query",d=t.manifest.platform,l=e.agentRunner??{run:async(g,h,_)=>{let w=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${g}`,h,{threadId:_?.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:_}=await l.run(h,g.text,{threadId:g.threadId});return {accepted:true,output:_}}),p=Er({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=>de(a.role.toLowerCase(),d)))),o&&(i=i.filter(a=>a.team&&o.some(d=>de(a.team.toLowerCase(),d)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(l=>s.some(u=>de(l.toLowerCase(),u))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,r=this._agents.get(t);if(!r)throw new pe(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 pe(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??va(),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),_={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},A=o.provider,w=Array.isArray(A)?A:typeof A=="string"&&A.length>0?[A]:[],k=w.join(", ")||(typeof A=="string"?A:""),x=o.options,S=["goals","daily"],T={goals:false,daily:false},F;if(!Array.isArray(x)&&typeof x=="object"&&x!==null){let I=x;if("goals"in I){let G=I.goals;typeof G=="string"||Array.isArray(G)?T.goals=G:T.goals=!!G;}"daily"in I&&(T.daily=!!I.daily);let $={};for(let[G,Ye]of Object.entries(I))S.includes(G)||($[G]=Ye);if(Object.keys($).length>0){let G=w.some(tr=>tr.startsWith("cli/")),Ye={};for(let[tr,Qe]of Object.entries($)){let qe={};if(Array.isArray(Qe))G&&(qe.rawArgs=Qe);else if(typeof Qe=="object"&&Qe!==null){let pn=Qe;Object.keys(pn).length>0&&(qe.named=pn);}(qe.named||qe.rawArgs&&qe.rawArgs.length>0)&&(Ye[tr]=qe);}F=Object.keys(Ye).length>0?Ye:void 0;}}let j=Array.isArray(x)?x:void 0,R={};for(let[I,$]of Object.entries(u))R[I]={content:$.content??"",toc:$.toc,summary:$.summary,path:$.path};if(T.goals){let I=B.join(this._projectRoot,"docs","goal"),$=await jn(I,void 0,T.goals);$&&(R.active_goals={content:$});}if(T.daily){let I=B.join(this._projectRoot,"docs","daily"),$=await Un(I);$&&(R.today_daily={content:$});}let H=t?.vars?.user_input??void 0,Q=this._config?.settings?.dreaming?.continuity,z=Q?.reuseReadOnly!==false,W=typeof Q?.lookback=="number"?Q.lookback:1,v=t?.threadId??"",O=o.id,P=z&&W>0&&v&&t?.messages&&t.messages.length>0?Xn({threadId:v,agentId:O,lookback:W}):new Map,E=(t?.messages??[]).map(I=>{if(!I.isAssistant)return I;let $=I.metadata?.task_id;return !$||!P.has($)?I:{...I,activity_log:P.get($)}}),q={user_input:H,agent:{id:o.id,name:o.name??o.id,role:o.role??"",team:o.team??"",description:o.description??"",provider:k,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:F,optionsArray:j},agentMetadata:{specialties:o.specialties??[],capabilities:o.capabilities??[],description:o.description??""},contextOptions:T,documents:R,skills:t?.skills??[],session:_,env:p,vars:{security_key:y,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:_.platform,mode:_.mode,thread_id:v,now:dt(new Date),has_activity_log:P.size>0,messages:E,tools:this._tools.size>0?{list:Array.from(this._tools.values()).map(I=>({name:I.name,description:I.description,parameters:I.parameters})),json:JSON.stringify(Array.from(this._tools.values()).map(I=>({name:I.name,description:I.description,parameters:I.parameters})),null,2),count:this._tools.size}:null,metadata:{}};return this._layoutRenderer.render(d,q)}_filterToolsByMode(e){return e?e.map(t=>this._tools.get(t)).filter(t=>t!==void 0):Array.from(this._tools.values())}_resolveLayoutSpec(e,t){if(t!==void 0)return t;let r=e.inline?.layout;if(r!==void 0)return r;let 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:Tr(s)}catch{return}}_resolveTimeout(e){let t=Cn();return e==="query"?t.queryMs:t.executeMs}_resolveEffectiveCwd(e,t){return t?.cwd??(e.working_directory?B.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)??rt(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=pt.getStore()??Cr(r?.trace),i=r?.taskId??Oe("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return pt.run(d,async()=>{let l=Date.now(),u=new Date,p;try{p=Tt(e,Array.from(this._agents.values()));}catch(v){if(v instanceof pe){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 O=Date.now()-l,P={code:"AGENT_NOT_FOUND",message:v.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:O,error:P,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:P,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:O}}}throw v}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 _;try{_=me(g);}catch(v){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 O=Date.now()-l,P={code:"PROVIDER_ERROR",message:v.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:O,error:P,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:P,meta:{agentId:p.id,provider:g,model:h,durationMs:O}}}let A=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:A,threadId:r?.threadId});}catch(v){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${v instanceof Error?v.message:String(v)}`);}let k,x,S,T=h,F=false,j=v=>{F||(F=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",pid:v,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:T,provider:g,codingAgentCommand:k,renderedPrompt:w,metadata:{...r?.metadata??{},provider:g},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},R=p.options,H=Array.isArray(R?.query?.tools)?R.query.tools:void 0,re=this._tools.size>0?this._filterToolsByMode(H):[],_e=(()=>{let v=R?.query;if(!v||Array.isArray(v))return;let{tools:O,effort:P,mode:E,...q}=v,I=Object.entries(q).filter(([,$])=>$!=null);if(I.length!==0)return Object.fromEntries(I.map(([$,G])=>[$,String(G)]))})(),Q=p.inline?.max_steps;g.startsWith("api/")&&j();let z=false,W=0;try{let v=await _.query(t,{model:h,effort:R?.query?.effort,mode:R?.query?.mode,context:r?.context,systemPrompt:w??p.inline?.system_prompt??p.inline?.prompt??p.description??`You are ${p.id}.`,additionalArgs:Array.isArray(R?.query)?R.query:void 0,tools:re.length>0?re:void 0,maxSteps:Q,configOptions:_e,timeoutMs:this._resolveTimeout("query"),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=>j(E),onOutput:(E,q)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:E,level:q}),q==="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 q of E)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(q),level:"info"});},onCommand:E=>{k=E;},onUsage:E=>{x=E;},onExitCode:E=>{S=E;},onModel:E=>{T||(T=E);}});W=fr(x?.costUsd,x?.inputTokens,x?.outputTokens,x?.cachedInputTokens,T),j();let O=Date.now()-l,P={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:v,durationMs:O,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:W,model:T,metadata:Object.keys(P).length>0?P:void 0}),z=!0,{ok:!0,data:v,meta:{agentId:p.id,provider:g,model:h,durationMs:O,taskId:i}}}catch(v){if(v instanceof exports.ClientToolCallRequiredError){let E=Oe("thd");return this._pendingThreads.set(E,{agentRef:p.id,providerStr:g,continuationState:v.continuationState,toolCall:v.toolCall,traceId:i,startMs:l,model:h}),z=true,{ok:true,status:"requires_action",data:"",toolCall:v.toolCall,threadId:E,meta:{agentId:p.id,provider:g,model:h,durationMs:Date.now()-l,taskId:i}}}j();let O=Date.now()-l,P={code:"QUERY_FAILED",message:v.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:O,error:P,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:W,model:T,metadata:r?.metadata?{...r.metadata}:void 0}),z=true,{ok:false,data:"",error:P,meta:{agentId:p.id,provider:g,model:h,durationMs:O,taskId:i}}}finally{z||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:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:W,model:T});}})}async continueQuery(e,t){let r=this._pendingThreads.get(e);if(!r)return {ok:false,data:"",error:{code:"THREAD_NOT_FOUND",message:`No pending thread: ${e}`},meta:{agentId:"",provider:"",durationMs:0}};this._pendingThreads.delete(e);let o=me(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=pt.getStore()??Cr(r?.trace),i=r?.taskId??Oe("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return pt.run(d,async()=>{let l=Date.now(),u=new Date,p;try{p=Tt(e,Array.from(this._agents.values()));}catch(v){if(v instanceof pe){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 O=Date.now()-l,P={code:"AGENT_NOT_FOUND",message:v.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:O,error:P,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:P,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:O}}}throw v}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 _;try{_=me(g);}catch(v){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 O=Date.now()-l,P={code:"PROVIDER_ERROR",message:v.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:O,error:P,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:P,meta:{agentId:p.id,provider:g,model:h,durationMs:O}}}let A=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:A,threadId:r?.threadId});}catch(v){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${v instanceof Error?v.message:String(v)}`);}let k,x,S,T=h,F=false,j=v=>{F||(F=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",pid:v,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:T,provider:g,codingAgentCommand:k,renderedPrompt:w,metadata:{...r?.metadata??{},provider:g},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},R=p.options,H=Array.isArray(R?.execute?.tools)?R.execute.tools:void 0,re=this._tools.size>0?this._filterToolsByMode(H):[],_e=(()=>{let v=R?.execute;if(!v||Array.isArray(v))return;let{tools:O,effort:P,mode:E,...q}=v,I=Object.entries(q).filter(([,$])=>$!=null);if(I.length!==0)return Object.fromEntries(I.map(([$,G])=>[$,String(G)]))})(),Q=p.inline?.max_steps;g.startsWith("api/")&&j();let z=false,W=0;try{let v=await _.execute(t,{model:h,effort:R?.execute?.effort,mode:R?.execute?.mode,context:r?.context,systemPrompt:w??p.inline?.system_prompt??p.inline?.prompt??p.description??`You are ${p.id}.`,additionalArgs:Array.isArray(R?.execute)?R.execute:void 0,tools:re.length>0?re:void 0,maxSteps:Q,configOptions:_e,timeoutMs:this._resolveTimeout("execute"),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=>j(E),onOutput:(E,q)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:E,level:q}),q==="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 q of E)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(q),level:"info"});},onCommand:E=>{k=E;},onUsage:E=>{x=E;},onExitCode:E=>{S=E;},onModel:E=>{T||(T=E);}});W=fr(x?.costUsd,x?.inputTokens,x?.outputTokens,x?.cachedInputTokens,T),j();let O=Date.now()-l,P={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:v,durationMs:O,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:W,model:T,metadata:Object.keys(P).length>0?P:void 0}),z=!0,{ok:!0,data:v,meta:{agentId:p.id,provider:g,model:h,durationMs:O,taskId:i}}}catch(v){j();let O=Date.now()-l,P={code:"EXECUTE_FAILED",message:v.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:O,error:P,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:W,model:T,metadata:r?.metadata?{...r.metadata}:void 0}),z=true,{ok:false,data:"",error:P,meta:{agentId:p.id,provider:g,model:h,durationMs:O}}}finally{z||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:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:W,model:T});}})}};function ko(n,e){let t=Zr(n)?n:void 0,r=Zr(e)?e:void 0;if(!(!t&&!r))return {...t??{},...r??{}}}function Zr(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function Aa(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(!Zr(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 _o(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(()=>(jr(),so));o(t?.api);}await Ea(n,e),Ca(n,e),Ra(n);}function Ra(n){if(!n.some(r=>(Array.isArray(r.provider)?r.provider:[r.provider]).some(s=>s.startsWith("acp/"))))return;let{registerAcpProviders:t}=(zr(),gn(po));t();}async function Ea(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(()=>(Gr(),mo)),s=new Map;for(let i of r)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&ge("remote",o(s,me));}function Ca(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(),gn(wo)),s=new Map;for(let i of r)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&ge("plugin",o(s));}c();var en=class{detach(e){}};c();var Ta="crewx:fs:",tn=class{prefix;store;constructor(e){this.prefix=e?.prefix??Ta,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 ba(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))}le();$r();jr();c();Ur();ye();c();zt();Qt();Vt();var Pa="model",Sa="mode",Ia="thought_level";function rn(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 Oa(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 Ma(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 Na(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()===Sa&&w.options!=null)for(let k of rn(w.options))k.value!=null&&l.push({id:k.value,name:k.name??k.value});let u=Ma(d,l),p=[];for(let w of i)if(w.category?.trim().toLowerCase()===Ia&&w.type==="select")for(let k of rn(w.options??[]))k.value!=null&&p.push(k.value);if(n==="claude"){let w=co.map(x=>({id:x.id,name:x.name})),k=vo(t);return Ao(n,{models:w,modes:u,availableModelsCount:0,configModelsCount:0,skipModelWarn:true}),{id:`acp/${n}`,name:s,modes:u,effort:p,models:w,capabilities:k}}let g=(r.models?.availableModels??[]).map(w=>({id:w.modelId})),h=[];for(let w of i)if(w.category?.trim().toLowerCase()===Pa&&w.options!=null)for(let k of rn(w.options))k.value!=null&&h.push({id:k.value,...k.name!=null?{name:k.name}:{}});let _=Oa(g,h);Ao(n,{models:_,modes:u,availableModelsCount:g.length,configModelsCount:h.length,skipModelWarn:false});let A=vo(t);return {id:`acp/${n}`,name:s,modes:u,effort:p,models:_,capabilities:A}}function vo(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 Ao(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 Ro(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 Na(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 Da(){let n=Object.keys(exports.ACP_ADAPTERS),e=await Promise.allSettled(n.map(r=>Ro(r))),t=[];for(let r of e)r.status==="fulfilled"&&r.value!==null&&t.push(r.value);return t}zt();Hr();Qt();zr();or();be();c();var nn=0;function La(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(nn>=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(", ")}`;nn++;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{nn--;}}}}c();var Eo=typeof process<"u"?process.env:{};function $a(){return Eo.CREWX_CLI||"npx crewx"}function ja(){return Eo.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}c();var Ua=/^[a-zA-Z0-9._-]+$/,on=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(!Ua.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return Oe("box")}};c();function Ha(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,_=[];for(let k=0;k<p.length;k+=2){let x=p[k],S=p[k+1],T=x?.content||"",F=S?.content||"",j=o.countTokens(T+F),R=[];x&&R.push(x),S&&R.push(S),_.push({messages:R,tokens:j});}for(let k=_.length-1;k>=0;k--){let x=_[k];if(g+x.tokens>d){h=true;break}g+=x.tokens,y.unshift(...x.messages);}let A=[],w=0;if(h&&l>0)try{let{boxes:k}=t.listBoxes(n);for(let x=k.length-1;x>=0;x--){let S=k[x],T=S.summaryTokens??S.sourceTokens;if(w+T>l)break;w+=T,A.unshift({boxId:S.id,seq:S.seq,taskCount:S.taskCount,sourceTokens:S.sourceTokens,summary:S.summary,previewFirst:S.previewFirst,previewMid:S.previewMid,previewLast:S.previewLast,createdAt:S.createdAt});}}catch(k){if(k instanceof Error&&!/not found/i.test(k.message))throw k}return {hot:y,warm:A,hotTokens:g,warmTokens:w,hotOverflow:h,totalBudget:u,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}be();Te();c();var Zt=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},_t=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,_=perf_hooks.performance.now(),A=async R=>{a?.onTaskStart&&await a.onTaskStart(R),y+=1;let H=new AbortController,re={signal:H.signal},_e,Q;typeof s=="number"&&Number.isFinite(s)&&s>0&&(Q=new Promise((O,P)=>{_e=setTimeout(()=>{let E=new Zt(R.id,s);H.abort(E),P(E);},s);}));let z=perf_hooks.performance.now(),W=R.run(re),v=Q?Promise.race([W,Q]):W;try{let O=await v,P=perf_hooks.performance.now(),E=P-z,q=d(O,R),I={taskId:R.id,success:q,value:O,durationMs:E,startedAt:z,finishedAt:P,metadata:R.metadata,aborted:!1};l.push(I),q?u+=1:p+=1,a?.onTaskComplete&&await a.onTaskComplete(I),i&&!q&&(g=!0);}catch(O){let P=perf_hooks.performance.now(),E=P-z,q=O instanceof Error?O:new Error(String(O)),I={taskId:R.id,success:false,error:q,durationMs:E,startedAt:z,finishedAt:P,metadata:R.metadata,aborted:H.signal.aborted};l.push(I),p+=1,a?.onError&&await a.onError(R,q,E),i&&(g=true);}finally{_e&&clearTimeout(_e),Q&&W.catch(()=>{});}},w=async()=>{for(;!g;){let R=h;if(R>=e.length)break;h+=1;let H=e[R];if(!H||(await A(H),g))break}},k=Math.min(o,e.length),x=[];for(let R=0;R<k;R++)x.push(w());await Promise.all(x);let T=perf_hooks.performance.now()-_,F=l.length?l.reduce((R,H)=>R+H.durationMs,0)/l.length:0,j=T>0?l.length/(T/1e3):l.length;return this.metrics={totalTasks:e.length,startedTasks:y,completedTasks:l.length,successCount:u,failureCount:p,totalDurationMs:T,averageDurationMs:F,throughput:j},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 vt=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 Co=3,To=3e4,bo=500,Fa=n=>{if(typeof n!="number"||Number.isNaN(n)||!Number.isFinite(n))return Co;let e=Math.floor(n);return e>0?e:Co},qa=n=>n===void 0||typeof n!="number"||Number.isNaN(n)||n<=0?To:n,Ba=n=>{if(!n)return {maxRetries:0,retryDelay:bo};let e=Number.isInteger(n.maxRetries)&&n.maxRetries>=0?n.maxRetries:0,t=typeof n.retryDelay=="number"&&n.retryDelay>=0?n.retryDelay:bo;return {maxRetries:e,retryDelay:t}},sn=n=>{let e=n.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},Wa=(n,e)=>n<=0?Promise.resolve():new Promise((t,r)=>{let o=setTimeout(()=>{e.removeEventListener("abort",s),t();},n),s=()=>{clearTimeout(o),r(sn(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),za=async(n,e,t)=>{let r,o;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw sn(t);try{let i=await n();if(r=i,i.success||s===e.maxRetries)return i}catch(i){if(o=i,t.aborted)throw sn(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await Wa(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")},Po=(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);}},Ka=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}}}),Va=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")}}),Ga=(n,e)=>({onTaskComplete:async t=>{Po(e,n,t.success);},onError:async()=>{Po(e,n,false);}}),So=async(n,e,t={})=>{if(!Array.isArray(n))throw new TypeError("Parallel helpers expect an array of requests");if(n.length===0){let A={total:0,completed:0,successCount:0,failureCount:0,results:[],errors:[],metrics:{totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0}};return t.onComplete?.(A),[]}let r=Fa(t.concurrency),o=qa(t.timeout),s=Ba(t.retryPolicy),i=new _t,a=new vt,d=n.map((_,A)=>({id:`${e}:${_.agentId??"anonymous"}:${A}`,metadata:{index:A,mode:e,request:_},run:w=>za(()=>e==="query"?a.query(_):a.execute(_),s,w.signal)})),l={completed:0,success:0,failure:0,total:n.length},u=await i.run(d,{maxConcurrency:r,timeoutMs:o,evaluateTaskSuccess:_=>_.success,callbacks:Ga(l,t)}),p=Ka(u),y=Va(u),g=i.getMetrics(),h={total:n.length,completed:n.length,successCount:p.filter(_=>_.success).length,failureCount:p.filter(_=>!_.success).length,results:p,errors:y,metrics:g};return t.onComplete?.(h),p},Ja=(n,e)=>So(n,"query",e),Xa=(n,e)=>So(n,"execute",e);Jr();c();var an=class extends Ve{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=B.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let o=B.dirname(t);Jn.existsSync(o)||Jn.mkdirSync(o,{recursive:true});}else if(!Jn.existsSync(t))throw new N("NOT_FOUND","Database not found");let r=he(t);if(e)try{Ut(r.db,t);}catch(o){throw r.close(),o}return r}insertSpan(e){let t=this.openHandle(true);try{t.db.insert(Ne).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(Ne).where(drizzleOrm.eq(Ne.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(Ne).where(drizzleOrm.eq(Ne.id,e)).limit(1).get()??void 0}catch(r){throw new N("DB_ERROR","Failed to find span by id",r)}finally{t.close();}}};Gr();Vr();Kr();c();c();var er=class{capabilities={required:[]}};c();c();c();var Mo=2e3;function No(n){let e=n.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f\u2028\u2029]/g,"");return e.length<=Mo?e:e.slice(0,Mo-11)+" [redacted]"}var ad=10*1024*1024,dd={b:1,kb:1024,mb:1024*1024,gb:1024*1024*1024};function dn(n,e){return n===void 0?true:Array.isArray(n)?n.includes(e):n===e}function ld(n,e){return n===void 0?true:Array.isArray(n)?n.some(t=>e.includes(t)):e.includes(n)}function Lo(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*(dd[r]??1))}function $o(n){return typeof n=="string"}function jo(n){try{let e=Jn.statSync(n);return e.size>ad?(process.stderr.write(`[YamlHookPlugin] File too large for line count: ${n} (${e.size} bytes)
|
|
260
|
+
`),null):Jn.readFileSync(n,"utf8").split(`
|
|
261
|
+
`).length}catch{return null}}function Uo(n){try{return Jn.statSync(n).size}catch{return null}}function cd(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(de(o,n))return true;if(t&&o.startsWith("/")){let{relative:s,isAbsolute:i}=K("path");if(i(o)){let a=s(t,o);if(a&&!a.startsWith("..")&&de(a,n))return true}}return false}function ud(n,e){return n?JSON.stringify(e).includes(n):true}function pd(n,e){if(!n)return true;try{let t=new RegExp(n),r=JSON.stringify(e);return t.test(r)}catch{return false}}function gd(n,e){if(!n)return true;try{let t=new RegExp(n),r=JSON.stringify(e);return t.test(r)}catch{return false}}function md(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($o(n.pathSizeMin)){let o=Uo(r);if(o===null||o<Lo(n.pathSizeMin))return false}else {let o=jo(r);if(o===null||o<n.pathSizeMin)return false}if(n.pathSizeMax!==void 0)if($o(n.pathSizeMax)){let o=Uo(r);if(o===null||o>Lo(n.pathSizeMax))return false}else {let o=jo(r);if(o===null||o>n.pathSizeMax)return false}return true}function fd(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 cn=class extends er{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(`
|
|
144
262
|
|
|
145
|
-
`)):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=
|
|
146
|
-
`;
|
|
147
|
-
`);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return
|
|
263
|
+
`)):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=No(t.message).slice(0,500)));let o=`[${new Date().toISOString()}] HOOK: ${JSON.stringify(r)}
|
|
264
|
+
`;Jn.appendFileSync(e,o,{encoding:"utf8",mode:384});}catch{}}matchEntryLevel(e,t){if(e.provider!==void 0){let r=t.provider.replace(/^cli\//,"");if(!dn(e.provider,r))return false}if(e.team!==void 0){let o=this.agentMap.get(t.agent.id)?.team??t.agent.team;if(!dn(e.team,o))return false}if(e.role!==void 0){let o=this.agentMap.get(t.agent.id)?.role??t.agent.role;if(!dn(e.role,o))return false}if(e.tag!==void 0){let o=this.agentMap.get(t.agent.id)?.tags??[];if(!ld(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)||!ud(e.pattern,t.tool.input)||!pd(e.regex,t.tool.input)||!cd(e.pathPattern,t.tool.input,t.cwd)||!md(e,t.tool.input)||!gd(e.whenInputRegex,t.tool.input))}hasFired(e,t){try{let r=this.firedFilePath(e);if(!Jn.existsSync(r))return !1;let o=JSON.parse(Jn.readFileSync(r,"utf8"));return Array.isArray(o.fired)&&o.fired.includes(t)}catch{return false}}markFired(e,t){try{let r=this.firedFilePath(e);Jn.mkdirSync(B.dirname(r),{recursive:!0,mode:448});let o=Jn.existsSync(r)?JSON.parse(Jn.readFileSync(r,"utf8")):{fired:[]};Array.isArray(o.fired)||(o.fired=[]),o.fired.includes(t)||(o.fired.push(t),Jn.writeFileSync(r,JSON.stringify(o),{mode:384}));}catch(r){process.stderr.write(`[YamlHookPlugin] once state write failed: ${r}
|
|
265
|
+
`);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return B.join(di.homedir(),".crewx","sessions",t,"fired-rules.json")}};c();c();c();function yd(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 un=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 hd(n){return n}function wd(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);}}}St();exports.AdapterError=un;exports.AgentNotFoundError=pe;exports.AgentRuntime=vt;exports.AgentSkillsSchema=mn;exports.BrowserFsAdapter=tn;exports.ConfigLoadError=Ee;exports.Crewx=Qr;exports.CrewxPlugin=en;exports.DocumentLoader=Se;exports.LayoutLoadError=J;exports.LayoutLoader=at;exports.LayoutRenderer=ct;exports.NodeFsAdapter=$t;exports.ParallelRunner=_t;exports.ParallelRunnerTimeoutError=Zt;exports.PropsValidationError=fe;exports.PropsValidator=lt;exports.SdkBoxService=on;exports.SpanRepository=an;exports.TaskRepository=gt;exports.TemplateEngine=it;exports.TypedEventEmitter=ut;exports.YamlHookPlugin=cn;exports.buildContext=Ha;exports.createAdapterContext=Er;exports.createDelegateTool=La;exports.createHandler=Dr;exports.createPluginProviderFactory=ho;exports.createProvider=me;exports.createRemoteProviderFactory=go;exports.createScopedAdapterStore=Ar;exports.defaultExtractText=br;exports.defaultFsAdapter=Pe;exports.defaultParseEvent=Y;exports.defineChannelAdapter=hd;exports.defineChannelAdapterPlugin=wd;exports.escapeHandlebarsHelper=wr;exports.formatFileSizeHelper=xr;exports.formatTimestamp=vr;exports.formatTimestampHelper=kr;exports.generateFingerprint=Gs;exports.generateId=Oe;exports.getSyncWindowStore=Ys;exports.hashWorkspaceId=Lr;exports.lengthHelper=hr;exports.loadYamlFile=Et;exports.materializeWindowsSpawnProgram=et;exports.normalizeWorkspacePath=to;exports.parseStdoutEvent=rt;exports.parseUsage=ne;exports.parseYamlContent=Rt;exports.queryAcpProviderMeta=Ro;exports.queryAllAcpProviderMetas=Da;exports.registerAcpProviders=uo;exports.registerApiProviders=oo;exports.registerProviderFactory=ge;exports.resolveAgent=Tt;exports.resolveAgentSkills=ba;exports.resolveCrewxCli=$a;exports.resolveCrewxWorkspace=ja;exports.resolveDefaultAgentsYaml=nr;exports.resolveTemplatesPath=Be;exports.resolveWindowsExecutablePath=hn;exports.resolveWindowsSpawnProgram=Ze;exports.runExecutesParallel=Xa;exports.runInSyncWindow=Qs;exports.runQueriesParallel=Ja;exports.setAuditVerbose=Ms;exports.toTaskReader=yd;exports.toTemplateMessages=Tr;exports.truncateHelper=yr;exports.validateHooksSchema=fd;
|