@crewx/sdk 0.8.3-rc.11 → 0.8.3-rc.12
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/esm/index.js +22 -22
- package/dist/index.js +22 -22
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -1,54 +1,54 @@
|
|
|
1
|
-
'use strict';var fs$1=require('fs'),H=require('path'),child_process=require('child_process'),jsYaml=require('js-yaml'),zod=require('zod'),module$1=require('module'),Y=require('handlebars'),promises=require('fs/promises'),crypto$1=require('crypto'),events=require('events'),async_hooks=require('async_hooks'),mcp_js=require('@modelcontextprotocol/sdk/server/mcp.js'),webStandardStreamableHttp_js=require('@modelcontextprotocol/sdk/server/webStandardStreamableHttp.js'),Mo=require('os'),drizzleOrm=require('drizzle-orm'),sqliteCore=require('drizzle-orm/sqlite-core'),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 H__namespace=/*#__PURE__*/_interopNamespace(H);var Y__namespace=/*#__PURE__*/_interopNamespace(Y);var Mo__default=/*#__PURE__*/_interopDefault(Mo);var vt=Object.defineProperty;var wn=Object.getOwnPropertyDescriptor;var xn=Object.getOwnPropertyNames;var vn=Object.prototype.hasOwnProperty;var F=(o=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(o,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):o)(function(o){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+o+'" is not supported')});var j=(o,e)=>()=>(o&&(e=o(o=0)),e);var kt=(o,e)=>{for(var t in e)vt(o,t,{get:e[t],enumerable:true});},kn=(o,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of xn(e))!vn.call(o,n)&&n!==t&&vt(o,n,{get:()=>e[n],enumerable:!(r=wn(e,n))||r.enumerable});return o};var cr=o=>kn(vt({},"__esModule",{value:true}),o);var l=j(()=>{});function rt(o){return typeof o!="string"?void 0:o.trim()||void 0}function nt(o){return rt(o)?.toLowerCase()??""}function
|
|
2
|
-
`))if(t.trim())try{let r=JSON.parse(t),n=jn(r)??Hn(r)??Fn(r);n&&(e=n);}catch{}return e??void 0}var fe=j(()=>{l();});exports.RateLimitError=void 0;var Rt=j(()=>{l();exports.RateLimitError=class extends Error{name="RateLimitError";constructor(e){super(e);}};});function J(o){return /crewx\s+(x|execute)\s/.test(o)}function X(o,e){let t=e.match(/@(\S+)/);return {timestamp:o,type:"agent_call",targetAgent:t?.[1]?.replace(/["']/g,""),toolInput:e}}var
|
|
3
|
-
`):i=JSON.stringify(s),{timestamp:o,type:"tool_result",toolUseId:n,resultPreview:i,isError:r}}return null}exports.claudeAdapter=void 0;var Pt=j(()=>{l();Rt();
|
|
1
|
+
'use strict';var fs$1=require('fs'),H=require('path'),child_process=require('child_process'),jsYaml=require('js-yaml'),zod=require('zod'),module$1=require('module'),Y=require('handlebars'),promises=require('fs/promises'),crypto$1=require('crypto'),events=require('events'),async_hooks=require('async_hooks'),mcp_js=require('@modelcontextprotocol/sdk/server/mcp.js'),webStandardStreamableHttp_js=require('@modelcontextprotocol/sdk/server/webStandardStreamableHttp.js'),Mo=require('os'),drizzleOrm=require('drizzle-orm'),sqliteCore=require('drizzle-orm/sqlite-core'),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 H__namespace=/*#__PURE__*/_interopNamespace(H);var Y__namespace=/*#__PURE__*/_interopNamespace(Y);var Mo__default=/*#__PURE__*/_interopDefault(Mo);var vt=Object.defineProperty;var wn=Object.getOwnPropertyDescriptor;var xn=Object.getOwnPropertyNames;var vn=Object.prototype.hasOwnProperty;var F=(o=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(o,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):o)(function(o){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+o+'" is not supported')});var j=(o,e)=>()=>(o&&(e=o(o=0)),e);var kt=(o,e)=>{for(var t in e)vt(o,t,{get:e[t],enumerable:true});},kn=(o,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of xn(e))!vn.call(o,n)&&n!==t&&vt(o,n,{get:()=>e[n],enumerable:!(r=wn(e,n))||r.enumerable});return o};var cr=o=>kn(vt({},"__esModule",{value:true}),o);var l=j(()=>{});function rt(o){return typeof o!="string"?void 0:o.trim()||void 0}function nt(o){return rt(o)?.toLowerCase()??""}function be(o){try{return fs$1.statSync(o).isFile()}catch{return false}}function mr(o,e){if(o.includes("/")||o.includes("\\")||H__namespace.default.isAbsolute(o))return o;let r=(e.PATH??e.Path??process.env.PATH??process.env.Path??"").split(";").map(a=>a.trim()).filter(Boolean),n=H__namespace.default.extname(o).length>0,s=e.PATHEXT??e.Pathext??process.env.PATHEXT??process.env.Pathext??".EXE;.CMD;.BAT;.COM",i=n?[""]:s.split(";").map(a=>a.trim()).filter(Boolean).map(a=>a.startsWith(".")?a:`.${a}`);for(let a of r)for(let d of i){let c=nt(d),u=d.toUpperCase();for(let g of [d,c,u]){let p=H__namespace.default.join(a,`${o}${g}`);if(be(p))return p}}return o}function Mn(o){if(!be(o))return null;try{let e=fs$1.readFileSync(o,"utf8"),t=H__namespace.default.dirname(o),r=[];for(let a of e.matchAll(/"([^"\r\n]*)"/g)){let u=(a[1]??"").match(/%~?dp0%?\s*[\\/]*(.*)$/i)?.[1]?.trim();if(!u)continue;let g=u.replace(/[\\/]+/g,H__namespace.default.sep).replace(/^[\\/]+/,""),p=H__namespace.default.resolve(t,g);be(p)&&r.push(p);}let n=[],s=new Map;for(let a of e.matchAll(/SET\s+"(\w+)=%~?dp0%?[\\/]?([^"]+)"/gi)){let d=a[1].toUpperCase(),c=a[2].trim().replace(/[\\/]+/g,H__namespace.default.sep).replace(/^[\\/]+/,"");s.set(d,H__namespace.default.resolve(t,c));}for(let a of e.split(/\r?\n/))if(a.includes("%*"))for(let d of a.matchAll(/"%(\w+)%"/g)){let c=s.get(d[1].toUpperCase());c&&be(c)&&n.push(c);}let i=a=>a.find(d=>{let c=nt(H__namespace.default.basename(d));return c!=="node.exe"&&c!=="node"})??null;return i(n)??i(r)}catch{return null}}function Dn(o,e){if(typeof e=="string")return rt(e)||null;if(!e||typeof e!="object")return null;if(o){let t=e[o],r=typeof t=="string"?rt(t):void 0;if(r)return r}for(let t of Object.values(e)){let r=typeof t=="string"?rt(t):void 0;if(r)return r}return null}function Nn(o,e){if(!e)return null;let t=H__namespace.default.dirname(o),r=[H__namespace.default.resolve(t,"..",e),H__namespace.default.resolve(t,"node_modules",e)];for(let n of r){let s=H__namespace.default.join(n,"package.json");if(be(s))try{let i=JSON.parse(fs$1.readFileSync(s,"utf8")),a=Dn(e,i.bin);if(!a)continue;let d=H__namespace.default.resolve(n,a);if(be(d))return d}catch{}}return null}function Ln(o){let e=o.platform??process.platform,t=o.env??process.env,r=o.execPath??process.execPath;if(e!=="win32")return {command:o.command,leadingArgv:[],resolution:"direct"};let n=mr(o.command,t),s=nt(H__namespace.default.extname(n));if(s===".js"||s===".cjs"||s===".mjs")return {command:r,leadingArgv:[n],resolution:"node-entrypoint",windowsHide:true};if(s===".cmd"||s===".bat"){let i=Mn(n)??Nn(n,o.packageName);return i?nt(H__namespace.default.extname(i))===".exe"?{command:i,leadingArgv:[],resolution:"exe-entrypoint",windowsHide:true}:{command:r,leadingArgv:[i],resolution:"node-entrypoint",windowsHide:true}:{command:n,leadingArgv:[],resolution:"unresolved-wrapper"}}return {command:n,leadingArgv:[],resolution:"direct"}}function $n(o){if(o.candidate.resolution!=="unresolved-wrapper")return {command:o.candidate.command,leadingArgv:o.candidate.leadingArgv,resolution:o.candidate.resolution,windowsHide:o.candidate.windowsHide};if(o.allowShellFallback===true)return {command:o.candidate.command,leadingArgv:[],resolution:"shell-fallback",shell:true};throw new Error(`${H__namespace.default.basename(o.candidate.command)} wrapper resolved, but no executable/Node entrypoint could be resolved without shell execution.`)}function Ie(o){let e=Ln(o);return $n({candidate:e,allowShellFallback:o.allowShellFallback})}function Oe(o,e){return {command:o.command,argv:[...o.leadingArgv,...e],resolution:o.resolution,shell:o.shell,windowsHide:o.windowsHide}}var ot=j(()=>{l();});function jn(o){if(o.type!=="usage"||!("input_tokens"in o))return null;let e=Number(o.input_tokens??0),t=Number(o.output_tokens??0),n="cache_read_input_tokens"in o?Number(o.cache_read_input_tokens):void 0,s="cached_input_tokens"in o?Number(o.cached_input_tokens):void 0,i=n!==void 0?n:s??0;return {inputTokens:n!==void 0?e+n:e,outputTokens:t,cachedInputTokens:i}}function Hn(o){let e=o.usage;if(!e||typeof e!="object"||Array.isArray(e))return null;let t=e;if(!("input_tokens"in t))return null;let r=Number(t.input_tokens??0),n=Number(t.output_tokens??0),i="cache_read_input_tokens"in t?Number(t.cache_read_input_tokens):void 0,a="cached_input_tokens"in t?Number(t.cached_input_tokens):void 0,d=i!==void 0?i:a??0;return {inputTokens:i!==void 0?r+i:r,outputTokens:n,cachedInputTokens:d}}function Fn(o){if(o.type!=="step_finish")return null;let t=o.part?.tokens;if(!t)return null;let r=Number(t.input??0),n=Number(t.output??0),s=t.cache,i=s?Number(s.read??0):0;return {inputTokens:r+i,outputTokens:n,cachedInputTokens:i}}function K(o){if(!o||!o.trim())return;let e=null;for(let t of o.split(`
|
|
2
|
+
`))if(t.trim())try{let r=JSON.parse(t),n=jn(r)??Hn(r)??Fn(r);n&&(e=n);}catch{}return e??void 0}var fe=j(()=>{l();});exports.RateLimitError=void 0;var Rt=j(()=>{l();exports.RateLimitError=class extends Error{name="RateLimitError";constructor(e){super(e);}};});function J(o){return /crewx\s+(x|execute)\s/.test(o)}function X(o,e){let t=e.match(/@(\S+)/);return {timestamp:o,type:"agent_call",targetAgent:t?.[1]?.replace(/["']/g,""),toolInput:e}}var Ce=j(()=>{l();});function qn(o,e){let t=e.type;if(t==="text"){let r=String(e.text||"");return r?{timestamp:o,type:"text",content:r}:null}if(t==="tool_use"){let r=String(e.name||""),n=e.id,s=e.input,i=s?.command?String(s.command):JSON.stringify(s||{});return r==="Bash"&&J(i)?X(o,i):{timestamp:o,type:"tool_use",toolUseId:n,toolName:r,toolInput:i}}if(t==="tool_result"){let r=!!e.is_error,n=e.tool_use_id,s=e.output??e.content??"",i;return typeof s=="string"?i=s:Array.isArray(s)?i=s.filter(a=>a.type==="text"&&typeof a.text=="string").map(a=>a.text).join(`
|
|
3
|
+
`):i=JSON.stringify(s),{timestamp:o,type:"tool_result",toolUseId:n,resultPreview:i,isError:r}}return null}exports.claudeAdapter=void 0;var Pt=j(()=>{l();Rt();Ce();exports.claudeAdapter={command:"claude",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs],s=n.indexOf("-p");return s!==-1?(n.splice(s+1,0,o),e.model&&n.push("--model",e.model),{args:n}):(e.model&&n.push("--model",e.model),{args:n,stdinMessage:o})}let r=["-p",o,"--output-format","stream-json","--verbose"];return e.model&&r.push("--model",e.model),{args:r}},extractText(o){let e=o.split(`
|
|
4
4
|
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="assistant"&&Array.isArray(s.message?.content))for(let i of s.message.content)i.type==="text"&&typeof i.text=="string"&&i.text.trim()&&t.push(i.text.trim());s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(`
|
|
5
5
|
|
|
6
6
|
`):r||o.trim()},extractFailure(o){if(o.includes('"rate_limit_event"'))try{let e=JSON.parse(o);if(e.type==="rate_limit_event"){let t=e.rate_limit_info??{};if(t.status==="rejected")return new exports.RateLimitError(`Claude rate limit: ${t.rateLimitType??"unknown"} (status: ${t.status})`)}}catch{}return null},parseResultMeta(o){let e=o.split(`
|
|
7
|
-
`);for(let t of e)if(t.trim())try{let r=JSON.parse(t);if(r.type==="result"){let n=r.usage,s=n?{inputTokens:Number(n.input_tokens??0)+Number(n.cache_read_input_tokens??0),outputTokens:Number(n.output_tokens??0),cachedInputTokens:Number(n.cache_read_input_tokens??0),costUsd:Number(r.total_cost_usd??0)}:null,i=r.modelUsage,a=i?Object.keys(i)[0]??null:null;return {usage:s,model:a}}}catch{}return {usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(r!=="assistant"&&r!=="user")return [];let s=t.message?.content;if(!Array.isArray(s))return [];let i=e??new Date().toISOString(),a=[];for(let d of s){let
|
|
8
|
-
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);s.type==="message"&&s.role==="assistant"&&s.delta===!0&&typeof s.content=="string"&&t.push(s.content),s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(""):r||o.trim()},parseResultMeta(o){let e=K(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(r!=="message"&&r!=="tool_use"&&r!=="tool_result")return [];let n=e??new Date().toISOString();if(r==="message"){if(t.role!=="assistant")return [];let i=t.content;return i?[{timestamp:n,type:"text",content:i}]:[]}if(r==="tool_use"){let s=String(t.tool_name||""),i=t.tool_id,a=t.parameters,d=a?.command?String(a.command):JSON.stringify(a||{});return /^bash$/i.test(s)&&J(d)?[X(n,d)]:[{timestamp:n,type:"tool_use",toolName:s,toolUseId:i,toolInput:d}]}if(r==="tool_result"){let s=t.tool_id,i=String(t.output||""),a=t.status!=="success";return [{timestamp:n,type:"tool_result",toolUseId:s,resultPreview:i,isError:a}]}return []}};});exports.copilotAdapter=void 0;var Ct=j(()=>{l();fe();
|
|
7
|
+
`);for(let t of e)if(t.trim())try{let r=JSON.parse(t);if(r.type==="result"){let n=r.usage,s=n?{inputTokens:Number(n.input_tokens??0)+Number(n.cache_read_input_tokens??0),outputTokens:Number(n.output_tokens??0),cachedInputTokens:Number(n.cache_read_input_tokens??0),costUsd:Number(r.total_cost_usd??0)}:null,i=r.modelUsage,a=i?Object.keys(i)[0]??null:null;return {usage:s,model:a}}}catch{}return {usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(r!=="assistant"&&r!=="user")return [];let s=t.message?.content;if(!Array.isArray(s))return [];let i=e??new Date().toISOString(),a=[];for(let d of s){let c=qn(i,d);c&&a.push(c);}return a}};});exports.geminiAdapter=void 0;var bt=j(()=>{l();fe();Ce();exports.geminiAdapter={command:"gemini",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs],s=n.indexOf("-p");return s!==-1?(n.splice(s+1,0,o),e.model&&n.push("--model",e.model),{args:n}):(e.model&&n.push("--model",e.model),{args:n,stdinMessage:o})}let r=["-p",o,"--output-format","stream-json","--verbose"];return e.model&&r.push("--model",e.model),{args:r}},extractText(o){let e=o.split(`
|
|
8
|
+
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);s.type==="message"&&s.role==="assistant"&&s.delta===!0&&typeof s.content=="string"&&t.push(s.content),s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(""):r||o.trim()},parseResultMeta(o){let e=K(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(r!=="message"&&r!=="tool_use"&&r!=="tool_result")return [];let n=e??new Date().toISOString();if(r==="message"){if(t.role!=="assistant")return [];let i=t.content;return i?[{timestamp:n,type:"text",content:i}]:[]}if(r==="tool_use"){let s=String(t.tool_name||""),i=t.tool_id,a=t.parameters,d=a?.command?String(a.command):JSON.stringify(a||{});return /^bash$/i.test(s)&&J(d)?[X(n,d)]:[{timestamp:n,type:"tool_use",toolName:s,toolUseId:i,toolInput:d}]}if(r==="tool_result"){let s=t.tool_id,i=String(t.output||""),a=t.status!=="success";return [{timestamp:n,type:"tool_result",toolUseId:s,resultPreview:i,isError:a}]}return []}};});exports.copilotAdapter=void 0;var Ct=j(()=>{l();fe();Ce();exports.copilotAdapter={command:"copilot",buildArgs(o,e,t){let r=e.additionalArgs?[...e.additionalArgs]:[];return e.model&&r.push("--model",e.model),{args:r,stdinMessage:o}},extractText(o){let e=o.split(`
|
|
9
9
|
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="assistant.message"&&typeof s.data?.content=="string"){let i=s.data.content;i.trim()&&t.push(i.trim());}s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(`
|
|
10
10
|
|
|
11
|
-
`):r||o.trim()},parseResultMeta(o){let e=K(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(!r.startsWith("tool.execution")&&!r.startsWith("assistant.")&&r!=="user.message")return [];let n=t.data;if(!n)return [];let s=e??new Date().toISOString(),i=n.toolCallId;if(r==="tool.execution_start"){let a=String(n.toolName||""),d=n.arguments,
|
|
11
|
+
`):r||o.trim()},parseResultMeta(o){let e=K(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(!r.startsWith("tool.execution")&&!r.startsWith("assistant.")&&r!=="user.message")return [];let n=t.data;if(!n)return [];let s=e??new Date().toISOString(),i=n.toolCallId;if(r==="tool.execution_start"){let a=String(n.toolName||""),d=n.arguments,c=d?.command?String(d.command):JSON.stringify(d||{});return (a==="bash"||a==="Bash")&&J(c)?[X(s,c)]:[{timestamp:s,type:"tool_use",toolName:a,toolInput:c,...i&&{toolUseId:i}}]}if(r==="tool.execution_complete"){let a=n.error;if(a)return [{timestamp:s,type:"tool_result",isError:true,resultPreview:String(a.message||""),...i&&{toolUseId:i}}];let d=n.result,c=String(d?.content||"");return [{timestamp:s,type:"tool_result",resultPreview:c,isError:false,...i&&{toolUseId:i}}]}if(r==="assistant.message"){let a=String(n.content||"");return a?[{timestamp:s,type:"text",content:a}]:[]}return []}};});function Un(o,e){if(e.type==="command_execution"){let r=String(e.command||"");return J(r)?[X(o,r)]:[{timestamp:o,type:"tool_use",toolName:"Bash",toolInput:r}]}return []}function Wn(o,e){let t=e.type;if(t==="message"||t==="text"){let r=e.content;if(Array.isArray(r))for(let n of r){let s=Bn(o,n);if(s)return s}if(typeof e.text=="string")return {timestamp:o,type:"text",content:e.text}}if(t==="reasoning")return {timestamp:o,type:"text",content:String(e.text||"")};if(t==="command_execution"){let r=String(e.aggregated_output||e.output||""),n=!!e.is_error;return {timestamp:o,type:"tool_result",resultPreview:r,isError:n}}if(t==="tool_use"){let r=String(e.name||e.tool_name||""),n=e.input,s=n?.command?String(n.command):JSON.stringify(n||{});return r==="Bash"&&J(s)?X(o,s):{timestamp:o,type:"tool_use",toolName:r,toolInput:s}}if(t==="tool_result"){let r=!!e.is_error,n=String(e.output||e.content||"");return {timestamp:o,type:"tool_result",resultPreview:n,isError:r}}return null}function Bn(o,e){let t=e.type;if(t==="text")return {timestamp:o,type:"text",content:String(e.text||"")};if(t==="tool_use"){let r=String(e.name||""),n=e.input,s=n?.command?String(n.command):JSON.stringify(n||{});return r==="Bash"&&J(s)?X(o,s):{timestamp:o,type:"tool_use",toolName:r,toolInput:s}}return null}exports.codexAdapter=void 0;var At=j(()=>{l();fe();Ce();exports.codexAdapter={command:"codex",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs];return !n.includes("--json")&&!n.includes("--experimental-json")&&n.push("--json"),e.model&&n.push("--model",e.model),{args:n,stdinMessage:o}}let r=["exec","--json"];return e.model&&r.push("--model",e.model),{args:r,stdinMessage:o}},extractText(o){let e=o.split(`
|
|
12
12
|
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="item.completed"&&(s.item?.type==="message"||s.item?.type==="agent_message")&&typeof s.item?.text=="string"){let i=s.item.text;i.trim()&&t.push(i.trim());}s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(`
|
|
13
13
|
|
|
14
14
|
`):r||o.trim()},parseResultMeta(o){let e=K(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(!r.startsWith("item.")&&!r.startsWith("turn.")&&!r.startsWith("thread."))return [];let n=t.item;if(!n)return [];let s=e??new Date().toISOString();if(r==="item.started")return Un(s,n);if(r==="item.completed"){let i=Wn(s,n);return i?[i]:[]}return []}};});function zn(o){if(typeof o=="string")return o;if(!o||typeof o!="object")return JSON.stringify(o??{});let e=o;return e.command?String(e.command):e.filePath?String(e.filePath):e.pattern?String(e.pattern):JSON.stringify(e)}exports.opencodeAdapter=void 0;var Tt=j(()=>{l();fe();exports.opencodeAdapter={command:"opencode",buildArgs(o,e,t){let r=e.additionalArgs,n=r!==void 0?[...r]:["run"];return n.includes("--format")||n.push("--format","json"),e.model&&n.push("--model",e.model),n.push(o),{args:n}},extractText(o){let e=o.split(`
|
|
15
|
-
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="text"&&typeof s.part?.text=="string"){let i=s.part.text;i.trim()&&t.push(i.trim());}s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(""):r||o.trim()},parseResultMeta(o){let e=K(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];let n=e??new Date().toISOString();if(r==="text"){let i=t.part?.text;return i?[{timestamp:n,type:"text",content:i}]:[]}if(r==="tool_use"){let s=t.part;if(!s)return [];let i=String(s.tool||""),a=String(s.callID||""),d=s.state,
|
|
16
|
-
`).filter(d=>d.trim()),t=[],r=[],n=[],s=[],i=[],a=null;for(let d of e)try{let
|
|
15
|
+
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="text"&&typeof s.part?.text=="string"){let i=s.part.text;i.trim()&&t.push(i.trim());}s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(""):r||o.trim()},parseResultMeta(o){let e=K(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];let n=e??new Date().toISOString();if(r==="text"){let i=t.part?.text;return i?[{timestamp:n,type:"text",content:i}]:[]}if(r==="tool_use"){let s=t.part;if(!s)return [];let i=String(s.tool||""),a=String(s.callID||""),d=s.state,c=String(d?.status||""),u=d?.input,g=zn(u),p=[{timestamp:n,type:"tool_use",toolName:i,toolUseId:a,toolInput:g}];if(c==="completed"&&d?.output!==void 0){let f=d.output,y=typeof f=="string"?f:JSON.stringify(f);p.push({timestamp:n,type:"tool_result",toolUseId:a,resultPreview:y,isError:false});}else c==="error"&&p.push({timestamp:n,type:"tool_result",toolUseId:a,resultPreview:String(d?.error||"tool error"),isError:true});return p}return []}};});function Et(o,e,t){if(t){let r=exports.BUILTIN_ADAPTERS[t];if(r?.parseEvent)return r.parseEvent(e,o)}for(let r of Object.values(exports.BUILTIN_ADAPTERS)){let n=r.parseEvent?.(e,o)??[];if(n.length>0)return n}return []}exports.BUILTIN_ADAPTERS=void 0;var Ae=j(()=>{l();Pt();bt();Ct();At();Tt();Pt();bt();Ct();At();Tt();Ce();exports.BUILTIN_ADAPTERS={claude:exports.claudeAdapter,gemini:exports.geminiAdapter,copilot:exports.copilotAdapter,codex:exports.codexAdapter,opencode:exports.opencodeAdapter};});function Kn(o){let e=o.split(`
|
|
16
|
+
`).filter(d=>d.trim()),t=[],r=[],n=[],s=[],i=[],a=null;for(let d of e)try{let c=JSON.parse(d);if(c.type==="assistant"&&Array.isArray(c.message?.content))for(let u of c.message.content)u.type==="text"&&typeof u.text=="string"&&u.text.trim()&&t.push(u.text.trim());if(c.type==="message"&&c.role==="assistant"&&c.delta===!0&&typeof c.content=="string"&&r.push(c.content),c.type==="assistant.message"&&typeof c.data?.content=="string"){let u=c.data.content;u.trim()&&n.push(u.trim());}if(c.type==="item.completed"&&(c.item?.type==="message"||c.item?.type==="agent_message")&&typeof c.item?.text=="string"){let u=c.item.text;u.trim()&&s.push(u.trim());}if(c.type==="text"&&typeof c.part?.text=="string"){let u=c.part.text;u.trim()&&i.push(u.trim());}c.type==="result"&&typeof c.result=="string"&&(a=c.result);}catch{}return t.length>0?t.join(`
|
|
17
17
|
|
|
18
18
|
`):r.length>0?r.join(""):n.length>0?n.join(`
|
|
19
19
|
|
|
20
20
|
`):s.length>0?s.join(`
|
|
21
21
|
|
|
22
|
-
`):i.length>0?i.join(""):a||o.trim()}function Jn(o){let e=K(o);return e?{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0}:null}function Xn(o,e,t,r,n,s,i){return new Promise((a,d)=>{let
|
|
23
|
-
`);T=C.pop()??"";for(let h of C)if(h.trim()&&(n?.onOutput?.(h,"stdout"),i?.extractFailure)){let E=i.extractFailure(h);if(E){f=true,clearTimeout(_);try{
|
|
24
|
-
`);M=C.pop()??"";for(let h of C)h.trim()&&n?.onOutput?.(h,"stderr");}),
|
|
22
|
+
`):i.length>0?i.join(""):a||o.trim()}function Jn(o){let e=K(o);return e?{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0}:null}function Xn(o,e,t,r,n,s,i){return new Promise((a,d)=>{let c=n?.timeoutMs??36e5,u=Ie({command:o,allowShellFallback:true}),g=Oe(u,e),p=child_process.spawn(g.command,g.argv,{env:{...process.env,...n?.env??{}},cwd:n?.cwd,stdio:["pipe","pipe","pipe"],shell:g.shell??false,windowsHide:g.windowsHide});s!==void 0&&p.stdin.write(s),p.stdin.end(),p.pid!==void 0&&n?.onPid?.(p.pid);let f=false,y=false,R=()=>{try{p.kill("SIGKILL");}catch{}},_=setTimeout(()=>{if(!f){y=true;try{p.kill("SIGTERM");}catch{}setTimeout(R,fr).unref();}},c);_.unref();let w="",b="",T="",M="";p.stdout.on("data",$=>{let L=$.toString();w+=L,T+=L;let C=T.split(`
|
|
23
|
+
`);T=C.pop()??"";for(let h of C)if(h.trim()&&(n?.onOutput?.(h,"stdout"),i?.extractFailure)){let E=i.extractFailure(h);if(E){f=true,clearTimeout(_);try{p.kill("SIGTERM");}catch{}setTimeout(R,fr).unref(),d(E);return}}}),p.stderr.on("data",$=>{let L=$.toString();b+=L,M+=L;let C=M.split(`
|
|
24
|
+
`);M=C.pop()??"";for(let h of C)h.trim()&&n?.onOutput?.(h,"stderr");}),p.on("error",$=>{f=true,clearTimeout(_),$.code==="ENOENT"?d(new exports.ProviderError(`CLI command "${o}" not found. Is ${t} installed?`,t)):d(new exports.ProviderError(`Spawn error: ${$.message}`,t));}),p.on("close",$=>{if(f)return;f=true,clearTimeout(_),T.trim()&&n?.onOutput?.(T,"stdout"),M.trim()&&n?.onOutput?.(M,"stderr");let L=$??0;if(n?.onExitCode?.(L),y&&$!==0)return d(new St(`Total runtime exceeded ${c}ms; process killed.`,t));if(L!==0){if(i?.interpretExit){let h=i.interpretExit(L,b);if(h){d(h);return}}d(new exports.ProviderError(`Process exited with code ${L}: ${b.slice(0,500)}`,t));return}let C=i?i.extractText(w):Kn(w);a({stdout:w,parsed:C});});})}function Te(o,e){yr.set(o,e);}function ne(o){let e=o.split("/");if(e.length!==2)throw new exports.ProviderError(`Invalid provider format: "${o}". Expected namespace/id (e.g., cli/claude)`,o);let[t,r]=e,n=yr.get(t);if(n)return n(r,o);if(t==="cli"){let s=exports.BUILTIN_ADAPTERS[r];if(!s)throw new exports.ProviderError(`Unknown CLI provider id: "${r}". Supported: ${Object.keys(exports.BUILTIN_ADAPTERS).join(", ")}`,o);return new It(r,s,o)}throw new exports.ProviderError(`Unsupported provider namespace: "${t}". Register a factory with registerProviderFactory('${t}', factory).`,o)}exports.ProviderError=void 0;var St,fr;exports.ClientToolCallRequiredError=void 0;var yr,It,ye=j(()=>{l();ot();fe();Ae();exports.ProviderError=class extends Error{constructor(t,r){super(t);this.providerStr=r;this.name="ProviderError";}providerStr},St=class extends exports.ProviderError{constructor(e,t){super(e,t),this.name="TotalTimeoutError";}},fr=2e3;exports.ClientToolCallRequiredError=class extends Error{constructor(t,r){super(`Client tool call required: ${t.toolName}`);this.toolCall=t;this.continuationState=r;}toolCall;continuationState;name="ClientToolCallRequiredError"},yr=new Map;It=class{constructor(e,t,r){this.providerId=e;this.adapter=t;this.providerStr=r;}providerId;adapter;providerStr;async execute(e,t){let r=this.composeMessage(e,t),{args:n,stdinMessage:s}=this.adapter.buildArgs(r,t??{},true);t?.onCommand?.(`${this.adapter.command} ${n.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(n,t,s);return this.handleResultMeta(i,t),a}async query(e,t){let r=this.composeMessage(e,t),{args:n,stdinMessage:s}=this.adapter.buildArgs(r,t??{},false);t?.onCommand?.(`${this.adapter.command} ${n.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(n,t,s);return this.handleResultMeta(i,t),a}composeMessage(e,t){return t?.systemPrompt?`${t.systemPrompt}
|
|
25
25
|
|
|
26
26
|
---
|
|
27
27
|
|
|
28
|
-
${e}`:e}runProcess(e,t,r){return Xn(this.adapter.command,e,this.providerStr,this.providerId,t,r,this.adapter)}handleResultMeta(e,t){if(!this.adapter.parseResultMeta){let i=Jn(e);i&&t?.onUsage&&t.onUsage(i);return}let{usage:r,model:n}=this.adapter.parseResultMeta(e);r&&t?.onUsage&&t.onUsage(r);let s=n??(this.providerId==="opencode"?t?.model??null:null);s&&t?.onModel&&t.onModel(s);}};});var Ur,Wr;exports.VercelProviderRuntime=void 0;var Jt=j(()=>{l();ye();Ur=10,Wr=50,exports.VercelProviderRuntime=class{config;constructor(e){this.config=e;}async query(e,t){return this._run(e,"query",t)}async execute(e,t){return this._run(e,"execute",t)}async _run(e,t,r){let{generateText:n,tool:s}=await import('ai'),i=this.convertTools(r?.tools??[],s),a=this.createModel(r?.model),d=Math.min(r?.maxSteps??this.config.maxSteps??Ur,Wr);try{let u=0,c=await n({model:a,system:r?.systemPrompt??void 0,prompt:e,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens},onStepFinish:g=>{if(u++,!!r?.onOutput){if(g.toolCalls&&g.toolCalls.length>0)for(let f of g.toolCalls)r.onOutput(JSON.stringify({type:"assistant",message:{content:[{type:"tool_use",id:f.toolCallId,name:f.toolName,input:f.args}]}}),"stdout");if(g.toolResults&&g.toolResults.length>0)for(let f of g.toolResults){let y=typeof f.result=="string"?f.result:JSON.stringify(f.result);r.onOutput(JSON.stringify({type:"user",message:{content:[{type:"tool_result",tool_use_id:f.toolCallId,output:y,is_error:!1}]}}),"stdout");}}}}),p=new Set((r?.tools??[]).filter(g=>!g.execute).map(g=>g.name));if(c.finishReason==="tool-calls"&&Array.isArray(c.toolCalls)&&c.toolCalls.length>0){let g=c.toolCalls.filter(f=>p.has(f.toolName));if(g.length>0){let f=g[0];throw new exports.ClientToolCallRequiredError({toolCallId:f.toolCallId,toolName:f.toolName,args:f.args},{userMessage:e,responseMessages:c.response?.messages??[],toolDefinitions:r?.tools??[],maxSteps:d,systemPrompt:r?.systemPrompt,modelOverride:r?.model})}}if(r?.onUsage&&c.usage){let g={inputTokens:c.usage.promptTokens??0,outputTokens:c.usage.completionTokens??0,cachedInputTokens:0,costUsd:0};r.onUsage(g);}return r?.onModel&&r.onModel(r.model??this.config.model),c.text??""}catch(u){throw u instanceof exports.ClientToolCallRequiredError?u:u.status===401?new exports.ProviderError(`Authentication failed for ${this.config.provider}. Check your API key.`,this.config.provider):u.status===429?new exports.ProviderError(`Rate limit exceeded for ${this.config.provider}.`,this.config.provider):new exports.ProviderError(`Provider error: ${u.message}`,this.config.provider)}}async continueWithToolResults(e,t,r){let{generateText:n,tool:s}=await import('ai'),i=this.convertTools(e.toolDefinitions,s),a=this.createModel(e.modelOverride),d=Math.min(e.maxSteps??this.config.maxSteps??Ur,Wr),u=[{role:"user",content:e.userMessage},...e.responseMessages,{role:"tool",content:t.map(c=>({type:"tool-result",toolCallId:c.toolCallId,toolName:c.toolName,result:typeof c.result=="string"?c.result:JSON.stringify(c.result)}))}];try{let c=await n({model:a,system:e.systemPrompt??void 0,messages:u,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(g=>!g.execute).map(g=>g.name));if(c.finishReason==="tool-calls"&&Array.isArray(c.toolCalls)&&c.toolCalls.length>0){let g=c.toolCalls.filter(f=>p.has(f.toolName));if(g.length>0){let f=g[0];throw new exports.ClientToolCallRequiredError({toolCallId:f.toolCallId,toolName:f.toolName,args:f.args},{userMessage:e.userMessage,responseMessages:[...e.responseMessages,{role:"tool",content:t.map(y=>({type:"tool-result",toolCallId:y.toolCallId,toolName:y.toolName,result:typeof y.result=="string"?y.result:JSON.stringify(y.result)}))},...c.response?.messages??[]],toolDefinitions:e.toolDefinitions,maxSteps:e.maxSteps,systemPrompt:e.systemPrompt,modelOverride:e.modelOverride})}}return r?.onUsage&&c.usage&&r.onUsage({inputTokens:c.usage.promptTokens??0,outputTokens:c.usage.completionTokens??0,cachedInputTokens:0,costUsd:0}),r?.onModel&&r.onModel(e.modelOverride??this.config.model),c.text??""}catch(c){throw c instanceof exports.ClientToolCallRequiredError?c:new exports.ProviderError(`Provider error: ${c.message}`,this.config.provider)}}convertTools(e,t){let{z:r}=F("zod"),n={};for(let s of e){let i=this.jsonSchemaToZod(s.parameters??{},r);s.execute?n[s.name]=t({description:s.description,parameters:i,execute:async a=>s.execute(a)}):n[s.name]=t({description:s.description,parameters:i});}return n}jsonSchemaToZod(e,t){if(!e||!e.properties)return t.object({});let r={},n=e.properties,s=e.required??[];for(let[i,a]of Object.entries(n)){let d;switch(a.type){case "string":d=t.string();break;case "number":d=t.number();break;case "integer":d=t.number().int();break;case "boolean":d=t.boolean();break;case "array":d=t.array(t.any());break;default:d=t.any();}a.description&&(d=d.describe(a.description)),s.includes(i)||(d=d.optional()),r[i]=d;}return t.object(r)}createModel(e){let{provider:t,apiKey:r,baseURL:n}=this.config,s=e||this.config.model;switch(t){case "api/openrouter":{let{createOpenAI:i}=F("@ai-sdk/openai");return i({apiKey:r||process.env.OPENROUTER_API_KEY,baseURL:n||"https://openrouter.ai/api/v1"})(s)}case "api/openai":{let{createOpenAI:i}=F("@ai-sdk/openai");return i({apiKey:r||process.env.OPENAI_API_KEY,...n&&{baseURL:n}})(s)}case "api/anthropic":{let{createAnthropic:i}=F("@ai-sdk/anthropic");return i({apiKey:r||process.env.ANTHROPIC_API_KEY,...n&&{baseURL:n}})(s)}case "api/google":{let{createGoogleGenerativeAI:i}=F("@ai-sdk/google");return i({apiKey:r||process.env.GOOGLE_API_KEY})(s)}default:throw new exports.ProviderError(`Unsupported API provider: ${t}`,t)}}};});var zr={};kt(zr,{registerApiProviders:()=>Br});function Br(o){Ae("api",(e,t)=>{let r=o?.apiKeys?.[e];return new exports.VercelProviderRuntime({provider:t,model:"",apiKey:r,maxSteps:o?.defaults?.maxSteps,temperature:o?.defaults?.temperature})});}var Xt=j(()=>{l();ye();Jt();});function is(o){if(!o)return o;let e=o.trim().replace(/\/+$/,"");return e.toLowerCase().endsWith("/mcp")?e.slice(0,-4):e}exports.McpHttpTransport=void 0;var Gt=j(()=>{l();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=is(e.url);this.endpoint=`${t}/mcp`,this.headers={"Content-Type":"application/json",...e.headers??{}},e.apiKey&&(this.headers.Authorization=`Bearer ${e.apiKey}`),this.timeoutMs=e.timeoutMs??3e4;}async send(e){let t=new AbortController,r=setTimeout(()=>t.abort(),this.timeoutMs);try{let n=await fetch(this.endpoint,{method:"POST",headers:this.headers,body:JSON.stringify(e),signal:t.signal});if(clearTimeout(r),!n.ok){let a=await n.text();throw new Error(`HTTP ${n.status}: ${n.statusText}${a?` - ${a}`:""}`)}let s=n.headers.get("content-type");if(s?.includes("application/json"))return await n.json();let i=await n.text();return {jsonrpc:"2.0",id:e.id,error:{code:-32600,message:`Unexpected response content-type: ${s}`,data:i}}}catch(n){throw clearTimeout(r),n instanceof Error&&n.name==="AbortError"?new Error(`MCP-HTTP request timeout after ${this.timeoutMs}ms to ${this.endpoint}`):n}}async close(){}};});exports.RemoteAgentManager=void 0;var Qt=j(()=>{l();Gt();exports.RemoteAgentManager=class{logger;configs=new Map;transports=new Map;constructor(e={}){this.logger=e.logger??(()=>{});}loadConfig(e,t){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,new exports.McpHttpTransport({url:t.url,apiKey:t.apiKey,headers:t.headers,timeoutMs:t.timeoutMs})),this.logger(`Loaded remote agent config for: ${e}`,"debug");}loadConfigWithTransport(e,t,r){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,r),this.logger(`Loaded remote agent config for: ${e} (custom transport)`,"debug");}getConfig(e){return this.configs.get(e)}isRemoteAgent(e){return this.configs.has(e)}getRemoteAgentIds(){return Array.from(this.configs.keys())}async query(e,t){let r=this.requireConfig(e),n=r.tools?.query??"crewx_queryAgent",i={agentId:r.agentId??e,query:t.query};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote query failed for agent ${e}: ${d}`,"error"),a}}async execute(e,t){let r=this.requireConfig(e),n=r.tools?.execute??"crewx_executeAgent",i={agentId:r.agentId??e,task:t.task};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote execute failed for agent ${e}: ${d}`,"error"),a}}mapToolNames(e,t){let r=this.requireConfig(e);r.tools={query:t.query??r.tools?.query??"crewx_queryAgent",execute:t.execute??r.tools?.execute??"crewx_executeAgent"},this.logger(`Updated tool name mapping for agent ${e}`,"debug");}async clearConfigs(){for(let e of this.transports.values())await e.close();this.configs.clear(),this.transports.clear(),this.logger("Cleared all remote agent configurations","debug");}requireConfig(e){let t=this.configs.get(e);if(!t)throw new Error(`Agent ${e} is not configured as a remote agent`);return t}async callRemoteTool(e,t,r){let n=this.transports.get(e);if(!n)throw new Error(`No transport available for agent ${e}`);let s={jsonrpc:"2.0",id:`${t}-${Date.now()}`,method:"tools/call",params:{name:t,arguments:r}};this.logger(`Calling remote MCP tool ${t} for agent ${e}`,"debug");let i=await n.send(s);if(i.error)throw new Error(i.error.message||"MCP server returned an error");return i.result}normalizeResponse(e){if(!e)return {success:false,content:[{type:"text",text:"Remote agent returned no response."}]};let t=e;if(Array.isArray(t.content)&&t.content.length>0)return t;let r=t.response??t.implementation??t.message??t.output,n=typeof r=="string"?r:JSON.stringify(r??e,null,2);return {...t,content:[{type:"text",text:n}]}}validateConfig(e){if(!e.url)throw new Error("Remote agent configuration requires a URL");if(!e.url.startsWith("http://")&&!e.url.startsWith("https://"))throw new Error("Remote agent URL must start with http:// or https://");if(e.type!=="mcp-http")throw new Error(`Unsupported remote agent type: ${e.type}`)}};});var Kr={};kt(Kr,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>Vr,resolveFileRemoteAgent:()=>ms});function ps(o){let e=fs$1.readFileSync(o,"utf-8"),t=jsYaml.load(e);return {agents:Array.isArray(t?.agents)?t.agents:void 0}}function gs(o){let e=Array.isArray(o.provider)?o.provider[0]:o.provider;return e||(Array.isArray(o.inline?.provider)?o.inline.provider[0]:o.inline?.provider)}function ms(o,e=ps,t=fs$1.existsSync){let r=o.location.replace("file://","");if(!t(r))throw new Error(`Remote config file not found: ${r}`);if(!o.external_agent_id)throw new Error(`external_agent_id is required for file:// remote provider "${o.id}"`);let s=e(r).agents?.find(d=>d.id===o.external_agent_id);if(!s)throw new Error(`Agent "${o.external_agent_id}" not found in ${r}`);let i=gs(s);if(!i)throw new Error(`Agent "${o.external_agent_id}" in ${r} has no provider configured`);if(i.startsWith("remote/"))throw new Error(`Chained remotes not allowed: ${o.id} \u2192 ${i}`);let a=H.resolve(H.dirname(r),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function Vr(o,e=ne){return (t,r)=>{let n=o.get(t);if(!n)throw new Error(`Remote provider "${t}" not found. Available: ${Array.from(o.keys()).join(", ")||"(none)"}`);if(n.location.startsWith("file://"))throw new Error(`Remote provider "${t}" uses file:// location which is not supported at the SDK level. Use the CLI commands (crewx query / crewx execute) which handle file:// remotes automatically.`);return new exports.RemoteProviderRuntime(t,n,e)}}function fs(o,e){let t=e.location;if(!t)throw new Error("Remote provider config requires a location");if(!t.startsWith("http://")&&!t.startsWith("https://"))throw new Error(`Unsupported remote location protocol for MCP-HTTP: ${t}`);return {type:"mcp-http",url:t,apiKey:e.apiKey,headers:e.headers,timeoutMs:e.timeout?.query??3e4,agentId:e.external_agent_id??o}}exports.RemoteProviderRuntime=void 0;var Yt=j(()=>{l();ye();Qt();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,r=ne){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let n=fs(e,t);this.manager.loadConfig(this.agentId,n);}async query(e,t){return (await this.manager.query(this.agentId,{agentId:this.agentId,query:e,model:t?.model,context:t?.context??t?.systemPrompt})).content.map(n=>n.text).join(`
|
|
28
|
+
${e}`:e}runProcess(e,t,r){return Xn(this.adapter.command,e,this.providerStr,this.providerId,t,r,this.adapter)}handleResultMeta(e,t){if(!this.adapter.parseResultMeta){let i=Jn(e);i&&t?.onUsage&&t.onUsage(i);return}let{usage:r,model:n}=this.adapter.parseResultMeta(e);r&&t?.onUsage&&t.onUsage(r);let s=n??(this.providerId==="opencode"?t?.model??null:null);s&&t?.onModel&&t.onModel(s);}};});var Ur,Wr;exports.VercelProviderRuntime=void 0;var Jt=j(()=>{l();ye();Ur=10,Wr=50,exports.VercelProviderRuntime=class{config;constructor(e){this.config=e;}async query(e,t){return this._run(e,"query",t)}async execute(e,t){return this._run(e,"execute",t)}async _run(e,t,r){let{generateText:n,tool:s}=await import('ai'),i=this.convertTools(r?.tools??[],s),a=this.createModel(r?.model),d=Math.min(r?.maxSteps??this.config.maxSteps??Ur,Wr);try{let c=0,u=await n({model:a,system:r?.systemPrompt??void 0,prompt:e,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens},onStepFinish:p=>{if(c++,!!r?.onOutput){if(p.toolCalls&&p.toolCalls.length>0)for(let f of p.toolCalls)r.onOutput(JSON.stringify({type:"assistant",message:{content:[{type:"tool_use",id:f.toolCallId,name:f.toolName,input:f.args}]}}),"stdout");if(p.toolResults&&p.toolResults.length>0)for(let f of p.toolResults){let y=typeof f.result=="string"?f.result:JSON.stringify(f.result);r.onOutput(JSON.stringify({type:"user",message:{content:[{type:"tool_result",tool_use_id:f.toolCallId,output:y,is_error:!1}]}}),"stdout");}}}}),g=new Set((r?.tools??[]).filter(p=>!p.execute).map(p=>p.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let p=u.toolCalls.filter(f=>g.has(f.toolName));if(p.length>0){let f=p[0];throw new exports.ClientToolCallRequiredError({toolCallId:f.toolCallId,toolName:f.toolName,args:f.args},{userMessage:e,responseMessages:u.response?.messages??[],toolDefinitions:r?.tools??[],maxSteps:d,systemPrompt:r?.systemPrompt,modelOverride:r?.model})}}if(r?.onUsage&&u.usage){let p={inputTokens:u.usage.promptTokens??0,outputTokens:u.usage.completionTokens??0,cachedInputTokens:0,costUsd:0};r.onUsage(p);}return r?.onModel&&r.onModel(r.model??this.config.model),u.text??""}catch(c){throw c instanceof exports.ClientToolCallRequiredError?c:c.status===401?new exports.ProviderError(`Authentication failed for ${this.config.provider}. Check your API key.`,this.config.provider):c.status===429?new exports.ProviderError(`Rate limit exceeded for ${this.config.provider}.`,this.config.provider):new exports.ProviderError(`Provider error: ${c.message}`,this.config.provider)}}async continueWithToolResults(e,t,r){let{generateText:n,tool:s}=await import('ai'),i=this.convertTools(e.toolDefinitions,s),a=this.createModel(e.modelOverride),d=Math.min(e.maxSteps??this.config.maxSteps??Ur,Wr),c=[{role:"user",content:e.userMessage},...e.responseMessages,{role:"tool",content:t.map(u=>({type:"tool-result",toolCallId:u.toolCallId,toolName:u.toolName,result:typeof u.result=="string"?u.result:JSON.stringify(u.result)}))}];try{let u=await n({model:a,system:e.systemPrompt??void 0,messages:c,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens}}),g=new Set(e.toolDefinitions.filter(p=>!p.execute).map(p=>p.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let p=u.toolCalls.filter(f=>g.has(f.toolName));if(p.length>0){let f=p[0];throw new exports.ClientToolCallRequiredError({toolCallId:f.toolCallId,toolName:f.toolName,args:f.args},{userMessage:e.userMessage,responseMessages:[...e.responseMessages,{role:"tool",content:t.map(y=>({type:"tool-result",toolCallId:y.toolCallId,toolName:y.toolName,result:typeof y.result=="string"?y.result:JSON.stringify(y.result)}))},...u.response?.messages??[]],toolDefinitions:e.toolDefinitions,maxSteps:e.maxSteps,systemPrompt:e.systemPrompt,modelOverride:e.modelOverride})}}return r?.onUsage&&u.usage&&r.onUsage({inputTokens:u.usage.promptTokens??0,outputTokens:u.usage.completionTokens??0,cachedInputTokens:0,costUsd:0}),r?.onModel&&r.onModel(e.modelOverride??this.config.model),u.text??""}catch(u){throw u instanceof exports.ClientToolCallRequiredError?u:new exports.ProviderError(`Provider error: ${u.message}`,this.config.provider)}}convertTools(e,t){let{z:r}=F("zod"),n={};for(let s of e){let i=this.jsonSchemaToZod(s.parameters??{},r);s.execute?n[s.name]=t({description:s.description,parameters:i,execute:async a=>s.execute(a)}):n[s.name]=t({description:s.description,parameters:i});}return n}jsonSchemaToZod(e,t){if(!e||!e.properties)return t.object({});let r={},n=e.properties,s=e.required??[];for(let[i,a]of Object.entries(n)){let d;switch(a.type){case "string":d=t.string();break;case "number":d=t.number();break;case "integer":d=t.number().int();break;case "boolean":d=t.boolean();break;case "array":d=t.array(t.any());break;default:d=t.any();}a.description&&(d=d.describe(a.description)),s.includes(i)||(d=d.optional()),r[i]=d;}return t.object(r)}createModel(e){let{provider:t,apiKey:r,baseURL:n}=this.config,s=e||this.config.model;switch(t){case "api/openrouter":{let{createOpenAI:i}=F("@ai-sdk/openai");return i({apiKey:r||process.env.OPENROUTER_API_KEY,baseURL:n||"https://openrouter.ai/api/v1"})(s)}case "api/openai":{let{createOpenAI:i}=F("@ai-sdk/openai");return i({apiKey:r||process.env.OPENAI_API_KEY,...n&&{baseURL:n}})(s)}case "api/anthropic":{let{createAnthropic:i}=F("@ai-sdk/anthropic");return i({apiKey:r||process.env.ANTHROPIC_API_KEY,...n&&{baseURL:n}})(s)}case "api/google":{let{createGoogleGenerativeAI:i}=F("@ai-sdk/google");return i({apiKey:r||process.env.GOOGLE_API_KEY})(s)}default:throw new exports.ProviderError(`Unsupported API provider: ${t}`,t)}}};});var zr={};kt(zr,{registerApiProviders:()=>Br});function Br(o){Te("api",(e,t)=>{let r=o?.apiKeys?.[e];return new exports.VercelProviderRuntime({provider:t,model:"",apiKey:r,maxSteps:o?.defaults?.maxSteps,temperature:o?.defaults?.temperature})});}var Xt=j(()=>{l();ye();Jt();});function is(o){if(!o)return o;let e=o.trim().replace(/\/+$/,"");return e.toLowerCase().endsWith("/mcp")?e.slice(0,-4):e}exports.McpHttpTransport=void 0;var Gt=j(()=>{l();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=is(e.url);this.endpoint=`${t}/mcp`,this.headers={"Content-Type":"application/json",...e.headers??{}},e.apiKey&&(this.headers.Authorization=`Bearer ${e.apiKey}`),this.timeoutMs=e.timeoutMs??3e4;}async send(e){let t=new AbortController,r=setTimeout(()=>t.abort(),this.timeoutMs);try{let n=await fetch(this.endpoint,{method:"POST",headers:this.headers,body:JSON.stringify(e),signal:t.signal});if(clearTimeout(r),!n.ok){let a=await n.text();throw new Error(`HTTP ${n.status}: ${n.statusText}${a?` - ${a}`:""}`)}let s=n.headers.get("content-type");if(s?.includes("application/json"))return await n.json();let i=await n.text();return {jsonrpc:"2.0",id:e.id,error:{code:-32600,message:`Unexpected response content-type: ${s}`,data:i}}}catch(n){throw clearTimeout(r),n instanceof Error&&n.name==="AbortError"?new Error(`MCP-HTTP request timeout after ${this.timeoutMs}ms to ${this.endpoint}`):n}}async close(){}};});exports.RemoteAgentManager=void 0;var Qt=j(()=>{l();Gt();exports.RemoteAgentManager=class{logger;configs=new Map;transports=new Map;constructor(e={}){this.logger=e.logger??(()=>{});}loadConfig(e,t){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,new exports.McpHttpTransport({url:t.url,apiKey:t.apiKey,headers:t.headers,timeoutMs:t.timeoutMs})),this.logger(`Loaded remote agent config for: ${e}`,"debug");}loadConfigWithTransport(e,t,r){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,r),this.logger(`Loaded remote agent config for: ${e} (custom transport)`,"debug");}getConfig(e){return this.configs.get(e)}isRemoteAgent(e){return this.configs.has(e)}getRemoteAgentIds(){return Array.from(this.configs.keys())}async query(e,t){let r=this.requireConfig(e),n=r.tools?.query??"crewx_queryAgent",i={agentId:r.agentId??e,query:t.query};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote query failed for agent ${e}: ${d}`,"error"),a}}async execute(e,t){let r=this.requireConfig(e),n=r.tools?.execute??"crewx_executeAgent",i={agentId:r.agentId??e,task:t.task};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote execute failed for agent ${e}: ${d}`,"error"),a}}mapToolNames(e,t){let r=this.requireConfig(e);r.tools={query:t.query??r.tools?.query??"crewx_queryAgent",execute:t.execute??r.tools?.execute??"crewx_executeAgent"},this.logger(`Updated tool name mapping for agent ${e}`,"debug");}async clearConfigs(){for(let e of this.transports.values())await e.close();this.configs.clear(),this.transports.clear(),this.logger("Cleared all remote agent configurations","debug");}requireConfig(e){let t=this.configs.get(e);if(!t)throw new Error(`Agent ${e} is not configured as a remote agent`);return t}async callRemoteTool(e,t,r){let n=this.transports.get(e);if(!n)throw new Error(`No transport available for agent ${e}`);let s={jsonrpc:"2.0",id:`${t}-${Date.now()}`,method:"tools/call",params:{name:t,arguments:r}};this.logger(`Calling remote MCP tool ${t} for agent ${e}`,"debug");let i=await n.send(s);if(i.error)throw new Error(i.error.message||"MCP server returned an error");return i.result}normalizeResponse(e){if(!e)return {success:false,content:[{type:"text",text:"Remote agent returned no response."}]};let t=e;if(Array.isArray(t.content)&&t.content.length>0)return t;let r=t.response??t.implementation??t.message??t.output,n=typeof r=="string"?r:JSON.stringify(r??e,null,2);return {...t,content:[{type:"text",text:n}]}}validateConfig(e){if(!e.url)throw new Error("Remote agent configuration requires a URL");if(!e.url.startsWith("http://")&&!e.url.startsWith("https://"))throw new Error("Remote agent URL must start with http:// or https://");if(e.type!=="mcp-http")throw new Error(`Unsupported remote agent type: ${e.type}`)}};});var Kr={};kt(Kr,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>Vr,resolveFileRemoteAgent:()=>ms});function ps(o){let e=fs$1.readFileSync(o,"utf-8"),t=jsYaml.load(e);return {agents:Array.isArray(t?.agents)?t.agents:void 0}}function gs(o){let e=Array.isArray(o.provider)?o.provider[0]:o.provider;return e||(Array.isArray(o.inline?.provider)?o.inline.provider[0]:o.inline?.provider)}function ms(o,e=ps,t=fs$1.existsSync){let r=o.location.replace("file://","");if(!t(r))throw new Error(`Remote config file not found: ${r}`);if(!o.external_agent_id)throw new Error(`external_agent_id is required for file:// remote provider "${o.id}"`);let s=e(r).agents?.find(d=>d.id===o.external_agent_id);if(!s)throw new Error(`Agent "${o.external_agent_id}" not found in ${r}`);let i=gs(s);if(!i)throw new Error(`Agent "${o.external_agent_id}" in ${r} has no provider configured`);if(i.startsWith("remote/"))throw new Error(`Chained remotes not allowed: ${o.id} \u2192 ${i}`);let a=H.resolve(H.dirname(r),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function Vr(o,e=ne){return (t,r)=>{let n=o.get(t);if(!n)throw new Error(`Remote provider "${t}" not found. Available: ${Array.from(o.keys()).join(", ")||"(none)"}`);if(n.location.startsWith("file://"))throw new Error(`Remote provider "${t}" uses file:// location which is not supported at the SDK level. Use the CLI commands (crewx query / crewx execute) which handle file:// remotes automatically.`);return new exports.RemoteProviderRuntime(t,n,e)}}function fs(o,e){let t=e.location;if(!t)throw new Error("Remote provider config requires a location");if(!t.startsWith("http://")&&!t.startsWith("https://"))throw new Error(`Unsupported remote location protocol for MCP-HTTP: ${t}`);return {type:"mcp-http",url:t,apiKey:e.apiKey,headers:e.headers,timeoutMs:e.timeout?.query??3e4,agentId:e.external_agent_id??o}}exports.RemoteProviderRuntime=void 0;var Yt=j(()=>{l();ye();Qt();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,r=ne){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let n=fs(e,t);this.manager.loadConfig(this.agentId,n);}async query(e,t){return (await this.manager.query(this.agentId,{agentId:this.agentId,query:e,model:t?.model,context:t?.context??t?.systemPrompt})).content.map(n=>n.text).join(`
|
|
29
29
|
`)}async execute(e,t){return (await this.manager.execute(this.agentId,{agentId:this.agentId,task:e,model:t?.model,context:t?.context??t?.systemPrompt})).content.map(n=>n.text).join(`
|
|
30
|
-
`)}};});var Qr={};kt(Qr,{PluginProviderRuntime:()=>exports.PluginProviderRuntime,createPluginProviderFactory:()=>Gr});function Gr(o){return (e,t)=>{let r=o.get(e);if(!r)throw new exports.ProviderError(`Plugin provider "${e}" not found. Available: ${Array.from(o.keys()).join(", ")||"(none)"}`,`plugin/${e}`);return new exports.PluginProviderRuntime(e,r)}}function Jr(o,e,t,r){let n=o.map(s=>s.replace(/\{model\}/g,e));return r&&n.push(t),n}function hs(o){if(!o||typeof o!="string")throw new Error("Plugin provider requires a cli_command")}function Xr(o){if(!Array.isArray(o))throw new Error("CLI arguments must be an array");for(let e of o)if(typeof e!="string")throw new Error("Each CLI argument must be a string")}function ws(o){for(let{pattern:e}of o)if(typeof e!="string")throw new Error("Error pattern must be a string")}function xs(o){for(let[e,t]of Object.entries(o))if(typeof e!="string"||typeof t!="string")throw new Error("env entries must be string key/value pairs")}exports.PluginProviderRuntime=void 0;var Zt=j(()=>{l();ye();ot();exports.PluginProviderRuntime=class{constructor(e,t){this.config=t;this.providerStr=`plugin/${e}`,hs(t.cli_command),Xr(t.query_args),Xr(t.execute_args),t.error_patterns&&ws(t.error_patterns),t.env&&xs(t.env);}config;providerStr;async query(e,t){let r=t?.model??this.config.default_model??"default",n=Jr(this.config.query_args,r,e,this.config.prompt_in_args),s=this.config.prompt_in_args?void 0:e;t?.onCommand?.(`${this.config.cli_command} ${n.join(" ")}`);let i=this.config.timeout?.query??6e5;return this.runProcess(n,t,s,i)}async execute(e,t){let r=t?.model??this.config.default_model??"default",n=Jr(this.config.execute_args,r,e,this.config.prompt_in_args),s=this.config.prompt_in_args?void 0:e;t?.onCommand?.(`${this.config.cli_command} ${n.join(" ")}`);let i=this.config.timeout?.execute??6e5;return this.runProcess(n,t,s,i)}runProcess(e,t,r,n){return new Promise((s,i)=>{let a={...process.env,...this.config.env??{}},d=Ie({command:this.config.cli_command,allowShellFallback:true}),
|
|
31
|
-
`);f=w.pop()??"";for(let b of w)b.trim()&&t?.onOutput?.(b,"stdout");}),
|
|
32
|
-
`);y=w.pop()??"";for(let b of w)b.trim()&&t?.onOutput?.(b,"stderr");});let R=setTimeout(()=>{
|
|
30
|
+
`)}};});var Qr={};kt(Qr,{PluginProviderRuntime:()=>exports.PluginProviderRuntime,createPluginProviderFactory:()=>Gr});function Gr(o){return (e,t)=>{let r=o.get(e);if(!r)throw new exports.ProviderError(`Plugin provider "${e}" not found. Available: ${Array.from(o.keys()).join(", ")||"(none)"}`,`plugin/${e}`);return new exports.PluginProviderRuntime(e,r)}}function Jr(o,e,t,r){let n=o.map(s=>s.replace(/\{model\}/g,e));return r&&n.push(t),n}function hs(o){if(!o||typeof o!="string")throw new Error("Plugin provider requires a cli_command")}function Xr(o){if(!Array.isArray(o))throw new Error("CLI arguments must be an array");for(let e of o)if(typeof e!="string")throw new Error("Each CLI argument must be a string")}function ws(o){for(let{pattern:e}of o)if(typeof e!="string")throw new Error("Error pattern must be a string")}function xs(o){for(let[e,t]of Object.entries(o))if(typeof e!="string"||typeof t!="string")throw new Error("env entries must be string key/value pairs")}exports.PluginProviderRuntime=void 0;var Zt=j(()=>{l();ye();ot();exports.PluginProviderRuntime=class{constructor(e,t){this.config=t;this.providerStr=`plugin/${e}`,hs(t.cli_command),Xr(t.query_args),Xr(t.execute_args),t.error_patterns&&ws(t.error_patterns),t.env&&xs(t.env);}config;providerStr;async query(e,t){let r=t?.model??this.config.default_model??"default",n=Jr(this.config.query_args,r,e,this.config.prompt_in_args),s=this.config.prompt_in_args?void 0:e;t?.onCommand?.(`${this.config.cli_command} ${n.join(" ")}`);let i=this.config.timeout?.query??6e5;return this.runProcess(n,t,s,i)}async execute(e,t){let r=t?.model??this.config.default_model??"default",n=Jr(this.config.execute_args,r,e,this.config.prompt_in_args),s=this.config.prompt_in_args?void 0:e;t?.onCommand?.(`${this.config.cli_command} ${n.join(" ")}`);let i=this.config.timeout?.execute??6e5;return this.runProcess(n,t,s,i)}runProcess(e,t,r,n){return new Promise((s,i)=>{let a={...process.env,...this.config.env??{}},d=Ie({command:this.config.cli_command,allowShellFallback:true}),c=Oe(d,e),u=child_process.spawn(c.command,c.argv,{env:a,shell:c.shell??false,stdio:["pipe","pipe","pipe"],windowsHide:c.windowsHide});r!==void 0&&u.stdin.write(r),u.stdin.end(),u.pid!==void 0&&t?.onPid?.(u.pid);let g="",p="",f="",y="";u.stdout.on("data",x=>{let _=x.toString();g+=_,f+=_;let w=f.split(`
|
|
31
|
+
`);f=w.pop()??"";for(let b of w)b.trim()&&t?.onOutput?.(b,"stdout");}),u.stderr.on("data",x=>{let _=x.toString();p+=_,y+=_;let w=y.split(`
|
|
32
|
+
`);y=w.pop()??"";for(let b of w)b.trim()&&t?.onOutput?.(b,"stderr");});let R=setTimeout(()=>{u.kill("SIGTERM"),i(new exports.ProviderError(`Plugin provider "${this.providerStr}" timed out after ${n}ms`,this.providerStr));},n);u.on("error",x=>{if(clearTimeout(R),x.code==="ENOENT"){let _=this.config.not_installed_message??`CLI command "${this.config.cli_command}" not found. Is ${this.config.id} installed?`;i(new exports.ProviderError(_,this.providerStr));}else i(new exports.ProviderError(`Spawn error: ${x.message}`,this.providerStr));}),u.on("close",x=>{clearTimeout(R),f.trim()&&t?.onOutput?.(f,"stdout"),y.trim()&&t?.onOutput?.(y,"stderr");let _=x??0;if(t?.onExitCode?.(_),this.config.error_patterns){let w=p||g;for(let b of this.config.error_patterns)if(w.includes(b.pattern)){i(new exports.ProviderError(b.message,this.providerStr));return}}if(x!==0){i(new exports.ProviderError(`Process exited with code ${x}: ${p.slice(0,500)}`,this.providerStr));return}s(g.trim());});})}};});l();l();l();function _n(o){let e=n=>n.replace(/[.+^${}()|[\]\\]/g,"\\$&"),r=o.split("/").map(n=>n==="**"?".*":n.split("*").map(e).join("[^/]*"));return new RegExp(`^${r.join("\\/")}$`)}function Q(o,e){try{return _n(e).test(o)}catch{return false}}l();l();var Rn=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()),ur=zod.z.object({include:zod.z.array(zod.z.string()).optional()}).optional(),Pn=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:Rn.optional(),skills:ur}).catchall(zod.z.unknown()),pr=zod.z.object({agents:zod.z.array(Pn).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 ge=class extends Error{constructor(t,r){super(t);this.cause=r;this.name="ConfigLoadError";}cause};function Ye(o){if(!o||typeof o!="string"||!o.trim())throw new ge("YAML content must be a non-empty string");let e;try{e=jsYaml.load(o);}catch(n){throw new ge(`YAML parse error: ${n.message}`,n)}let t=An(e),r=pr.safeParse(t);if(!r.success)throw new ge(`Config validation error: ${r.error.message}`);return r.data}function Ze(o){let e;try{e=fs$1.readFileSync(o,"utf-8");}catch(t){throw new ge(`Cannot read file: ${o}`,t)}return Ye(e)}function An(o){if(!o||typeof o!="object")return {agents:[]};let e=o,t;if(e.agents&&typeof e.agents=="object"&&!Array.isArray(e.agents)){let n=e.agents;t=Object.entries(n).map(([s,i])=>({id:s,...i&&typeof i=="object"?i:{}}));}else if(Array.isArray(e.agents))t=e.agents;else return {...e,agents:[]};let r=t.map(n=>{if(n.provider===void 0&&n.inline&&typeof n.inline=="object"){let s=n.inline;if(s.provider!==void 0)return {...n,provider:s.provider}}return n});return {...e,agents:r}}l();var me=H.join("templates","agents");function Sn(){try{let e=(typeof F=="function"?F:module$1.createRequire(typeof __filename<"u"?__filename:process.cwd()+"/")).resolve("@crewx/sdk/package.json");return H.dirname(e)}catch{return null}}function Pe(o){if(o&&fs$1.existsSync(o))return o;let e=process.env.CREWX_SDK_TEMPLATES_PATH;if(e&&fs$1.existsSync(e))return e;let t=Sn();if(t){let n=H.join(t,me);if(fs$1.existsSync(n))return n}let r=[H.join(__dirname,"..",me),H.join(__dirname,"..","..",me),H.join(__dirname,"..","..","..",me),H.join(process.cwd(),"packages","sdk",me),H.join(process.cwd(),me)];for(let n of r)if(fs$1.existsSync(n))return n;throw new Error(`[@crewx/sdk] Templates directory not found.
|
|
33
33
|
`+(t?` package anchor: ${H.join(t,me)}
|
|
34
34
|
`:` package anchor: (unresolved)
|
|
35
35
|
`)+r.map(n=>` candidate: ${n}`).join(`
|
|
36
36
|
`)+`
|
|
37
|
-
Set CREWX_SDK_TEMPLATES_PATH or pass options.templatesPath.`)}function _t(){let o=Pe();return {yamlPath:H.join(o,"default.yaml"),dir:o}}l();var re=class extends Error{constructor(e,t){let r=t.length>0?` Available: ${t.join(", ")}`:"";super(`Agent not found: "${e}".${r}`),this.name="AgentNotFoundError";}},In={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(o,e){let t=o.startsWith("@")?o.slice(1):o,r=e.find(s=>s.id===t);if(r)return r;let n=In[t];if(n)return n;throw new re(o,e.map(s=>s.id))}ye();l();function hr(o,e){if(o===void 0||o==="")return e;let t=parseInt(o,10);return Number.isNaN(t)?e:t}function wr(o=process.env){return {queryMs:hr(o.CREWX_TIMEOUT_QUERY,36e5),executeMs:hr(o.CREWX_TIMEOUT_EXECUTE,36e5)}}l();l();var Qn=[/^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],Yn=/[;|&`$(){}!><\n\r]/,Zn=2,eo=["*","**","*:*","* *","**/*"];function to(){let o={};for(let[e,t]of Object.entries(process.env))t!==void 0&&(Qn.some(r=>r.test(e))||(o[e]=t));return o}function ro(o){if(Yn.test(o))throw new Error(`exec blocked: shell metacharacter detected in "${o}"`)}function no(o){return /^npx\s+@crewx\/[\w-]+/.test(o)}function oo(o){if(eo.includes(o.trim()))throw new Error(`exec config error: overly broad pattern "${o}" is not allowed`);if(!/^[\w./@-]/.test(o))throw new Error("exec config error: pattern must start with a command name")}function so(o,e){let t=e.allow??[],r=e.deny??[];for(let n of [...t,...r])oo(n);return r.some(n=>Q(o,n))?false:no(o)?true:t.some(n=>Q(o,n))}var xr=false;function io(o){xr=o;}function De(o){if(!xr)return;let e=JSON.stringify({span:"template_exec",...o,timestamp:new Date().toISOString()});console.error(e);}function ao(o){let e=[],t="",r=false,n=false;for(let s=0;s<o.length;s++){let i=o[s];i==="'"&&!n?r=!r:i==='"'&&!r?n=!n:i===" "&&!r&&!n?t.length>0&&(e.push(t),t=""):t+=i;}return t.length>0&&e.push(t),e}function vr(o,e){let t=Date.now(),r=parseInt(process.env.CREWX_EXEC_DEPTH??"0",10);if(isNaN(r)||r>=Zn)return De({command:o,status:"denied",reason:"invalid or max recursion depth"}),"(exec blocked: max recursion depth reached)";try{ro(o);}catch{return De({command:o,status:"denied",reason:"shell metacharacter detected"}),`(exec blocked: shell metacharacter detected in "${o}")`}if(!so(o,e))return De({command:o,status:"denied",reason:"not in allow list"}),`(exec blocked: ${o})`;try{let n=ao(o),[s,...i]=n;if(!s)return `(exec failed: ${o})`;let a=to(),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"]}),
|
|
37
|
+
Set CREWX_SDK_TEMPLATES_PATH or pass options.templatesPath.`)}function _t(){let o=Pe();return {yamlPath:H.join(o,"default.yaml"),dir:o}}l();var re=class extends Error{constructor(e,t){let r=t.length>0?` Available: ${t.join(", ")}`:"";super(`Agent not found: "${e}".${r}`),this.name="AgentNotFoundError";}},In={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(o,e){let t=o.startsWith("@")?o.slice(1):o,r=e.find(s=>s.id===t);if(r)return r;let n=In[t];if(n)return n;throw new re(o,e.map(s=>s.id))}ye();l();function hr(o,e){if(o===void 0||o==="")return e;let t=parseInt(o,10);return Number.isNaN(t)?e:t}function wr(o=process.env){return {queryMs:hr(o.CREWX_TIMEOUT_QUERY,36e5),executeMs:hr(o.CREWX_TIMEOUT_EXECUTE,36e5)}}l();l();var Qn=[/^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],Yn=/[;|&`$(){}!><\n\r]/,Zn=2,eo=["*","**","*:*","* *","**/*"];function to(){let o={};for(let[e,t]of Object.entries(process.env))t!==void 0&&(Qn.some(r=>r.test(e))||(o[e]=t));return o}function ro(o){if(Yn.test(o))throw new Error(`exec blocked: shell metacharacter detected in "${o}"`)}function no(o){return /^npx\s+@crewx\/[\w-]+/.test(o)}function oo(o){if(eo.includes(o.trim()))throw new Error(`exec config error: overly broad pattern "${o}" is not allowed`);if(!/^[\w./@-]/.test(o))throw new Error("exec config error: pattern must start with a command name")}function so(o,e){let t=e.allow??[],r=e.deny??[];for(let n of [...t,...r])oo(n);return r.some(n=>Q(o,n))?false:no(o)?true:t.some(n=>Q(o,n))}var xr=false;function io(o){xr=o;}function De(o){if(!xr)return;let e=JSON.stringify({span:"template_exec",...o,timestamp:new Date().toISOString()});console.error(e);}function ao(o){let e=[],t="",r=false,n=false;for(let s=0;s<o.length;s++){let i=o[s];i==="'"&&!n?r=!r:i==='"'&&!r?n=!n:i===" "&&!r&&!n?t.length>0&&(e.push(t),t=""):t+=i;}return t.length>0&&e.push(t),e}function vr(o,e){let t=Date.now(),r=parseInt(process.env.CREWX_EXEC_DEPTH??"0",10);if(isNaN(r)||r>=Zn)return De({command:o,status:"denied",reason:"invalid or max recursion depth"}),"(exec blocked: max recursion depth reached)";try{ro(o);}catch{return De({command:o,status:"denied",reason:"shell metacharacter detected"}),`(exec blocked: shell metacharacter detected in "${o}")`}if(!so(o,e))return De({command:o,status:"denied",reason:"not in allow list"}),`(exec blocked: ${o})`;try{let n=ao(o),[s,...i]=n;if(!s)return `(exec failed: ${o})`;let a=to(),d=child_process.execFileSync(s,i,{timeout:e.timeout??5e3,maxBuffer:64*1024,encoding:"utf-8",env:{...a,CREWX_EXEC_DEPTH:String(r+1)},stdio:["pipe","pipe","pipe"]}),c=Date.now()-t;return De({command:o,status:"allowed",allowed_by:"policy",duration_ms:c}),`<exec-output cmd="${o}">
|
|
38
38
|
${d.trim()}
|
|
39
39
|
</exec-output>`}catch{return De({command:o,status:"error",reason:"execution failed"}),`(exec failed: ${o})`}}l();function kr(o){return o==null?"":String(o)}l();function _r(o,e){return `\`\`\`${e?.hash?.lang??""}
|
|
40
40
|
${o??""}
|
|
41
41
|
\`\`\``}l();function Ot(o,e){if(!o)return "";if(o.length<=e)return o;let t=o.length-e;return `${o.substring(0,e)} (...+${t} chars)`}function Mt(o){return Array.isArray(o)||typeof o=="string"?o.length:0}function Dt(o){return typeof o!="string"?"":o.replace(/\{\{/g,"{{").replace(/\}\}/g,"}}")}var Rr=["B","KB","MB","GB"];function Nt(o){if(o===0)return "0 B";let e=Math.min(Math.floor(Math.log(o)/Math.log(1024)),Rr.length-1);return `${Math.round(o/Math.pow(1024,e)*100)/100} ${Rr[e]}`}function Lt(o){if(!o)return "";try{let e=o instanceof Date?o:new Date(o);return isNaN(e.getTime())?"":e.toLocaleString("ko-KR",{year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1})}catch{return ""}}var Ne=class{hbs;execPolicy;execEnabled;constructor(e={}){this.hbs=Y__namespace.create(),this.execPolicy=e.execPolicy??{allow:[],deny:[]},this.execEnabled=e.execEnabled??true,this.registerHelpers();}registerHelpers(){let e=this.hbs,t=this.execPolicy,r=this.execEnabled;e.registerHelper("exec",function(n){return typeof n!="string"?"":r?new e.SafeString(vr(n,t)):"(exec disabled)"}),e.registerHelper("include",function(n){return new e.SafeString(kr(n))}),e.registerHelper("fenced_code",function(n,s){return new e.SafeString(_r(n,s))}),e.registerHelper("eq",function(n,s){return n===s}),e.registerHelper("ne",function(n,s){return n!==s}),e.registerHelper("and",function(n,s){return n&&s}),e.registerHelper("or",function(n,s){return n||s}),e.registerHelper("not",function(n){return !n}),e.registerHelper("contains",function(n,s){return Array.isArray(n)&&n.includes(s)}),e.registerHelper("json",function(n){return JSON.stringify(n,null,2)}),e.registerHelper("truncate",function(n,s){return Ot(n,s)}),e.registerHelper("length",function(n){return Mt(n)}),e.registerHelper("escapeHandlebars",function(n){return new e.SafeString(Dt(n))}),e.registerHelper("formatFileSize",function(n){return Nt(n)}),e.registerHelper("formatTimestamp",function(n){return Lt(n)});}async render(e,t={}){return this.hbs.compile(e,{noEscape:true})(t)}};l();l();var ct=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?H.resolve(e[0]):H.resolve(H.join(...e))}isAbsolute(e){return H.isAbsolute(e)}},$t=new ct;var he=class{docs=new Map;fs;constructor(e){this.fs=e??$t;}async load(e,t){if(e)for(let[r,n]of Object.entries(e)){let s=n;if(typeof s=="string")this.docs.set(r,{content:s});else if(s&&typeof s=="object"){let i=s;"content"in i&&typeof i.content=="string"?this.docs.set(r,{content:i.content}):"path"in i&&typeof i.path=="string"?await this.loadFromFile(r,i.path,t):console.warn(`[DocumentLoader] Skipping '${r}': unsupported format`);}else console.warn(`[DocumentLoader] Skipping '${r}': unsupported format`);}}async getContent(e){return this.docs.get(e)?.content}async getToc(e){let t=this.docs.get(e);if(!t)return;let r=[];for(let n of t.content.split(`
|
|
42
42
|
`)){let s=/^(#{1,6})\s+(.+)$/.exec(n.trim());s&&r.push({depth:s[1].length,text:s[2].trim()});}if(r.length!==0)return r.map(({depth:n,text:s})=>`${" ".repeat(n-1)}- ${s}`).join(`
|
|
43
|
-
`)}getPath(e){return this.docs.get(e)?.path}getNames(){return Array.from(this.docs.keys())}async buildContext(){let e={};for(let t of this.docs.keys()){let r=await this.getContent(t)??"",n=await this.getToc(t),s=this.getPath(t);e[t]={content:r,toc:n,...s?{path:s}:{}};}return e}async loadFromFile(e,t,r){try{let n=this.resolve(t,r),s=await this.fs.readFile(n);this.docs.set(e,{content:s,path:n});}catch(n){let s=n instanceof Error?n.message:String(n);console.warn(`[DocumentLoader] Failed to load '${e}' from '${t}': ${s}`);}}resolve(e,t){return this.fs.isAbsolute(e)?e:t?this.fs.resolvePath(t,e):this.fs.resolvePath(e)}};l();l();var q=class extends Error{constructor(t,r,n){super(t);this.layoutId=r;this.cause=n;this.name="LayoutLoadError";}layoutId;cause},oe=class extends Error{constructor(t,r=[],n){super(t);this.errors=r;this.cause=n;this.name="PropsValidationError";}errors;cause};var ho={validationMode:"lenient",fallbackLayoutId:"crewx/default"},Le=class{layouts=new Map;options;constructor(e){this.options={...ho,...e,templatesPath:e?.templatesPath??Pe()},this.loadAllLayouts();}load(e,t){let r=this.layouts.get(e);if(!r){let n=this.normalizeLayoutId(e);r=this.layouts.get(n);}if(!r&&(console.warn(`Layout not found: ${e}, falling back to ${this.options.fallbackLayoutId}`),r=this.layouts.get(this.options.fallbackLayoutId),!r))throw new q(`Fallback layout not found: ${this.options.fallbackLayoutId}`,this.options.fallbackLayoutId);return t&&Object.keys(t).length>0?{...r,defaultProps:{...r.defaultProps,...t}}:r}getLayoutIds(){return Array.from(this.layouts.keys())}hasLayout(e){if(this.layouts.has(e))return true;let t=this.normalizeLayoutId(e);return this.layouts.has(t)}reload(){this.layouts.clear(),this.loadAllLayouts();}registerLayout(e,t){if(!e||typeof e!="string")throw new q("Layout ID must be a non-empty string",e);let r=typeof t=="string"?{template:t}:t,n=typeof r.template=="string"?r.template:"";if(!n||n.trim().length===0)throw new q(`Custom layout template is empty for ${e}`,e);let s=r.propsSchema||{},i=this.extractDefaultProps(s),a=r.defaultProps||{},d={id:e,version:r.version||"1.0.0",description:r.description||`Custom layout ${e}`,template:n,propsSchema:this.parsePropsSchema(s),defaultProps:{...i,...a}},u=this.layouts.get(e),c=u?.template===n&&JSON.stringify(u?.defaultProps??{})===JSON.stringify(d.defaultProps??{})&&JSON.stringify(u?.propsSchema??{})===JSON.stringify(d.propsSchema??{});this.layouts.set(e,d),process.env.CREWX_VERBOSE==="1"&&(u?c||console.error(`Updated custom layout: ${e}`):console.error(`Registered custom layout: ${e}`));}registerLayouts(e){for(let[t,r]of Object.entries(e))try{this.registerLayout(t,r);}catch(n){console.warn(`Failed to register custom layout ${t}:`,n instanceof Error?n.message:n);}}loadAllLayouts(){let e=this.options.templatesPath;if(!fs$1.existsSync(e))throw new q(`Templates directory not found: ${e}`,void 0,new Error(`Directory does not exist: ${e}`));try{let t=fs$1.readdirSync(e).filter(r=>r.endsWith(".yaml")||r.endsWith(".yml"));t.length===0&&console.warn(`No layout files found in ${e}`);for(let r of t){let n=r.replace(/\.(yaml|yml)$/,""),s=H__namespace.join(e,r);try{let i=this.loadLayoutFile(s,n),a=`crewx/${n}`;this.layouts.set(a,i),a!=="crewx/minimal"&&process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded layout: ${a} from ${r}`);}catch(i){console.error(`Failed to load layout file ${r}:`,i);}}process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded ${this.layouts.size} layouts from ${e}`);}catch(t){throw new q(`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 q(`Empty YAML file: ${e}`,t,new Error("File content is empty"));let n=jsYaml.load(r);if(!n||typeof n!="object")throw console.warn(`Invalid YAML content in ${e} (parsed as ${typeof n}), will use fallback`),new q(`Invalid or empty YAML in ${e}`,t,new Error("YAML parsing returned null/undefined or non-object"));if(n.layouts&&typeof n.layouts=="object"){let s=this.resolveLayoutEntry(n.layouts,t);if(!s||s.template.trim().length===0)throw console.warn(`Empty or missing layout template in ${e} for ${t}`),new q(`Layout template not found or empty in layouts map: ${t}`,t);let i=s.propsSchema||n.propsSchema||{};return {id:`crewx/${t}`,version:n.version||"1.0.0",description:n.description||`CrewX ${t} layout`,template:s.template,propsSchema:this.parsePropsSchema(i),defaultProps:this.extractDefaultProps(i)}}else {if(!n.template||typeof n.template=="string"&&n.template.trim().length===0)throw console.warn(`Empty or missing template field in ${e}`),new q(`Layout template is missing or empty in ${e}`,t);return {id:n.id||`crewx/${t}`,version:n.version||"1.0.0",description:n.description||"",template:n.template,propsSchema:this.parsePropsSchema(n.propsSchema||{}),defaultProps:this.extractDefaultProps(n.propsSchema||{})}}}catch(r){throw new q(`Failed to load layout file: ${e}`,t,r instanceof Error?r:new Error(String(r)))}}parsePropsSchema(e){let t={};for(let[r,n]of Object.entries(e))typeof n=="object"&&n!==null&&(t[r]=n);return t}extractDefaultProps(e){let t={};for(let[r,n]of Object.entries(e))n&&typeof n=="object"&&("defaultValue"in n?t[r]=n.defaultValue:"default"in n&&(t[r]=n.default));return t}normalizeLayoutId(e){return e?e.includes("/")?e:`crewx/${e}`:this.options.fallbackLayoutId}resolveLayoutEntry(e,t){let r=new Set;if(t)if(r.add(t),t.includes("/")){let n=t.split("/"),s=n[n.length-1];s&&r.add(s);}else r.add(`crewx/${t}`);r.add("default");for(let n of r){let s=e[n];if(typeof s=="string"&&s.trim().length>0)return {template:s};if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}for(let n of Object.values(e)){if(typeof n=="string"&&n.trim().length>0)return {template:n};let s=n;if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}}};l();l();function wo(o){return Array.from(new Set(o.filter(e=>e?.isAssistant&&e?.metadata?.agent_id).map(e=>String(e.metadata.agent_id))))}function Ar(o,e,t){if(!Array.isArray(o)||o.length===0||!(t&&typeof t.fn=="function"))return "";let n=wo(o),s=n.length>0?n[0]:"",i={messages:o,platform:typeof e=="string"?e:"",messagesCount:o.length,agentIds:n,primaryAgentId:s};return t.fn(i)}l();var $e=class{defaultMode;constructor(e={}){this.defaultMode=e.defaultMode??"lenient";}validate(e,t,r=this.defaultMode){let n=[],s=this.validateObject(e??{},t,r,["props"],n);if(n.length>0&&r==="strict")throw new oe("Props validation failed in strict mode",n);return {valid:n.length===0,props:s,errors:n}}validateObject(e,t,r,n,s){let i={};if(r==="strict")for(let a of Object.keys(e))t[a]||s.push({path:this.buildPath([...n,a]),message:`Unknown prop '${a}'`,value:e[a]});for(let[a,d]of Object.entries(t)){let u=[...n,a],c=e[a],p=this.resolveProp(c,d,u,r,s);p.shouldAssign&&(i[a]=p.value);}return i}resolveProp(e,t,r,n,s){let i=this.buildPath(r);if(this.isNil(e)){if(t.isRequired&&s.push({path:i,message:`Required prop '${r[r.length-1]}' is missing`}),t.defaultValue!==void 0)return {shouldAssign:true,value:this.cloneValue(t.defaultValue)};if(t.type==="shape"&&t.shape){let d=this.applyDefaults(t.shape);if(Object.keys(d).length>0)return {shouldAssign:true,value:d}}return {shouldAssign:false}}let a=this.validateType(e,t,r,n,s);if(!a.valid){if(t.type==="shape"&&a.value&&this.isPlainObject(a.value))return {shouldAssign:true,value:a.value};if(s.push({path:i,message:a.error??"Invalid value",value:e}),t.defaultValue!==void 0)return {shouldAssign:true,value:this.cloneValue(t.defaultValue)};if(t.type==="shape"&&t.shape){let d=this.applyDefaults(t.shape);if(Object.keys(d).length>0)return {shouldAssign:true,value:d}}return {shouldAssign:false}}return {shouldAssign:true,value:a.value}}validateType(e,t,r,n,s){let{type:i}=t;switch(i){case "string":return this.validateString(e,t);case "number":return this.validateNumber(e,t);case "bool":return this.validateBoolean(e);case "array":return this.validateArray(e,t);case "arrayOf":return this.validateArrayOf(e,t,r,n,s);case "object":return this.validatePlainObject(e);case "shape":return this.validateShape(e,t,r,n,s);case "oneOfType":return this.validateOneOfType(e,t);case "func":return this.validateFunction(e);case "node":return {valid:true,value:e};default:return {valid:true,value:e}}}validateString(e,t){return typeof e!="string"?{valid:false,error:`Expected string, got ${this.describeType(e)}`}:t.oneOf&&!t.oneOf.includes(e)?{valid:false,error:`Expected one of: ${t.oneOf.join(", ")}`}:t.minLength!==void 0&&e.length<t.minLength?{valid:false,error:`String length must be >= ${t.minLength}`}:t.maxLength!==void 0&&e.length>t.maxLength?{valid:false,error:`String length must be <= ${t.maxLength}`}:t.pattern&&!new RegExp(t.pattern).test(e)?{valid:false,error:`String does not match pattern ${t.pattern}`}:{valid:true,value:e}}validateNumber(e,t){return typeof e!="number"||Number.isNaN(e)?{valid:false,error:`Expected number, got ${this.describeType(e)}`}:t.min!==void 0&&e<t.min?{valid:false,error:`Number must be >= ${t.min}`}:t.max!==void 0&&e>t.max?{valid:false,error:`Number must be <= ${t.max}`}:t.oneOf&&!t.oneOf.includes(e)?{valid:false,error:`Expected one of: ${t.oneOf.join(", ")}`}:{valid:true,value:e}}validateBoolean(e){return typeof e!="boolean"?{valid:false,error:`Expected boolean, got ${this.describeType(e)}`}:{valid:true,value:e}}validateArray(e,t){return Array.isArray(e)?t.minLength!==void 0&&e.length<t.minLength?{valid:false,error:`Array length must be >= ${t.minLength}`}:t.maxLength!==void 0&&e.length>t.maxLength?{valid:false,error:`Array length must be <= ${t.maxLength}`}:{valid:true,value:[...e]}:{valid:false,error:`Expected array, got ${this.describeType(e)}`}}validateArrayOf(e,t,r,n,s){let i=this.validateArray(e,t);if(!i.valid)return i;let a=[],d=t.itemType,u=t.itemOneOf,c=s.length;return i.value.forEach((p,g)=>{let f=[...r,String(g)];if(d){let y=this.validateType(p,{type:d},f,n,s);y.valid?a.push(y.value):s.push({path:this.buildPath(f),message:y.error??"Invalid array item",value:p});}else a.push(p);u&&!u.includes(p)&&s.push({path:this.buildPath(f),message:`Array item must be one of: ${u.join(", ")}`,value:p});}),{valid:s.length===c,value:a}}validatePlainObject(e){return this.isPlainObject(e)?{valid:true,value:{...e}}:{valid:false,error:`Expected object, got ${this.describeType(e)}`}}validateFunction(e){return typeof e!="function"?{valid:false,error:`Expected function, got ${this.describeType(e)}`}:{valid:true,value:e}}validateShape(e,t,r,n,s){if(!this.isPlainObject(e))return {valid:false,error:`Expected object, got ${this.describeType(e)}`};let i=s.length,a=this.validateObject(e,t.shape??{},n,r,s);return {valid:s.length===i,value:a}}validateOneOfType(e,t){let r=t.types??[];return r.some(s=>this.matchesType(e,s))?{valid:true,value:e}:{valid:false,error:`Value does not match any allowed type: ${r.join(", ")}`}}matchesType(e,t){switch(t){case "string":return typeof e=="string";case "number":return typeof e=="number"&&!Number.isNaN(e);case "bool":case "boolean":return typeof e=="boolean";case "array":return Array.isArray(e);case "object":return this.isPlainObject(e);case "func":case "function":return typeof e=="function";case "shape":return this.isPlainObject(e);case "node":return e==null||typeof e!="symbol";default:return true}}applyDefaults(e){let t={};for(let[r,n]of Object.entries(e)){if(n.defaultValue!==void 0){t[r]=this.cloneValue(n.defaultValue);continue}if(n.type==="shape"&&n.shape){let s=this.applyDefaults(n.shape);Object.keys(s).length>0&&(t[r]=s);}}return t}cloneValue(e){if(Array.isArray(e))return e.map(t=>this.cloneValue(t));if(this.isPlainObject(e)){let t={};for(let[r,n]of Object.entries(e))t[r]=this.cloneValue(n);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}isNil(e){return e==null}buildPath(e){return e.join(".")}describeType(e){return Array.isArray(e)?"array":e===null?"null":typeof e}};var je=class{handlebars;propsValidator;constructor(e){this.handlebars=Y__namespace.default.create(),this.propsValidator=e??new $e,this.registerHelpers();}render(e,t,r={}){try{let n=this.prepareRenderContext(e,t,r);return this.handlebars.compile(e.template,{noEscape:!0})(n)}catch(n){throw n instanceof Error?new Error(`Template rendering failed for layout '${e.id}': ${n.message}`):new Error(`Unknown error rendering layout '${e.id}'`)}}validate(e,t,r="lenient"){return this.executeValidation(e,t,r)}resolveProps(e,t,r="lenient"){let n=this.mergeProps(e.defaultProps,t);return !e.propsSchema||Object.keys(e.propsSchema).length===0?{valid:true,props:n,errors:[]}:this.executeValidation(n,e.propsSchema,r)}prepareRenderContext(e,t,r){let{validationMode:n="lenient",skipValidation:s=false}=r,i=s?this.mergeProps(e.defaultProps,t.props):this.resolveProps(e,t.props,n).props;return {...t,vars:this.sanitizeVars(t.vars),props:i}}registerHelpers(){this.handlebars.registerHelper("formatConversation",Ar),Y__namespace.default.helpers.each&&this.handlebars.registerHelper("each",Y__namespace.default.helpers.each),Y__namespace.default.helpers.if&&this.handlebars.registerHelper("if",Y__namespace.default.helpers.if),Y__namespace.default.helpers.unless&&this.handlebars.registerHelper("unless",Y__namespace.default.helpers.unless),Y__namespace.default.helpers.with&&this.handlebars.registerHelper("with",Y__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 Y__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(n){if(n instanceof oe&&n.errors&&n.errors.length>0){let s=n.errors[0];if(s)throw new oe(s.message,n.errors)}throw n}}mergeProps(e,t){let r=this.cloneDeep(e??{});return t?this.deepMerge(r,t):r}deepMerge(e,t){for(let[r,n]of Object.entries(t)){if(this.isPlainObject(n)){let s=e[r];e[r]=this.deepMerge(this.isPlainObject(s)?s:{},n);continue}if(Array.isArray(n)){e[r]=this.cloneDeep(n);continue}e[r]=n;}return e}cloneDeep(e){if(Array.isArray(e))return e.map(t=>this.cloneDeep(t));if(this.isPlainObject(e)){let t={};for(let[r,n]of Object.entries(e))t[r]=this.cloneDeep(n);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}sanitizeVars(e){if(!e)return {};let t={...e};if(typeof e.user_input=="string"){t.user_input_raw=e.user_input;let r=e.user_input.replace(/\{\{\{/g,"{{{").replace(/\}\}\}/g,"}}}").replace(/\{\{/g,"{{").replace(/\}\}/g,"}}");t.user_input=this.handlebars.escapeExpression(r);}return t}};l();var jt="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function xo(o){let e=crypto$1.randomBytes(o*2),t="";for(let r=0;r<e.length&&t.length<o;r++){let n=e[r];n<248&&(t+=jt[n%62]);}for(;t.length<o;)t+=jt[crypto$1.randomBytes(1)[0]%62];return t}function we(o){return `${o}_${xo(8)}`}function vo(o,e){let{createHash:t}=F("crypto"),r=t("sha256").update(e).digest(),n=Buffer.alloc(8);for(let i=0;i<32;i++)n[i%8]^=r[i];let s="";for(let i of n)s+=jt[i%62];return `${o}_${s}`}l();function Ht(o){let e=t=>String(t).padStart(2,"0");return `${o.getFullYear()}${e(o.getMonth()+1)}${e(o.getDate())}T${e(o.getHours())}${e(o.getMinutes())}${e(o.getSeconds())}`}l();function Er(o,e){return t=>{try{let r=e(t);r instanceof Promise&&r.catch(n=>{console.error(`[crewx] event listener error (${o}): ${n instanceof Error?n.message:String(n)}`);});}catch(r){console.error(`[crewx] event listener error (${o}): ${r instanceof Error?r.message:String(r)}`);}}}var He=class{_emitter=new events.EventEmitter;on(e,t){let r=Er(e,t);return this._emitter.on(e,r),()=>this._emitter.off(e,r)}once(e,t){let r=Er(e,t);return this._emitter.once(e,r),()=>this._emitter.off(e,r)}emit(e,t){this._emitter.emit(e,t);}};l();function Ft(o){let e=new Map,t=r=>r.startsWith(`${o}::`)?r:`${o}::${r}`;return {async get(r){let n=e.get(t(r));return n?n.value:void 0},async set(r,n){e.set(t(r),{value:n});},async delete(r){return e.delete(t(r))},async list(r){let n=r?t(r):`${o}::`,s=[];for(let i of e.keys())i.startsWith(n)&&s.push(i.slice(o.length+2));return s}}}l();var qt=new async_hooks.AsyncLocalStorage;function Ro(){return qt}function Po(o,e){return qt.run(o,e)}function Ut(o){let e=o.log??o.logger??{debug:()=>{},info:()=>{},warn:()=>{},error:()=>{}},t=o.agentRunner??{run:async()=>({output:""})},r=o.db??{get:async()=>{},set:async()=>{},delete:async()=>false,list:async()=>[]},n=o.storage??{put:async()=>"",get:async()=>{},delete:async()=>false},s=o.audit??{log:async()=>{}},i=o.onInbound??(async()=>({accepted:true})),a=o.onEmitEvent??(async()=>({accepted:true})),d=o.onUpdateMessage??(async()=>{}),u=o.onResolveUser??(async g=>({userId:g,displayName:g})),c=async g=>{let f=qt.getStore();if(!f){e.warn("respondSync called outside sync window \u2014 graceful degradation (no-op)",{textPreview:typeof g=="object"&&"text"in g?g.text.slice(0,80):void 0});return}let y="text"in g?g.text:"";f.res.status(200).json({text:y});},p=o.httpRouter??{registerRoute:()=>{e.warn("httpRouter not configured \u2014 registerRoute is a no-op");}};return {instanceId:o.instanceId,config:o.config,capabilities:o.capabilities,log:e,agentRunner:t,db:r,storage:n,audit:s,abortSignal:o.abortSignal??new AbortController().signal,httpRouter:p,inbound:i,emitEvent:a,updateMessage:d,resolveUser:u,respondSync:c}}Ce();Ce();l();function bo(o){return typeof o!="string"?"":o.replace(/</g,"<").replace(/>/g,">")}function Wt(o){return o.messages.map(e=>({text:bo(e.text),isAssistant:e.isAssistant,metadata:e.metadata,files:void 0}))}l();l();var Co={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")},Ao={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 Sr(o,e,t){o.tool("crewx_listAgents","List available CrewX agents exposed by this server",async()=>{let r=[];for(let n of t){let s=e.agents.get(n);s&&r.push({id:s.id,name:s.name??s.id,description:s.description??""});}return {content:[{type:"text",text:JSON.stringify(r,null,2)}]}}),o.tool("crewx_queryAgent","Query a CrewX agent with a read-only question",Co,async({agentId:r,query:n,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.query(r,n,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Query failed"}],isError:true}}),o.tool("crewx_executeAgent","Execute a task on a CrewX agent (may modify state)",Ao,async({agentId:r,task:n,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.execute(r,n,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Execute failed"}],isError:true}});}l();function Ir(o){return o.headers.get("Origin")?null:new Response(JSON.stringify({error:"Forbidden: Origin header required"}),{status:403,headers:{"Content-Type":"application/json"}})}async function Or(o,e){return e?await e(o)?null:new Response(JSON.stringify({error:"Unauthorized"}),{status:401,headers:{"Content-Type":"application/json"}}):null}function So(o,e){let t=new mcp_js.McpServer({name:"crewx-mcp-server",version:"1.0.0"},{capabilities:{tools:{}}});return Sr(t,o,e),t}function Bt(o,e){if(!e.agents||e.agents.length===0)throw new Error("crewx.handler() requires at least one agent in the agents option");let t=new Set(e.agents),r=new Map;return async n=>{let s=Ir(n);if(s)return s;let i=await Or(n,e.auth);if(i)return i;let a=n.headers.get("mcp-session-id");if(a&&r.has(a))return r.get(a).transport.handleRequest(n);let d=So(o,t),u=new webStandardStreamableHttp_js.WebStandardStreamableHTTPServerTransport({sessionIdGenerator:()=>crypto.randomUUID(),onsessioninitialized:c=>{r.set(c,{transport:u,server:d});},onsessionclosed:c=>{r.delete(c);},enableJsonResponse:true});return await d.connect(u),u.handleRequest(n)}}l();l();var Fe=class{detach(e){}};l();l();l();var ut=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:H.join(Mo__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 Z(o){let e=F("better-sqlite3"),{drizzle:t}=F("drizzle-orm/better-sqlite3"),r=new e(o);return r.exec("PRAGMA journal_mode = WAL"),r.exec("PRAGMA busy_timeout = 5000"),r.exec("PRAGMA foreign_keys = ON"),{db:t(r),runRaw:(n,s=[])=>r.prepare(n).run(...s),close:()=>r.close()}}l();var Mr=new Set;function No(o){let{migrate:e}=F("drizzle-orm/better-sqlite3/migrator"),t=[H__namespace.default.join(__dirname,"../migrations"),H__namespace.default.join(__dirname,"migrations")],r=t.find(n=>fs$1.existsSync(H__namespace.default.join(n,"meta/_journal.json")));if(!r)throw new Error(`migrations folder not found. Searched:
|
|
43
|
+
`)}getPath(e){return this.docs.get(e)?.path}getNames(){return Array.from(this.docs.keys())}async buildContext(){let e={};for(let t of this.docs.keys()){let r=await this.getContent(t)??"",n=await this.getToc(t),s=this.getPath(t);e[t]={content:r,toc:n,...s?{path:s}:{}};}return e}async loadFromFile(e,t,r){try{let n=this.resolve(t,r),s=await this.fs.readFile(n);this.docs.set(e,{content:s,path:n});}catch(n){let s=n instanceof Error?n.message:String(n);console.warn(`[DocumentLoader] Failed to load '${e}' from '${t}': ${s}`);}}resolve(e,t){return this.fs.isAbsolute(e)?e:t?this.fs.resolvePath(t,e):this.fs.resolvePath(e)}};l();l();var q=class extends Error{constructor(t,r,n){super(t);this.layoutId=r;this.cause=n;this.name="LayoutLoadError";}layoutId;cause},oe=class extends Error{constructor(t,r=[],n){super(t);this.errors=r;this.cause=n;this.name="PropsValidationError";}errors;cause};var ho={validationMode:"lenient",fallbackLayoutId:"crewx/default"},Le=class{layouts=new Map;options;constructor(e){this.options={...ho,...e,templatesPath:e?.templatesPath??Pe()},this.loadAllLayouts();}load(e,t){let r=this.layouts.get(e);if(!r){let n=this.normalizeLayoutId(e);r=this.layouts.get(n);}if(!r&&(console.warn(`Layout not found: ${e}, falling back to ${this.options.fallbackLayoutId}`),r=this.layouts.get(this.options.fallbackLayoutId),!r))throw new q(`Fallback layout not found: ${this.options.fallbackLayoutId}`,this.options.fallbackLayoutId);return t&&Object.keys(t).length>0?{...r,defaultProps:{...r.defaultProps,...t}}:r}getLayoutIds(){return Array.from(this.layouts.keys())}hasLayout(e){if(this.layouts.has(e))return true;let t=this.normalizeLayoutId(e);return this.layouts.has(t)}reload(){this.layouts.clear(),this.loadAllLayouts();}registerLayout(e,t){if(!e||typeof e!="string")throw new q("Layout ID must be a non-empty string",e);let r=typeof t=="string"?{template:t}:t,n=typeof r.template=="string"?r.template:"";if(!n||n.trim().length===0)throw new q(`Custom layout template is empty for ${e}`,e);let s=r.propsSchema||{},i=this.extractDefaultProps(s),a=r.defaultProps||{},d={id:e,version:r.version||"1.0.0",description:r.description||`Custom layout ${e}`,template:n,propsSchema:this.parsePropsSchema(s),defaultProps:{...i,...a}},c=this.layouts.get(e),u=c?.template===n&&JSON.stringify(c?.defaultProps??{})===JSON.stringify(d.defaultProps??{})&&JSON.stringify(c?.propsSchema??{})===JSON.stringify(d.propsSchema??{});this.layouts.set(e,d),process.env.CREWX_VERBOSE==="1"&&(c?u||console.error(`Updated custom layout: ${e}`):console.error(`Registered custom layout: ${e}`));}registerLayouts(e){for(let[t,r]of Object.entries(e))try{this.registerLayout(t,r);}catch(n){console.warn(`Failed to register custom layout ${t}:`,n instanceof Error?n.message:n);}}loadAllLayouts(){let e=this.options.templatesPath;if(!fs$1.existsSync(e))throw new q(`Templates directory not found: ${e}`,void 0,new Error(`Directory does not exist: ${e}`));try{let t=fs$1.readdirSync(e).filter(r=>r.endsWith(".yaml")||r.endsWith(".yml"));t.length===0&&console.warn(`No layout files found in ${e}`);for(let r of t){let n=r.replace(/\.(yaml|yml)$/,""),s=H__namespace.join(e,r);try{let i=this.loadLayoutFile(s,n),a=`crewx/${n}`;this.layouts.set(a,i),a!=="crewx/minimal"&&process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded layout: ${a} from ${r}`);}catch(i){console.error(`Failed to load layout file ${r}:`,i);}}process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded ${this.layouts.size} layouts from ${e}`);}catch(t){throw new q(`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 q(`Empty YAML file: ${e}`,t,new Error("File content is empty"));let n=jsYaml.load(r);if(!n||typeof n!="object")throw console.warn(`Invalid YAML content in ${e} (parsed as ${typeof n}), will use fallback`),new q(`Invalid or empty YAML in ${e}`,t,new Error("YAML parsing returned null/undefined or non-object"));if(n.layouts&&typeof n.layouts=="object"){let s=this.resolveLayoutEntry(n.layouts,t);if(!s||s.template.trim().length===0)throw console.warn(`Empty or missing layout template in ${e} for ${t}`),new q(`Layout template not found or empty in layouts map: ${t}`,t);let i=s.propsSchema||n.propsSchema||{};return {id:`crewx/${t}`,version:n.version||"1.0.0",description:n.description||`CrewX ${t} layout`,template:s.template,propsSchema:this.parsePropsSchema(i),defaultProps:this.extractDefaultProps(i)}}else {if(!n.template||typeof n.template=="string"&&n.template.trim().length===0)throw console.warn(`Empty or missing template field in ${e}`),new q(`Layout template is missing or empty in ${e}`,t);return {id:n.id||`crewx/${t}`,version:n.version||"1.0.0",description:n.description||"",template:n.template,propsSchema:this.parsePropsSchema(n.propsSchema||{}),defaultProps:this.extractDefaultProps(n.propsSchema||{})}}}catch(r){throw new q(`Failed to load layout file: ${e}`,t,r instanceof Error?r:new Error(String(r)))}}parsePropsSchema(e){let t={};for(let[r,n]of Object.entries(e))typeof n=="object"&&n!==null&&(t[r]=n);return t}extractDefaultProps(e){let t={};for(let[r,n]of Object.entries(e))n&&typeof n=="object"&&("defaultValue"in n?t[r]=n.defaultValue:"default"in n&&(t[r]=n.default));return t}normalizeLayoutId(e){return e?e.includes("/")?e:`crewx/${e}`:this.options.fallbackLayoutId}resolveLayoutEntry(e,t){let r=new Set;if(t)if(r.add(t),t.includes("/")){let n=t.split("/"),s=n[n.length-1];s&&r.add(s);}else r.add(`crewx/${t}`);r.add("default");for(let n of r){let s=e[n];if(typeof s=="string"&&s.trim().length>0)return {template:s};if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}for(let n of Object.values(e)){if(typeof n=="string"&&n.trim().length>0)return {template:n};let s=n;if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}}};l();l();function wo(o){return Array.from(new Set(o.filter(e=>e?.isAssistant&&e?.metadata?.agent_id).map(e=>String(e.metadata.agent_id))))}function Ar(o,e,t){if(!Array.isArray(o)||o.length===0||!(t&&typeof t.fn=="function"))return "";let n=wo(o),s=n.length>0?n[0]:"",i={messages:o,platform:typeof e=="string"?e:"",messagesCount:o.length,agentIds:n,primaryAgentId:s};return t.fn(i)}l();var $e=class{defaultMode;constructor(e={}){this.defaultMode=e.defaultMode??"lenient";}validate(e,t,r=this.defaultMode){let n=[],s=this.validateObject(e??{},t,r,["props"],n);if(n.length>0&&r==="strict")throw new oe("Props validation failed in strict mode",n);return {valid:n.length===0,props:s,errors:n}}validateObject(e,t,r,n,s){let i={};if(r==="strict")for(let a of Object.keys(e))t[a]||s.push({path:this.buildPath([...n,a]),message:`Unknown prop '${a}'`,value:e[a]});for(let[a,d]of Object.entries(t)){let c=[...n,a],u=e[a],g=this.resolveProp(u,d,c,r,s);g.shouldAssign&&(i[a]=g.value);}return i}resolveProp(e,t,r,n,s){let i=this.buildPath(r);if(this.isNil(e)){if(t.isRequired&&s.push({path:i,message:`Required prop '${r[r.length-1]}' is missing`}),t.defaultValue!==void 0)return {shouldAssign:true,value:this.cloneValue(t.defaultValue)};if(t.type==="shape"&&t.shape){let d=this.applyDefaults(t.shape);if(Object.keys(d).length>0)return {shouldAssign:true,value:d}}return {shouldAssign:false}}let a=this.validateType(e,t,r,n,s);if(!a.valid){if(t.type==="shape"&&a.value&&this.isPlainObject(a.value))return {shouldAssign:true,value:a.value};if(s.push({path:i,message:a.error??"Invalid value",value:e}),t.defaultValue!==void 0)return {shouldAssign:true,value:this.cloneValue(t.defaultValue)};if(t.type==="shape"&&t.shape){let d=this.applyDefaults(t.shape);if(Object.keys(d).length>0)return {shouldAssign:true,value:d}}return {shouldAssign:false}}return {shouldAssign:true,value:a.value}}validateType(e,t,r,n,s){let{type:i}=t;switch(i){case "string":return this.validateString(e,t);case "number":return this.validateNumber(e,t);case "bool":return this.validateBoolean(e);case "array":return this.validateArray(e,t);case "arrayOf":return this.validateArrayOf(e,t,r,n,s);case "object":return this.validatePlainObject(e);case "shape":return this.validateShape(e,t,r,n,s);case "oneOfType":return this.validateOneOfType(e,t);case "func":return this.validateFunction(e);case "node":return {valid:true,value:e};default:return {valid:true,value:e}}}validateString(e,t){return typeof e!="string"?{valid:false,error:`Expected string, got ${this.describeType(e)}`}:t.oneOf&&!t.oneOf.includes(e)?{valid:false,error:`Expected one of: ${t.oneOf.join(", ")}`}:t.minLength!==void 0&&e.length<t.minLength?{valid:false,error:`String length must be >= ${t.minLength}`}:t.maxLength!==void 0&&e.length>t.maxLength?{valid:false,error:`String length must be <= ${t.maxLength}`}:t.pattern&&!new RegExp(t.pattern).test(e)?{valid:false,error:`String does not match pattern ${t.pattern}`}:{valid:true,value:e}}validateNumber(e,t){return typeof e!="number"||Number.isNaN(e)?{valid:false,error:`Expected number, got ${this.describeType(e)}`}:t.min!==void 0&&e<t.min?{valid:false,error:`Number must be >= ${t.min}`}:t.max!==void 0&&e>t.max?{valid:false,error:`Number must be <= ${t.max}`}:t.oneOf&&!t.oneOf.includes(e)?{valid:false,error:`Expected one of: ${t.oneOf.join(", ")}`}:{valid:true,value:e}}validateBoolean(e){return typeof e!="boolean"?{valid:false,error:`Expected boolean, got ${this.describeType(e)}`}:{valid:true,value:e}}validateArray(e,t){return Array.isArray(e)?t.minLength!==void 0&&e.length<t.minLength?{valid:false,error:`Array length must be >= ${t.minLength}`}:t.maxLength!==void 0&&e.length>t.maxLength?{valid:false,error:`Array length must be <= ${t.maxLength}`}:{valid:true,value:[...e]}:{valid:false,error:`Expected array, got ${this.describeType(e)}`}}validateArrayOf(e,t,r,n,s){let i=this.validateArray(e,t);if(!i.valid)return i;let a=[],d=t.itemType,c=t.itemOneOf,u=s.length;return i.value.forEach((g,p)=>{let f=[...r,String(p)];if(d){let y=this.validateType(g,{type:d},f,n,s);y.valid?a.push(y.value):s.push({path:this.buildPath(f),message:y.error??"Invalid array item",value:g});}else a.push(g);c&&!c.includes(g)&&s.push({path:this.buildPath(f),message:`Array item must be one of: ${c.join(", ")}`,value:g});}),{valid:s.length===u,value:a}}validatePlainObject(e){return this.isPlainObject(e)?{valid:true,value:{...e}}:{valid:false,error:`Expected object, got ${this.describeType(e)}`}}validateFunction(e){return typeof e!="function"?{valid:false,error:`Expected function, got ${this.describeType(e)}`}:{valid:true,value:e}}validateShape(e,t,r,n,s){if(!this.isPlainObject(e))return {valid:false,error:`Expected object, got ${this.describeType(e)}`};let i=s.length,a=this.validateObject(e,t.shape??{},n,r,s);return {valid:s.length===i,value:a}}validateOneOfType(e,t){let r=t.types??[];return r.some(s=>this.matchesType(e,s))?{valid:true,value:e}:{valid:false,error:`Value does not match any allowed type: ${r.join(", ")}`}}matchesType(e,t){switch(t){case "string":return typeof e=="string";case "number":return typeof e=="number"&&!Number.isNaN(e);case "bool":case "boolean":return typeof e=="boolean";case "array":return Array.isArray(e);case "object":return this.isPlainObject(e);case "func":case "function":return typeof e=="function";case "shape":return this.isPlainObject(e);case "node":return e==null||typeof e!="symbol";default:return true}}applyDefaults(e){let t={};for(let[r,n]of Object.entries(e)){if(n.defaultValue!==void 0){t[r]=this.cloneValue(n.defaultValue);continue}if(n.type==="shape"&&n.shape){let s=this.applyDefaults(n.shape);Object.keys(s).length>0&&(t[r]=s);}}return t}cloneValue(e){if(Array.isArray(e))return e.map(t=>this.cloneValue(t));if(this.isPlainObject(e)){let t={};for(let[r,n]of Object.entries(e))t[r]=this.cloneValue(n);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}isNil(e){return e==null}buildPath(e){return e.join(".")}describeType(e){return Array.isArray(e)?"array":e===null?"null":typeof e}};var je=class{handlebars;propsValidator;constructor(e){this.handlebars=Y__namespace.default.create(),this.propsValidator=e??new $e,this.registerHelpers();}render(e,t,r={}){try{let n=this.prepareRenderContext(e,t,r);return this.handlebars.compile(e.template,{noEscape:!0})(n)}catch(n){throw n instanceof Error?new Error(`Template rendering failed for layout '${e.id}': ${n.message}`):new Error(`Unknown error rendering layout '${e.id}'`)}}validate(e,t,r="lenient"){return this.executeValidation(e,t,r)}resolveProps(e,t,r="lenient"){let n=this.mergeProps(e.defaultProps,t);return !e.propsSchema||Object.keys(e.propsSchema).length===0?{valid:true,props:n,errors:[]}:this.executeValidation(n,e.propsSchema,r)}prepareRenderContext(e,t,r){let{validationMode:n="lenient",skipValidation:s=false}=r,i=s?this.mergeProps(e.defaultProps,t.props):this.resolveProps(e,t.props,n).props;return {...t,vars:this.sanitizeVars(t.vars),props:i}}registerHelpers(){this.handlebars.registerHelper("formatConversation",Ar),Y__namespace.default.helpers.each&&this.handlebars.registerHelper("each",Y__namespace.default.helpers.each),Y__namespace.default.helpers.if&&this.handlebars.registerHelper("if",Y__namespace.default.helpers.if),Y__namespace.default.helpers.unless&&this.handlebars.registerHelper("unless",Y__namespace.default.helpers.unless),Y__namespace.default.helpers.with&&this.handlebars.registerHelper("with",Y__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 Y__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(n){if(n instanceof oe&&n.errors&&n.errors.length>0){let s=n.errors[0];if(s)throw new oe(s.message,n.errors)}throw n}}mergeProps(e,t){let r=this.cloneDeep(e??{});return t?this.deepMerge(r,t):r}deepMerge(e,t){for(let[r,n]of Object.entries(t)){if(this.isPlainObject(n)){let s=e[r];e[r]=this.deepMerge(this.isPlainObject(s)?s:{},n);continue}if(Array.isArray(n)){e[r]=this.cloneDeep(n);continue}e[r]=n;}return e}cloneDeep(e){if(Array.isArray(e))return e.map(t=>this.cloneDeep(t));if(this.isPlainObject(e)){let t={};for(let[r,n]of Object.entries(e))t[r]=this.cloneDeep(n);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}sanitizeVars(e){if(!e)return {};let t={...e};if(typeof e.user_input=="string"){t.user_input_raw=e.user_input;let r=e.user_input.replace(/\{\{\{/g,"{{{").replace(/\}\}\}/g,"}}}").replace(/\{\{/g,"{{").replace(/\}\}/g,"}}");t.user_input=this.handlebars.escapeExpression(r);}return t}};l();var jt="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function xo(o){let e=crypto$1.randomBytes(o*2),t="";for(let r=0;r<e.length&&t.length<o;r++){let n=e[r];n<248&&(t+=jt[n%62]);}for(;t.length<o;)t+=jt[crypto$1.randomBytes(1)[0]%62];return t}function we(o){return `${o}_${xo(8)}`}function vo(o,e){let{createHash:t}=F("crypto"),r=t("sha256").update(e).digest(),n=Buffer.alloc(8);for(let i=0;i<32;i++)n[i%8]^=r[i];let s="";for(let i of n)s+=jt[i%62];return `${o}_${s}`}l();function Ht(o){let e=t=>String(t).padStart(2,"0");return `${o.getFullYear()}${e(o.getMonth()+1)}${e(o.getDate())}T${e(o.getHours())}${e(o.getMinutes())}${e(o.getSeconds())}`}l();function Er(o,e){return t=>{try{let r=e(t);r instanceof Promise&&r.catch(n=>{console.error(`[crewx] event listener error (${o}): ${n instanceof Error?n.message:String(n)}`);});}catch(r){console.error(`[crewx] event listener error (${o}): ${r instanceof Error?r.message:String(r)}`);}}}var He=class{_emitter=new events.EventEmitter;on(e,t){let r=Er(e,t);return this._emitter.on(e,r),()=>this._emitter.off(e,r)}once(e,t){let r=Er(e,t);return this._emitter.once(e,r),()=>this._emitter.off(e,r)}emit(e,t){this._emitter.emit(e,t);}};l();function Ft(o){let e=new Map,t=r=>r.startsWith(`${o}::`)?r:`${o}::${r}`;return {async get(r){let n=e.get(t(r));return n?n.value:void 0},async set(r,n){e.set(t(r),{value:n});},async delete(r){return e.delete(t(r))},async list(r){let n=r?t(r):`${o}::`,s=[];for(let i of e.keys())i.startsWith(n)&&s.push(i.slice(o.length+2));return s}}}l();var qt=new async_hooks.AsyncLocalStorage;function Ro(){return qt}function Po(o,e){return qt.run(o,e)}function Ut(o){let e=o.log??o.logger??{debug:()=>{},info:()=>{},warn:()=>{},error:()=>{}},t=o.agentRunner??{run:async()=>({output:""})},r=o.db??{get:async()=>{},set:async()=>{},delete:async()=>false,list:async()=>[]},n=o.storage??{put:async()=>"",get:async()=>{},delete:async()=>false},s=o.audit??{log:async()=>{}},i=o.onInbound??(async()=>({accepted:true})),a=o.onEmitEvent??(async()=>({accepted:true})),d=o.onUpdateMessage??(async()=>{}),c=o.onResolveUser??(async p=>({userId:p,displayName:p})),u=async p=>{let f=qt.getStore();if(!f){e.warn("respondSync called outside sync window \u2014 graceful degradation (no-op)",{textPreview:typeof p=="object"&&"text"in p?p.text.slice(0,80):void 0});return}let y="text"in p?p.text:"";f.res.status(200).json({text:y});},g=o.httpRouter??{registerRoute:()=>{e.warn("httpRouter not configured \u2014 registerRoute is a no-op");}};return {instanceId:o.instanceId,config:o.config,capabilities:o.capabilities,log:e,agentRunner:t,db:r,storage:n,audit:s,abortSignal:o.abortSignal??new AbortController().signal,httpRouter:g,inbound:i,emitEvent:a,updateMessage:d,resolveUser:c,respondSync:u}}Ae();Ae();l();function bo(o){return typeof o!="string"?"":o.replace(/</g,"<").replace(/>/g,">")}function Wt(o){return o.messages.map(e=>({text:bo(e.text),isAssistant:e.isAssistant,metadata:e.metadata,files:void 0}))}l();l();var Co={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")},Ao={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 Sr(o,e,t){o.tool("crewx_listAgents","List available CrewX agents exposed by this server",async()=>{let r=[];for(let n of t){let s=e.agents.get(n);s&&r.push({id:s.id,name:s.name??s.id,description:s.description??""});}return {content:[{type:"text",text:JSON.stringify(r,null,2)}]}}),o.tool("crewx_queryAgent","Query a CrewX agent with a read-only question",Co,async({agentId:r,query:n,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.query(r,n,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Query failed"}],isError:true}}),o.tool("crewx_executeAgent","Execute a task on a CrewX agent (may modify state)",Ao,async({agentId:r,task:n,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.execute(r,n,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Execute failed"}],isError:true}});}l();function Ir(o){return o.headers.get("Origin")?null:new Response(JSON.stringify({error:"Forbidden: Origin header required"}),{status:403,headers:{"Content-Type":"application/json"}})}async function Or(o,e){return e?await e(o)?null:new Response(JSON.stringify({error:"Unauthorized"}),{status:401,headers:{"Content-Type":"application/json"}}):null}function So(o,e){let t=new mcp_js.McpServer({name:"crewx-mcp-server",version:"1.0.0"},{capabilities:{tools:{}}});return Sr(t,o,e),t}function Bt(o,e){if(!e.agents||e.agents.length===0)throw new Error("crewx.handler() requires at least one agent in the agents option");let t=new Set(e.agents),r=new Map;return async n=>{let s=Ir(n);if(s)return s;let i=await Or(n,e.auth);if(i)return i;let a=n.headers.get("mcp-session-id");if(a&&r.has(a))return r.get(a).transport.handleRequest(n);let d=So(o,t),c=new webStandardStreamableHttp_js.WebStandardStreamableHTTPServerTransport({sessionIdGenerator:()=>crypto.randomUUID(),onsessioninitialized:u=>{r.set(u,{transport:c,server:d});},onsessionclosed:u=>{r.delete(u);},enableJsonResponse:true});return await d.connect(c),c.handleRequest(n)}}l();l();var Fe=class{detach(e){}};l();l();l();var ut=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:H.join(Mo__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 Z(o){let e=F("better-sqlite3"),{drizzle:t}=F("drizzle-orm/better-sqlite3"),r=new e(o);return r.exec("PRAGMA journal_mode = WAL"),r.exec("PRAGMA busy_timeout = 5000"),r.exec("PRAGMA foreign_keys = ON"),{db:t(r),runRaw:(n,s=[])=>r.prepare(n).run(...s),close:()=>r.close()}}l();var Mr=new Set;function No(o){let{migrate:e}=F("drizzle-orm/better-sqlite3/migrator"),t=[H__namespace.default.join(__dirname,"../migrations"),H__namespace.default.join(__dirname,"migrations")],r=t.find(n=>fs$1.existsSync(H__namespace.default.join(n,"meta/_journal.json")));if(!r)throw new Error(`migrations folder not found. Searched:
|
|
44
44
|
${t.join(`
|
|
45
|
-
`)}`);e(o,{migrationsFolder:r});}function Dr(o,e){Mr.has(e)||(No(o),Mr.add(e));}l();var D=class extends Error{code;cause;constructor(e,t,r){super(t),this.name="RepositoryError",this.code=e,this.cause=r,Object.setPrototypeOf(this,new.target.prototype);}};l();l();var Te=sqliteCore.sqliteTable("workspaces",{id:sqliteCore.text("id").primaryKey(),slug:sqliteCore.text("slug").notNull().unique(),name:sqliteCore.text("name").notNull(),workspace_path:sqliteCore.text("workspace_path"),description:sqliteCore.text("description"),is_active:sqliteCore.integer("is_active").notNull().default(1),created_at:sqliteCore.text("created_at").notNull(),updated_at:sqliteCore.text("updated_at").notNull()});l();var S=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"),workspace_name:sqliteCore.text("workspace_name"),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_name:sqliteCore.text("project_name"),project_ref:sqliteCore.text("project_ref"),cached_input_tokens:sqliteCore.integer("cached_input_tokens").default(0)},o=>({idx_tasks_agent_id:sqliteCore.index("idx_tasks_agent_id").on(o.agent_id),idx_tasks_status:sqliteCore.index("idx_tasks_status").on(o.status),idx_tasks_started_at:sqliteCore.index("idx_tasks_started_at").on(o.started_at),idx_tasks_trace_id:sqliteCore.index("idx_tasks_trace_id").on(o.trace_id),idx_tasks_parent_task_id:sqliteCore.index("idx_tasks_parent_task_id").on(o.parent_task_id),idx_tasks_crewx_version:sqliteCore.index("idx_tasks_crewx_version").on(o.crewx_version),idx_tasks_pid:sqliteCore.index("idx_tasks_pid").on(o.pid),idx_tasks_thread_id:sqliteCore.index("idx_tasks_thread_id").on(o.thread_id),idx_tasks_workspace_id:sqliteCore.index("idx_tasks_workspace_id").on(o.workspace_id),idx_tasks_workspace_ref:sqliteCore.index("idx_tasks_workspace_ref").on(o.workspace_ref),idx_tasks_project_id:sqliteCore.index("idx_tasks_project_id").on(o.project_id),idx_tasks_ws_started:sqliteCore.index("idx_tasks_ws_started").on(o.workspace_id,o.started_at)}));l();var P=sqliteCore.sqliteTable("threads",{id:sqliteCore.text("id").primaryKey(),workspace_id:sqliteCore.text("workspace_id").references(()=>Te.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)},o=>({idx_threads_updated_at:sqliteCore.index("idx_threads_updated_at").on(o.updated_at),idx_threads_workspace_id:sqliteCore.index("idx_threads_workspace_id").on(o.workspace_id)}));l();var Wo=sqliteCore.sqliteTable("spans",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>S.id,{onDelete:"set null"}),parent_span_id:sqliteCore.text("parent_span_id").references(()=>Wo.id,{onDelete:"set null"}),name:sqliteCore.text("name").notNull(),kind:sqliteCore.text("kind").notNull().default("internal"),status:sqliteCore.text("status").notNull().default("ok"),started_at:sqliteCore.text("started_at").notNull(),completed_at:sqliteCore.text("completed_at"),duration_ms:sqliteCore.integer("duration_ms"),input:sqliteCore.text("input"),output:sqliteCore.text("output"),error:sqliteCore.text("error"),attributes:sqliteCore.text("attributes")},o=>({idx_spans_task_id:sqliteCore.index("idx_spans_task_id").on(o.task_id),idx_spans_parent_span_id:sqliteCore.index("idx_spans_parent_span_id").on(o.parent_span_id)}));l();sqliteCore.sqliteTable("tool_calls",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").notNull().references(()=>S.id,{onDelete:"cascade"}),session_id:sqliteCore.text("session_id"),tool_name:sqliteCore.text("tool_name").notNull(),files:sqliteCore.text("files"),input:sqliteCore.text("input"),output:sqliteCore.text("output"),duration_ms:sqliteCore.integer("duration_ms"),timestamp:sqliteCore.text("timestamp").notNull()},o=>({idx_tool_calls_task_id:sqliteCore.index("idx_tool_calls_task_id").on(o.task_id),idx_tool_calls_tool_name:sqliteCore.index("idx_tool_calls_tool_name").on(o.tool_name),idx_tool_calls_timestamp:sqliteCore.index("idx_tool_calls_timestamp").on(o.timestamp)}));l();sqliteCore.sqliteTable("thread_boxes",{id:sqliteCore.text("id").primaryKey(),thread_id:sqliteCore.text("thread_id").notNull().references(()=>P.id,{onDelete:"cascade"}),seq:sqliteCore.integer("seq").notNull(),first_task_id:sqliteCore.text("first_task_id").notNull(),mid_task_id:sqliteCore.text("mid_task_id").notNull(),last_task_id:sqliteCore.text("last_task_id").notNull(),task_count:sqliteCore.integer("task_count").notNull(),summary:sqliteCore.text("summary"),source_tokens:sqliteCore.integer("source_tokens").notNull(),summary_tokens:sqliteCore.integer("summary_tokens"),created_at:sqliteCore.text("created_at").notNull()},o=>({idx_thread_boxes_thread_id:sqliteCore.index("idx_thread_boxes_thread_id").on(o.thread_id),idx_thread_boxes_seq:sqliteCore.index("idx_thread_boxes_seq").on(o.thread_id,o.seq),uniq_thread_boxes_thread_seq:sqliteCore.unique().on(o.thread_id,o.seq)}));l();sqliteCore.sqliteTable("request_logs",{id:sqliteCore.text("id").primaryKey(),path:sqliteCore.text("path").notNull(),method:sqliteCore.text("method").notNull(),status_code:sqliteCore.integer("status_code").notNull(),duration_ms:sqliteCore.integer("duration_ms").notNull(),ip:sqliteCore.text("ip"),request_headers:sqliteCore.text("request_headers"),response_headers:sqliteCore.text("response_headers"),request_body:sqliteCore.text("request_body"),response_body:sqliteCore.text("response_body"),query:sqliteCore.text("query"),user_id:sqliteCore.text("user_id"),project_id:sqliteCore.text("project_id"),partition_key:sqliteCore.text("partition_key").notNull(),timestamp:sqliteCore.text("timestamp").notNull().default(drizzleOrm.sql`(datetime('now'))`),metadata:sqliteCore.text("metadata")},o=>({idx_request_logs_timestamp:sqliteCore.index("idx_request_logs_timestamp").on(o.timestamp),idx_request_logs_path:sqliteCore.index("idx_request_logs_path").on(o.path),idx_request_logs_status_code:sqliteCore.index("idx_request_logs_status_code").on(o.status_code),idx_request_logs_partition_key:sqliteCore.index("idx_request_logs_partition_key").on(o.partition_key)}));var ft=class extends ut{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=H.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let n=H.dirname(t);fs$1.existsSync(n)||fs$1.mkdirSync(n,{recursive:true});}else if(!fs$1.existsSync(t))throw new D("NOT_FOUND","Database not found");let r=Z(t);if(e)try{Dr(r.db,t);}catch(n){throw r.close(),n}return r}validateWorkspaceId(e,t){return e.db.select({id:Te.id}).from(Te).where(drizzleOrm.eq(Te.id,t)).limit(1).get()?t:null}findAllThreads(e){let t=this.resolveDbPaths(),r=new Set,n=[];for(let s of t){if(!fs$1.existsSync(s))continue;let i=Z(s);try{let a=e?drizzleOrm.or(drizzleOrm.eq(P.workspace_id,e),drizzleOrm.isNull(P.workspace_id)):void 0,d=i.db.select().from(P).where(a).orderBy(drizzleOrm.desc(P.updated_at)).all();for(let u of d)r.has(u.id)||(r.add(u.id),n.push(u));}catch(a){throw new D("DB_ERROR","Failed to find all threads",a)}finally{i.close();}}return n}findThreadById(e,t){let r=this.resolveDbPaths();for(let n of r){if(!fs$1.existsSync(n))continue;let s=Z(n);try{let i=drizzleOrm.eq(P.id,e),a=t?drizzleOrm.and(i,drizzleOrm.or(drizzleOrm.eq(P.workspace_id,t),drizzleOrm.isNull(P.workspace_id))):i,d=s.db.select().from(P).where(a).limit(1).get()??void 0;if(d)return d}catch(i){throw new D("DB_ERROR","Failed to find thread by id",i)}finally{s.close();}}}threadExists(e,t){let r=this.resolveDbPaths();for(let n of r){if(!fs$1.existsSync(n))continue;let s=Z(n);try{let i=drizzleOrm.eq(P.id,e),a=t?drizzleOrm.and(i,drizzleOrm.or(drizzleOrm.eq(P.workspace_id,t),drizzleOrm.isNull(P.workspace_id))):i;if(s.db.select({id:P.id}).from(P).where(a).limit(1).get())return !0}catch(i){throw new D("DB_ERROR","Failed to check thread existence",i)}finally{s.close();}}return false}aggregateTaskStats(e,t){let r=this.resolveDbPaths(),n=0,s=0,i=0,a=0,d=0,u=new Set;for(let c of r){if(!fs$1.existsSync(c))continue;let p=Z(c);try{let g=drizzleOrm.and(drizzleOrm.eq(S.thread_id,e),drizzleOrm.or(drizzleOrm.isNull(S.parent_task_id),drizzleOrm.eq(S.parent_task_id,""))),f=t?drizzleOrm.and(g,drizzleOrm.eq(S.workspace_id,t)):g,y=p.db.select({cnt:drizzleOrm.sql`count(*)`,total_input:drizzleOrm.sql`COALESCE(SUM(input_tokens), 0)`,total_output:drizzleOrm.sql`COALESCE(SUM(output_tokens), 0)`,total_cached:drizzleOrm.sql`COALESCE(SUM(cached_input_tokens), 0)`,total_cost:drizzleOrm.sql`COALESCE(SUM(cost_usd), 0)`}).from(S).where(f).get();y&&(n+=y.cnt,s+=y.total_input,i+=y.total_output,a+=y.total_cached,d+=y.total_cost);let R=p.db.all(drizzleOrm.sql`
|
|
45
|
+
`)}`);e(o,{migrationsFolder:r});}function Dr(o,e){Mr.has(e)||(No(o),Mr.add(e));}l();var D=class extends Error{code;cause;constructor(e,t,r){super(t),this.name="RepositoryError",this.code=e,this.cause=r,Object.setPrototypeOf(this,new.target.prototype);}};l();l();var Ee=sqliteCore.sqliteTable("workspaces",{id:sqliteCore.text("id").primaryKey(),slug:sqliteCore.text("slug").notNull().unique(),name:sqliteCore.text("name").notNull(),workspace_path:sqliteCore.text("workspace_path"),description:sqliteCore.text("description"),is_active:sqliteCore.integer("is_active").notNull().default(1),created_at:sqliteCore.text("created_at").notNull(),updated_at:sqliteCore.text("updated_at").notNull()});l();var S=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"),workspace_name:sqliteCore.text("workspace_name"),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_name:sqliteCore.text("project_name"),project_ref:sqliteCore.text("project_ref"),cached_input_tokens:sqliteCore.integer("cached_input_tokens").default(0)},o=>({idx_tasks_agent_id:sqliteCore.index("idx_tasks_agent_id").on(o.agent_id),idx_tasks_status:sqliteCore.index("idx_tasks_status").on(o.status),idx_tasks_started_at:sqliteCore.index("idx_tasks_started_at").on(o.started_at),idx_tasks_trace_id:sqliteCore.index("idx_tasks_trace_id").on(o.trace_id),idx_tasks_parent_task_id:sqliteCore.index("idx_tasks_parent_task_id").on(o.parent_task_id),idx_tasks_crewx_version:sqliteCore.index("idx_tasks_crewx_version").on(o.crewx_version),idx_tasks_pid:sqliteCore.index("idx_tasks_pid").on(o.pid),idx_tasks_thread_id:sqliteCore.index("idx_tasks_thread_id").on(o.thread_id),idx_tasks_workspace_id:sqliteCore.index("idx_tasks_workspace_id").on(o.workspace_id),idx_tasks_workspace_ref:sqliteCore.index("idx_tasks_workspace_ref").on(o.workspace_ref),idx_tasks_project_id:sqliteCore.index("idx_tasks_project_id").on(o.project_id),idx_tasks_ws_started:sqliteCore.index("idx_tasks_ws_started").on(o.workspace_id,o.started_at)}));l();var P=sqliteCore.sqliteTable("threads",{id:sqliteCore.text("id").primaryKey(),workspace_id:sqliteCore.text("workspace_id").references(()=>Ee.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)},o=>({idx_threads_updated_at:sqliteCore.index("idx_threads_updated_at").on(o.updated_at),idx_threads_workspace_id:sqliteCore.index("idx_threads_workspace_id").on(o.workspace_id)}));l();var Wo=sqliteCore.sqliteTable("spans",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>S.id,{onDelete:"set null"}),parent_span_id:sqliteCore.text("parent_span_id").references(()=>Wo.id,{onDelete:"set null"}),name:sqliteCore.text("name").notNull(),kind:sqliteCore.text("kind").notNull().default("internal"),status:sqliteCore.text("status").notNull().default("ok"),started_at:sqliteCore.text("started_at").notNull(),completed_at:sqliteCore.text("completed_at"),duration_ms:sqliteCore.integer("duration_ms"),input:sqliteCore.text("input"),output:sqliteCore.text("output"),error:sqliteCore.text("error"),attributes:sqliteCore.text("attributes")},o=>({idx_spans_task_id:sqliteCore.index("idx_spans_task_id").on(o.task_id),idx_spans_parent_span_id:sqliteCore.index("idx_spans_parent_span_id").on(o.parent_span_id)}));l();sqliteCore.sqliteTable("tool_calls",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").notNull().references(()=>S.id,{onDelete:"cascade"}),session_id:sqliteCore.text("session_id"),tool_name:sqliteCore.text("tool_name").notNull(),files:sqliteCore.text("files"),input:sqliteCore.text("input"),output:sqliteCore.text("output"),duration_ms:sqliteCore.integer("duration_ms"),timestamp:sqliteCore.text("timestamp").notNull()},o=>({idx_tool_calls_task_id:sqliteCore.index("idx_tool_calls_task_id").on(o.task_id),idx_tool_calls_tool_name:sqliteCore.index("idx_tool_calls_tool_name").on(o.tool_name),idx_tool_calls_timestamp:sqliteCore.index("idx_tool_calls_timestamp").on(o.timestamp)}));l();sqliteCore.sqliteTable("thread_boxes",{id:sqliteCore.text("id").primaryKey(),thread_id:sqliteCore.text("thread_id").notNull().references(()=>P.id,{onDelete:"cascade"}),seq:sqliteCore.integer("seq").notNull(),first_task_id:sqliteCore.text("first_task_id").notNull(),mid_task_id:sqliteCore.text("mid_task_id").notNull(),last_task_id:sqliteCore.text("last_task_id").notNull(),task_count:sqliteCore.integer("task_count").notNull(),summary:sqliteCore.text("summary"),source_tokens:sqliteCore.integer("source_tokens").notNull(),summary_tokens:sqliteCore.integer("summary_tokens"),created_at:sqliteCore.text("created_at").notNull()},o=>({idx_thread_boxes_thread_id:sqliteCore.index("idx_thread_boxes_thread_id").on(o.thread_id),idx_thread_boxes_seq:sqliteCore.index("idx_thread_boxes_seq").on(o.thread_id,o.seq),uniq_thread_boxes_thread_seq:sqliteCore.unique().on(o.thread_id,o.seq)}));l();sqliteCore.sqliteTable("request_logs",{id:sqliteCore.text("id").primaryKey(),path:sqliteCore.text("path").notNull(),method:sqliteCore.text("method").notNull(),status_code:sqliteCore.integer("status_code").notNull(),duration_ms:sqliteCore.integer("duration_ms").notNull(),ip:sqliteCore.text("ip"),request_headers:sqliteCore.text("request_headers"),response_headers:sqliteCore.text("response_headers"),request_body:sqliteCore.text("request_body"),response_body:sqliteCore.text("response_body"),query:sqliteCore.text("query"),user_id:sqliteCore.text("user_id"),project_id:sqliteCore.text("project_id"),partition_key:sqliteCore.text("partition_key").notNull(),timestamp:sqliteCore.text("timestamp").notNull().default(drizzleOrm.sql`(datetime('now'))`),metadata:sqliteCore.text("metadata")},o=>({idx_request_logs_timestamp:sqliteCore.index("idx_request_logs_timestamp").on(o.timestamp),idx_request_logs_path:sqliteCore.index("idx_request_logs_path").on(o.path),idx_request_logs_status_code:sqliteCore.index("idx_request_logs_status_code").on(o.status_code),idx_request_logs_partition_key:sqliteCore.index("idx_request_logs_partition_key").on(o.partition_key)}));var ft=class extends ut{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=H.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let n=H.dirname(t);fs$1.existsSync(n)||fs$1.mkdirSync(n,{recursive:true});}else if(!fs$1.existsSync(t))throw new D("NOT_FOUND","Database not found");let r=Z(t);if(e)try{Dr(r.db,t);}catch(n){throw r.close(),n}return r}validateWorkspaceId(e,t){return e.db.select({id:Ee.id}).from(Ee).where(drizzleOrm.eq(Ee.id,t)).limit(1).get()?t:null}findAllThreads(e){let t=this.resolveDbPaths(),r=new Set,n=[];for(let s of t){if(!fs$1.existsSync(s))continue;let i=Z(s);try{let a=e?drizzleOrm.or(drizzleOrm.eq(P.workspace_id,e),drizzleOrm.isNull(P.workspace_id)):void 0,d=i.db.select().from(P).where(a).orderBy(drizzleOrm.desc(P.updated_at)).all();for(let c of d)r.has(c.id)||(r.add(c.id),n.push(c));}catch(a){throw new D("DB_ERROR","Failed to find all threads",a)}finally{i.close();}}return n}findThreadById(e,t){let r=this.resolveDbPaths();for(let n of r){if(!fs$1.existsSync(n))continue;let s=Z(n);try{let i=drizzleOrm.eq(P.id,e),a=t?drizzleOrm.and(i,drizzleOrm.or(drizzleOrm.eq(P.workspace_id,t),drizzleOrm.isNull(P.workspace_id))):i,d=s.db.select().from(P).where(a).limit(1).get()??void 0;if(d)return d}catch(i){throw new D("DB_ERROR","Failed to find thread by id",i)}finally{s.close();}}}threadExists(e,t){let r=this.resolveDbPaths();for(let n of r){if(!fs$1.existsSync(n))continue;let s=Z(n);try{let i=drizzleOrm.eq(P.id,e),a=t?drizzleOrm.and(i,drizzleOrm.or(drizzleOrm.eq(P.workspace_id,t),drizzleOrm.isNull(P.workspace_id))):i;if(s.db.select({id:P.id}).from(P).where(a).limit(1).get())return !0}catch(i){throw new D("DB_ERROR","Failed to check thread existence",i)}finally{s.close();}}return false}aggregateTaskStats(e,t){let r=this.resolveDbPaths(),n=0,s=0,i=0,a=0,d=0,c=new Set;for(let u of r){if(!fs$1.existsSync(u))continue;let g=Z(u);try{let p=drizzleOrm.and(drizzleOrm.eq(S.thread_id,e),drizzleOrm.or(drizzleOrm.isNull(S.parent_task_id),drizzleOrm.eq(S.parent_task_id,""))),f=t?drizzleOrm.and(p,drizzleOrm.eq(S.workspace_id,t)):p,y=g.db.select({cnt:drizzleOrm.sql`count(*)`,total_input:drizzleOrm.sql`COALESCE(SUM(input_tokens), 0)`,total_output:drizzleOrm.sql`COALESCE(SUM(output_tokens), 0)`,total_cached:drizzleOrm.sql`COALESCE(SUM(cached_input_tokens), 0)`,total_cost:drizzleOrm.sql`COALESCE(SUM(cost_usd), 0)`}).from(S).where(f).get();y&&(n+=y.cnt,s+=y.total_input,i+=y.total_output,a+=y.total_cached,d+=y.total_cost);let R=g.db.all(drizzleOrm.sql`
|
|
46
46
|
SELECT DISTINCT agent_id FROM tasks
|
|
47
47
|
WHERE thread_id = ${e}
|
|
48
48
|
AND agent_id IS NOT NULL AND agent_id != ''
|
|
49
49
|
AND (parent_task_id IS NULL OR parent_task_id = '')
|
|
50
50
|
${t?drizzleOrm.sql`AND workspace_id = ${t}`:drizzleOrm.sql``}
|
|
51
|
-
`);for(let x of R)
|
|
51
|
+
`);for(let x of R)c.add(x.agent_id);}catch(p){throw new D("DB_ERROR","Failed to aggregate task stats",p)}finally{g.close();}}return {taskCount:n,inputTokens:s,outputTokens:i,cachedInputTokens:a,costUsd:d,agentIds:Array.from(c)}}findTopLevelTasks(e,t){let r=this.resolveDbPaths(),n=new Set,s=[];for(let i of r){if(!fs$1.existsSync(i))continue;let a=Z(i);try{let d=drizzleOrm.and(drizzleOrm.eq(S.thread_id,e),drizzleOrm.or(drizzleOrm.isNull(S.parent_task_id),drizzleOrm.eq(S.parent_task_id,""))),c=t?drizzleOrm.and(d,drizzleOrm.eq(S.workspace_id,t)):d,u=a.db.select().from(S).where(c).orderBy(drizzleOrm.asc(S.started_at)).all();for(let g of u)n.has(g.id)||(n.add(g.id),s.push(g));}catch(d){throw new D("DB_ERROR","Failed to find top-level tasks",d)}finally{a.close();}}return s}findAllTasks(e,t){let r=this.resolveDbPaths(),n=new Set,s=[];for(let i of r){if(!fs$1.existsSync(i))continue;let a=Z(i);try{let d=drizzleOrm.eq(S.thread_id,e),c=t?drizzleOrm.and(d,drizzleOrm.eq(S.workspace_id,t)):d,u=a.db.select().from(S).where(c).orderBy(drizzleOrm.asc(S.started_at)).all();for(let g of u)n.has(g.id)||(n.add(g.id),s.push(g));}catch(d){throw new D("DB_ERROR","Failed to find all tasks for thread",d)}finally{a.close();}}return s}findTaskById(e,t,r){let n=this.resolveDbPaths();for(let s of n){if(!fs$1.existsSync(s))continue;let i=Z(s);try{let a=drizzleOrm.and(drizzleOrm.eq(S.id,t),drizzleOrm.eq(S.thread_id,e)),d=r?drizzleOrm.and(a,drizzleOrm.eq(S.workspace_id,r)):a,c=i.db.select().from(S).where(d).limit(1).get();if(!c)continue;let u=i.db.select().from(S).where(drizzleOrm.eq(S.parent_task_id,c.id)).orderBy(drizzleOrm.asc(S.started_at)).all();return {task:c,children:u}}catch(a){throw new D("DB_ERROR","Failed to find task by id",a)}finally{i.close();}}}batchFetchTasks(e,t){let r=new Map;if(e.length===0)return r;let n=this.resolveDbPaths();for(let s of n){if(!fs$1.existsSync(s))continue;let i=Z(s);try{let a=drizzleOrm.and(drizzleOrm.inArray(S.thread_id,e),drizzleOrm.or(drizzleOrm.isNull(S.parent_task_id),drizzleOrm.eq(S.parent_task_id,""))),d=t?drizzleOrm.and(a,drizzleOrm.eq(S.workspace_id,t)):a,c=i.db.select().from(S).where(d).orderBy(drizzleOrm.asc(S.started_at)).all();for(let u of c){let g=u.thread_id;r.has(g)||r.set(g,[]),r.get(g).push(u);}}catch(a){throw new D("DB_ERROR","Failed to batch fetch tasks",a)}finally{i.close();}}return r}updateThreadTitle(e,t,r){if(!this.dbExists())return;let n=this.openHandle(true);try{let s=drizzleOrm.eq(P.id,e),i=r?drizzleOrm.and(s,drizzleOrm.or(drizzleOrm.eq(P.workspace_id,r),drizzleOrm.isNull(P.workspace_id))):s;if(!n.db.select({id:P.id}).from(P).where(i).limit(1).get())return;n.db.update(P).set({title:t,title_locked:1,updated_at:new Date().toISOString()}).where(drizzleOrm.eq(P.id,e)).run();}catch(s){throw s instanceof D?s:new D("DB_ERROR","Failed to update thread title",s)}finally{n.close();}}upsertThread(e,t){let r=this.openHandle(true);try{let n=t.workspaceId?this.validateWorkspaceId(r,t.workspaceId):null,s=new Date().toISOString();if(r.db.select({id:P.id,message_count:P.message_count}).from(P).where(drizzleOrm.eq(P.id,e)).limit(1).get()){let a={updated_at:s};t.title!==void 0&&(a.title=t.title),t.titleLocked!==void 0&&(a.title_locked=t.titleLocked?1:0),r.db.update(P).set(a).where(drizzleOrm.eq(P.id,e)).run();}else r.db.insert(P).values({id:e,platform:t.platform,workspace_id:n,title:t.title??null,title_locked:t.titleLocked?1:0,message_count:0,created_at:s,updated_at:s}).run();}catch(n){throw n instanceof D?n:new D("DB_ERROR","Failed to upsert thread",n)}finally{r.close();}}ensureThread(e,t,r){let n=this.openHandle(true);try{let s=r?this.validateWorkspaceId(n,r):null,i=n.db.select({id:P.id,platform:P.platform,workspace_id:P.workspace_id}).from(P).where(drizzleOrm.eq(P.id,e)).limit(1).get();if(i){s&&!i.workspace_id&&n.db.update(P).set({workspace_id:s}).where(drizzleOrm.eq(P.id,e)).run();return}let a=new Date().toISOString();n.db.insert(P).values({id:e,platform:t,workspace_id:s,message_count:0,created_at:a,updated_at:a}).run();}catch(s){throw s instanceof D?s:new D("DB_ERROR","Failed to ensure thread",s)}finally{n.close();}}saveUserMessage(e,t,r){if(!this.dbExists())return;let n=this.openHandle(true);try{let s=new Date().toISOString();n.db.run(drizzleOrm.sql`
|
|
52
52
|
UPDATE threads
|
|
53
53
|
SET first_message = COALESCE(first_message, ${t}),
|
|
54
54
|
title = CASE WHEN title_locked = 0 AND title IS NULL THEN substr(${t}, 1, 60) ELSE title END,
|
|
@@ -59,11 +59,11 @@ ${t.join(`
|
|
|
59
59
|
`);}catch(s){throw s instanceof D?s:new D("DB_ERROR","Failed to save user message",s)}finally{n.close();}}saveAssistantMessage(e,t,r){if(!this.dbExists())return;let n=this.openHandle(true);try{let s=new Date().toISOString();n.db.update(P).set({last_message:t,updated_at:s}).where(drizzleOrm.eq(P.id,e)).run();}catch(s){throw s instanceof D?s:new D("DB_ERROR","Failed to save assistant message",s)}finally{n.close();}}updateThread(e,t){if(!this.dbExists())return;let r=this.openHandle(true);try{let n={updated_at:new Date().toISOString()};t.title!==void 0&&(n.title=t.title,n.title_locked=1),t.titleLocked!==void 0&&(n.title_locked=t.titleLocked?1:0),r.db.update(P).set(n).where(drizzleOrm.eq(P.id,e)).run();}catch(n){throw n instanceof D?n:new D("DB_ERROR","Failed to update thread",n)}finally{r.close();}}};function ns(o){return o.replace(/<conversation_history[^>]*>[\s\S]*?<\/conversation_history>/g,"").split(`
|
|
60
60
|
`).filter(n=>!(n.startsWith("Loaded ")&&n.includes("layouts from")||n.includes("[dotenv@")||n.includes("[Nest]")&&n.includes("DEBUG")||n.startsWith("Registered custom layout:")||n.startsWith("Updated custom layout:"))).join(`
|
|
61
61
|
`).trim()}function os(o){if(!o)return "";let e=o;try{let t=JSON.parse(e);Array.isArray(t)?e=t.filter(r=>r?.type==="text"&&r?.text).map(r=>r.text).join(`
|
|
62
|
-
`):t&&typeof t=="object"&&t.result!==void 0&&(e=t.result||"");}catch{e=ns(e);}return e}var yt=class{dbPath;constructor(e){this.dbPath=e??H.join(Mo.homedir(),".crewx","crewx.db");}getThreadRepo(){return new ft({dbPath:this.dbPath})}updateThread(e,t){this.getThreadRepo().updateThread(e,{title:t.title});}async ensureThread(e,t,r){let n=this.getThreadRepo(),s=n.findThreadById(e);if(s){if(s.platform!==t)throw new Error(`Thread '${e}' already exists with platform '${s.platform}' \u2014 cannot change to '${t}' (platform is immutable)`);return}n.ensureThread(e,t,r);}async fetchHistory(e,t){let r=t?.limit??100,n=this.getThreadRepo(),s=n.findThreadById(e),i=n.findTopLevelTasks(e),a=new Set(["done","completed","success"]);i=i.filter(
|
|
63
|
-
${i.message}`)}let s=Ye(n);if(s.documents&&typeof s.documents=="object"){let i={};for(let[a,d]of Object.entries(s.documents))if(d&&typeof d=="object"){let u=d;typeof u.path=="string"&&!H.isAbsolute(u.path)?i[a]={...u,path:H.resolve(r,u.path)}:i[a]=u;}else i[a]=d;return {...s,documents:i}}return s}static mergeCrewxConfig(e,t){let r=new Map;for(let w of e.agents??[])r.set(w.id,w);for(let w of t.agents??[])r.has(w.id)&&console.warn(`[agent-loader] User agent "${w.id}" overrides built-in`),r.set(w.id,w);let n=Array.from(r.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,d=t,u=en(a.vars,d.vars),c=en(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 g=[...e.hooks??[],...t.hooks??[]],f=Cs(a.providers,d.providers),y={...e},R={...t};for(let w of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete y[w],delete R[w];let _={...{...y,...R},agents:n,layouts:s,documents:i,skills:p};return g.length>0&&(_.hooks=g),u!==void 0&&(_.vars=u),c!==void 0&&(_.settings=c),f!==void 0&&(_.providers=f),_}static async loadYaml(e,t,r){let n=t?.includeBuiltIns!==false,s,i;if(n){let c=await o.loadBuiltInConfig(r);if(e!==void 0){let p=Ze(e);s=o.mergeCrewxConfig(c,p),i=H.dirname(e);}else s=c,i=process.cwd();}else {if(e===void 0)throw new Error("[@crewx/sdk] loadYaml: path is required when includeBuiltIns is false");s=Ze(e),i=H.dirname(e);}let a=new he(r);await a.load(s.documents,i);let d=s.agents??[];await tn(d,s,t);let u=new o(d,t??{},s,a,i);return await u.use(new qe),u}static async fromConfig(e,t,r,n){let s=t?.includeBuiltIns===true,i=e;if(s){let c=await o.loadBuiltInConfig(n);i=o.mergeCrewxConfig(c,e);}let a=new he(n);await a.load(i.documents,r??(typeof process<"u"?process.cwd():"/"));let d=i.agents??[];await tn(d,i,t);let u=new o(d,t??{},i,a,r);return await u.use(new qe),u}get agents(){return this._agents}get config(){return this._config}get plugins(){return this._plugins}get tools(){return this._tools}get workspaceId(){return this._workspaceId}get workspaceName(){return this._workspaceName}getAgent(e){let t=e.startsWith("@")?e.slice(1):e;return this._agents.get(t)}getRemoteProviderConfig(e){let t=this._config?.providers;return Array.isArray(t)?t.find(n=>n.type==="remote"&&n.id===e):void 0}computeTaskLogPath(e,t){let r=Ht(t);return H.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 Bt(this,e)}async registerChannelAdapter(e){let{adapter:t,instanceId:r,config:n}=e;if(this._activeAdapters.has(r))throw new Error(`Adapter instance already registered: ${r}`);let s=new Set(t.manifest.capabilities),i=e.store??Ft(r),a=e.defaultMode??"query",d=t.manifest.platform,u=e.agentRunner??{run:async(f,y,R)=>{let _=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${f}`,y,{threadId:R?.threadId,platform:d});return {output:_.ok?_.data:_.error?.message??""}}},c=e.onInbound??(async f=>{let y=f.routingHints?.agentId??e.defaultAgent;if(!y)return {accepted:false,reason:"no_agent"};let{output:R}=await u.run(y,f.text,{threadId:f.threadId});return {accepted:true,output:R}}),p=Ut({instanceId:r,config:n,capabilities:s,db:i,agentRunner:u,onInbound:c}),g={adapter:t,ctx:p,state:"starting"};this._activeAdapters.set(r,g),this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"starting",timestamp:new Date});try{await t.start(p),g.state="started",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"started",timestamp:new Date});}catch(f){throw g.state="failed",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"failed",error:f instanceof Error?f:new Error(String(f)),timestamp:new Date}),this._activeAdapters.delete(r),f}}async unregisterChannelAdapter(e){let t=this._activeAdapters.get(e);if(t){t.state="stopping",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopping",timestamp:new Date});try{await t.adapter.stop(t.ctx),t.state="stopped",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopped",timestamp:new Date});}catch(r){t.state="failed",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"failed",error:r instanceof Error?r:new Error(String(r)),timestamp:new Date});}finally{this._activeAdapters.delete(e);}}}async stopAllAdapters(e={}){let t=e.timeoutMs??1e4,r=Array.from(this._activeAdapters.keys()),n=await Promise.allSettled(r.map(s=>Promise.race([this.unregisterChannelAdapter(s),new Promise((i,a)=>setTimeout(()=>a(new Error(`Adapter stop timeout: ${s}`)),t))])));for(let s=0;s<n.length;s++)n[s].status==="rejected"&&console.error(`[crewx] adapter stop error (${r[s]}): ${n[s].reason}`);}async close(){await this.stopAllAdapters({timeoutMs:1e4});let e=[...this._remoteTargets.values()];this._remoteTargets.clear(),await Promise.allSettled(e.map(async r=>{try{await(await r).close();}catch(n){console.error(`[crewx] remote target close error: ${n instanceof Error?n.message:String(n)}`);}}));let t=[...this._plugins].reverse();for(let r of t)try{await r.detach(this);}catch(n){console.error(`[crewx] plugin ${r.name} detach error: ${n instanceof Error?n.message:String(n)}`);}this._plugins.length=0;}filterAgents(e){let t=a=>a?a.split(",").map(d=>d.trim().toLowerCase()).filter(Boolean):void 0,r=t(e.role),n=t(e.team),s=t(e.provider),i=Array.from(this._agents.values());return r&&(i=i.filter(a=>a.role&&r.some(d=>Q(a.role.toLowerCase(),d)))),n&&(i=i.filter(a=>a.team&&n.some(d=>Q(a.team.toLowerCase(),d)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(u=>s.some(c=>Q(u.toLowerCase(),c))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,r=this._agents.get(t);if(!r)throw new re(t,Array.from(this._agents.keys()));return r.inline?.prompt??r.inline?.system_prompt??r.description??`You are an expert ${t}.`}async renderPrompt(e,t){let n={...await this._documentLoader.buildContext(),...t?.documents??{}},s={...t,documents:n};return this._templateEngine.render(e,s)}registerLayout(e,t){this._layoutLoader.registerLayout(e,t);}async renderAgentPromptFull(e,t){let r=e.startsWith("@")?e.slice(1):e,n=this._agents.get(r);if(!n)throw new re(r,Array.from(this._agents.keys()));let s=this._resolveLayoutSpec(n,t?.layout),i=this._extractLayoutId(s),a=this._extractLayoutProps(n,s,t?.layout),d=this._layoutLoader.load(i,a),u=n.inline?.prompt??n.inline?.system_prompt??n.description??`You are an expert ${r}.`,c=await this._documentLoader.buildContext(),p=t?.env??(typeof process<"u"?process.env:{}),g=t?.vars?.security_key??bs(),f={...t?.vars??{},documents:c,env:p,agent:{id:n.id,name:n.name??n.id,role:n.role??"",team:n.team??"",description:n.description??""}},y=await this._templateEngine.render(u,f),R={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},x=n.provider,_=Array.isArray(x)?x:typeof x=="string"&&x.length>0?[x]:[],w=_.join(", ")||(typeof x=="string"?x:""),b=n.options,T=!Array.isArray(b)&&typeof b=="object"&&b!==null?b:void 0,M=Array.isArray(b)?b:void 0,$={};for(let[h,E]of Object.entries(c))$[h]={content:E.content??"",toc:E.toc,summary:E.summary,path:E.path};let C={user_input:t?.vars?.user_input??void 0,agent:{id:n.id,name:n.name??n.id,role:n.role??"",team:n.team??"",description:n.description??"",provider:w,providerList:_,model:n.inline?.model,workingDirectory:n.working_directory??n.workingDirectory??".",inline:{...n.inline??{},prompt:y},specialties:n.specialties??[],capabilities:n.capabilities??[],remote:n.remote??null,optionsByMode:T,optionsArray:M},agentMetadata:{specialties:n.specialties??[],capabilities:n.capabilities??[],description:n.description??""},documents:$,skills:t?.skills??[],session:R,env:p,vars:{security_key:g,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:R.platform,mode:R.mode,messages:t?.messages??[],tools:this._tools.size>0?{list:Array.from(this._tools.values()).map(h=>({name:h.name,description:h.description,parameters:h.parameters})),json:JSON.stringify(Array.from(this._tools.values()).map(h=>({name:h.name,description:h.description,parameters:h.parameters})),null,2),count:this._tools.size}:null,metadata:{}};return this._layoutRenderer.render(d,C)}_filterToolsByMode(e){return e?e.map(t=>this._tools.get(t)).filter(t=>t!==void 0):Array.from(this._tools.values())}_resolveLayoutSpec(e,t){if(t!==void 0)return t;let r=e.inline?.layout;if(r!==void 0)return r;let n=this._config?.layouts?.default;return typeof n=="string"&&n?n:"crewx/default"}_extractLayoutId(e){if(typeof e=="string")return e;if("id"in e)return e.id;let t=`crewx/__inline_${Date.now()}`;return this._layoutLoader.registerLayout(t,e.template),t}_extractLayoutProps(e,t,r){let n=e.inline?.layout,s=n&&typeof n=="object"&&"props"in n?n.props:void 0,i=r&&typeof r=="object"&&"id"in r?r.props:void 0;if(s||i)return {...s??{},...i??{}}}_getConversationProvider(){return this._plugins.find(t=>t.name==="conversation")?.conversationProvider}async _fetchHistoryMessages(e,t,r){if(r&&r.length>0)return r;if(!e)return;let n=this._getConversationProvider();if(n)try{let s=await n.fetchHistory(e,{currentTraceId:t});return s.messages.length===0?void 0:Wt(s)}catch{return}}_resolveTimeout(e){let t=wr();return e==="query"?t.queryMs:t.executeMs}emitToolEvents(e,t,r,n,s,i,a){try{let u=exports.BUILTIN_ADAPTERS[r]?.parseEvent?.(n)??Et(new Date().toISOString(),n);for(let c of u)c.type==="tool_use"&&c.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:c.toolName,rawName:c.toolName,input:c.toolInput?this.tryParseJson(c.toolInput):void 0,toolUseId:c.toolUseId}}),c.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:c.toolName??"unknown",rawName:c.toolName??"unknown",toolUseId:c.toolUseId,result:c.resultPreview,isError:c.isError}});}catch{}}tryParseJson(e){try{return JSON.parse(e)}catch{return e}}async query(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.query(n.agentRef,t,r);let s=Date.now(),i=we("tsk"),a=new Date,d;try{d=tt(e,Array.from(this._agents.values()));}catch(h){if(h instanceof re){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let E=Date.now()-s,v={code:"AGENT_NOT_FOUND",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:E,error:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:E}}}throw h}let u=Array.isArray(d.provider)?d.provider[0]??"cli/claude":d.provider,c=r?.provider??u,p=r?.model??d.inline?.model,g;try{g=ne(c);}catch(h){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let E=Date.now()-s,v={code:"PROVIDER_ERROR",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:E,error:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:d.id,provider:c,model:p,durationMs:E}}}let f=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),y;try{y=await this.renderAgentPromptFull(e,{session:{mode:"query",platform:r?.platform},vars:{user_input:t},messages:f});}catch{}let R,x,_,w=p,b=false,T=h=>{b||(b=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",pid:h,model:w,provider:c,codingAgentCommand:R,renderedPrompt:y,metadata:{...r?.metadata??{},provider:c},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},M=d.options,$=Array.isArray(M?.query?.tools)?M.query.tools:void 0,L=this._tools.size>0?this._filterToolsByMode($):[],C=d.inline?.max_steps;c.startsWith("api/")&&T();try{let h=await g.query(t,{model:p,context:r?.context,systemPrompt:y??d.inline?.system_prompt??d.inline?.prompt,additionalArgs:Array.isArray(M?.query)?M.query:void 0,tools:L.length>0?L:void 0,maxSteps:C,timeoutMs:this._resolveTimeout("query"),env:{CREWX_AGENT_ID:d.id,CREWX_AGENT_ROLE:d.role??"",CREWX_AGENT_TEAM:d.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:c,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,a)},onPid:v=>T(v),onOutput:(v,W)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:v,level:W}),W==="stdout"&&this.emitToolEvents(i,e,c,v,d.id,r?.threadId??"","");},onCommand:v=>{R=v;},onUsage:v=>{x=v;},onExitCode:v=>{_=v;},onModel:v=>{w||(w=v);}});T();let E=Date.now()-s;return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:h,durationMs:E,exitCode:_,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:w,metadata:{...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}}}),{ok:!0,data:h,meta:{agentId:d.id,provider:c,model:p,durationMs:E}}}catch(h){if(h instanceof exports.ClientToolCallRequiredError){let W=we("thd");return this._pendingThreads.set(W,{agentRef:d.id,providerStr:c,continuationState:h.continuationState,toolCall:h.toolCall,traceId:i,startMs:s,model:p}),{ok:true,status:"requires_action",data:"",toolCall:h.toolCall,threadId:W,meta:{agentId:d.id,provider:c,model:p,durationMs:Date.now()-s}}}T();let E=Date.now()-s,v={code:"QUERY_FAILED",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:E,error:v,exitCode:_,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:w,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:d.id,provider:c,model:p,durationMs:E}}}}async continueQuery(e,t){let r=this._pendingThreads.get(e);if(!r)return {ok:false,data:"",error:{code:"THREAD_NOT_FOUND",message:`No pending thread: ${e}`},meta:{agentId:"",provider:"",durationMs:0}};this._pendingThreads.delete(e);let n=ne(r.providerStr);if(!n.continueWithToolResults)return {ok:false,data:"",error:{code:"UNSUPPORTED",message:"Provider does not support client tool continuation"},meta:{agentId:r.agentRef,provider:r.providerStr,durationMs:0}};let s=t.map(i=>({...i,toolName:r.toolCall.toolCallId===i.toolCallId?r.toolCall.toolName:i.toolCallId}));try{let i=await n.continueWithToolResults(r.continuationState,s),a=Date.now()-r.startMs;return this.emit("task:end",{traceId:r.traceId,timestamp:new Date,agentRef:r.agentRef,mode:"query",result:i,durationMs:a}),{ok:!0,status:"complete",data:i,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}catch(i){if(i instanceof exports.ClientToolCallRequiredError)return this._pendingThreads.set(e,{...r,continuationState:i.continuationState,toolCall:i.toolCall}),{ok:true,status:"requires_action",data:"",toolCall:i.toolCall,threadId:e,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:Date.now()-r.startMs}};let a=Date.now()-r.startMs;return {ok:false,data:"",error:{code:"CONTINUE_FAILED",message:i.message},meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}}async execute(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.execute(n.agentRef,t,r);let s=Date.now(),i=we("tsk"),a=new Date,d;try{d=tt(e,Array.from(this._agents.values()));}catch(h){if(h instanceof re){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let E=Date.now()-s,v={code:"AGENT_NOT_FOUND",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:E,error:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:E}}}throw h}let u=Array.isArray(d.provider)?d.provider[0]??"cli/claude":d.provider,c=r?.provider??u,p=r?.model??d.inline?.model,g;try{g=ne(c);}catch(h){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let E=Date.now()-s,v={code:"PROVIDER_ERROR",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:E,error:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:d.id,provider:c,model:p,durationMs:E}}}let f=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),y;try{y=await this.renderAgentPromptFull(e,{session:{mode:"execute",platform:r?.platform},vars:{user_input:t},messages:f});}catch{}let R,x,_,w=p,b=false,T=h=>{b||(b=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",pid:h,model:w,provider:c,codingAgentCommand:R,renderedPrompt:y,metadata:{...r?.metadata??{},provider:c},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},M=d.options,$=Array.isArray(M?.execute?.tools)?M.execute.tools:void 0,L=this._tools.size>0?this._filterToolsByMode($):[],C=d.inline?.max_steps;c.startsWith("api/")&&T();try{let h=await g.execute(t,{model:p,context:r?.context,systemPrompt:y??d.inline?.system_prompt??d.inline?.prompt,additionalArgs:Array.isArray(M?.execute)?M.execute:void 0,tools:L.length>0?L:void 0,maxSteps:C,timeoutMs:this._resolveTimeout("execute"),env:{CREWX_AGENT_ID:d.id,CREWX_AGENT_ROLE:d.role??"",CREWX_AGENT_TEAM:d.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:c,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,a)},onPid:v=>T(v),onOutput:(v,W)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:v,level:W}),W==="stdout"&&this.emitToolEvents(i,e,c,v,d.id,r?.threadId??"","");},onCommand:v=>{R=v;},onUsage:v=>{x=v;},onExitCode:v=>{_=v;},onModel:v=>{w||(w=v);}});T();let E=Date.now()-s;return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:h,durationMs:E,exitCode:_,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:w,metadata:{...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}}}),{ok:!0,data:h,meta:{agentId:d.id,provider:c,model:p,durationMs:E}}}catch(h){T();let E=Date.now()-s,v={code:"EXECUTE_FAILED",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:E,error:v,exitCode:_,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:w,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:d.id,provider:c,model:p,durationMs:E}}}}};function en(o,e){let t=tr(o)?o:void 0,r=tr(e)?e:void 0;if(!(!t&&!r))return {...t??{},...r??{}}}function tr(o){return typeof o=="object"&&o!==null&&!Array.isArray(o)}function Cs(o,e){let t=Array.isArray(o)?o:void 0,r=Array.isArray(e)?e:void 0;if(!t&&!r)return;let n=a=>{if(!tr(a))return;let d=a.id;if(typeof d=="string")return `id:${d}`;let u=a.name;if(typeof u=="string")return `name:${u}`},s=new Set;for(let a of r??[]){let d=n(a);d&&s.add(d);}let i=[];for(let a of t??[]){let d=n(a);d&&s.has(d)||i.push(a);}for(let a of r??[])i.push(a);return i}async function tn(o,e,t){if(o.some(n=>(Array.isArray(n.provider)?n.provider:[n.provider]).some(i=>i.startsWith("api/")))){let{registerApiProviders:n}=await Promise.resolve().then(()=>(Xt(),zr));n(t?.api);}As(o,e),Ts(o,e);}function As(o,e){if(!o.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("remote/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createRemoteProviderFactory:n}=(Yt(),cr(Kr)),s=new Map;for(let i of r)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&Ae("remote",n(s,ne));}function Ts(o,e){if(!o.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("plugin/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createPluginProviderFactory:n}=(Zt(),cr(Qr)),s=new Map;for(let i of r)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&Ae("plugin",n(s));}l();var Es="crewx:fs:",rr=class{prefix;store;constructor(e){this.prefix=e?.prefix??Es,this.store=e?.storage??new Map;}async readFile(e){let t=this.toKey(e),r=this.store.get(t);if(r===void 0)throw new Error(`BrowserFsAdapter: file not found: ${e}`);return r}async exists(e){return this.store.has(this.toKey(e))}resolvePath(...e){let t=e.map(i=>i.replace(/\\/g,"/")).join("/").replace(/\/+/g,"/"),r=t.split("/"),n=[];for(let i of r)i==="."||i===""||(i===".."?n.pop():n.push(i));let s=n.join("/");return t.startsWith("/")?`/${s}`:s}isAbsolute(e){return e.startsWith("/")}setItem(e,t){this.store.set(this.toKey(e),t);}removeItem(e){this.store.delete(this.toKey(e));}keys(){return Array.from(this.store.keys()).filter(e=>e.startsWith(this.prefix)).map(e=>e.slice(this.prefix.length))}toKey(e){return `${this.prefix}${e.replace(/\\/g,"/")}`}};l();function Ss(o,e){let t=o.skills?.include;if(t===void 0)return [...e];if(t.length===0)return [];let r=new Set(t);return e.filter(n=>r.has(n))}ye();Jt();Xt();Rt();Ce();l();var nr=0;function Is(o){let e=Array.from(o.agents.keys());return {name:"delegate_to_agent",description:`Delegate a task to another agent. Available agents: ${e.join(", ")}`,parameters:{type:"object",properties:{agent:{type:"string",description:`Agent ID to delegate to. One of: ${e.join(", ")}`},message:{type:"string",description:"Task description for the target agent"},mode:{type:"string",description:'Execution mode: "query" for questions, "execute" for actions. Default: query'}},required:["agent","message"]},execute:async t=>{if(nr>=3)return "Error: Maximum delegation depth (3) reached. Cannot delegate further.";let r=t.agent,n=t.message,s=t.mode??"query";if(!e.includes(r))return `Error: Unknown agent "${r}". Available: ${e.join(", ")}`;nr++;try{if(s==="execute"){let a=await o.execute(r,n);return a.ok?a.data:`Error: ${a.error?.message??"Unknown error"}`}let i=await o.query(r,n);return i.ok?i.data:`Error: ${i.error?.message??"Unknown error"}`}finally{nr--;}}}}l();var rn=typeof process<"u"?process.env:{};function Os(){return rn.CREWX_CLI||"npx crewx"}function Ms(){return rn.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}l();var Ds=/^[a-zA-Z0-9._-]+$/,or=class{constructor(e){this.storage=e;}storage;listBoxes(e){this.validateId(e);let r=this.storage.listBoxes(e).map(n=>this.toBoxResponse(n));return {boxes:r,total:r.length}}getBox(e,t){this.validateId(e),this.validateId(t);let r=this.storage.findBox(e,t);return r?this.toBoxResponse(r):null}createBox(e,t){this.validateId(e);let r=this.generateBoxId(),n=new Date().toISOString(),s=this.storage.insertBox(e,{id:r,seq:t.seq,firstTaskId:t.firstTaskId,midTaskId:t.midTaskId,lastTaskId:t.lastTaskId,taskCount:t.taskCount,summary:t.summary??null,sourceTokens:t.sourceTokens,summaryTokens:t.summaryTokens??null,createdAt:n});return this.toBoxResponse(s)}toBoxResponse(e){return {id:e.id,threadId:e.thread_id,seq:e.seq,firstTaskId:e.first_task_id,lastTaskId:e.last_task_id,taskCount:e.task_count,sourceTokens:e.source_tokens,summaryTokens:e.summary_tokens,summary:e.summary,previewFirst:this.storage.getTaskPreview(e.first_task_id,200),previewMid:this.storage.getTaskPreview(e.mid_task_id,200),previewLast:this.storage.getTaskPreview(e.last_task_id,200),createdAt:e.created_at}}validateId(e){if(!Ds.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return we("box")}};l();function Ns(o,e,t,r,n){let{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}=r,d=s*i,u=s*a,c=d+u,p=e.getThreadMessages(o),g=[],f=0,y=false,R=[];for(let w=0;w<p.length;w+=2){let b=p[w],T=p[w+1],M=b?.content||"",$=T?.content||"",L=n.countTokens(M+$),C=[];b&&C.push(b),T&&C.push(T),R.push({messages:C,tokens:L});}for(let w=R.length-1;w>=0;w--){let b=R[w];if(f+b.tokens>d){y=true;break}f+=b.tokens,g.unshift(...b.messages);}let x=[],_=0;if(y&&u>0)try{let{boxes:w}=t.listBoxes(o);for(let b=w.length-1;b>=0;b--){let T=w[b],M=T.summaryTokens??T.sourceTokens;if(_+M>u)break;_+=M,x.unshift({boxId:T.id,seq:T.seq,taskCount:T.taskCount,sourceTokens:T.sourceTokens,summary:T.summary,previewFirst:T.previewFirst,previewMid:T.previewMid,previewLast:T.previewLast,createdAt:T.createdAt});}}catch(w){if(w instanceof Error&&!/not found/i.test(w.message))throw w}return {hot:g,warm:x,hotTokens:f,warmTokens:_,hotOverflow:y,totalBudget:c,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}Ce();fe();l();var ht=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},Je=class{constructor(e={}){this.defaults=e;}defaults;metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0};async run(e,t={}){if(!Array.isArray(e))throw new TypeError("ParallelRunner.run expects an array of tasks");if(e.length===0)return this.metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0},[];let r=this.mergeOptions(t),n=Math.max(1,r.maxConcurrency??5),s=r.timeoutMs,i=r.failFast??false,a=r.callbacks,d=r.evaluateTaskSuccess??(()=>true),u=[],c=0,p=0,g=0,f=false,y=0,R=perf_hooks.performance.now(),x=async C=>{a?.onTaskStart&&await a.onTaskStart(C),g+=1;let h=new AbortController,E={signal:h.signal},v,W;typeof s=="number"&&Number.isFinite(s)&&s>0&&(W=new Promise((ce,ue)=>{v=setTimeout(()=>{let pe=new ht(C.id,s);h.abort(pe),ue(pe);},s);}));let Ge=perf_hooks.performance.now(),xt=C.run(E),hn=W?Promise.race([xt,W]):xt;try{let ce=await hn,ue=perf_hooks.performance.now(),pe=ue-Ge,Re=d(ce,C),Qe={taskId:C.id,success:Re,value:ce,durationMs:pe,startedAt:Ge,finishedAt:ue,metadata:C.metadata,aborted:!1};u.push(Qe),Re?c+=1:p+=1,a?.onTaskComplete&&await a.onTaskComplete(Qe),i&&!Re&&(f=!0);}catch(ce){let ue=perf_hooks.performance.now(),pe=ue-Ge,Re=ce instanceof Error?ce:new Error(String(ce)),Qe={taskId:C.id,success:false,error:Re,durationMs:pe,startedAt:Ge,finishedAt:ue,metadata:C.metadata,aborted:h.signal.aborted};u.push(Qe),p+=1,a?.onError&&await a.onError(C,Re,pe),i&&(f=true);}finally{v&&clearTimeout(v),W&&xt.catch(()=>{});}},_=async()=>{for(;!f;){let C=y;if(C>=e.length)break;y+=1;let h=e[C];if(!h||(await x(h),f))break}},w=Math.min(n,e.length),b=[];for(let C=0;C<w;C++)b.push(_());await Promise.all(b);let M=perf_hooks.performance.now()-R,$=u.length?u.reduce((C,h)=>C+h.durationMs,0)/u.length:0,L=M>0?u.length/(M/1e3):u.length;return this.metrics={totalTasks:e.length,startedTasks:g,completedTasks:u.length,successCount:c,failureCount:p,totalDurationMs:M,averageDurationMs:$,throughput:L},u}getMetrics(){return this.metrics}mergeOptions(e){return {maxConcurrency:e.maxConcurrency??this.defaults.maxConcurrency,timeoutMs:e.timeoutMs??this.defaults.timeoutMs,failFast:e.failFast??this.defaults.failFast,evaluateTaskSuccess:e.evaluateTaskSuccess??this.defaults.evaluateTaskSuccess,callbacks:this.mergeCallbacks(this.defaults.callbacks,e.callbacks)}}mergeCallbacks(e,t){if(!(!e&&!t))return {onTaskStart:async r=>{e?.onTaskStart&&await e.onTaskStart(r),t?.onTaskStart&&await t.onTaskStart(r);},onTaskComplete:async r=>{e?.onTaskComplete&&await e.onTaskComplete(r),t?.onTaskComplete&&await t.onTaskComplete(r);},onError:async(r,n,s)=>{e?.onError&&await e.onError(r,n,s),t?.onError&&await t.onError(r,n,s);}}}};l();l();var Xe=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 nn=3,on=3e4,sn=500,Ls=o=>{if(typeof o!="number"||Number.isNaN(o)||!Number.isFinite(o))return nn;let e=Math.floor(o);return e>0?e:nn},$s=o=>o===void 0||typeof o!="number"||Number.isNaN(o)||o<=0?on:o,js=o=>{if(!o)return {maxRetries:0,retryDelay:sn};let e=Number.isInteger(o.maxRetries)&&o.maxRetries>=0?o.maxRetries:0,t=typeof o.retryDelay=="number"&&o.retryDelay>=0?o.retryDelay:sn;return {maxRetries:e,retryDelay:t}},sr=o=>{let e=o.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},Hs=(o,e)=>o<=0?Promise.resolve():new Promise((t,r)=>{let n=setTimeout(()=>{e.removeEventListener("abort",s),t();},o),s=()=>{clearTimeout(n),r(sr(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),Fs=async(o,e,t)=>{let r,n;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw sr(t);try{let i=await o();if(r=i,i.success||s===e.maxRetries)return i}catch(i){if(n=i,t.aborted)throw sr(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await Hs(e.retryDelay,t);}if(r)return r;throw n?n instanceof Error?n:new Error(String(n)):new Error("Parallel helper encountered an unexpected state")},an=(o,e,t)=>{e.completed+=1,t?e.success+=1:e.failure+=1;try{o.onProgress?.(e.completed,e.total);}catch(r){process.env.NODE_ENV!=="production"&&console.warn("Parallel helper onProgress callback threw an error:",r);}},qs=o=>o.map(t=>({metadata:t.metadata,taskResult:t})).slice().sort((t,r)=>t.metadata.index-r.metadata.index).map(({metadata:t,taskResult:r})=>{if(r.value){let s=r.value;return {...s,agentId:s.agentId??t.request.agentId,metadata:{...s.metadata,requestIndex:t.index,mode:t.mode}}}let n=r.error??new Error("Unknown error");return {agentId:t.request.agentId,content:n.message,success:false,metadata:{error:n.message,aborted:r.aborted??false,requestIndex:t.index,mode:t.mode}}}),Us=o=>o.filter(e=>!e.success).map(e=>{let t=e.metadata;if(e.error instanceof Error)return {index:t.index,error:e.error};if(e.value&&!e.value.success){let r=String(e.value.metadata?.error??e.value.content??"Agent returned unsuccessful result");return {index:t.index,error:new Error(r)}}return {index:t.index,error:new Error("Unknown failure")}}),Ws=(o,e)=>({onTaskComplete:async t=>{an(e,o,t.success);},onError:async()=>{an(e,o,false);}}),dn=async(o,e,t={})=>{if(!Array.isArray(o))throw new TypeError("Parallel helpers expect an array of requests");if(o.length===0){let x={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?.(x),[]}let r=Ls(t.concurrency),n=$s(t.timeout),s=js(t.retryPolicy),i=new Je,a=new Xe,d=o.map((R,x)=>({id:`${e}:${R.agentId??"anonymous"}:${x}`,metadata:{index:x,mode:e,request:R},run:_=>Fs(()=>e==="query"?a.query(R):a.execute(R),s,_.signal)})),u={completed:0,success:0,failure:0,total:o.length},c=await i.run(d,{maxConcurrency:r,timeoutMs:n,evaluateTaskSuccess:R=>R.success,callbacks:Ws(u,t)}),p=qs(c),g=Us(c),f=i.getMetrics(),y={total:o.length,completed:o.length,successCount:p.filter(R=>R.success).length,failureCount:p.filter(R=>!R.success).length,results:p,errors:g,metrics:f};return t.onComplete?.(y),p},Bs=(o,e)=>dn(o,"query",e),zs=(o,e)=>dn(o,"execute",e);Zt();Yt();Qt();Gt();l();l();var wt=class{capabilities={required:[]}};l();l();l();var ln=2e3;function cn(o){let e=o.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f\u2028\u2029]/g,"");return e.length<=ln?e:e.slice(0,ln-11)+" [redacted]"}var Zs=10*1024*1024,ei={b:1,kb:1024,mb:1024*1024,gb:1024*1024*1024};function ir(o,e){return o===void 0?true:Array.isArray(o)?o.includes(e):o===e}function ti(o,e){return o===void 0?true:Array.isArray(o)?o.some(t=>e.includes(t)):e.includes(o)}function pn(o){if(typeof o=="number")return o;let e=o.match(/^(\d+(?:\.\d+)?)\s*(b|kb|mb|gb)?$/i);if(!e)return 0;let t=parseFloat(e[1]),r=(e[2]??"b").toLowerCase();return Math.floor(t*(ei[r]??1))}function gn(o){return typeof o=="string"}function mn(o){try{let e=fs$1.statSync(o);return e.size>Zs?(process.stderr.write(`[YamlHookPlugin] File too large for line count: ${o} (${e.size} bytes)
|
|
62
|
+
`):t&&typeof t=="object"&&t.result!==void 0&&(e=t.result||"");}catch{e=ns(e);}return e}var yt=class{dbPath;constructor(e){this.dbPath=e??H.join(Mo.homedir(),".crewx","crewx.db");}getThreadRepo(){return new ft({dbPath:this.dbPath})}updateThread(e,t){this.getThreadRepo().updateThread(e,{title:t.title});}async ensureThread(e,t,r){let n=this.getThreadRepo(),s=n.findThreadById(e);if(s){if(s.platform!==t)throw new Error(`Thread '${e}' already exists with platform '${s.platform}' \u2014 cannot change to '${t}' (platform is immutable)`);return}n.ensureThread(e,t,r);}async fetchHistory(e,t){let r=t?.limit??100,n=this.getThreadRepo(),s=n.findThreadById(e),i=n.findTopLevelTasks(e),a=new Set(["done","completed","success"]);i=i.filter(u=>(!u.status||a.has(u.status))&&(!t?.currentTraceId||u.trace_id!==t.currentTraceId)),i=i.slice(0,r);let d=s?.platform??"cli",c=this.rowsToMessages(i);return {threadId:e,platform:d,messages:c,metadata:{title:s?.title??void 0,firstMessage:s?.first_message??void 0,lastMessage:s?.last_message??void 0,messageCount:s?.message_count??0,updatedAt:s?.updated_at?new Date(s.updated_at).getTime():void 0}}}async saveUserMessage(e,t,r,n){this.getThreadRepo().saveUserMessage(e,t);}async saveAssistantMessage(e,t,r,n){this.getThreadRepo().saveAssistantMessage(e,t);}close(){}rowsToMessages(e){let t=[];for(let r of e){r.prompt&&t.push({id:`${r.id}-user`,text:r.prompt,isAssistant:false,timestamp:new Date(r.started_at).getTime()});let n=os(r.result);n&&t.push({id:`${r.id}-assistant`,text:n,isAssistant:true,timestamp:new Date(r.started_at).getTime()});}return t}};var qe=class extends Fe{name="conversation";_provider;unsubStart=null;unsubEnd=null;constructor(e){super(),this._provider=new yt(e?.dbPath);}get conversationProvider(){return this._provider}attach(e){this.unsubStart=e.on("task:start",async t=>{if(!t.threadId)return;let r=t.platform??"cli";try{await this._provider.ensureThread(t.threadId,r,t.workspaceId),await this._provider.saveUserMessage(t.threadId,t.message??"");}catch{}}),this.unsubEnd=e.on("task:end",async t=>{if(!t.result)return;let r=t.metadata?.threadId;if(!r)return;let n=t.agentRef?.replace(/^@/,"")??"";try{await this._provider.saveAssistantMessage(r,t.result,n);}catch{}});}detach(e){this.unsubStart?.(),this.unsubStart=null,this.unsubEnd?.(),this.unsubEnd=null,this._provider.close?.();}};l();function qr(o){let e=H__namespace.resolve(o);return process.platform==="win32"&&(e=e.replace(/\\/g,"/"),e=e.replace(/^([A-Z]):/,(t,r)=>`${r.toLowerCase()}:`)),e.length>1&&!/^[a-zA-Z]:\/$/.test(e)&&(e=e.replace(/\/+$/,"")),e}function Kt(o){let e=qr(o);return crypto$1.createHash("sha256").update(e).digest("hex")}function Ps(o){return o?o.settings?.template?.exec:void 0}function bs(){try{let o=new Uint8Array(8);return globalThis.crypto.getRandomValues(o),Array.from(o,e=>e.toString(16).padStart(2,"0")).join("")}catch{let{randomBytes:o}=F("crypto");return o(8).toString("hex")}}var er=class o extends He{_agents;_templateEngine;_documentLoader;_layoutLoader;_layoutRenderer;_config;_projectRoot;_workspaceId;_workspaceName;_plugins=[];_tools=new Map;_activeAdapters=new Map;_pendingThreads=new Map;_remoteFactory;_remoteTargets=new Map;constructor(e,t={},r,n,s){super(),this._agents=new Map(e.map(d=>[d.id,d])),this._config=r,this._projectRoot=s??(typeof process<"u"?process.cwd():"/");let i=s??(typeof process<"u"?process.env.CREWX_WORKSPACE??process.cwd():"/");this._workspaceId=Kt(i),this._workspaceName=H.basename(i);let a=Ps(r);this._templateEngine=new Ne({execPolicy:t.execPolicy??a}),this._documentLoader=n??new he,this._layoutLoader=new Le({templatesPath:Pe()}),this._layoutRenderer=new je,this._remoteFactory=t.remoteFactory;}async resolveFileRemoteTarget(e){let t=this.getAgent(e),r=Array.isArray(t?.provider)?t?.provider[0]:t?.provider;if(!r?.startsWith("remote/"))return null;let n=r.slice(7),s=this.getRemoteProviderConfig(n);if(!s?.location?.startsWith("file://"))return null;let i=H.resolve(s.location.replace("file://","")),a=s.external_agent_id??e.replace(/^@/,""),d=this._remoteTargets.get(i);d||(d=(this._remoteFactory??(f=>o.loadYaml(f)))(i),this._remoteTargets.set(i,d),d.catch(()=>this._remoteTargets.delete(i)));let c=await d,u=c.getAgent("@"+a),g=Array.isArray(u?.provider)?u?.provider[0]:u?.provider;if(g?.startsWith("remote/"))throw new Error(`Chained remotes not allowed: "${n}" \u2192 "${g}"`);return {target:c,agentRef:"@"+a}}static async loadBuiltInConfig(e){let{yamlPath:t,dir:r}=_t(),n;try{n=fs$1.readFileSync(t,"utf-8");}catch(i){throw new Error(`[@crewx/sdk] Cannot read built-in config: ${t}
|
|
63
|
+
${i.message}`)}let s=Ye(n);if(s.documents&&typeof s.documents=="object"){let i={};for(let[a,d]of Object.entries(s.documents))if(d&&typeof d=="object"){let c=d;typeof c.path=="string"&&!H.isAbsolute(c.path)?i[a]={...c,path:H.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 w of e.agents??[])r.set(w.id,w);for(let w of t.agents??[])r.has(w.id)&&console.warn(`[agent-loader] User agent "${w.id}" overrides built-in`),r.set(w.id,w);let n=Array.from(r.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,d=t,c=en(a.vars,d.vars),u=en(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 p=[...e.hooks??[],...t.hooks??[]],f=Cs(a.providers,d.providers),y={...e},R={...t};for(let w of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete y[w],delete R[w];let _={...{...y,...R},agents:n,layouts:s,documents:i,skills:g};return p.length>0&&(_.hooks=p),c!==void 0&&(_.vars=c),u!==void 0&&(_.settings=u),f!==void 0&&(_.providers=f),_}static async loadYaml(e,t,r){let n=t?.includeBuiltIns!==false,s,i;if(n){let u=await o.loadBuiltInConfig(r);if(e!==void 0){let g=Ze(e);s=o.mergeCrewxConfig(u,g),i=H.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=Ze(e),i=H.dirname(e);}let a=new he(r);await a.load(s.documents,i);let d=s.agents??[];await tn(d,s,t);let c=new o(d,t??{},s,a,i);return await c.use(new qe),c}static async fromConfig(e,t,r,n){let s=t?.includeBuiltIns===true,i=e;if(s){let u=await o.loadBuiltInConfig(n);i=o.mergeCrewxConfig(u,e);}let a=new he(n);await a.load(i.documents,r??(typeof process<"u"?process.cwd():"/"));let d=i.agents??[];await tn(d,i,t);let c=new o(d,t??{},i,a,r);return await c.use(new qe),c}get agents(){return this._agents}get config(){return this._config}get plugins(){return this._plugins}get tools(){return this._tools}get workspaceId(){return this._workspaceId}get workspaceName(){return this._workspaceName}getAgent(e){let t=e.startsWith("@")?e.slice(1):e;return this._agents.get(t)}getRemoteProviderConfig(e){let t=this._config?.providers;return Array.isArray(t)?t.find(n=>n.type==="remote"&&n.id===e):void 0}computeTaskLogPath(e,t){let r=Ht(t);return H.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 Bt(this,e)}async registerChannelAdapter(e){let{adapter:t,instanceId:r,config:n}=e;if(this._activeAdapters.has(r))throw new Error(`Adapter instance already registered: ${r}`);let s=new Set(t.manifest.capabilities),i=e.store??Ft(r),a=e.defaultMode??"query",d=t.manifest.platform,c=e.agentRunner??{run:async(f,y,R)=>{let _=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${f}`,y,{threadId:R?.threadId,platform:d});return {output:_.ok?_.data:_.error?.message??""}}},u=e.onInbound??(async f=>{let y=f.routingHints?.agentId??e.defaultAgent;if(!y)return {accepted:false,reason:"no_agent"};let{output:R}=await c.run(y,f.text,{threadId:f.threadId});return {accepted:true,output:R}}),g=Ut({instanceId:r,config:n,capabilities:s,db:i,agentRunner:c,onInbound:u}),p={adapter:t,ctx:g,state:"starting"};this._activeAdapters.set(r,p),this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"starting",timestamp:new Date});try{await t.start(g),p.state="started",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"started",timestamp:new Date});}catch(f){throw p.state="failed",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"failed",error:f instanceof Error?f:new Error(String(f)),timestamp:new Date}),this._activeAdapters.delete(r),f}}async unregisterChannelAdapter(e){let t=this._activeAdapters.get(e);if(t){t.state="stopping",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopping",timestamp:new Date});try{await t.adapter.stop(t.ctx),t.state="stopped",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopped",timestamp:new Date});}catch(r){t.state="failed",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"failed",error:r instanceof Error?r:new Error(String(r)),timestamp:new Date});}finally{this._activeAdapters.delete(e);}}}async stopAllAdapters(e={}){let t=e.timeoutMs??1e4,r=Array.from(this._activeAdapters.keys()),n=await Promise.allSettled(r.map(s=>Promise.race([this.unregisterChannelAdapter(s),new Promise((i,a)=>setTimeout(()=>a(new Error(`Adapter stop timeout: ${s}`)),t))])));for(let s=0;s<n.length;s++)n[s].status==="rejected"&&console.error(`[crewx] adapter stop error (${r[s]}): ${n[s].reason}`);}async close(){await this.stopAllAdapters({timeoutMs:1e4});let e=[...this._remoteTargets.values()];this._remoteTargets.clear(),await Promise.allSettled(e.map(async r=>{try{await(await r).close();}catch(n){console.error(`[crewx] remote target close error: ${n instanceof Error?n.message:String(n)}`);}}));let t=[...this._plugins].reverse();for(let r of t)try{await r.detach(this);}catch(n){console.error(`[crewx] plugin ${r.name} detach error: ${n instanceof Error?n.message:String(n)}`);}this._plugins.length=0;}filterAgents(e){let t=a=>a?a.split(",").map(d=>d.trim().toLowerCase()).filter(Boolean):void 0,r=t(e.role),n=t(e.team),s=t(e.provider),i=Array.from(this._agents.values());return r&&(i=i.filter(a=>a.role&&r.some(d=>Q(a.role.toLowerCase(),d)))),n&&(i=i.filter(a=>a.team&&n.some(d=>Q(a.team.toLowerCase(),d)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(c=>s.some(u=>Q(c.toLowerCase(),u))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,r=this._agents.get(t);if(!r)throw new re(t,Array.from(this._agents.keys()));return r.inline?.prompt??r.inline?.system_prompt??r.description??`You are an expert ${t}.`}async renderPrompt(e,t){let n={...await this._documentLoader.buildContext(),...t?.documents??{}},s={...t,documents:n};return this._templateEngine.render(e,s)}registerLayout(e,t){this._layoutLoader.registerLayout(e,t);}async renderAgentPromptFull(e,t){let r=e.startsWith("@")?e.slice(1):e,n=this._agents.get(r);if(!n)throw new re(r,Array.from(this._agents.keys()));let s=this._resolveLayoutSpec(n,t?.layout),i=this._extractLayoutId(s),a=this._extractLayoutProps(n,s,t?.layout),d=this._layoutLoader.load(i,a),c=n.inline?.prompt??n.inline?.system_prompt??n.description??`You are an expert ${r}.`,u=await this._documentLoader.buildContext(),g=t?.env??(typeof process<"u"?process.env:{}),p=t?.vars?.security_key??bs(),f={...t?.vars??{},documents:u,env:g,agent:{id:n.id,name:n.name??n.id,role:n.role??"",team:n.team??"",description:n.description??""}},y=await this._templateEngine.render(c,f),R={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},x=n.provider,_=Array.isArray(x)?x:typeof x=="string"&&x.length>0?[x]:[],w=_.join(", ")||(typeof x=="string"?x:""),b=n.options,T=!Array.isArray(b)&&typeof b=="object"&&b!==null?b:void 0,M=Array.isArray(b)?b:void 0,$={};for(let[h,E]of Object.entries(u))$[h]={content:E.content??"",toc:E.toc,summary:E.summary,path:E.path};let C={user_input:t?.vars?.user_input??void 0,agent:{id:n.id,name:n.name??n.id,role:n.role??"",team:n.team??"",description:n.description??"",provider:w,providerList:_,model:n.inline?.model,workingDirectory:n.working_directory??n.workingDirectory??".",inline:{...n.inline??{},prompt:y},specialties:n.specialties??[],capabilities:n.capabilities??[],remote:n.remote??null,optionsByMode:T,optionsArray:M},agentMetadata:{specialties:n.specialties??[],capabilities:n.capabilities??[],description:n.description??""},documents:$,skills:t?.skills??[],session:R,env:g,vars:{security_key:p,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:R.platform,mode:R.mode,messages:t?.messages??[],tools:this._tools.size>0?{list:Array.from(this._tools.values()).map(h=>({name:h.name,description:h.description,parameters:h.parameters})),json:JSON.stringify(Array.from(this._tools.values()).map(h=>({name:h.name,description:h.description,parameters:h.parameters})),null,2),count:this._tools.size}:null,metadata:{}};return this._layoutRenderer.render(d,C)}_filterToolsByMode(e){return e?e.map(t=>this._tools.get(t)).filter(t=>t!==void 0):Array.from(this._tools.values())}_resolveLayoutSpec(e,t){if(t!==void 0)return t;let r=e.inline?.layout;if(r!==void 0)return r;let n=this._config?.layouts?.default;return typeof n=="string"&&n?n:"crewx/default"}_extractLayoutId(e){if(typeof e=="string")return e;if("id"in e)return e.id;let t=`crewx/__inline_${Date.now()}`;return this._layoutLoader.registerLayout(t,e.template),t}_extractLayoutProps(e,t,r){let n=e.inline?.layout,s=n&&typeof n=="object"&&"props"in n?n.props:void 0,i=r&&typeof r=="object"&&"id"in r?r.props:void 0;if(s||i)return {...s??{},...i??{}}}_getConversationProvider(){return this._plugins.find(t=>t.name==="conversation")?.conversationProvider}async _fetchHistoryMessages(e,t,r){if(r&&r.length>0)return r;if(!e)return;let n=this._getConversationProvider();if(n)try{let s=await n.fetchHistory(e,{currentTraceId:t});return s.messages.length===0?void 0:Wt(s)}catch{return}}_resolveTimeout(e){let t=wr();return e==="query"?t.queryMs:t.executeMs}emitToolEvents(e,t,r,n,s,i,a){try{let c=exports.BUILTIN_ADAPTERS[r]?.parseEvent?.(n)??Et(new Date().toISOString(),n);for(let u of c)u.type==="tool_use"&&u.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName,rawName:u.toolName,input:u.toolInput?this.tryParseJson(u.toolInput):void 0,toolUseId:u.toolUseId}}),u.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName??"unknown",rawName:u.toolName??"unknown",toolUseId:u.toolUseId,result:u.resultPreview,isError:u.isError}});}catch{}}tryParseJson(e){try{return JSON.parse(e)}catch{return e}}async query(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.query(n.agentRef,t,r);let s=Date.now(),i=we("tsk"),a=new Date,d;try{d=tt(e,Array.from(this._agents.values()));}catch(h){if(h instanceof re){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let E=Date.now()-s,v={code:"AGENT_NOT_FOUND",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:E,error:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:E}}}throw h}let c=Array.isArray(d.provider)?d.provider[0]??"cli/claude":d.provider,u=r?.provider??c,g=r?.model??d.inline?.model,p;try{p=ne(u);}catch(h){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let E=Date.now()-s,v={code:"PROVIDER_ERROR",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:E,error:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:d.id,provider:u,model:g,durationMs:E}}}let f=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),y;try{y=await this.renderAgentPromptFull(e,{session:{mode:"query",platform:r?.platform},vars:{user_input:t},messages:f});}catch{}let R,x,_,w=g,b=false,T=h=>{b||(b=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",pid:h,model:w,provider:u,codingAgentCommand:R,renderedPrompt:y,metadata:{...r?.metadata??{},provider:u},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},M=d.options,$=Array.isArray(M?.query?.tools)?M.query.tools:void 0,L=this._tools.size>0?this._filterToolsByMode($):[],C=d.inline?.max_steps;u.startsWith("api/")&&T();try{let h=await p.query(t,{model:g,context:r?.context,systemPrompt:y??d.inline?.system_prompt??d.inline?.prompt,additionalArgs:Array.isArray(M?.query)?M.query:void 0,tools:L.length>0?L:void 0,maxSteps:C,timeoutMs:this._resolveTimeout("query"),env:{CREWX_AGENT_ID:d.id,CREWX_AGENT_ROLE:d.role??"",CREWX_AGENT_TEAM:d.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:u,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,a)},onPid:v=>T(v),onOutput:(v,W)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:v,level:W}),W==="stdout"&&this.emitToolEvents(i,e,u,v,d.id,r?.threadId??"","");},onCommand:v=>{R=v;},onUsage:v=>{x=v;},onExitCode:v=>{_=v;},onModel:v=>{w||(w=v);}});T();let E=Date.now()-s;return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:h,durationMs:E,exitCode:_,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:w,metadata:{...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}}}),{ok:!0,data:h,meta:{agentId:d.id,provider:u,model:g,durationMs:E}}}catch(h){if(h instanceof exports.ClientToolCallRequiredError){let W=we("thd");return this._pendingThreads.set(W,{agentRef:d.id,providerStr:u,continuationState:h.continuationState,toolCall:h.toolCall,traceId:i,startMs:s,model:g}),{ok:true,status:"requires_action",data:"",toolCall:h.toolCall,threadId:W,meta:{agentId:d.id,provider:u,model:g,durationMs:Date.now()-s}}}T();let E=Date.now()-s,v={code:"QUERY_FAILED",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:E,error:v,exitCode:_,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:w,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:d.id,provider:u,model:g,durationMs:E}}}}async continueQuery(e,t){let r=this._pendingThreads.get(e);if(!r)return {ok:false,data:"",error:{code:"THREAD_NOT_FOUND",message:`No pending thread: ${e}`},meta:{agentId:"",provider:"",durationMs:0}};this._pendingThreads.delete(e);let n=ne(r.providerStr);if(!n.continueWithToolResults)return {ok:false,data:"",error:{code:"UNSUPPORTED",message:"Provider does not support client tool continuation"},meta:{agentId:r.agentRef,provider:r.providerStr,durationMs:0}};let s=t.map(i=>({...i,toolName:r.toolCall.toolCallId===i.toolCallId?r.toolCall.toolName:i.toolCallId}));try{let i=await n.continueWithToolResults(r.continuationState,s),a=Date.now()-r.startMs;return this.emit("task:end",{traceId:r.traceId,timestamp:new Date,agentRef:r.agentRef,mode:"query",result:i,durationMs:a}),{ok:!0,status:"complete",data:i,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}catch(i){if(i instanceof exports.ClientToolCallRequiredError)return this._pendingThreads.set(e,{...r,continuationState:i.continuationState,toolCall:i.toolCall}),{ok:true,status:"requires_action",data:"",toolCall:i.toolCall,threadId:e,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:Date.now()-r.startMs}};let a=Date.now()-r.startMs;return {ok:false,data:"",error:{code:"CONTINUE_FAILED",message:i.message},meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}}async execute(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.execute(n.agentRef,t,r);let s=Date.now(),i=we("tsk"),a=new Date,d;try{d=tt(e,Array.from(this._agents.values()));}catch(h){if(h instanceof re){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let E=Date.now()-s,v={code:"AGENT_NOT_FOUND",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:E,error:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:E}}}throw h}let c=Array.isArray(d.provider)?d.provider[0]??"cli/claude":d.provider,u=r?.provider??c,g=r?.model??d.inline?.model,p;try{p=ne(u);}catch(h){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let E=Date.now()-s,v={code:"PROVIDER_ERROR",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:E,error:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:d.id,provider:u,model:g,durationMs:E}}}let f=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),y;try{y=await this.renderAgentPromptFull(e,{session:{mode:"execute",platform:r?.platform},vars:{user_input:t},messages:f});}catch{}let R,x,_,w=g,b=false,T=h=>{b||(b=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",pid:h,model:w,provider:u,codingAgentCommand:R,renderedPrompt:y,metadata:{...r?.metadata??{},provider:u},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},M=d.options,$=Array.isArray(M?.execute?.tools)?M.execute.tools:void 0,L=this._tools.size>0?this._filterToolsByMode($):[],C=d.inline?.max_steps;u.startsWith("api/")&&T();try{let h=await p.execute(t,{model:g,context:r?.context,systemPrompt:y??d.inline?.system_prompt??d.inline?.prompt,additionalArgs:Array.isArray(M?.execute)?M.execute:void 0,tools:L.length>0?L:void 0,maxSteps:C,timeoutMs:this._resolveTimeout("execute"),env:{CREWX_AGENT_ID:d.id,CREWX_AGENT_ROLE:d.role??"",CREWX_AGENT_TEAM:d.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:u,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,a)},onPid:v=>T(v),onOutput:(v,W)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:v,level:W}),W==="stdout"&&this.emitToolEvents(i,e,u,v,d.id,r?.threadId??"","");},onCommand:v=>{R=v;},onUsage:v=>{x=v;},onExitCode:v=>{_=v;},onModel:v=>{w||(w=v);}});T();let E=Date.now()-s;return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:h,durationMs:E,exitCode:_,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:w,metadata:{...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}}}),{ok:!0,data:h,meta:{agentId:d.id,provider:u,model:g,durationMs:E}}}catch(h){T();let E=Date.now()-s,v={code:"EXECUTE_FAILED",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:E,error:v,exitCode:_,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:w,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:d.id,provider:u,model:g,durationMs:E}}}}};function en(o,e){let t=tr(o)?o:void 0,r=tr(e)?e:void 0;if(!(!t&&!r))return {...t??{},...r??{}}}function tr(o){return typeof o=="object"&&o!==null&&!Array.isArray(o)}function Cs(o,e){let t=Array.isArray(o)?o:void 0,r=Array.isArray(e)?e:void 0;if(!t&&!r)return;let n=a=>{if(!tr(a))return;let d=a.id;if(typeof d=="string")return `id:${d}`;let c=a.name;if(typeof c=="string")return `name:${c}`},s=new Set;for(let a of r??[]){let d=n(a);d&&s.add(d);}let i=[];for(let a of t??[]){let d=n(a);d&&s.has(d)||i.push(a);}for(let a of r??[])i.push(a);return i}async function tn(o,e,t){if(o.some(n=>(Array.isArray(n.provider)?n.provider:[n.provider]).some(i=>i.startsWith("api/")))){let{registerApiProviders:n}=await Promise.resolve().then(()=>(Xt(),zr));n(t?.api);}As(o,e),Ts(o,e);}function As(o,e){if(!o.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("remote/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createRemoteProviderFactory:n}=(Yt(),cr(Kr)),s=new Map;for(let i of r)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&Te("remote",n(s,ne));}function Ts(o,e){if(!o.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("plugin/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createPluginProviderFactory:n}=(Zt(),cr(Qr)),s=new Map;for(let i of r)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&Te("plugin",n(s));}l();var Es="crewx:fs:",rr=class{prefix;store;constructor(e){this.prefix=e?.prefix??Es,this.store=e?.storage??new Map;}async readFile(e){let t=this.toKey(e),r=this.store.get(t);if(r===void 0)throw new Error(`BrowserFsAdapter: file not found: ${e}`);return r}async exists(e){return this.store.has(this.toKey(e))}resolvePath(...e){let t=e.map(i=>i.replace(/\\/g,"/")).join("/").replace(/\/+/g,"/"),r=t.split("/"),n=[];for(let i of r)i==="."||i===""||(i===".."?n.pop():n.push(i));let s=n.join("/");return t.startsWith("/")?`/${s}`:s}isAbsolute(e){return e.startsWith("/")}setItem(e,t){this.store.set(this.toKey(e),t);}removeItem(e){this.store.delete(this.toKey(e));}keys(){return Array.from(this.store.keys()).filter(e=>e.startsWith(this.prefix)).map(e=>e.slice(this.prefix.length))}toKey(e){return `${this.prefix}${e.replace(/\\/g,"/")}`}};l();function Ss(o,e){let t=o.skills?.include;if(t===void 0)return [...e];if(t.length===0)return [];let r=new Set(t);return e.filter(n=>r.has(n))}ye();Jt();Xt();Rt();Ae();l();var nr=0;function Is(o){let e=Array.from(o.agents.keys());return {name:"delegate_to_agent",description:`Delegate a task to another agent. Available agents: ${e.join(", ")}`,parameters:{type:"object",properties:{agent:{type:"string",description:`Agent ID to delegate to. One of: ${e.join(", ")}`},message:{type:"string",description:"Task description for the target agent"},mode:{type:"string",description:'Execution mode: "query" for questions, "execute" for actions. Default: query'}},required:["agent","message"]},execute:async t=>{if(nr>=3)return "Error: Maximum delegation depth (3) reached. Cannot delegate further.";let r=t.agent,n=t.message,s=t.mode??"query";if(!e.includes(r))return `Error: Unknown agent "${r}". Available: ${e.join(", ")}`;nr++;try{if(s==="execute"){let a=await o.execute(r,n);return a.ok?a.data:`Error: ${a.error?.message??"Unknown error"}`}let i=await o.query(r,n);return i.ok?i.data:`Error: ${i.error?.message??"Unknown error"}`}finally{nr--;}}}}l();var rn=typeof process<"u"?process.env:{};function Os(){return rn.CREWX_CLI||"npx crewx"}function Ms(){return rn.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}l();var Ds=/^[a-zA-Z0-9._-]+$/,or=class{constructor(e){this.storage=e;}storage;listBoxes(e){this.validateId(e);let r=this.storage.listBoxes(e).map(n=>this.toBoxResponse(n));return {boxes:r,total:r.length}}getBox(e,t){this.validateId(e),this.validateId(t);let r=this.storage.findBox(e,t);return r?this.toBoxResponse(r):null}createBox(e,t){this.validateId(e);let r=this.generateBoxId(),n=new Date().toISOString(),s=this.storage.insertBox(e,{id:r,seq:t.seq,firstTaskId:t.firstTaskId,midTaskId:t.midTaskId,lastTaskId:t.lastTaskId,taskCount:t.taskCount,summary:t.summary??null,sourceTokens:t.sourceTokens,summaryTokens:t.summaryTokens??null,createdAt:n});return this.toBoxResponse(s)}toBoxResponse(e){return {id:e.id,threadId:e.thread_id,seq:e.seq,firstTaskId:e.first_task_id,lastTaskId:e.last_task_id,taskCount:e.task_count,sourceTokens:e.source_tokens,summaryTokens:e.summary_tokens,summary:e.summary,previewFirst:this.storage.getTaskPreview(e.first_task_id,200),previewMid:this.storage.getTaskPreview(e.mid_task_id,200),previewLast:this.storage.getTaskPreview(e.last_task_id,200),createdAt:e.created_at}}validateId(e){if(!Ds.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return we("box")}};l();function Ns(o,e,t,r,n){let{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}=r,d=s*i,c=s*a,u=d+c,g=e.getThreadMessages(o),p=[],f=0,y=false,R=[];for(let w=0;w<g.length;w+=2){let b=g[w],T=g[w+1],M=b?.content||"",$=T?.content||"",L=n.countTokens(M+$),C=[];b&&C.push(b),T&&C.push(T),R.push({messages:C,tokens:L});}for(let w=R.length-1;w>=0;w--){let b=R[w];if(f+b.tokens>d){y=true;break}f+=b.tokens,p.unshift(...b.messages);}let x=[],_=0;if(y&&c>0)try{let{boxes:w}=t.listBoxes(o);for(let b=w.length-1;b>=0;b--){let T=w[b],M=T.summaryTokens??T.sourceTokens;if(_+M>c)break;_+=M,x.unshift({boxId:T.id,seq:T.seq,taskCount:T.taskCount,sourceTokens:T.sourceTokens,summary:T.summary,previewFirst:T.previewFirst,previewMid:T.previewMid,previewLast:T.previewLast,createdAt:T.createdAt});}}catch(w){if(w instanceof Error&&!/not found/i.test(w.message))throw w}return {hot:p,warm:x,hotTokens:f,warmTokens:_,hotOverflow:y,totalBudget:u,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}Ae();fe();l();var ht=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},Je=class{constructor(e={}){this.defaults=e;}defaults;metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0};async run(e,t={}){if(!Array.isArray(e))throw new TypeError("ParallelRunner.run expects an array of tasks");if(e.length===0)return this.metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0},[];let r=this.mergeOptions(t),n=Math.max(1,r.maxConcurrency??5),s=r.timeoutMs,i=r.failFast??false,a=r.callbacks,d=r.evaluateTaskSuccess??(()=>true),c=[],u=0,g=0,p=0,f=false,y=0,R=perf_hooks.performance.now(),x=async C=>{a?.onTaskStart&&await a.onTaskStart(C),p+=1;let h=new AbortController,E={signal:h.signal},v,W;typeof s=="number"&&Number.isFinite(s)&&s>0&&(W=new Promise((ce,ue)=>{v=setTimeout(()=>{let pe=new ht(C.id,s);h.abort(pe),ue(pe);},s);}));let Ge=perf_hooks.performance.now(),xt=C.run(E),hn=W?Promise.race([xt,W]):xt;try{let ce=await hn,ue=perf_hooks.performance.now(),pe=ue-Ge,Re=d(ce,C),Qe={taskId:C.id,success:Re,value:ce,durationMs:pe,startedAt:Ge,finishedAt:ue,metadata:C.metadata,aborted:!1};c.push(Qe),Re?u+=1:g+=1,a?.onTaskComplete&&await a.onTaskComplete(Qe),i&&!Re&&(f=!0);}catch(ce){let ue=perf_hooks.performance.now(),pe=ue-Ge,Re=ce instanceof Error?ce:new Error(String(ce)),Qe={taskId:C.id,success:false,error:Re,durationMs:pe,startedAt:Ge,finishedAt:ue,metadata:C.metadata,aborted:h.signal.aborted};c.push(Qe),g+=1,a?.onError&&await a.onError(C,Re,pe),i&&(f=true);}finally{v&&clearTimeout(v),W&&xt.catch(()=>{});}},_=async()=>{for(;!f;){let C=y;if(C>=e.length)break;y+=1;let h=e[C];if(!h||(await x(h),f))break}},w=Math.min(n,e.length),b=[];for(let C=0;C<w;C++)b.push(_());await Promise.all(b);let M=perf_hooks.performance.now()-R,$=c.length?c.reduce((C,h)=>C+h.durationMs,0)/c.length:0,L=M>0?c.length/(M/1e3):c.length;return this.metrics={totalTasks:e.length,startedTasks:p,completedTasks:c.length,successCount:u,failureCount:g,totalDurationMs:M,averageDurationMs:$,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,n,s)=>{e?.onError&&await e.onError(r,n,s),t?.onError&&await t.onError(r,n,s);}}}};l();l();var Xe=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 nn=3,on=3e4,sn=500,Ls=o=>{if(typeof o!="number"||Number.isNaN(o)||!Number.isFinite(o))return nn;let e=Math.floor(o);return e>0?e:nn},$s=o=>o===void 0||typeof o!="number"||Number.isNaN(o)||o<=0?on:o,js=o=>{if(!o)return {maxRetries:0,retryDelay:sn};let e=Number.isInteger(o.maxRetries)&&o.maxRetries>=0?o.maxRetries:0,t=typeof o.retryDelay=="number"&&o.retryDelay>=0?o.retryDelay:sn;return {maxRetries:e,retryDelay:t}},sr=o=>{let e=o.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},Hs=(o,e)=>o<=0?Promise.resolve():new Promise((t,r)=>{let n=setTimeout(()=>{e.removeEventListener("abort",s),t();},o),s=()=>{clearTimeout(n),r(sr(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),Fs=async(o,e,t)=>{let r,n;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw sr(t);try{let i=await o();if(r=i,i.success||s===e.maxRetries)return i}catch(i){if(n=i,t.aborted)throw sr(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await Hs(e.retryDelay,t);}if(r)return r;throw n?n instanceof Error?n:new Error(String(n)):new Error("Parallel helper encountered an unexpected state")},an=(o,e,t)=>{e.completed+=1,t?e.success+=1:e.failure+=1;try{o.onProgress?.(e.completed,e.total);}catch(r){process.env.NODE_ENV!=="production"&&console.warn("Parallel helper onProgress callback threw an error:",r);}},qs=o=>o.map(t=>({metadata:t.metadata,taskResult:t})).slice().sort((t,r)=>t.metadata.index-r.metadata.index).map(({metadata:t,taskResult:r})=>{if(r.value){let s=r.value;return {...s,agentId:s.agentId??t.request.agentId,metadata:{...s.metadata,requestIndex:t.index,mode:t.mode}}}let n=r.error??new Error("Unknown error");return {agentId:t.request.agentId,content:n.message,success:false,metadata:{error:n.message,aborted:r.aborted??false,requestIndex:t.index,mode:t.mode}}}),Us=o=>o.filter(e=>!e.success).map(e=>{let t=e.metadata;if(e.error instanceof Error)return {index:t.index,error:e.error};if(e.value&&!e.value.success){let r=String(e.value.metadata?.error??e.value.content??"Agent returned unsuccessful result");return {index:t.index,error:new Error(r)}}return {index:t.index,error:new Error("Unknown failure")}}),Ws=(o,e)=>({onTaskComplete:async t=>{an(e,o,t.success);},onError:async()=>{an(e,o,false);}}),dn=async(o,e,t={})=>{if(!Array.isArray(o))throw new TypeError("Parallel helpers expect an array of requests");if(o.length===0){let x={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?.(x),[]}let r=Ls(t.concurrency),n=$s(t.timeout),s=js(t.retryPolicy),i=new Je,a=new Xe,d=o.map((R,x)=>({id:`${e}:${R.agentId??"anonymous"}:${x}`,metadata:{index:x,mode:e,request:R},run:_=>Fs(()=>e==="query"?a.query(R):a.execute(R),s,_.signal)})),c={completed:0,success:0,failure:0,total:o.length},u=await i.run(d,{maxConcurrency:r,timeoutMs:n,evaluateTaskSuccess:R=>R.success,callbacks:Ws(c,t)}),g=qs(u),p=Us(u),f=i.getMetrics(),y={total:o.length,completed:o.length,successCount:g.filter(R=>R.success).length,failureCount:g.filter(R=>!R.success).length,results:g,errors:p,metrics:f};return t.onComplete?.(y),g},Bs=(o,e)=>dn(o,"query",e),zs=(o,e)=>dn(o,"execute",e);Zt();Yt();Qt();Gt();l();l();var wt=class{capabilities={required:[]}};l();l();l();var ln=2e3;function cn(o){let e=o.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f\u2028\u2029]/g,"");return e.length<=ln?e:e.slice(0,ln-11)+" [redacted]"}var Zs=10*1024*1024,ei={b:1,kb:1024,mb:1024*1024,gb:1024*1024*1024};function ir(o,e){return o===void 0?true:Array.isArray(o)?o.includes(e):o===e}function ti(o,e){return o===void 0?true:Array.isArray(o)?o.some(t=>e.includes(t)):e.includes(o)}function pn(o){if(typeof o=="number")return o;let e=o.match(/^(\d+(?:\.\d+)?)\s*(b|kb|mb|gb)?$/i);if(!e)return 0;let t=parseFloat(e[1]),r=(e[2]??"b").toLowerCase();return Math.floor(t*(ei[r]??1))}function gn(o){return typeof o=="string"}function mn(o){try{let e=fs$1.statSync(o);return e.size>Zs?(process.stderr.write(`[YamlHookPlugin] File too large for line count: ${o} (${e.size} bytes)
|
|
64
64
|
`),null):fs$1.readFileSync(o,"utf8").split(`
|
|
65
65
|
`).length}catch{return null}}function fn(o){try{return fs$1.statSync(o).size}catch{return null}}function ri(o,e,t){if(!o)return true;let r=e,n=r?.path??r?.file_path??r?.filePath??r?.filename;if(typeof n!="string")return false;if(Q(n,o))return true;if(t&&n.startsWith("/")){let{relative:s,isAbsolute:i}=F("path");if(i(n)){let a=s(t,n);if(a&&!a.startsWith("..")&&Q(a,o))return true}}return false}function ni(o,e){return o?JSON.stringify(e).includes(o):true}function oi(o,e){if(!o)return true;try{let t=new RegExp(o),r=JSON.stringify(e);return t.test(r)}catch{return false}}function si(o,e){if(!o)return true;try{let t=new RegExp(o),r=JSON.stringify(e);return t.test(r)}catch{return false}}function ii(o,e){if(o.pathSizeMin===void 0&&o.pathSizeMax===void 0)return true;let t=e,r=t?.path??t?.file_path??t?.filePath??t?.filename;if(typeof r!="string")return false;if(o.pathSizeMin!==void 0)if(gn(o.pathSizeMin)){let n=fn(r);if(n===null||n<pn(o.pathSizeMin))return false}else {let n=mn(r);if(n===null||n<o.pathSizeMin)return false}if(o.pathSizeMax!==void 0)if(gn(o.pathSizeMax)){let n=fn(r);if(n===null||n>pn(o.pathSizeMax))return false}else {let n=mn(r);if(n===null||n>o.pathSizeMax)return false}return true}function ai(o){let e=[],t=[];for(let r=0;r<o.length;r++){let n=o[r];if(!n||typeof n!="object"){t.push(`Hook at index ${r}: not an object, skipping`);continue}let s=n;if(typeof s.name!="string"||!s.name){t.push(`Hook at index ${r}: missing or invalid "name", skipping`);continue}let i=s.guide&&typeof s.guide=="object",a=s.deny&&typeof s.deny=="object",d=typeof s.plugin=="string";if(!i&&!a&&!d){t.push(`Hook "${s.name}": missing guide/deny/plugin, skipping`);continue}if(i&&typeof s.guide.say!="string"){t.push(`Hook "${s.name}": guide.say is required and must be string, skipping`);continue}if(a&&typeof s.deny.reason!="string"){t.push(`Hook "${s.name}": deny.reason is required and must be string, skipping`);continue}e.push(s);}return {valid:e,warnings:t}}var dr=class extends wt{name="@crewx/yaml-hook-plugin";version="0.1.0";capabilities={required:["inject"]};hooks;agentMap;constructor(e){super(),this.hooks=e.hooks,this.agentMap=new Map((e.agents??[]).map(t=>[t.id,t]));}async run(e){let t=[],r=process.env.CREWX_TASK_LOG_PATH,n=process.env.CREWX_HOOK_LOG_VERBOSE==="1";for(let s of this.hooks)if(this.matchEntryLevel(s,e)&&s.guide){if(!this.matchRuleLevel(s.guide,e)){n&&r&&this.appendHookLog(r,{rule:s.name,action:"pass",once:s.guide.once??false,ctx:e,matched:false});continue}s.guide.once&&this.hasFired(e.sessionId,s.name)||(s.guide.once&&this.markFired(e.sessionId,s.name),t.push(s.guide.say),r&&this.appendHookLog(r,{rule:s.name,action:"inject",once:s.guide.once??false,ctx:e,matched:true,message:s.guide.say}));}return t.length?e.inject(t.join(`
|
|
66
66
|
|
|
67
67
|
`)):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=cn(t.message).slice(0,500)));let n=`[${new Date().toISOString()}] HOOK: ${JSON.stringify(r)}
|
|
68
68
|
`;fs$1.appendFileSync(e,n,{encoding:"utf8",mode:384});}catch{}}matchEntryLevel(e,t){if(e.provider!==void 0){let r=t.provider.replace(/^cli\//,"");if(!ir(e.provider,r))return false}if(e.team!==void 0){let n=this.agentMap.get(t.agent.id)?.team??t.agent.team;if(!ir(e.team,n))return false}if(e.role!==void 0){let n=this.agentMap.get(t.agent.id)?.role??t.agent.role;if(!ir(e.role,n))return false}if(e.tag!==void 0){let n=this.agentMap.get(t.agent.id)?.tags??[];if(!ti(e.tag,n))return false}return !(e.agents!==void 0&&!e.agents.includes(t.agent.id))}matchRuleLevel(e,t){return !(e.when!==void 0&&e.when.length>0&&!e.when.includes(t.tool.name)&&!e.when.includes(t.tool.rawName)||!ni(e.pattern,t.tool.input)||!oi(e.regex,t.tool.input)||!ri(e.pathPattern,t.tool.input,t.cwd)||!ii(e,t.tool.input)||!si(e.whenInputRegex,t.tool.input))}hasFired(e,t){try{let r=this.firedFilePath(e);if(!fs$1.existsSync(r))return !1;let n=JSON.parse(fs$1.readFileSync(r,"utf8"));return Array.isArray(n.fired)&&n.fired.includes(t)}catch{return false}}markFired(e,t){try{let r=this.firedFilePath(e);fs$1.mkdirSync(H.dirname(r),{recursive:!0,mode:448});let n=fs$1.existsSync(r)?JSON.parse(fs$1.readFileSync(r,"utf8")):{fired:[]};Array.isArray(n.fired)||(n.fired=[]),n.fired.includes(t)||(n.fired.push(t),fs$1.writeFileSync(r,JSON.stringify(n),{mode:384}));}catch(r){process.stderr.write(`[YamlHookPlugin] once state write failed: ${r}
|
|
69
|
-
`);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return H.join(Mo.homedir(),".crewx","sessions",t,"fired-rules.json")}};l();l();l();function di(o){let e=o.messages.map(t=>({id:t.id,role:t.isAssistant?"assistant":"user",content:t.text,timestamp:new Date(t.timestamp).toISOString(),metadata:t.metadata??null}));return {getThreadMessages(t){return e}}}l();var lr=class extends Error{code;kind;retryAfterMs;constructor(e,t,r){super(`AdapterError: ${e}`),this.name="AdapterError",this.code=e,this.kind=t,this.retryAfterMs=r;}};l();function li(o){return o}function ci(o){return {name:o.name,async attach(e){let t=await o.configFactory(e),n=e.registerChannelAdapter,s=o.instanceId??o.name;n&&await n({adapter:o.adapter,instanceId:s,config:t}),o.onAttach&&await o.onAttach(e);},async detach(e){let r=e.unregisterChannelAdapter;r&&await r(o.instanceId??o.name),o.onDetach&&await o.onDetach(e);}}}ot();exports.AdapterError=lr;exports.AgentNotFoundError=re;exports.AgentRuntime=Xe;exports.AgentSkillsSchema=ur;exports.BrowserFsAdapter=rr;exports.ConfigLoadError=ge;exports.Crewx=er;exports.CrewxPlugin=Fe;exports.DocumentLoader=he;exports.LayoutLoadError=q;exports.LayoutLoader=Le;exports.LayoutRenderer=je;exports.NodeFsAdapter=ct;exports.ParallelRunner=Je;exports.ParallelRunnerTimeoutError=ht;exports.PropsValidationError=oe;exports.PropsValidator=$e;exports.SdkBoxService=or;exports.TemplateEngine=Ne;exports.TypedEventEmitter=He;exports.YamlHookPlugin=dr;exports.buildContext=Ns;exports.createAdapterContext=Ut;exports.createDelegateTool=Is;exports.createHandler=Bt;exports.createPluginProviderFactory=Gr;exports.createProvider=ne;exports.createRemoteProviderFactory=Vr;exports.createScopedAdapterStore=Ft;exports.defaultFsAdapter=$t;exports.defineChannelAdapter=li;exports.defineChannelAdapterPlugin=ci;exports.escapeHandlebarsHelper=Dt;exports.formatFileSizeHelper=Nt;exports.formatTimestamp=Ht;exports.formatTimestampHelper=Lt;exports.generateFingerprint=vo;exports.generateId=we;exports.getSyncWindowStore=Ro;exports.hashWorkspaceId=Kt;exports.lengthHelper=Mt;exports.loadYamlFile=Ze;exports.materializeWindowsSpawnProgram=Oe;exports.normalizeWorkspacePath=qr;exports.parseStdoutEvent=Et;exports.parseUsage=K;exports.parseYamlContent=Ye;exports.registerApiProviders=Br;exports.registerProviderFactory=
|
|
69
|
+
`);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return H.join(Mo.homedir(),".crewx","sessions",t,"fired-rules.json")}};l();l();l();function di(o){let e=o.messages.map(t=>({id:t.id,role:t.isAssistant?"assistant":"user",content:t.text,timestamp:new Date(t.timestamp).toISOString(),metadata:t.metadata??null}));return {getThreadMessages(t){return e}}}l();var lr=class extends Error{code;kind;retryAfterMs;constructor(e,t,r){super(`AdapterError: ${e}`),this.name="AdapterError",this.code=e,this.kind=t,this.retryAfterMs=r;}};l();function li(o){return o}function ci(o){return {name:o.name,async attach(e){let t=await o.configFactory(e),n=e.registerChannelAdapter,s=o.instanceId??o.name;n&&await n({adapter:o.adapter,instanceId:s,config:t}),o.onAttach&&await o.onAttach(e);},async detach(e){let r=e.unregisterChannelAdapter;r&&await r(o.instanceId??o.name),o.onDetach&&await o.onDetach(e);}}}ot();exports.AdapterError=lr;exports.AgentNotFoundError=re;exports.AgentRuntime=Xe;exports.AgentSkillsSchema=ur;exports.BrowserFsAdapter=rr;exports.ConfigLoadError=ge;exports.Crewx=er;exports.CrewxPlugin=Fe;exports.DocumentLoader=he;exports.LayoutLoadError=q;exports.LayoutLoader=Le;exports.LayoutRenderer=je;exports.NodeFsAdapter=ct;exports.ParallelRunner=Je;exports.ParallelRunnerTimeoutError=ht;exports.PropsValidationError=oe;exports.PropsValidator=$e;exports.SdkBoxService=or;exports.TemplateEngine=Ne;exports.TypedEventEmitter=He;exports.YamlHookPlugin=dr;exports.buildContext=Ns;exports.createAdapterContext=Ut;exports.createDelegateTool=Is;exports.createHandler=Bt;exports.createPluginProviderFactory=Gr;exports.createProvider=ne;exports.createRemoteProviderFactory=Vr;exports.createScopedAdapterStore=Ft;exports.defaultFsAdapter=$t;exports.defineChannelAdapter=li;exports.defineChannelAdapterPlugin=ci;exports.escapeHandlebarsHelper=Dt;exports.formatFileSizeHelper=Nt;exports.formatTimestamp=Ht;exports.formatTimestampHelper=Lt;exports.generateFingerprint=vo;exports.generateId=we;exports.getSyncWindowStore=Ro;exports.hashWorkspaceId=Kt;exports.lengthHelper=Mt;exports.loadYamlFile=Ze;exports.materializeWindowsSpawnProgram=Oe;exports.normalizeWorkspacePath=qr;exports.parseStdoutEvent=Et;exports.parseUsage=K;exports.parseYamlContent=Ye;exports.registerApiProviders=Br;exports.registerProviderFactory=Te;exports.resolveAgent=tt;exports.resolveAgentSkills=Ss;exports.resolveCrewxCli=Os;exports.resolveCrewxWorkspace=Ms;exports.resolveDefaultAgentsYaml=_t;exports.resolveTemplatesPath=Pe;exports.resolveWindowsExecutablePath=mr;exports.resolveWindowsSpawnProgram=Ie;exports.runExecutesParallel=zs;exports.runInSyncWindow=Po;exports.runQueriesParallel=Bs;exports.setAuditVerbose=io;exports.toTaskReader=di;exports.toTemplateMessages=Wt;exports.truncateHelper=Ot;exports.validateHooksSchema=ai;
|