@crewx/sdk 0.8.4-rc.3 → 0.8.4
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 +33 -33
- package/dist/esm/plugins/index.js +1 -1
- package/dist/esm/repository/index.js +1 -1
- package/dist/index.browser.js +2 -2
- package/dist/index.js +31 -31
- package/dist/migrations/0001_sparkling_tiger_shark.sql +21 -0
- package/dist/migrations/meta/0001_snapshot.json +1091 -0
- package/dist/migrations/meta/_journal.json +7 -0
- package/dist/plugins/index.js +1 -1
- package/dist/provider/acp/adapter.d.ts +5 -0
- package/dist/provider/acp/connection.d.ts +5 -1
- package/dist/provider/acp/index.d.ts +3 -1
- package/dist/provider/acp/meta.d.ts +16 -0
- package/dist/repository/index.js +1 -1
- package/dist/schema/tool-calls.d.ts +1 -1
- package/dist/types/index.d.ts +1 -0
- package/package.json +16 -14
package/dist/index.js
CHANGED
|
@@ -1,58 +1,58 @@
|
|
|
1
|
-
'use strict';var fs=require('fs'),F=require('path'),child_process=require('child_process'),sdk=require('@agentclientprotocol/sdk'),jsYaml=require('js-yaml'),zod=require('zod'),module$1=require('module'),oe=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'),
|
|
2
|
-
`))if(t.trim())try{let r=JSON.parse(t),n=
|
|
3
|
-
`):i=JSON.stringify(s),{timestamp:o,type:"tool_result",toolUseId:n,resultPreview:i,isError:r}}return null}exports.claudeAdapter=void 0;var
|
|
1
|
+
'use strict';var fs=require('fs'),F=require('path'),child_process=require('child_process'),sdk=require('@agentclientprotocol/sdk'),jsYaml=require('js-yaml'),zod=require('zod'),module$1=require('module'),oe=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'),cs=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 F__namespace=/*#__PURE__*/_interopNamespace(F);var oe__namespace=/*#__PURE__*/_interopNamespace(oe);var cs__default=/*#__PURE__*/_interopDefault(cs);var Ht=Object.defineProperty;var Gn=Object.getOwnPropertyDescriptor;var Qn=Object.getOwnPropertyNames;var Yn=Object.prototype.hasOwnProperty;var W=(o=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(o,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):o)(function(o){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+o+'" is not supported')});var M=(o,e)=>()=>(o&&(e=o(o=0)),e);var ct=(o,e)=>{for(var t in e)Ht(o,t,{get:e[t],enumerable:true});},Zn=(o,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of Qn(e))!Yn.call(o,n)&&n!==t&&Ht(o,n,{get:()=>e[n],enumerable:!(r=Gn(e,n))||r.enumerable});return o};var Ut=o=>Zn(Ht({},"__esModule",{value:true}),o);var l=M(()=>{});function ft(o){return typeof o!="string"?void 0:o.trim()||void 0}function yt(o){return ft(o)?.toLowerCase()??""}function De(o){try{return fs.statSync(o).isFile()}catch{return false}}function Ur(o,e){if(o.includes("/")||o.includes("\\")||F__namespace.default.isAbsolute(o))return o;let r=(e.PATH??e.Path??process.env.PATH??process.env.Path??"").split(";").map(a=>a.trim()).filter(Boolean),n=F__namespace.default.extname(o).length>0,s=e.PATHEXT??e.Pathext??process.env.PATHEXT??process.env.Pathext??".EXE;.CMD;.BAT;.COM",i=n?[""]:s.split(";").map(a=>a.trim()).filter(Boolean).map(a=>a.startsWith(".")?a:`.${a}`);for(let a of r)for(let d of i){let c=yt(d),u=d.toUpperCase();for(let p of [d,c,u]){let g=F__namespace.default.join(a,`${o}${p}`);if(De(g))return g}}return o}function po(o){if(!De(o))return null;try{let e=fs.readFileSync(o,"utf8"),t=F__namespace.default.dirname(o),r=[];for(let a of e.matchAll(/"([^"\r\n]*)"/g)){let u=(a[1]??"").match(/%~?dp0%?\s*[\\/]*(.*)$/i)?.[1]?.trim();if(!u)continue;let p=u.replace(/[\\/]+/g,F__namespace.default.sep).replace(/^[\\/]+/,""),g=F__namespace.default.resolve(t,p);De(g)&&r.push(g);}let n=[],s=new Map;for(let a of e.matchAll(/SET\s+"(\w+)=%~?dp0%?[\\/]?([^"]+)"/gi)){let d=a[1].toUpperCase(),c=a[2].trim().replace(/[\\/]+/g,F__namespace.default.sep).replace(/^[\\/]+/,"");s.set(d,F__namespace.default.resolve(t,c));}for(let a of e.split(/\r?\n/))if(a.includes("%*"))for(let d of a.matchAll(/"%(\w+)%"/g)){let c=s.get(d[1].toUpperCase());c&&De(c)&&n.push(c);}let i=a=>a.find(d=>{let c=yt(F__namespace.default.basename(d));return c!=="node.exe"&&c!=="node"})??null;return i(n)??i(r)}catch{return null}}function go(o,e){if(typeof e=="string")return ft(e)||null;if(!e||typeof e!="object")return null;if(o){let t=e[o],r=typeof t=="string"?ft(t):void 0;if(r)return r}for(let t of Object.values(e)){let r=typeof t=="string"?ft(t):void 0;if(r)return r}return null}function mo(o,e){if(!e)return null;let t=F__namespace.default.dirname(o),r=[F__namespace.default.resolve(t,"..",e),F__namespace.default.resolve(t,"node_modules",e)];for(let n of r){let s=F__namespace.default.join(n,"package.json");if(De(s))try{let i=JSON.parse(fs.readFileSync(s,"utf8")),a=go(e,i.bin);if(!a)continue;let d=F__namespace.default.resolve(n,a);if(De(d))return d}catch{}}return null}function fo(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=Ur(o.command,t),s=yt(F__namespace.default.extname(n));if(s===".js"||s===".cjs"||s===".mjs")return {command:r,leadingArgv:[n],resolution:"node-entrypoint",windowsHide:true};if(s===".cmd"||s===".bat"){let i=po(n)??mo(n,o.packageName);return i?yt(F__namespace.default.extname(i))===".exe"?{command:i,leadingArgv:[],resolution:"exe-entrypoint",windowsHide:true}:{command:r,leadingArgv:[i],resolution:"node-entrypoint",windowsHide:true}:{command:n,leadingArgv:[],resolution:"unresolved-wrapper"}}return {command:n,leadingArgv:[],resolution:"direct"}}function yo(o){if(o.candidate.resolution!=="unresolved-wrapper")return {command:o.candidate.command,leadingArgv:o.candidate.leadingArgv,resolution:o.candidate.resolution,windowsHide:o.candidate.windowsHide};if(o.allowShellFallback===true)return {command:o.candidate.command,leadingArgv:[],resolution:"shell-fallback",shell:true};throw new Error(`${F__namespace.default.basename(o.candidate.command)} wrapper resolved, but no executable/Node entrypoint could be resolved without shell execution.`)}function Fe(o){let e=fo(o);return yo({candidate:e,allowShellFallback:o.allowShellFallback})}function We(o,e){return {command:o.command,argv:[...o.leadingArgv,...e],resolution:o.resolution,shell:o.shell,windowsHide:o.windowsHide}}var ht=M(()=>{l();});function ho(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 wo(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 xo(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 G(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=ho(r)??wo(r)??xo(r);n&&(e=n);}catch{}return e??void 0}var Pe=M(()=>{l();});exports.RateLimitError=void 0;var Ft=M(()=>{l();exports.RateLimitError=class extends Error{name="RateLimitError";constructor(e){super(e);}};});function Q(o){return /crewx\s+(x|execute)\s/.test(o)}function Y(o,e){let t=e.match(/@(\S+)/);return {timestamp:o,type:"agent_call",targetAgent:t?.[1]?.replace(/["']/g,""),toolInput:e}}var $e=M(()=>{l();});function Z(o){if(typeof o=="string")return o;if(!o||typeof o!="object")return JSON.stringify(o??{});let e=o;return typeof e.command=="string"?e.command:typeof e.file_path=="string"?e.file_path:typeof e.filePath=="string"?e.filePath:typeof e.path=="string"?e.path:typeof e.query=="string"?e.query:typeof e.pattern=="string"?e.pattern:typeof e.url=="string"?e.url:typeof e.prompt=="string"?e.prompt.length>200?e.prompt.slice(0,200)+"\u2026":e.prompt:typeof e.description=="string"?e.description:JSON.stringify(e)}var Le=M(()=>{l();});function vo(o,e){let t=e.type;if(t==="text"){let r=String(e.text||"");return r?{timestamp:o,type:"text",content:r}:null}if(t==="thinking"){let r=String(e.thinking||"");return {timestamp:o,type:"thinking",content:r||"(thinking)"}}if(t==="tool_use"){let r=String(e.name||""),n=e.id,s=e.input,i=Z(s);return r==="Bash"&&Q(i)?Y(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 Wt=M(()=>{l();Ft();$e();Le();exports.claudeAdapter={command:"claude",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs],s=n.indexOf("-p");return s!==-1?(n.splice(s+1,0,o),e.model&&n.push("--model",e.model),{args:n}):(e.model&&n.push("--model",e.model),{args:n,stdinMessage:o})}let r=["-p",o,"--output-format","stream-json","--verbose"];return e.model&&r.push("--model",e.model),{args:r}},extractText(o){let e=o.split(`
|
|
4
4
|
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="assistant"&&Array.isArray(s.message?.content))for(let i of s.message.content)i.type==="text"&&typeof i.text=="string"&&i.text.trim()&&t.push(i.text.trim());s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(`
|
|
5
5
|
|
|
6
6
|
`):r||o.trim()},extractFailure(o){if(o.includes('"rate_limit_event"'))try{let e=JSON.parse(o);if(e.type==="rate_limit_event"){let t=e.rate_limit_info??{};if(t.status==="rejected")return new exports.RateLimitError(`Claude rate limit: ${t.rateLimitType??"unknown"} (status: ${t.status})`)}}catch{}return null},parseResultMeta(o){let e=o.split(`
|
|
7
|
-
`);for(let t of e)if(t.trim())try{let r=JSON.parse(t);if(r.type==="result"){let n=r.usage,s=n?{inputTokens:Number(n.input_tokens??0)+Number(n.cache_read_input_tokens??0),outputTokens:Number(n.output_tokens??0),cachedInputTokens:Number(n.cache_read_input_tokens??0),costUsd:Number(r.total_cost_usd??0)}:null,i=r.modelUsage,a=i?Object.keys(i)[0]??null:null;return {usage:s,model:a}}}catch{}return {usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(r!=="assistant"&&r!=="user")return [];let s=t.message?.content;if(!Array.isArray(s))return [];let i=e??new Date().toISOString(),a=[];for(let d of s){let c=
|
|
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=
|
|
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=vo(i,d);c&&a.push(c);}return a}};});exports.geminiAdapter=void 0;var Bt=M(()=>{l();Pe();$e();Le();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=G(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=Z(a);return /^bash$/i.test(s)&&Q(d)?[Y(n,d)]:[{timestamp:n,type:"tool_use",toolName:s,toolUseId:i,toolInput:d}]}if(r==="tool_result"){let s=t.tool_id,i=String(t.output||""),a=t.status!=="success";return [{timestamp:n,type:"tool_result",toolUseId:s,resultPreview:i,isError:a}]}return []}};});exports.copilotAdapter=void 0;var zt=M(()=>{l();Pe();$e();Le();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=
|
|
11
|
+
`):r||o.trim()},parseResultMeta(o){let e=G(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=Z(d);return (a==="bash"||a==="Bash")&&Q(c)?[Y(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 ko(o,e){if(e.type==="command_execution"){let r=String(e.command||"");return Q(r)?[Y(o,r)]:[{timestamp:o,type:"tool_use",toolName:"Bash",toolInput:r}]}return []}function _o(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=Ro(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=Z(n);return r==="Bash"&&Q(s)?Y(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 Ro(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=Z(n);return r==="Bash"&&Q(s)?Y(o,s):{timestamp:o,type:"tool_use",toolName:r,toolInput:s}}return null}exports.codexAdapter=void 0;var Vt=M(()=>{l();Pe();$e();Le();exports.codexAdapter={command:"codex",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs];return !n.includes("--json")&&!n.includes("--experimental-json")&&n.push("--json"),e.model&&n.push("--model",e.model),{args:n,stdinMessage:o}}let r=["exec","--json"];return e.model&&r.push("--model",e.model),{args:r,stdinMessage:o}},extractText(o){let e=o.split(`
|
|
12
12
|
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="item.completed"&&(s.item?.type==="message"||s.item?.type==="agent_message")&&typeof s.item?.text=="string"){let i=s.item.text;i.trim()&&t.push(i.trim());}s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(`
|
|
13
13
|
|
|
14
|
-
`):r||o.trim()},parseResultMeta(o){let e=
|
|
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=
|
|
14
|
+
`):r||o.trim()},parseResultMeta(o){let e=G(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 ko(s,n);if(r==="item.completed"){let i=_o(s,n);return i?[i]:[]}return []}};});exports.opencodeAdapter=void 0;var Kt=M(()=>{l();Pe();Le();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=G(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,p=Z(u),g=[{timestamp:n,type:"tool_use",toolName:i,toolUseId:a,toolInput:p}];if(c==="completed"&&d?.output!==void 0){let m=d.output,y=typeof m=="string"?m:JSON.stringify(m);g.push({timestamp:n,type:"tool_result",toolUseId:a,resultPreview:y,isError:false});}else c==="error"&&g.push({timestamp:n,type:"tool_result",toolUseId:a,resultPreview:String(d?.error||"tool error"),isError:true});return g}return []}};});function Jt(o,e,t){if(t){let r=exports.BUILTIN_ADAPTERS[t];if(r?.parseEvent)return r.parseEvent(e,o)}for(let r of Object.values(exports.BUILTIN_ADAPTERS)){let n=r.parseEvent?.(e,o)??[];if(n.length>0)return n}return []}exports.BUILTIN_ADAPTERS=void 0;var je=M(()=>{l();Wt();Bt();zt();Vt();Kt();Wt();Bt();zt();Vt();Kt();$e();exports.BUILTIN_ADAPTERS={claude:exports.claudeAdapter,gemini:exports.geminiAdapter,copilot:exports.copilotAdapter,codex:exports.codexAdapter,opencode:exports.opencodeAdapter};});function Ao(o){let e=o.split(`
|
|
16
16
|
`).filter(d=>d.trim()),t=[],r=[],n=[],s=[],i=[],a=null;for(let d of e)try{let c=JSON.parse(d);if(c.type==="assistant"&&Array.isArray(c.message?.content))for(let u of c.message.content)u.type==="text"&&typeof u.text=="string"&&u.text.trim()&&t.push(u.text.trim());if(c.type==="message"&&c.role==="assistant"&&c.delta===!0&&typeof c.content=="string"&&r.push(c.content),c.type==="assistant.message"&&typeof c.data?.content=="string"){let u=c.data.content;u.trim()&&n.push(u.trim());}if(c.type==="item.completed"&&(c.item?.type==="message"||c.item?.type==="agent_message")&&typeof c.item?.text=="string"){let u=c.item.text;u.trim()&&s.push(u.trim());}if(c.type==="text"&&typeof c.part?.text=="string"){let u=c.part.text;u.trim()&&i.push(u.trim());}c.type==="result"&&typeof c.result=="string"&&(a=c.result);}catch{}return t.length>0?t.join(`
|
|
17
17
|
|
|
18
18
|
`):r.length>0?r.join(""):n.length>0?n.join(`
|
|
19
19
|
|
|
20
20
|
`):s.length>0?s.join(`
|
|
21
21
|
|
|
22
|
-
`):i.length>0?i.join(""):a||o.trim()}function
|
|
23
|
-
`);
|
|
24
|
-
`);I=
|
|
22
|
+
`):i.length>0?i.join(""):a||o.trim()}function bo(o){let e=G(o);return e?{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0}:null}function Co(o,e,t=process.platform){return o==="copilot"&&t==="win32"&&e instanceof exports.ProviderError&&e.message.includes('CLI command "copilot" not found')}function Fr(o,e,t,r,n,s,i){return new Promise((a,d)=>{let c=n?.timeoutMs??36e5,u=Fe({command:o,allowShellFallback:true}),p=We(u,e),g=child_process.spawn(p.command,p.argv,{env:{...process.env,...n?.env??{}},cwd:n?.cwd,stdio:["pipe","pipe","pipe"],shell:p.shell??false,windowsHide:p.windowsHide});s!==void 0&&g.stdin.write(s),g.stdin.end(),g.pid!==void 0&&n?.onPid?.(g.pid);let m=false,y=false,w=()=>{try{g.kill("SIGKILL");}catch{}},_=setTimeout(()=>{if(!m){y=true;try{g.kill("SIGTERM");}catch{}setTimeout(w,qr).unref();}},c);_.unref();let v="",A="",S="",I="";g.stdout.on("data",H=>{let j=H.toString();v+=j,S+=j;let C=S.split(`
|
|
23
|
+
`);S=C.pop()??"";for(let O of C)if(O.trim()&&(n?.onOutput?.(O,"stdout"),i?.extractFailure)){let k=i.extractFailure(O);if(k){m=true,clearTimeout(_);try{g.kill("SIGTERM");}catch{}setTimeout(w,qr).unref(),d(k);return}}}),g.stderr.on("data",H=>{let j=H.toString();A+=j,I+=j;let C=I.split(`
|
|
24
|
+
`);I=C.pop()??"";for(let O of C)O.trim()&&n?.onOutput?.(O,"stderr");}),g.on("error",H=>{m=true,clearTimeout(_),H.code==="ENOENT"?d(new exports.ProviderError(`CLI command "${o}" not found. Is ${t} installed?`,t)):d(new exports.ProviderError(`Spawn error: ${H.message}`,t));}),g.on("close",H=>{if(m)return;m=true,clearTimeout(_),S.trim()&&n?.onOutput?.(S,"stdout"),I.trim()&&n?.onOutput?.(I,"stderr");let j=H??0;if(n?.onExitCode?.(j),y&&H!==0)return d(new ze(`Total runtime exceeded ${c}ms; process killed.`,t));if(j!==0){if(i?.interpretExit){let O=i.interpretExit(j,A);if(O){d(O);return}}d(new exports.ProviderError(`Process exited with code ${j}: ${A.slice(0,500)}`,t));return}let C=i?i.extractText(v):Ao(v);a({stdout:v,parsed:C});});})}function le(o,e){Wr.set(o,e);}function ce(o){let e=o.split("/");if(e.length!==2)throw new exports.ProviderError(`Invalid provider format: "${o}". Expected namespace/id (e.g., cli/claude)`,o);let[t,r]=e,n=Wr.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 Xt(r,s,o)}throw new exports.ProviderError(`Unsupported provider namespace: "${t}". Register a factory with registerProviderFactory('${t}', factory).`,o)}exports.ProviderError=void 0;var ze,qr;exports.ClientToolCallRequiredError=void 0;var Wr,Xt,ne=M(()=>{l();ht();Pe();je();exports.ProviderError=class extends Error{constructor(t,r){super(t);this.providerStr=r;this.name="ProviderError";}providerStr},ze=class extends exports.ProviderError{constructor(e,t){super(e,t),this.name="TotalTimeoutError";}};qr=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"},Wr=new Map;Xt=class{constructor(e,t,r){this.providerId=e;this.adapter=t;this.providerStr=r;}providerId;adapter;providerStr;async execute(e,t){let r=this.composeMessage(e,t),{args:n,stdinMessage:s}=this.adapter.buildArgs(r,t??{},true);t?.onCommand?.(`${this.adapter.command} ${n.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(n,t,s);return this.handleResultMeta(i,t),a}async query(e,t){let r=this.composeMessage(e,t),{args:n,stdinMessage:s}=this.adapter.buildArgs(r,t??{},false);t?.onCommand?.(`${this.adapter.command} ${n.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(n,t,s);return this.handleResultMeta(i,t),a}composeMessage(e,t){return t?.systemPrompt?`${t.systemPrompt}
|
|
25
25
|
|
|
26
26
|
---
|
|
27
27
|
|
|
28
|
-
${e}`:e}async runProcess(e,t,r){try{return await Fr(this.adapter.command,e,this.providerStr,this.providerId,t,r,this.adapter)}catch(n){if(Co(this.providerId,n)){let s=e[0]==="copilot"?e:["copilot",...e];return Fr("gh",s,this.providerStr,this.providerId,t,r,this.adapter)}throw n}}handleResultMeta(e,t){if(!this.adapter.parseResultMeta){let i=
|
|
29
|
-
`);this.stderrBuffer=w.pop()??"";for(let h of w)h.trim()&&this.options.onStderr?.(h);}),this.proc=n;let s=new WritableStream({write:m=>new Promise((y,w)=>{n.stdin.write(m,h=>{h?w(h):y();});}),close:()=>{n.stdin.end();}}),i=new ReadableStream({start:m=>{n.stdout.on("data",y=>{m.enqueue(new Uint8Array(y));}),n.stdout.on("end",()=>{m.close();}),n.stdout.on("error",y=>{m.error(y);});}}),a=sdk.ndJsonStream(s,i),d=this,c=new sdk.ClientSideConnection(m=>({requestPermission:async y=>{if(d.options.configOptions?.allow_all!==void 0){let w=y.options;if(Array.isArray(w)&&w.length>0)return {outcome:{outcome:"selected",optionId:(w.find(_=>_.kind==="allow_once")??w.find(_=>_.kind?.startsWith("allow_"))??w[0]).optionId}}}return {outcome:{outcome:"cancelled"}}},sessionUpdate:async y=>{d.pendingUpdateCallback?.(y);}}),a);this.sdkConnection=c;let u=new Promise((m,y)=>{n.on("error",w=>{if(w.code==="ENOENT"){let _=t.command==="npx"&&t.args.length>0?`@agentclientprotocol/${t.args[0]}`:t.command;y(new exports.ProviderError(`ACP command "${t.command}" not found. Is the ACP adapter installed? Try: npm install -g ${_}`,"acp"));}else y(new exports.ProviderError(`ACP spawn error: ${w.message}`,"acp"));});}),p=this.doInitialize(c,e),g=new Promise((m,y)=>{setTimeout(()=>{y(new exports.AcpProtocolError(`ACP connect timeout after ${vn}ms. The ACP adapter may not be installed or may require interactive setup.`));},vn).unref();});await Promise.race([p,g,u]);}async doInitialize(e,t){let r=await e.initialize({protocolVersion:1,clientCapabilities:{auth:{}},clientInfo:{name:t?.name??"crewx-sdk",version:t?.version??"0.8.4"}});this.authMethods=r.authMethods??[];}async newSession(e){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");try{return await this.newSessionWithTimeout(e)}catch(t){if(!this.isAuthError(t))throw t;return await this.tryAuthenticate(),this.newSessionWithTimeout(e)}}async newSessionWithTimeout(e){let t=this.sdkConnection.newSession(e),r=new Promise((s
|
|
28
|
+
${e}`:e}async runProcess(e,t,r){try{return await Fr(this.adapter.command,e,this.providerStr,this.providerId,t,r,this.adapter)}catch(n){if(Co(this.providerId,n)){let s=e[0]==="copilot"?e:["copilot",...e];return Fr("gh",s,this.providerStr,this.providerId,t,r,this.adapter)}throw n}}handleResultMeta(e,t){if(!this.adapter.parseResultMeta){let i=bo(e);i&&t?.onUsage&&t.onUsage(i);return}let{usage:r,model:n}=this.adapter.parseResultMeta(e);r&&t?.onUsage&&t.onUsage(r);let s=n??(this.providerId==="opencode"?t?.model??null:null);s&&t?.onModel&&t.onModel(s);}};});var yn,hn;exports.VercelProviderRuntime=void 0;var pr=M(()=>{l();ne();yn=10,hn=50,exports.VercelProviderRuntime=class{config;constructor(e){this.config=e;}async query(e,t){return this._run(e,"query",t)}async execute(e,t){return this._run(e,"execute",t)}async _run(e,t,r){let{generateText:n,tool:s}=await import('ai'),i=this.convertTools(r?.tools??[],s),a=this.createModel(r?.model),d=Math.min(r?.maxSteps??this.config.maxSteps??yn,hn);try{let c=0,u=await n({model:a,system:r?.systemPrompt??void 0,prompt:e,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens},onStepFinish:g=>{if(c++,!!r?.onOutput){if(g.toolCalls&&g.toolCalls.length>0)for(let m of g.toolCalls)r.onOutput(JSON.stringify({type:"assistant",message:{content:[{type:"tool_use",id:m.toolCallId,name:m.toolName,input:m.args}]}}),"stdout");if(g.toolResults&&g.toolResults.length>0)for(let m of g.toolResults){let y=typeof m.result=="string"?m.result:JSON.stringify(m.result);r.onOutput(JSON.stringify({type:"user",message:{content:[{type:"tool_result",tool_use_id:m.toolCallId,output:y,is_error:!1}]}}),"stdout");}}}}),p=new Set((r?.tools??[]).filter(g=>!g.execute).map(g=>g.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let g=u.toolCalls.filter(m=>p.has(m.toolName));if(g.length>0){let m=g[0];throw new exports.ClientToolCallRequiredError({toolCallId:m.toolCallId,toolName:m.toolName,args:m.args},{userMessage:e,responseMessages:u.response?.messages??[],toolDefinitions:r?.tools??[],maxSteps:d,systemPrompt:r?.systemPrompt,modelOverride:r?.model})}}if(r?.onUsage&&u.usage){let g={inputTokens:u.usage.promptTokens??0,outputTokens:u.usage.completionTokens??0,cachedInputTokens:0,costUsd:0};r.onUsage(g);}return r?.onModel&&r.onModel(r.model??this.config.model),u.text??""}catch(c){throw c instanceof exports.ClientToolCallRequiredError?c:c.status===401?new exports.ProviderError(`Authentication failed for ${this.config.provider}. Check your API key.`,this.config.provider):c.status===429?new exports.ProviderError(`Rate limit exceeded for ${this.config.provider}.`,this.config.provider):new exports.ProviderError(`Provider error: ${c.message}`,this.config.provider)}}async continueWithToolResults(e,t,r){let{generateText:n,tool:s}=await import('ai'),i=this.convertTools(e.toolDefinitions,s),a=this.createModel(e.modelOverride),d=Math.min(e.maxSteps??this.config.maxSteps??yn,hn),c=[{role:"user",content:e.userMessage},...e.responseMessages,{role:"tool",content:t.map(u=>({type:"tool-result",toolCallId:u.toolCallId,toolName:u.toolName,result:typeof u.result=="string"?u.result:JSON.stringify(u.result)}))}];try{let u=await n({model:a,system:e.systemPrompt??void 0,messages:c,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens}}),p=new Set(e.toolDefinitions.filter(g=>!g.execute).map(g=>g.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let g=u.toolCalls.filter(m=>p.has(m.toolName));if(g.length>0){let m=g[0];throw new exports.ClientToolCallRequiredError({toolCallId:m.toolCallId,toolName:m.toolName,args:m.args},{userMessage:e.userMessage,responseMessages:[...e.responseMessages,{role:"tool",content:t.map(y=>({type:"tool-result",toolCallId:y.toolCallId,toolName:y.toolName,result:typeof y.result=="string"?y.result:JSON.stringify(y.result)}))},...u.response?.messages??[]],toolDefinitions:e.toolDefinitions,maxSteps:e.maxSteps,systemPrompt:e.systemPrompt,modelOverride:e.modelOverride})}}return r?.onUsage&&u.usage&&r.onUsage({inputTokens:u.usage.promptTokens??0,outputTokens:u.usage.completionTokens??0,cachedInputTokens:0,costUsd:0}),r?.onModel&&r.onModel(e.modelOverride??this.config.model),u.text??""}catch(u){throw u instanceof exports.ClientToolCallRequiredError?u:new exports.ProviderError(`Provider error: ${u.message}`,this.config.provider)}}convertTools(e,t){let{z:r}=W("zod"),n={};for(let s of e){let i=this.jsonSchemaToZod(s.parameters??{},r);s.execute?n[s.name]=t({description:s.description,parameters:i,execute:async a=>s.execute(a)}):n[s.name]=t({description:s.description,parameters:i});}return n}jsonSchemaToZod(e,t){if(!e||!e.properties)return t.object({});let r={},n=e.properties,s=e.required??[];for(let[i,a]of Object.entries(n)){let d;switch(a.type){case "string":d=t.string();break;case "number":d=t.number();break;case "integer":d=t.number().int();break;case "boolean":d=t.boolean();break;case "array":d=t.array(t.any());break;default:d=t.any();}a.description&&(d=d.describe(a.description)),s.includes(i)||(d=d.optional()),r[i]=d;}return t.object(r)}createModel(e){let{provider:t,apiKey:r,baseURL:n}=this.config,s=e||this.config.model;switch(t){case "api/openrouter":{let{createOpenAI:i}=W("@ai-sdk/openai");return i({apiKey:r||process.env.OPENROUTER_API_KEY,baseURL:n||"https://openrouter.ai/api/v1"})(s)}case "api/openai":{let{createOpenAI:i}=W("@ai-sdk/openai");return i({apiKey:r||process.env.OPENAI_API_KEY,...n&&{baseURL:n}})(s)}case "api/anthropic":{let{createAnthropic:i}=W("@ai-sdk/anthropic");return i({apiKey:r||process.env.ANTHROPIC_API_KEY,...n&&{baseURL:n}})(s)}case "api/google":{let{createGoogleGenerativeAI:i}=W("@ai-sdk/google");return i({apiKey:r||process.env.GOOGLE_API_KEY})(s)}default:throw new exports.ProviderError(`Unsupported API provider: ${t}`,t)}}};});var xn={};ct(xn,{registerApiProviders:()=>wn});function wn(o){le("api",(e,t)=>{let r=o?.apiKeys?.[e];return new exports.VercelProviderRuntime({provider:t,model:"",apiKey:r,maxSteps:o?.defaults?.maxSteps,temperature:o?.defaults?.temperature})});}var gr=M(()=>{l();ne();pr();});function mr(o){let e=o.update;if(e.sessionUpdate==="agent_message_chunk"){let t=e.content;if(t.type==="text"&&typeof t.text=="string")return t.text}return null}function te(o,e){try{let t=JSON.parse(o);if(t!=null&&typeof t=="object"&&typeof t.type=="string"&&Ls.has(t.type)){let r=e??new Date().toISOString();return [{...t,timestamp:t.timestamp||r}]}}catch{}return []}var Ls,we=M(()=>{l();Ls=new Set(["text","tool_use","tool_result","error","agent_call"]);});exports.AcpProtocolError=void 0;var fr=M(()=>{l();exports.AcpProtocolError=class extends Error{constructor(t,r,n){super(t);this.code=r;this.data=n;}code;data;name="AcpProtocolError"};});var qs,Fs,vn,kn;exports.AcpConnection=void 0;var Et=M(()=>{l();fr();ne();qs=-32e3,Fs=2e3,vn=3e4,kn=1e4,exports.AcpConnection=class{constructor(e){this.options=e;}options;proc=null;sdkConnection=null;disposed=false;stderrBuffer="";collectedStderr="";pendingUpdateCallback=null;authMethods=[];_initResponse=null;get initResponse(){return this._initResponse}async connect(e){if(this.disposed)throw new exports.ProviderError("AcpConnection has been disposed","acp");let t=this.options.spawn,r=process.platform==="win32"&&(t.shellOnWindows??true),n=child_process.spawn(t.command,t.args,{stdio:["pipe","pipe","pipe"],env:{...process.env,...this.options.env??{}},cwd:this.options.cwd,shell:r,windowsHide:true});n.pid!==void 0&&this.options.onPid?.(n.pid),n.stderr.on("data",m=>{let y=m.toString();this.collectedStderr+=y,this.stderrBuffer+=y;let w=this.stderrBuffer.split(`
|
|
29
|
+
`);this.stderrBuffer=w.pop()??"";for(let h of w)h.trim()&&this.options.onStderr?.(h);}),this.proc=n;let s=new WritableStream({write:m=>new Promise((y,w)=>{n.stdin.write(m,h=>{h?w(h):y();});}),close:()=>{n.stdin.end();}}),i=new ReadableStream({start:m=>{n.stdout.on("data",y=>{m.enqueue(new Uint8Array(y));}),n.stdout.on("end",()=>{m.close();}),n.stdout.on("error",y=>{m.error(y);});}}),a=sdk.ndJsonStream(s,i),d=this,c=new sdk.ClientSideConnection(m=>({requestPermission:async y=>{if(d.options.configOptions?.allow_all!==void 0){let w=y.options;if(Array.isArray(w)&&w.length>0)return {outcome:{outcome:"selected",optionId:(w.find(_=>_.kind==="allow_once")??w.find(_=>_.kind?.startsWith("allow_"))??w[0]).optionId}}}return {outcome:{outcome:"cancelled"}}},sessionUpdate:async y=>{d.pendingUpdateCallback?.(y);}}),a);this.sdkConnection=c;let u=new Promise((m,y)=>{n.on("error",w=>{if(w.code==="ENOENT"){let _=t.command==="npx"&&t.args.length>0?`@agentclientprotocol/${t.args[0]}`:t.command;y(new exports.ProviderError(`ACP command "${t.command}" not found. Is the ACP adapter installed? Try: npm install -g ${_}`,"acp"));}else y(new exports.ProviderError(`ACP spawn error: ${w.message}`,"acp"));});}),p=this.doInitialize(c,e),g=new Promise((m,y)=>{setTimeout(()=>{y(new exports.AcpProtocolError(`ACP connect timeout after ${vn}ms. The ACP adapter may not be installed or may require interactive setup.`));},vn).unref();});await Promise.race([p,g,u]);}async doInitialize(e,t){let r=await e.initialize({protocolVersion:1,clientCapabilities:{auth:{}},clientInfo:{name:t?.name??"crewx-sdk",version:t?.version??"0.8.4"}});this._initResponse=r,this.authMethods=r.authMethods??[];}async newSession(e){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");try{return await this.newSessionWithTimeout(e)}catch(t){if(!this.isAuthError(t))throw t;return await this.tryAuthenticate(),this.newSessionWithTimeout(e)}}async newSessionWithTimeout(e){return (await this.newSessionRawTimeout(e)).sessionId}async newSessionRaw(e){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");try{return await this.newSessionRawTimeout(e)}catch(t){if(!this.isAuthError(t))throw t;return await this.tryAuthenticate(),this.newSessionRawTimeout(e)}}async newSessionRawTimeout(e){let t=this.sdkConnection.newSession(e),r=new Promise((n,s)=>{setTimeout(()=>{s(new exports.AcpProtocolError(`ACP session/new timeout after ${kn}ms`));},kn).unref();});return Promise.race([t,r])}isAuthError(e){return typeof e=="object"&&e!==null&&"code"in e&&e.code===qs}async tryAuthenticate(){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected.","acp");let e=this.authMethods.find(r=>r.type==="env_var"&&this.hasEnvVarsFor(r));if(e){await this.sdkConnection.authenticate({methodId:e.id});return}let t=this.authMethods.map(r=>`${r.id} (${r.type??"agent"})`).join(", ");if(this.authMethods.length>0){let r=this.authMethods.filter(n=>n.type==="env_var");if(r.length>0){let n=r.flatMap(s=>(s.vars??[]).filter(i=>!i.optional&&!process.env[i.name]).map(i=>i.name));throw new exports.AcpProtocolError(`ACP authentication required. Missing environment variables: ${n.join(", ")}. Set them in your shell or crewx.yaml env block.`)}throw new exports.AcpProtocolError(`ACP authentication required but no supported method found. Available methods: ${t}. CrewX currently supports env_var authentication only.`)}throw new exports.AcpProtocolError("ACP agent requires authentication but advertised no auth methods.")}hasEnvVarsFor(e){return !e.vars||e.vars.length===0?true:e.vars.filter(t=>!t.optional).every(t=>!!process.env[t.name])}async setModel(e,t){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.unstable_setSessionModel({sessionId:e,modelId:t});}async setMode(e,t){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.setSessionMode({sessionId:e,modeId:t});}async setConfigOption(e,t,r){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.setSessionConfigOption({sessionId:e,configId:t,value:r});}async prompt(e,t,r,n){if(!this.sdkConnection||!this.proc)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");this.pendingUpdateCallback=r??null;let s=this.sdkConnection,i=this.proc,a=n??36e5,d=s.prompt({sessionId:e,prompt:t}),c=new Promise((p,g)=>{setTimeout(()=>{s.cancel({sessionId:e}).catch(()=>{}),g(new ze(`ACP prompt timeout after ${a}ms`,"acp"));},a).unref();}),u=new Promise((p,g)=>{let m=y=>{y!==0&&g(new exports.ProviderError(`ACP process exited unexpectedly (code=${String(y)}): ${this.collectedStderr.slice(0,500)}`,"acp"));};i.once("close",m),d.then(()=>i.off("close",m)).catch(()=>i.off("close",m));});try{return await Promise.race([d,c,u])}finally{this.pendingUpdateCallback=null;}}async dispose(){if(this.disposed)return;this.disposed=true,this.pendingUpdateCallback=null,this.sdkConnection=null;let e=this.proc;e&&(this.proc=null,this.stderrBuffer.trim()&&(this.options.onStderr?.(this.stderrBuffer),this.stderrBuffer=""),await new Promise(t=>{let r=()=>{clearTimeout(n),t();};e.once("close",r),e.once("error",r);try{e.kill("SIGTERM");}catch{r();return}let n=setTimeout(()=>{try{e.kill("SIGKILL");}catch{}},Fs);}));}get isConnected(){return !this.disposed&&this.sdkConnection!==null&&this.proc!==null}};});function _n(o,e){if(o!=null&&typeof o=="object"){let t=o;if(typeof t.command=="string")return t.command;if(typeof t.file_path=="string")return t.file_path;if(typeof t.filePath=="string")return t.filePath;if(typeof t.path=="string")return t.path;if(typeof t.query=="string")return t.query;if(typeof t.pattern=="string")return t.pattern;if(typeof t.url=="string")return t.url;if(Object.keys(t).length>0)return JSON.stringify(t)}if(e&&e.length>0)return e.map(t=>t.path).join(", ")}var Ws;exports.AcpProviderRuntime=void 0;var yr=M(()=>{l();we();Et();Ws={read:"Read",edit:"Edit",delete:"Delete",move:"Move",search:"Search",execute:"Bash",think:"Think",fetch:"WebFetch",switch_mode:"SwitchMode"};exports.AcpProviderRuntime=class{constructor(e,t,r){this.adapter=t;}adapter;async query(e,t){return this.runPrompt(e,t)}async execute(e,t){return this.runPrompt(e,t)}async dispose(){}async runPrompt(e,t){let{command:r,args:n}=this.adapter.spawn;t?.onCommand?.(`${r} ${n.join(" ")}`);let s=new exports.AcpConnection({spawn:this.adapter.spawn,env:t?.env,cwd:t?.cwd,timeoutMs:t?.timeoutMs,onPid:t?.onPid,onStderr:i=>t?.onOutput?.(i,"stderr"),configOptions:t?.configOptions});try{await s.connect(this.adapter.clientInfo);let i=this.adapter.buildSessionParams({cwd:t?.cwd,env:t?.env,model:t?.model,systemPrompt:t?.systemPrompt}),a=await s.newSession(i);await this.applySessionOptions(s,a,t);let d=this.composePrompt(e,t),c=[],u=await s.prompt(a,d,p=>this.handleUpdate(p,t,c),t?.timeoutMs);return this.handleUsage(u,t),c.join("")}finally{await s.dispose().catch(()=>{});}}async applySessionOptions(e,t,r){if(r?.model){let n=this.adapter.buildEffortAction?.(r.effort??"",r.model);n?.type==="set_model"?await e.setModel(t,n.modelId):await e.setModel(t,r.model);}if(r?.mode){let n=this.adapter.resolveMode?.(r.mode)??r.mode;if(n)try{await e.setMode(t,n);}catch(s){console.warn(`[acp] setMode(${n}) failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.effort){let n=this.adapter.buildEffortAction?.(r.effort,r.model);if(n&&n.type==="set_config_option")try{await e.setConfigOption(t,n.configId,n.value);}catch(s){console.warn(`[acp] setConfigOption(${n.configId}) effort failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.configOptions)for(let[n,s]of Object.entries(r.configOptions))try{await e.setConfigOption(t,n,s);}catch(i){console.warn(`[acp] setConfigOption(${n}) failed, retrying: ${i instanceof Error?i.message:String(i)}`);try{await new Promise(a=>setTimeout(a,500)),await e.setConfigOption(t,n,s);}catch(a){console.warn(`[acp] setConfigOption(${n}) retry failed: ${a instanceof Error?a.message:String(a)}`);}}}composePrompt(e,t){let r=[];return t?.systemPrompt?.trim()&&(r.push(t.systemPrompt),r.push("---")),t?.context&&(r.push(t.context),r.push("---")),r.push(e),[{type:"text",text:r.join(`
|
|
30
30
|
|
|
31
|
-
`)}]}handleUpdate(e,t,r){let n=e.update;if(n.sessionUpdate==="agent_message_chunk"){let s=null;this.adapter.extractTextFromUpdate?s=this.adapter.extractTextFromUpdate(e):s=
|
|
32
|
-
`)}if(typeof e=="object"){let t=e;if(typeof t.formatted_output=="string")return t.formatted_output;if(typeof t.content=="string")return t.content;if(Array.isArray(t.content)){let r=this.extractResultPreview(t.content);if(r)return r}if(typeof t.output=="string")return t.output;if(typeof t.text=="string")return t.text;if(typeof t.message=="string")return t.message;if(t.result!=null){let r=this.extractResultPreview(t.result);if(r)return r}if(t.error!=null){let r=this.extractResultPreview(t.error);if(r)return r}}return JSON.stringify(e)}}handleUsage(e,t){if(!t?.onUsage)return;if(this.adapter.extractUsage){let n=this.adapter.extractUsage(e);if(n){t.onUsage(n);return}}let r=e.usage;r&&t.onUsage({inputTokens:r.inputTokens??0,outputTokens:r.outputTokens??0,cachedInputTokens:r.cachedReadTokens??0,costUsd:0});}};});exports.claudeAcpAdapter=void 0;var yr=M(()=>{l();we();exports.claudeAcpAdapter={spawn:{command:"npx",args:["claude-agent-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/claude-agent-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},extractUsage(o){let e=o.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"bypassPermissions",buildEffortAction(o){return o?{type:"set_config_option",configId:"effort",value:o}:null},resolveMode(o){return {yolo:"bypassPermissions"}[o]??o},parseEvent:te};});exports.codexAcpAdapter=void 0;var hr=M(()=>{l();we();exports.codexAcpAdapter={spawn:{command:"npx",args:["codex-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/codex-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},extractUsage(o){let e=o.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"agent-full-access",buildEffortAction(o,e){return e&&o?{type:"set_model",modelId:`${e}[${o}]`}:e&&!o?{type:"set_model",modelId:`${e}[medium]`}:null},resolveMode(o){return {yolo:"agent-full-access",default:"agent",plan:"read-only"}[o]??o},parseEvent:te};});exports.geminiAcpAdapter=void 0;var wr=M(()=>{l();we();exports.geminiAcpAdapter={spawn:{command:"gemini",args:["--acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},yoloModeId:"yolo",buildEffortAction(o){return null},resolveMode(o){return {acceptEdits:"autoEdit"}[o]??o},parseEvent:te};});var He;exports.copilotAcpAdapter=void 0;var xr=M(()=>{l();we();He="https://agentclientprotocol.com/protocol/session-modes",exports.copilotAcpAdapter={spawn:{command:"copilot",args:["--acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},buildSessionParams(o){return {cwd:o.cwd?F.resolve(o.cwd):process.cwd(),mcpServers:[]}},yoloModeId:`${He}#autopilot`,buildEffortAction(o){return o?{type:"set_config_option",configId:"reasoning_effort",value:o}:null},resolveMode(o){return o.startsWith("https://")?o:{yolo:`${He}#autopilot`,default:`${He}#agent`,agent:`${He}#agent`,plan:`${He}#plan`,autopilot:`${He}#autopilot`}[o]??null},parseEvent:te};});exports.opencodeAcpAdapter=void 0;var vr=M(()=>{l();we();exports.opencodeAcpAdapter={spawn:{command:"opencode",args:["acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},yoloModeId:void 0,buildEffortAction(o){return o?{type:"set_config_option",configId:"effort",value:o}:null},resolveMode(o){let e={default:"build"};return o==="yolo"?null:e[o]??o},parseEvent:te};});exports.ACP_ADAPTERS=void 0;var kr=M(()=>{l();yr();hr();wr();xr();vr();yr();hr();wr();xr();vr();exports.ACP_ADAPTERS={claude:exports.claudeAcpAdapter,codex:exports.codexAcpAdapter,gemini:exports.geminiAcpAdapter,copilot:exports.copilotAcpAdapter,opencode:exports.opencodeAcpAdapter};});var Pn={};lt(Pn,{registerAcpProviders:()=>Rn});function Rn(o){if(o){le("acp",o);return}le("acp",(e,t)=>{let r=exports.ACP_ADAPTERS[e];if(!r)throw new exports.ProviderError(`Unknown ACP provider id: "${e}". Supported: ${Object.keys(exports.ACP_ADAPTERS).join(", ")}`,t);return new exports.AcpProviderRuntime(e,r,t)});}var _r=M(()=>{l();ne();fr();kr();ne();});function Bs(o){if(!o)return o;let e=o.trim().replace(/\/+$/,"");return e.toLowerCase().endsWith("/mcp")?e.slice(0,-4):e}exports.McpHttpTransport=void 0;var Rr=M(()=>{l();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=Bs(e.url);this.endpoint=`${t}/mcp`,this.headers={"Content-Type":"application/json",...e.headers??{}},e.apiKey&&(this.headers.Authorization=`Bearer ${e.apiKey}`),this.timeoutMs=e.timeoutMs??3e4;}async send(e){let t=new AbortController,r=setTimeout(()=>t.abort(),this.timeoutMs);try{let n=await fetch(this.endpoint,{method:"POST",headers:this.headers,body:JSON.stringify(e),signal:t.signal});if(clearTimeout(r),!n.ok){let a=await n.text();throw new Error(`HTTP ${n.status}: ${n.statusText}${a?` - ${a}`:""}`)}let s=n.headers.get("content-type");if(s?.includes("application/json"))return await n.json();let i=await n.text();return {jsonrpc:"2.0",id:e.id,error:{code:-32600,message:`Unexpected response content-type: ${s}`,data:i}}}catch(n){throw clearTimeout(r),n instanceof Error&&n.name==="AbortError"?new Error(`MCP-HTTP request timeout after ${this.timeoutMs}ms to ${this.endpoint}`):n}}async close(){}};});exports.RemoteAgentManager=void 0;var Pr=M(()=>{l();Rr();exports.RemoteAgentManager=class{logger;configs=new Map;transports=new Map;constructor(e={}){this.logger=e.logger??(()=>{});}loadConfig(e,t){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,new exports.McpHttpTransport({url:t.url,apiKey:t.apiKey,headers:t.headers,timeoutMs:t.timeoutMs})),this.logger(`Loaded remote agent config for: ${e}`,"debug");}loadConfigWithTransport(e,t,r){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,r),this.logger(`Loaded remote agent config for: ${e} (custom transport)`,"debug");}getConfig(e){return this.configs.get(e)}isRemoteAgent(e){return this.configs.has(e)}getRemoteAgentIds(){return Array.from(this.configs.keys())}async query(e,t){let r=this.requireConfig(e),n=r.tools?.query??"crewx_queryAgent",i={agentId:r.agentId??e,query:t.query};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote query failed for agent ${e}: ${d}`,"error"),a}}async execute(e,t){let r=this.requireConfig(e),n=r.tools?.execute??"crewx_executeAgent",i={agentId:r.agentId??e,task:t.task};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote execute failed for agent ${e}: ${d}`,"error"),a}}mapToolNames(e,t){let r=this.requireConfig(e);r.tools={query:t.query??r.tools?.query??"crewx_queryAgent",execute:t.execute??r.tools?.execute??"crewx_executeAgent"},this.logger(`Updated tool name mapping for agent ${e}`,"debug");}async clearConfigs(){for(let e of this.transports.values())await e.close();this.configs.clear(),this.transports.clear(),this.logger("Cleared all remote agent configurations","debug");}requireConfig(e){let t=this.configs.get(e);if(!t)throw new Error(`Agent ${e} is not configured as a remote agent`);return t}async callRemoteTool(e,t,r){let n=this.transports.get(e);if(!n)throw new Error(`No transport available for agent ${e}`);let s={jsonrpc:"2.0",id:`${t}-${Date.now()}`,method:"tools/call",params:{name:t,arguments:r}};this.logger(`Calling remote MCP tool ${t} for agent ${e}`,"debug");let i=await n.send(s);if(i.error)throw new Error(i.error.message||"MCP server returned an error");return i.result}normalizeResponse(e){if(!e)return {success:false,content:[{type:"text",text:"Remote agent returned no response."}]};let t=e;if(Array.isArray(t.content)&&t.content.length>0)return t;let r=t.response??t.implementation??t.message??t.output,n=typeof r=="string"?r:JSON.stringify(r??e,null,2);return {...t,content:[{type:"text",text:n}]}}validateConfig(e){if(!e.url)throw new Error("Remote agent configuration requires a URL");if(!e.url.startsWith("http://")&&!e.url.startsWith("https://"))throw new Error("Remote agent URL must start with http:// or https://");if(e.type!=="mcp-http")throw new Error(`Unsupported remote agent type: ${e.type}`)}};});var Cn={};lt(Cn,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>An,resolveFileRemoteAgent:()=>Ys});function Qs(o){let e=fs.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 Ys(o,e=Qs,t=fs.existsSync){let r=o.location.replace("file://","");if(!t(r))throw new Error(`Remote config file not found: ${r}`);if(!o.external_agent_id)throw new Error(`external_agent_id is required for file:// remote provider "${o.id}"`);let s=e(r).agents?.find(d=>d.id===o.external_agent_id);if(!s)throw new Error(`Agent "${o.external_agent_id}" not found in ${r}`);let i=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=F.resolve(F.dirname(r),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function An(o,e=ce){return (t,r)=>{let n=o.get(t);if(!n)throw new Error(`Remote provider "${t}" not found. Available: ${Array.from(o.keys()).join(", ")||"(none)"}`);if(n.location.startsWith("file://"))throw new Error(`Remote provider "${t}" uses file:// location which is not supported at the SDK level. Use the CLI commands (crewx query / crewx execute) which handle file:// remotes automatically.`);return new exports.RemoteProviderRuntime(t,n,e)}}function Zs(o,e){let t=e.location;if(!t)throw new Error("Remote provider config requires a location");if(!t.startsWith("http://")&&!t.startsWith("https://"))throw new Error(`Unsupported remote location protocol for MCP-HTTP: ${t}`);return {type:"mcp-http",url:t,apiKey:e.apiKey,headers:e.headers,timeoutMs:e.timeout?.query??3e4,agentId:e.external_agent_id??o}}exports.RemoteProviderRuntime=void 0;var Ar=M(()=>{l();ne();Pr();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,r=ce){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let n=Zs(e,t);this.manager.loadConfig(this.agentId,n);}async query(e,t){return (await this.manager.query(this.agentId,{agentId:this.agentId,query:e,model:t?.model,context:t?.context??t?.systemPrompt})).content.map(n=>n.text).join(`
|
|
31
|
+
`)}]}handleUpdate(e,t,r){let n=e.update;if(n.sessionUpdate==="agent_message_chunk"){let s=null;this.adapter.extractTextFromUpdate?s=this.adapter.extractTextFromUpdate(e):s=mr(e),s!==null&&(r.push(s),t?.onOutput?.(s,"stdout"));}else if(n.sessionUpdate==="tool_call"){let s=new Date().toISOString(),i=n,a={title:i.title??"",kind:i.kind,rawInput:i.rawInput,rawOutput:i.rawOutput,locations:i.locations,_meta:i._meta},d=this.resolveToolCall(a),c={timestamp:s,type:"tool_use",toolUseId:i.toolCallId,toolName:d.toolName,toolInput:d.toolInput};t?.onTaskLog?.([c]);}else if(n.sessionUpdate==="tool_call_update"){let s=new Date().toISOString(),i=n;if(i.status==="completed"||i.status==="failed"){let d=this.extractResultPreview(i.rawOutput),c={timestamp:s,type:"tool_result",toolUseId:i.toolCallId,resultPreview:d,isError:i.status==="failed"};t?.onTaskLog?.([c]);}else if(i.rawInput!=null&&typeof i.rawInput=="object"&&Object.keys(i.rawInput).length>0){let d={title:i.title??"",kind:i.kind,rawInput:i.rawInput,rawOutput:i.rawOutput,locations:i.locations,_meta:i._meta},c=this.resolveToolCall(d),u={timestamp:s,type:"tool_use",toolUseId:i.toolCallId,toolName:c.toolName,toolInput:c.toolInput};t?.onTaskLog?.([u]);}}else n.sessionUpdate;}resolveToolCall(e){let t=e._meta;if(t?.claudeCode?.toolName)return {toolName:t.claudeCode.toolName,toolInput:_n(e.rawInput,e.locations)??(e.title||void 0)};if(this.adapter.parseToolCall){let s=this.adapter.parseToolCall(e);if(s)return {toolName:s.toolName??e.title??"unknown",toolInput:s.toolInput}}let r=Ws[e.kind??""]??e.title??"unknown",n=_n(e.rawInput,e.locations)??(e.title||void 0);return {toolName:r,toolInput:n}}extractResultPreview(e){if(e!=null){if(typeof e=="string")return e;if(Array.isArray(e)){let t=e.filter(r=>r!=null&&typeof r=="object"&&r.type==="text"&&typeof r.text=="string").map(r=>r.text);if(t.length>0)return t.join(`
|
|
32
|
+
`)}if(typeof e=="object"){let t=e;if(typeof t.formatted_output=="string")return t.formatted_output;if(typeof t.content=="string")return t.content;if(Array.isArray(t.content)){let r=this.extractResultPreview(t.content);if(r)return r}if(typeof t.output=="string")return t.output;if(typeof t.text=="string")return t.text;if(typeof t.message=="string")return t.message;if(t.result!=null){let r=this.extractResultPreview(t.result);if(r)return r}if(t.error!=null){let r=this.extractResultPreview(t.error);if(r)return r}}return JSON.stringify(e)}}handleUsage(e,t){if(!t?.onUsage)return;if(this.adapter.extractUsage){let n=this.adapter.extractUsage(e);if(n){t.onUsage(n);return}}let r=e.usage;r&&t.onUsage({inputTokens:r.inputTokens??0,outputTokens:r.outputTokens??0,cachedInputTokens:r.cachedReadTokens??0,costUsd:0});}};});exports.claudeAcpAdapter=void 0;var hr=M(()=>{l();we();exports.claudeAcpAdapter={spawn:{command:"npx",args:["claude-agent-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/claude-agent-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Claude",defaultMode:"default"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},extractUsage(o){let e=o.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"bypassPermissions",buildEffortAction(o){return o?{type:"set_config_option",configId:"effort",value:o}:null},resolveMode(o){return {yolo:"bypassPermissions"}[o]??o},parseEvent:te};});exports.codexAcpAdapter=void 0;var wr=M(()=>{l();we();exports.codexAcpAdapter={spawn:{command:"npx",args:["codex-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/codex-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Codex",defaultMode:"agent"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},extractUsage(o){let e=o.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"agent-full-access",buildEffortAction(o,e){return e&&o?{type:"set_model",modelId:`${e}[${o}]`}:e&&!o?{type:"set_model",modelId:`${e}[medium]`}:null},resolveMode(o){return {yolo:"agent-full-access",default:"agent",plan:"read-only"}[o]??o},parseEvent:te};});exports.geminiAcpAdapter=void 0;var xr=M(()=>{l();we();exports.geminiAcpAdapter={spawn:{command:"gemini",args:["--acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Gemini"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},yoloModeId:"yolo",buildEffortAction(o){return null},resolveMode(o){return {acceptEdits:"autoEdit"}[o]??o},parseEvent:te};});var qe;exports.copilotAcpAdapter=void 0;var vr=M(()=>{l();we();qe="https://agentclientprotocol.com/protocol/session-modes",exports.copilotAcpAdapter={spawn:{command:"copilot",args:["--acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"GitHub Copilot"},buildSessionParams(o){return {cwd:o.cwd?F.resolve(o.cwd):process.cwd(),mcpServers:[]}},yoloModeId:`${qe}#autopilot`,buildEffortAction(o){return o?{type:"set_config_option",configId:"reasoning_effort",value:o}:null},resolveMode(o){return o.startsWith("https://")?o:{yolo:`${qe}#autopilot`,default:`${qe}#agent`,agent:`${qe}#agent`,plan:`${qe}#plan`,autopilot:`${qe}#autopilot`}[o]??null},parseEvent:te};});exports.opencodeAcpAdapter=void 0;var kr=M(()=>{l();we();exports.opencodeAcpAdapter={spawn:{command:"opencode",args:["acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"OpenCode"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},yoloModeId:void 0,buildEffortAction(o){return o?{type:"set_config_option",configId:"effort",value:o}:null},resolveMode(o){let e={default:"build"};return o==="yolo"?null:e[o]??o},parseEvent:te};});exports.ACP_ADAPTERS=void 0;var $t=M(()=>{l();hr();wr();xr();vr();kr();hr();wr();xr();vr();kr();exports.ACP_ADAPTERS={claude:exports.claudeAcpAdapter,codex:exports.codexAcpAdapter,gemini:exports.geminiAcpAdapter,copilot:exports.copilotAcpAdapter,opencode:exports.opencodeAcpAdapter};});var Pn={};ct(Pn,{registerAcpProviders:()=>Rn});function Rn(o){if(o){le("acp",o);return}le("acp",(e,t)=>{let r=exports.ACP_ADAPTERS[e];if(!r)throw new exports.ProviderError(`Unknown ACP provider id: "${e}". Supported: ${Object.keys(exports.ACP_ADAPTERS).join(", ")}`,t);return new exports.AcpProviderRuntime(e,r,t)});}var _r=M(()=>{l();ne();yr();$t();ne();});function zs(o){if(!o)return o;let e=o.trim().replace(/\/+$/,"");return e.toLowerCase().endsWith("/mcp")?e.slice(0,-4):e}exports.McpHttpTransport=void 0;var Rr=M(()=>{l();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=zs(e.url);this.endpoint=`${t}/mcp`,this.headers={"Content-Type":"application/json",...e.headers??{}},e.apiKey&&(this.headers.Authorization=`Bearer ${e.apiKey}`),this.timeoutMs=e.timeoutMs??3e4;}async send(e){let t=new AbortController,r=setTimeout(()=>t.abort(),this.timeoutMs);try{let n=await fetch(this.endpoint,{method:"POST",headers:this.headers,body:JSON.stringify(e),signal:t.signal});if(clearTimeout(r),!n.ok){let a=await n.text();throw new Error(`HTTP ${n.status}: ${n.statusText}${a?` - ${a}`:""}`)}let s=n.headers.get("content-type");if(s?.includes("application/json"))return await n.json();let i=await n.text();return {jsonrpc:"2.0",id:e.id,error:{code:-32600,message:`Unexpected response content-type: ${s}`,data:i}}}catch(n){throw clearTimeout(r),n instanceof Error&&n.name==="AbortError"?new Error(`MCP-HTTP request timeout after ${this.timeoutMs}ms to ${this.endpoint}`):n}}async close(){}};});exports.RemoteAgentManager=void 0;var Pr=M(()=>{l();Rr();exports.RemoteAgentManager=class{logger;configs=new Map;transports=new Map;constructor(e={}){this.logger=e.logger??(()=>{});}loadConfig(e,t){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,new exports.McpHttpTransport({url:t.url,apiKey:t.apiKey,headers:t.headers,timeoutMs:t.timeoutMs})),this.logger(`Loaded remote agent config for: ${e}`,"debug");}loadConfigWithTransport(e,t,r){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,r),this.logger(`Loaded remote agent config for: ${e} (custom transport)`,"debug");}getConfig(e){return this.configs.get(e)}isRemoteAgent(e){return this.configs.has(e)}getRemoteAgentIds(){return Array.from(this.configs.keys())}async query(e,t){let r=this.requireConfig(e),n=r.tools?.query??"crewx_queryAgent",i={agentId:r.agentId??e,query:t.query};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote query failed for agent ${e}: ${d}`,"error"),a}}async execute(e,t){let r=this.requireConfig(e),n=r.tools?.execute??"crewx_executeAgent",i={agentId:r.agentId??e,task:t.task};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote execute failed for agent ${e}: ${d}`,"error"),a}}mapToolNames(e,t){let r=this.requireConfig(e);r.tools={query:t.query??r.tools?.query??"crewx_queryAgent",execute:t.execute??r.tools?.execute??"crewx_executeAgent"},this.logger(`Updated tool name mapping for agent ${e}`,"debug");}async clearConfigs(){for(let e of this.transports.values())await e.close();this.configs.clear(),this.transports.clear(),this.logger("Cleared all remote agent configurations","debug");}requireConfig(e){let t=this.configs.get(e);if(!t)throw new Error(`Agent ${e} is not configured as a remote agent`);return t}async callRemoteTool(e,t,r){let n=this.transports.get(e);if(!n)throw new Error(`No transport available for agent ${e}`);let s={jsonrpc:"2.0",id:`${t}-${Date.now()}`,method:"tools/call",params:{name:t,arguments:r}};this.logger(`Calling remote MCP tool ${t} for agent ${e}`,"debug");let i=await n.send(s);if(i.error)throw new Error(i.error.message||"MCP server returned an error");return i.result}normalizeResponse(e){if(!e)return {success:false,content:[{type:"text",text:"Remote agent returned no response."}]};let t=e;if(Array.isArray(t.content)&&t.content.length>0)return t;let r=t.response??t.implementation??t.message??t.output,n=typeof r=="string"?r:JSON.stringify(r??e,null,2);return {...t,content:[{type:"text",text:n}]}}validateConfig(e){if(!e.url)throw new Error("Remote agent configuration requires a URL");if(!e.url.startsWith("http://")&&!e.url.startsWith("https://"))throw new Error("Remote agent URL must start with http:// or https://");if(e.type!=="mcp-http")throw new Error(`Unsupported remote agent type: ${e.type}`)}};});var bn={};ct(bn,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>An,resolveFileRemoteAgent:()=>Zs});function Qs(o){let e=fs.readFileSync(o,"utf-8"),t=jsYaml.load(e);return {agents:Array.isArray(t?.agents)?t.agents:void 0}}function Ys(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 Zs(o,e=Qs,t=fs.existsSync){let r=o.location.replace("file://","");if(!t(r))throw new Error(`Remote config file not found: ${r}`);if(!o.external_agent_id)throw new Error(`external_agent_id is required for file:// remote provider "${o.id}"`);let s=e(r).agents?.find(d=>d.id===o.external_agent_id);if(!s)throw new Error(`Agent "${o.external_agent_id}" not found in ${r}`);let i=Ys(s);if(!i)throw new Error(`Agent "${o.external_agent_id}" in ${r} has no provider configured`);if(i.startsWith("remote/"))throw new Error(`Chained remotes not allowed: ${o.id} \u2192 ${i}`);let a=F.resolve(F.dirname(r),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function An(o,e=ce){return (t,r)=>{let n=o.get(t);if(!n)throw new Error(`Remote provider "${t}" not found. Available: ${Array.from(o.keys()).join(", ")||"(none)"}`);if(n.location.startsWith("file://"))throw new Error(`Remote provider "${t}" uses file:// location which is not supported at the SDK level. Use the CLI commands (crewx query / crewx execute) which handle file:// remotes automatically.`);return new exports.RemoteProviderRuntime(t,n,e)}}function ei(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 Ar=M(()=>{l();ne();Pr();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,r=ce){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let n=ei(e,t);this.manager.loadConfig(this.agentId,n);}async query(e,t){return (await this.manager.query(this.agentId,{agentId:this.agentId,query:e,model:t?.model,context:t?.context??t?.systemPrompt})).content.map(n=>n.text).join(`
|
|
33
33
|
`)}async execute(e,t){return (await this.manager.execute(this.agentId,{agentId:this.agentId,task:e,model:t?.model,context:t?.context??t?.systemPrompt})).content.map(n=>n.text).join(`
|
|
34
|
-
`)}};});var
|
|
34
|
+
`)}};});var En={};ct(En,{PluginProviderRuntime:()=>exports.PluginProviderRuntime,createPluginProviderFactory:()=>Sn});function Sn(o){return (e,t)=>{let r=o.get(e);if(!r)throw new exports.ProviderError(`Plugin provider "${e}" not found. Available: ${Array.from(o.keys()).join(", ")||"(none)"}`,`plugin/${e}`);return new exports.PluginProviderRuntime(e,r)}}function Cn(o,e,t,r){let n=o.map(s=>s.replace(/\{model\}/g,e));return r&&n.push(t),n}function ri(o){if(!o||typeof o!="string")throw new Error("Plugin provider requires a cli_command")}function Tn(o){if(!Array.isArray(o))throw new Error("CLI arguments must be an array");for(let e of o)if(typeof e!="string")throw new Error("Each CLI argument must be a string")}function ni(o){for(let{pattern:e}of o)if(typeof e!="string")throw new Error("Error pattern must be a string")}function oi(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 br=M(()=>{l();ne();ht();exports.PluginProviderRuntime=class{constructor(e,t){this.config=t;this.providerStr=`plugin/${e}`,ri(t.cli_command),Tn(t.query_args),Tn(t.execute_args),t.error_patterns&&ni(t.error_patterns),t.env&&oi(t.env);}config;providerStr;async query(e,t){let r=t?.model??this.config.default_model??"default",n=Cn(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=Cn(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=Fe({command:this.config.cli_command,allowShellFallback:true}),c=We(d,e),u=child_process.spawn(c.command,c.argv,{env:a,shell:c.shell??false,stdio:["pipe","pipe","pipe"],windowsHide:c.windowsHide});r!==void 0&&u.stdin.write(r),u.stdin.end(),u.pid!==void 0&&t?.onPid?.(u.pid);let p="",g="",m="",y="";u.stdout.on("data",h=>{let _=h.toString();p+=_,m+=_;let v=m.split(`
|
|
35
35
|
`);m=v.pop()??"";for(let A of v)A.trim()&&t?.onOutput?.(A,"stdout");}),u.stderr.on("data",h=>{let _=h.toString();g+=_,y+=_;let v=y.split(`
|
|
36
|
-
`);y=v.pop()??"";for(let A of v)A.trim()&&t?.onOutput?.(A,"stderr");});let w=setTimeout(()=>{u.kill("SIGTERM"),i(new exports.ProviderError(`Plugin provider "${this.providerStr}" timed out after ${n}ms`,this.providerStr));},n);u.on("error",h=>{if(clearTimeout(w),h.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: ${h.message}`,this.providerStr));}),u.on("close",h=>{clearTimeout(w),m.trim()&&t?.onOutput?.(m,"stdout"),y.trim()&&t?.onOutput?.(y,"stderr");let _=h??0;if(t?.onExitCode?.(_),this.config.error_patterns){let v=g||p;for(let A of this.config.error_patterns)if(v.includes(A.pattern)){i(new exports.ProviderError(A.message,this.providerStr));return}}if(h!==0){i(new exports.ProviderError(`Process exited with code ${h}: ${g.slice(0,500)}`,this.providerStr));return}s(p.trim());});})}};});l();l();l();function
|
|
36
|
+
`);y=v.pop()??"";for(let A of v)A.trim()&&t?.onOutput?.(A,"stderr");});let w=setTimeout(()=>{u.kill("SIGTERM"),i(new exports.ProviderError(`Plugin provider "${this.providerStr}" timed out after ${n}ms`,this.providerStr));},n);u.on("error",h=>{if(clearTimeout(w),h.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: ${h.message}`,this.providerStr));}),u.on("close",h=>{clearTimeout(w),m.trim()&&t?.onOutput?.(m,"stdout"),y.trim()&&t?.onOutput?.(y,"stderr");let _=h??0;if(t?.onExitCode?.(_),this.config.error_patterns){let v=g||p;for(let A of this.config.error_patterns)if(v.includes(A.pattern)){i(new exports.ProviderError(A.message,this.providerStr));return}}if(h!==0){i(new exports.ProviderError(`Process exited with code ${h}: ${g.slice(0,500)}`,this.providerStr));return}s(p.trim());});})}};});l();l();l();function eo(o){let e=n=>n.replace(/[.+^${}()|[\]\\]/g,"\\$&"),r=o.split("/").map(n=>n==="**"?".*":n.split("*").map(e).join("[^/]*"));return new RegExp(`^${r.join("\\/")}$`)}function re(o,e){try{return eo(e).test(o)}catch{return false}}l();l();var to=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()),Lr=zod.z.object({include:zod.z.array(zod.z.string()).optional()}).optional(),ro=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:to.optional(),skills:Lr}).catchall(zod.z.unknown()),jr=zod.z.object({agents:zod.z.array(ro).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 _e=class extends Error{constructor(t,r){super(t);this.cause=r;this.name="ConfigLoadError";}cause};function ut(o){if(!o||typeof o!="string"||!o.trim())throw new _e("YAML content must be a non-empty string");let e;try{e=jsYaml.load(o);}catch(n){throw new _e(`YAML parse error: ${n.message}`,n)}let t=so(e),r=jr.safeParse(t);if(!r.success)throw new _e(`Config validation error: ${r.error.message}`);return r.data}function pt(o){let e;try{e=fs.readFileSync(o,"utf-8");}catch(t){throw new _e(`Cannot read file: ${o}`,t)}return ut(e)}function so(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 Re=F.join("templates","agents");function lo(){try{let e=(typeof W=="function"?W:module$1.createRequire(typeof __filename<"u"?__filename:process.cwd()+"/")).resolve("@crewx/sdk/package.json");return F.dirname(e)}catch{return null}}function Ne(o){if(o&&fs.existsSync(o))return o;let e=process.env.CREWX_SDK_TEMPLATES_PATH;if(e&&fs.existsSync(e))return e;let t=lo();if(t){let n=F.join(t,Re);if(fs.existsSync(n))return n}let r=[F.join(__dirname,"..",Re),F.join(__dirname,"..","..",Re),F.join(__dirname,"..","..","..",Re),F.join(process.cwd(),"packages","sdk",Re),F.join(process.cwd(),Re)];for(let n of r)if(fs.existsSync(n))return n;throw new Error(`[@crewx/sdk] Templates directory not found.
|
|
37
37
|
`+(t?` package anchor: ${F.join(t,Re)}
|
|
38
38
|
`:` package anchor: (unresolved)
|
|
39
39
|
`)+r.map(n=>` candidate: ${n}`).join(`
|
|
40
40
|
`)+`
|
|
41
|
-
Set CREWX_SDK_TEMPLATES_PATH or pass options.templatesPath.`)}function
|
|
41
|
+
Set CREWX_SDK_TEMPLATES_PATH or pass options.templatesPath.`)}function qt(){let o=Ne();return {yamlPath:F.join(o,"default.yaml"),dir:o}}l();var de=class extends Error{constructor(e,t){let r=t.length>0?` Available: ${t.join(", ")}`:"";super(`Agent not found: "${e}".${r}`),this.name="AgentNotFoundError";}},co={claude:{id:"claude",provider:"cli/claude"},gemini:{id:"gemini",provider:"cli/gemini"},copilot:{id:"copilot",provider:"cli/copilot"},codex:{id:"codex",provider:"cli/codex"}};function mt(o,e){let t=o.startsWith("@")?o.slice(1):o,r=e.find(s=>s.id===t);if(r)return r;let n=co[t];if(n)return n;throw new de(o,e.map(s=>s.id))}ne();l();function Br(o,e){if(o===void 0||o==="")return e;let t=parseInt(o,10);return Number.isNaN(t)?e:t}function zr(o=process.env){return {queryMs:Br(o.CREWX_TIMEOUT_QUERY,36e5),executeMs:Br(o.CREWX_TIMEOUT_EXECUTE,36e5)}}l();l();var So=[/^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],Eo=/[;|&`$(){}!><\n\r]/,Io=2,Oo=["*","**","*:*","* *","**/*"];function Mo(){let o={};for(let[e,t]of Object.entries(process.env))t!==void 0&&(So.some(r=>r.test(e))||(o[e]=t));return o}function No(o){if(Eo.test(o))throw new Error(`exec blocked: shell metacharacter detected in "${o}"`)}function Do(o){return /^npx\s+@crewx\/[\w-]+/.test(o)}function $o(o){if(Oo.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 Lo(o,e){let t=e.allow??[],r=e.deny??[];for(let n of [...t,...r])$o(n);return r.some(n=>re(o,n))?false:Do(o)?true:t.some(n=>re(o,n))}var Vr=false;function jo(o){Vr=o;}function Ve(o){if(!Vr)return;let e=JSON.stringify({span:"template_exec",...o,timestamp:new Date().toISOString()});console.error(e);}function Ho(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 Kr(o,e){let t=Date.now(),r=parseInt(process.env.CREWX_EXEC_DEPTH??"0",10);if(isNaN(r)||r>=Io)return Ve({command:o,status:"denied",reason:"invalid or max recursion depth"}),"(exec blocked: max recursion depth reached)";try{No(o);}catch{return Ve({command:o,status:"denied",reason:"shell metacharacter detected"}),`(exec blocked: shell metacharacter detected in "${o}")`}if(!Lo(o,e))return Ve({command:o,status:"denied",reason:"not in allow list"}),`(exec blocked: ${o})`;try{let n=Ho(o),[s,...i]=n;if(!s)return `(exec failed: ${o})`;let a=Mo(),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 Ve({command:o,status:"allowed",allowed_by:"policy",duration_ms:c}),`<exec-output cmd="${o}">
|
|
42
42
|
${d.trim()}
|
|
43
|
-
</exec-output>`}catch{return
|
|
43
|
+
</exec-output>`}catch{return Ve({command:o,status:"error",reason:"execution failed"}),`(exec failed: ${o})`}}l();function Jr(o){return o==null?"":String(o)}l();function Xr(o,e){return `\`\`\`${e?.hash?.lang??""}
|
|
44
44
|
${o??""}
|
|
45
|
-
\`\`\``}l();function
|
|
45
|
+
\`\`\``}l();function Gt(o,e){if(!o)return "";if(o.length<=e)return o;let t=o.length-e;return `${o.substring(0,e)} (...+${t} chars)`}function Qt(o){return Array.isArray(o)||typeof o=="string"?o.length:0}function Yt(o){return typeof o!="string"?"":o.replace(/\{\{/g,"{{").replace(/\}\}/g,"}}")}var Gr=["B","KB","MB","GB"];function Zt(o){if(o===0)return "0 B";let e=Math.min(Math.floor(Math.log(o)/Math.log(1024)),Gr.length-1);return `${Math.round(o/Math.pow(1024,e)*100)/100} ${Gr[e]}`}function er(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 Ke=class{hbs;execPolicy;execEnabled;constructor(e={}){this.hbs=oe__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(Kr(n,t)):"(exec disabled)"}),e.registerHelper("include",function(n){return new e.SafeString(Jr(n))}),e.registerHelper("fenced_code",function(n,s){return new e.SafeString(Xr(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 Gt(n,s)}),e.registerHelper("length",function(n){return Qt(n)}),e.registerHelper("escapeHandlebars",function(n){return new e.SafeString(Yt(n))}),e.registerHelper("formatFileSize",function(n){return Zt(n)}),e.registerHelper("formatTimestamp",function(n){return er(n)});}async render(e,t={}){return this.hbs.compile(e,{noEscape:true})(t)}};l();l();var Rt=class{async readFile(e){return promises.readFile(e,"utf-8")}async exists(e){try{return await promises.access(e),!0}catch{return false}}resolvePath(...e){return e.length===1?F.resolve(e[0]):F.resolve(F.join(...e))}isAbsolute(e){return F.isAbsolute(e)}},tr=new Rt;var Ae=class{docs=new Map;fs;constructor(e){this.fs=e??tr;}async load(e,t){if(e)for(let[r,n]of Object.entries(e)){let s=n;if(typeof s=="string")this.docs.set(r,{content:s});else if(s&&typeof s=="object"){let i=s;"content"in i&&typeof i.content=="string"?this.docs.set(r,{content:i.content}):"path"in i&&typeof i.path=="string"?await this.loadFromFile(r,i.path,t):console.warn(`[DocumentLoader] Skipping '${r}': unsupported format`);}else console.warn(`[DocumentLoader] Skipping '${r}': unsupported format`);}}async getContent(e){return this.docs.get(e)?.content}async getToc(e){let t=this.docs.get(e);if(!t)return;let r=[];for(let n of t.content.split(`
|
|
46
46
|
`)){let s=/^(#{1,6})\s+(.+)$/.exec(n.trim());s&&r.push({depth:s[1].length,text:s[2].trim()});}if(r.length!==0)return r.map(({depth:n,text:s})=>`${" ".repeat(n-1)}- ${s}`).join(`
|
|
47
|
-
`)}getPath(e){return this.docs.get(e)?.path}getNames(){return Array.from(this.docs.keys())}async buildContext(){let e={};for(let t of this.docs.keys()){let r=await this.getContent(t)??"",n=await this.getToc(t),s=this.getPath(t);e[t]={content:r,toc:n,...s?{path:s}:{}};}return e}async loadFromFile(e,t,r){try{let n=this.resolve(t,r),s=await this.fs.readFile(n);this.docs.set(e,{content:s,path:n});}catch(n){let s=n instanceof Error?n.message:String(n);console.warn(`[DocumentLoader] Failed to load '${e}' from '${t}': ${s}`);}}resolve(e,t){return this.fs.isAbsolute(e)?e:t?this.fs.resolvePath(t,e):this.fs.resolvePath(e)}};l();l();var B=class extends Error{constructor(t,r,n){super(t);this.layoutId=r;this.cause=n;this.name="LayoutLoadError";}layoutId;cause},ue=class extends Error{constructor(t,r=[],n){super(t);this.errors=r;this.cause=n;this.name="PropsValidationError";}errors;cause};var Ko={validationMode:"lenient",fallbackLayoutId:"crewx/default"},Ve=class{layouts=new Map;options;constructor(e){this.options={...Ko,...e,templatesPath:e?.templatesPath??Oe()},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 B(`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 B("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 B(`Custom layout template is empty for ${e}`,e);let s=r.propsSchema||{},i=this.extractDefaultProps(s),a=r.defaultProps||{},d={id:e,version:r.version||"1.0.0",description:r.description||`Custom layout ${e}`,template:n,propsSchema:this.parsePropsSchema(s),defaultProps:{...i,...a}},c=this.layouts.get(e),u=c?.template===n&&JSON.stringify(c?.defaultProps??{})===JSON.stringify(d.defaultProps??{})&&JSON.stringify(c?.propsSchema??{})===JSON.stringify(d.propsSchema??{});this.layouts.set(e,d),process.env.CREWX_VERBOSE==="1"&&(c?u||console.error(`Updated custom layout: ${e}`):console.error(`Registered custom layout: ${e}`));}registerLayouts(e){for(let[t,r]of Object.entries(e))try{this.registerLayout(t,r);}catch(n){console.warn(`Failed to register custom layout ${t}:`,n instanceof Error?n.message:n);}}loadAllLayouts(){let e=this.options.templatesPath;if(!fs.existsSync(e))throw new B(`Templates directory not found: ${e}`,void 0,new Error(`Directory does not exist: ${e}`));try{let t=fs.readdirSync(e).filter(r=>r.endsWith(".yaml")||r.endsWith(".yml"));t.length===0&&console.warn(`No layout files found in ${e}`);for(let r of t){let n=r.replace(/\.(yaml|yml)$/,""),s=F__namespace.join(e,r);try{let i=this.loadLayoutFile(s,n),a=`crewx/${n}`;this.layouts.set(a,i),a!=="crewx/minimal"&&process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded layout: ${a} from ${r}`);}catch(i){console.error(`Failed to load layout file ${r}:`,i);}}process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded ${this.layouts.size} layouts from ${e}`);}catch(t){throw new B(`Failed to read layouts directory: ${e}`,void 0,t instanceof Error?t:new Error(String(t)))}}loadLayoutFile(e,t){try{let r=fs.readFileSync(e,"utf-8");if(!r||r.trim().length===0)throw console.warn(`Empty YAML file: ${e}, will use fallback`),new B(`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 B(`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 B(`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 B(`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 B(`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 Jo(o){return Array.from(new Set(o.filter(e=>e?.isAssistant&&e?.metadata?.agent_id).map(e=>String(e.metadata.agent_id))))}function en(o,e,t){if(!Array.isArray(o)||o.length===0||!(t&&typeof t.fn=="function"))return "";let n=Jo(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 Ke=class{defaultMode;constructor(e={}){this.defaultMode=e.defaultMode??"lenient";}validate(e,t,r=this.defaultMode){let n=[],s=this.validateObject(e??{},t,r,["props"],n);if(n.length>0&&r==="strict")throw new ue("Props validation failed in strict mode",n);return {valid:n.length===0,props:s,errors:n}}validateObject(e,t,r,n,s){let i={};if(r==="strict")for(let a of Object.keys(e))t[a]||s.push({path:this.buildPath([...n,a]),message:`Unknown prop '${a}'`,value:e[a]});for(let[a,d]of Object.entries(t)){let c=[...n,a],u=e[a],p=this.resolveProp(u,d,c,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,c=t.itemOneOf,u=s.length;return i.value.forEach((p,g)=>{let m=[...r,String(g)];if(d){let y=this.validateType(p,{type:d},m,n,s);y.valid?a.push(y.value):s.push({path:this.buildPath(m),message:y.error??"Invalid array item",value:p});}else a.push(p);c&&!c.includes(p)&&s.push({path:this.buildPath(m),message:`Array item must be one of: ${c.join(", ")}`,value:p});}),{valid:s.length===u,value:a}}validatePlainObject(e){return this.isPlainObject(e)?{valid:true,value:{...e}}:{valid:false,error:`Expected object, got ${this.describeType(e)}`}}validateFunction(e){return typeof e!="function"?{valid:false,error:`Expected function, got ${this.describeType(e)}`}:{valid:true,value:e}}validateShape(e,t,r,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=oe__namespace.default.create(),this.propsValidator=e??new Ke,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",en),oe__namespace.default.helpers.each&&this.handlebars.registerHelper("each",oe__namespace.default.helpers.each),oe__namespace.default.helpers.if&&this.handlebars.registerHelper("if",oe__namespace.default.helpers.if),oe__namespace.default.helpers.unless&&this.handlebars.registerHelper("unless",oe__namespace.default.helpers.unless),oe__namespace.default.helpers.with&&this.handlebars.registerHelper("with",oe__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 oe__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 ue&&n.errors&&n.errors.length>0){let s=n.errors[0];if(s)throw new ue(s.message,n.errors)}throw n}}mergeProps(e,t){let r=this.cloneDeep(e??{});return t?this.deepMerge(r,t):r}deepMerge(e,t){for(let[r,n]of Object.entries(t)){if(this.isPlainObject(n)){let s=e[r];e[r]=this.deepMerge(this.isPlainObject(s)?s:{},n);continue}if(Array.isArray(n)){e[r]=this.cloneDeep(n);continue}e[r]=n;}return e}cloneDeep(e){if(Array.isArray(e))return e.map(t=>this.cloneDeep(t));if(this.isPlainObject(e)){let t={};for(let[r,n]of Object.entries(e))t[r]=this.cloneDeep(n);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}sanitizeVars(e){if(!e)return {};let t={...e};if(typeof e.user_input=="string"){t.user_input_raw=e.user_input;let r=e.user_input.replace(/\{\{\{/g,"{{{").replace(/\}\}\}/g,"}}}").replace(/\{\{/g,"{{").replace(/\}\}/g,"}}");t.user_input=this.handlebars.escapeExpression(r);}return t}};l();var er="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+=er[n%62]);}for(;t.length<o;)t+=er[crypto$1.randomBytes(1)[0]%62];return t}function Ce(o){return `${o}_${Xo(8)}`}function Qo(o,e){let{createHash:t}=W("crypto"),r=t("sha256").update(e).digest(),n=Buffer.alloc(8);for(let i=0;i<32;i++)n[i%8]^=r[i];let s="";for(let i of n)s+=er[i%62];return `${o}_${s}`}l();function tr(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 rn(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 Xe=class{_emitter=new events.EventEmitter;on(e,t){let r=rn(e,t);return this._emitter.on(e,r),()=>this._emitter.off(e,r)}once(e,t){let r=rn(e,t);return this._emitter.once(e,r),()=>this._emitter.off(e,r)}emit(e,t){this._emitter.emit(e,t);}};l();function rr(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 nr=new async_hooks.AsyncLocalStorage;function Zo(){return nr}function es(o,e){return nr.run(o,e)}function or(o){let e=o.log??o.logger??{debug:()=>{},info:()=>{},warn:()=>{},error:()=>{}},t=o.agentRunner??{run:async()=>({output:""})},r=o.db??{get:async()=>{},set:async()=>{},delete:async()=>false,list:async()=>[]},n=o.storage??{put:async()=>"",get:async()=>{},delete:async()=>false},s=o.audit??{log:async()=>{}},i=o.onInbound??(async()=>({accepted:true})),a=o.onEmitEvent??(async()=>({accepted:true})),d=o.onUpdateMessage??(async()=>{}),c=o.onResolveUser??(async g=>({userId:g,displayName:g})),u=async g=>{let m=nr.getStore();if(!m){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:"";m.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:c,respondSync:u}}$e();$e();l();function ts(o){return typeof o!="string"?"":o.replace(/</g,"<").replace(/>/g,">")}function sr(o){return o.messages.map(e=>({text:ts(e.text),isAssistant:e.isAssistant,metadata:e.metadata,files:void 0}))}l();l();var rs={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")},ns={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 nn(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",rs,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)",ns,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 on(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 sn(o,e){return e?await e(o)?null:new Response(JSON.stringify({error:"Unauthorized"}),{status:401,headers:{"Content-Type":"application/json"}}):null}function is(o,e){let t=new mcp_js.McpServer({name:"crewx-mcp-server",version:"1.0.0"},{capabilities:{tools:{}}});return nn(t,o,e),t}function ir(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=on(n);if(s)return s;let i=await sn(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=is(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 Qe=class{detach(e){}};l();l();l();var Rt=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:F.join(ls__default.default.homedir(),".crewx","crewx.db")}resolveDbPaths(){return [this.resolveDbPath()]}isMissingTableError(e){return e instanceof Error&&/no such table:/i.test(e.message)}dbExists(e){return fs.existsSync(e??this.resolveDbPath())}};l();function se(o){let e=W("better-sqlite3"),{drizzle:t}=W("drizzle-orm/better-sqlite3"),r=new e(o);return r.exec("PRAGMA journal_mode = WAL"),r.exec("PRAGMA busy_timeout = 5000"),r.exec("PRAGMA foreign_keys = ON"),{db:t(r),runRaw:(n,s=[])=>r.prepare(n).run(...s),close:()=>r.close()}}l();var an=new Set;function us(o){let{migrate:e}=W("drizzle-orm/better-sqlite3/migrator"),{sql:t}=W("drizzle-orm"),r=[F__namespace.default.join(__dirname,"../migrations"),F__namespace.default.join(__dirname,"migrations")],n=r.find(c=>fs.existsSync(F__namespace.default.join(c,"meta/_journal.json")));if(!n)throw new Error(`migrations folder not found. Searched:
|
|
47
|
+
`)}getPath(e){return this.docs.get(e)?.path}getNames(){return Array.from(this.docs.keys())}async buildContext(){let e={};for(let t of this.docs.keys()){let r=await this.getContent(t)??"",n=await this.getToc(t),s=this.getPath(t);e[t]={content:r,toc:n,...s?{path:s}:{}};}return e}async loadFromFile(e,t,r){try{let n=this.resolve(t,r),s=await this.fs.readFile(n);this.docs.set(e,{content:s,path:n});}catch(n){let s=n instanceof Error?n.message:String(n);console.warn(`[DocumentLoader] Failed to load '${e}' from '${t}': ${s}`);}}resolve(e,t){return this.fs.isAbsolute(e)?e:t?this.fs.resolvePath(t,e):this.fs.resolvePath(e)}};l();l();var B=class extends Error{constructor(t,r,n){super(t);this.layoutId=r;this.cause=n;this.name="LayoutLoadError";}layoutId;cause},ue=class extends Error{constructor(t,r=[],n){super(t);this.errors=r;this.cause=n;this.name="PropsValidationError";}errors;cause};var Jo={validationMode:"lenient",fallbackLayoutId:"crewx/default"},Je=class{layouts=new Map;options;constructor(e){this.options={...Jo,...e,templatesPath:e?.templatesPath??Ne()},this.loadAllLayouts();}load(e,t){let r=this.layouts.get(e);if(!r){let n=this.normalizeLayoutId(e);r=this.layouts.get(n);}if(!r&&(console.warn(`Layout not found: ${e}, falling back to ${this.options.fallbackLayoutId}`),r=this.layouts.get(this.options.fallbackLayoutId),!r))throw new B(`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 B("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 B(`Custom layout template is empty for ${e}`,e);let s=r.propsSchema||{},i=this.extractDefaultProps(s),a=r.defaultProps||{},d={id:e,version:r.version||"1.0.0",description:r.description||`Custom layout ${e}`,template:n,propsSchema:this.parsePropsSchema(s),defaultProps:{...i,...a}},c=this.layouts.get(e),u=c?.template===n&&JSON.stringify(c?.defaultProps??{})===JSON.stringify(d.defaultProps??{})&&JSON.stringify(c?.propsSchema??{})===JSON.stringify(d.propsSchema??{});this.layouts.set(e,d),process.env.CREWX_VERBOSE==="1"&&(c?u||console.error(`Updated custom layout: ${e}`):console.error(`Registered custom layout: ${e}`));}registerLayouts(e){for(let[t,r]of Object.entries(e))try{this.registerLayout(t,r);}catch(n){console.warn(`Failed to register custom layout ${t}:`,n instanceof Error?n.message:n);}}loadAllLayouts(){let e=this.options.templatesPath;if(!fs.existsSync(e))throw new B(`Templates directory not found: ${e}`,void 0,new Error(`Directory does not exist: ${e}`));try{let t=fs.readdirSync(e).filter(r=>r.endsWith(".yaml")||r.endsWith(".yml"));t.length===0&&console.warn(`No layout files found in ${e}`);for(let r of t){let n=r.replace(/\.(yaml|yml)$/,""),s=F__namespace.join(e,r);try{let i=this.loadLayoutFile(s,n),a=`crewx/${n}`;this.layouts.set(a,i),a!=="crewx/minimal"&&process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded layout: ${a} from ${r}`);}catch(i){console.error(`Failed to load layout file ${r}:`,i);}}process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded ${this.layouts.size} layouts from ${e}`);}catch(t){throw new B(`Failed to read layouts directory: ${e}`,void 0,t instanceof Error?t:new Error(String(t)))}}loadLayoutFile(e,t){try{let r=fs.readFileSync(e,"utf-8");if(!r||r.trim().length===0)throw console.warn(`Empty YAML file: ${e}, will use fallback`),new B(`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 B(`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 B(`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 B(`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 B(`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 Xo(o){return Array.from(new Set(o.filter(e=>e?.isAssistant&&e?.metadata?.agent_id).map(e=>String(e.metadata.agent_id))))}function en(o,e,t){if(!Array.isArray(o)||o.length===0||!(t&&typeof t.fn=="function"))return "";let n=Xo(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 Xe=class{defaultMode;constructor(e={}){this.defaultMode=e.defaultMode??"lenient";}validate(e,t,r=this.defaultMode){let n=[],s=this.validateObject(e??{},t,r,["props"],n);if(n.length>0&&r==="strict")throw new ue("Props validation failed in strict mode",n);return {valid:n.length===0,props:s,errors:n}}validateObject(e,t,r,n,s){let i={};if(r==="strict")for(let a of Object.keys(e))t[a]||s.push({path:this.buildPath([...n,a]),message:`Unknown prop '${a}'`,value:e[a]});for(let[a,d]of Object.entries(t)){let c=[...n,a],u=e[a],p=this.resolveProp(u,d,c,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,c=t.itemOneOf,u=s.length;return i.value.forEach((p,g)=>{let m=[...r,String(g)];if(d){let y=this.validateType(p,{type:d},m,n,s);y.valid?a.push(y.value):s.push({path:this.buildPath(m),message:y.error??"Invalid array item",value:p});}else a.push(p);c&&!c.includes(p)&&s.push({path:this.buildPath(m),message:`Array item must be one of: ${c.join(", ")}`,value:p});}),{valid:s.length===u,value:a}}validatePlainObject(e){return this.isPlainObject(e)?{valid:true,value:{...e}}:{valid:false,error:`Expected object, got ${this.describeType(e)}`}}validateFunction(e){return typeof e!="function"?{valid:false,error:`Expected function, got ${this.describeType(e)}`}:{valid:true,value:e}}validateShape(e,t,r,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 Ge=class{handlebars;propsValidator;constructor(e){this.handlebars=oe__namespace.default.create(),this.propsValidator=e??new Xe,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",en),oe__namespace.default.helpers.each&&this.handlebars.registerHelper("each",oe__namespace.default.helpers.each),oe__namespace.default.helpers.if&&this.handlebars.registerHelper("if",oe__namespace.default.helpers.if),oe__namespace.default.helpers.unless&&this.handlebars.registerHelper("unless",oe__namespace.default.helpers.unless),oe__namespace.default.helpers.with&&this.handlebars.registerHelper("with",oe__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 oe__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 ue&&n.errors&&n.errors.length>0){let s=n.errors[0];if(s)throw new ue(s.message,n.errors)}throw n}}mergeProps(e,t){let r=this.cloneDeep(e??{});return t?this.deepMerge(r,t):r}deepMerge(e,t){for(let[r,n]of Object.entries(t)){if(this.isPlainObject(n)){let s=e[r];e[r]=this.deepMerge(this.isPlainObject(s)?s:{},n);continue}if(Array.isArray(n)){e[r]=this.cloneDeep(n);continue}e[r]=n;}return e}cloneDeep(e){if(Array.isArray(e))return e.map(t=>this.cloneDeep(t));if(this.isPlainObject(e)){let t={};for(let[r,n]of Object.entries(e))t[r]=this.cloneDeep(n);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}sanitizeVars(e){if(!e)return {};let t={...e};if(typeof e.user_input=="string"){t.user_input_raw=e.user_input;let r=e.user_input.replace(/\{\{\{/g,"{{{").replace(/\}\}\}/g,"}}}").replace(/\{\{/g,"{{").replace(/\}\}/g,"}}");t.user_input=this.handlebars.escapeExpression(r);}return t}};l();var rr="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function Go(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+=rr[n%62]);}for(;t.length<o;)t+=rr[crypto$1.randomBytes(1)[0]%62];return t}function be(o){return `${o}_${Go(8)}`}function Qo(o,e){let{createHash:t}=W("crypto"),r=t("sha256").update(e).digest(),n=Buffer.alloc(8);for(let i=0;i<32;i++)n[i%8]^=r[i];let s="";for(let i of n)s+=rr[i%62];return `${o}_${s}`}l();function nr(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 rn(o,e){return t=>{try{let r=e(t);r instanceof Promise&&r.catch(n=>{console.error(`[crewx] event listener error (${o}): ${n instanceof Error?n.message:String(n)}`);});}catch(r){console.error(`[crewx] event listener error (${o}): ${r instanceof Error?r.message:String(r)}`);}}}var Qe=class{_emitter=new events.EventEmitter;on(e,t){let r=rn(e,t);return this._emitter.on(e,r),()=>this._emitter.off(e,r)}once(e,t){let r=rn(e,t);return this._emitter.once(e,r),()=>this._emitter.off(e,r)}emit(e,t){this._emitter.emit(e,t);}};l();function or(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 sr=new async_hooks.AsyncLocalStorage;function es(){return sr}function ts(o,e){return sr.run(o,e)}function ir(o){let e=o.log??o.logger??{debug:()=>{},info:()=>{},warn:()=>{},error:()=>{}},t=o.agentRunner??{run:async()=>({output:""})},r=o.db??{get:async()=>{},set:async()=>{},delete:async()=>false,list:async()=>[]},n=o.storage??{put:async()=>"",get:async()=>{},delete:async()=>false},s=o.audit??{log:async()=>{}},i=o.onInbound??(async()=>({accepted:true})),a=o.onEmitEvent??(async()=>({accepted:true})),d=o.onUpdateMessage??(async()=>{}),c=o.onResolveUser??(async g=>({userId:g,displayName:g})),u=async g=>{let m=sr.getStore();if(!m){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:"";m.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:c,respondSync:u}}je();je();l();function rs(o){return typeof o!="string"?"":o.replace(/</g,"<").replace(/>/g,">")}function ar(o){return o.messages.map(e=>({text:rs(e.text),isAssistant:e.isAssistant,metadata:e.metadata,files:void 0}))}l();l();var ns={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")},os={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 nn(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",ns,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)",os,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 on(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 sn(o,e){return e?await e(o)?null:new Response(JSON.stringify({error:"Unauthorized"}),{status:401,headers:{"Content-Type":"application/json"}}):null}function as(o,e){let t=new mcp_js.McpServer({name:"crewx-mcp-server",version:"1.0.0"},{capabilities:{tools:{}}});return nn(t,o,e),t}function dr(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=on(n);if(s)return s;let i=await sn(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=as(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 Ye=class{detach(e){}};l();l();l();var Pt=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:F.join(cs__default.default.homedir(),".crewx","crewx.db")}resolveDbPaths(){return [this.resolveDbPath()]}isMissingTableError(e){return e instanceof Error&&/no such table:/i.test(e.message)}dbExists(e){return fs.existsSync(e??this.resolveDbPath())}};l();function se(o){let e=W("better-sqlite3"),{drizzle:t}=W("drizzle-orm/better-sqlite3"),r=new e(o);return r.exec("PRAGMA journal_mode = WAL"),r.exec("PRAGMA busy_timeout = 5000"),r.exec("PRAGMA foreign_keys = ON"),{db:t(r),runRaw:(n,s=[])=>r.prepare(n).run(...s),close:()=>r.close()}}l();var an=new Set;function ps(o){let{migrate:e}=W("drizzle-orm/better-sqlite3/migrator"),{sql:t}=W("drizzle-orm"),r=[F__namespace.default.join(__dirname,"../migrations"),F__namespace.default.join(__dirname,"migrations")],n=r.find(c=>fs.existsSync(F__namespace.default.join(c,"meta/_journal.json")));if(!n)throw new Error(`migrations folder not found. Searched:
|
|
48
48
|
${r.join(`
|
|
49
|
-
`)}`);let s=o.get(t`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='__drizzle_migrations'`),i=0;s?.cnt&&(i=o.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0),e(o,{migrationsFolder:n});let d=(o.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0)-i;if(d>0){let c=s?.cnt?"Database migrated":"Database initialized";console.log(`[crewx] ${c} (${d} migration${d>1?"s":""} applied).`);}}function dn(o,e){an.has(e)||(us(o),an.add(e));}l();var L=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 Le=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(()=>Le.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 xs=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(()=>xs.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 bt=class extends Rt{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=F.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let n=F.dirname(t);fs.existsSync(n)||fs.mkdirSync(n,{recursive:true});}else if(!fs.existsSync(t))throw new L("NOT_FOUND","Database not found");let r=se(t);if(e)try{dn(r.db,t);}catch(n){throw r.close(),n}return r}validateWorkspaceId(e,t){return e.db.select({id:Le.id}).from(Le).where(drizzleOrm.eq(Le.id,t)).limit(1).get()?t:null}findAllThreads(e){let t=this.resolveDbPaths(),r=new Set,n=[];for(let s of t){if(!fs.existsSync(s))continue;let i=se(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 L("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.existsSync(n))continue;let s=se(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 L("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.existsSync(n))continue;let s=se(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 L("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.existsSync(u))continue;let p=se(u);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,""))),m=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(m).get();y&&(n+=y.cnt,s+=y.total_input,i+=y.total_output,a+=y.total_cached,d+=y.total_cost);let w=p.db.all(drizzleOrm.sql`
|
|
49
|
+
`)}`);let s=o.get(t`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='__drizzle_migrations'`),i=0;s?.cnt&&(i=o.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0),e(o,{migrationsFolder:n});let d=(o.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0)-i;if(d>0){let c=s?.cnt?"Database migrated":"Database initialized";console.log(`[crewx] ${c} (${d} migration${d>1?"s":""} applied).`);}}function dn(o,e){an.has(e)||(ps(o),an.add(e));}l();var L=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 He=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 E=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(()=>He.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 vs=sqliteCore.sqliteTable("spans",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>E.id,{onDelete:"set null"}),parent_span_id:sqliteCore.text("parent_span_id").references(()=>vs.id,{onDelete:"set null"}),name:sqliteCore.text("name").notNull(),kind:sqliteCore.text("kind").notNull().default("internal"),status:sqliteCore.text("status").notNull().default("ok"),started_at:sqliteCore.text("started_at").notNull(),completed_at:sqliteCore.text("completed_at"),duration_ms:sqliteCore.integer("duration_ms"),input:sqliteCore.text("input"),output:sqliteCore.text("output"),error:sqliteCore.text("error"),attributes:sqliteCore.text("attributes")},o=>({idx_spans_task_id:sqliteCore.index("idx_spans_task_id").on(o.task_id),idx_spans_parent_span_id:sqliteCore.index("idx_spans_parent_span_id").on(o.parent_span_id)}));l();sqliteCore.sqliteTable("tool_calls",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>E.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 Tt=class extends Pt{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=F.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let n=F.dirname(t);fs.existsSync(n)||fs.mkdirSync(n,{recursive:true});}else if(!fs.existsSync(t))throw new L("NOT_FOUND","Database not found");let r=se(t);if(e)try{dn(r.db,t);}catch(n){throw r.close(),n}return r}validateWorkspaceId(e,t){return e.db.select({id:He.id}).from(He).where(drizzleOrm.eq(He.id,t)).limit(1).get()?t:null}findAllThreads(e){let t=this.resolveDbPaths(),r=new Set,n=[];for(let s of t){if(!fs.existsSync(s))continue;let i=se(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 L("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.existsSync(n))continue;let s=se(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 L("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.existsSync(n))continue;let s=se(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 L("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.existsSync(u))continue;let p=se(u);try{let g=drizzleOrm.and(drizzleOrm.eq(E.thread_id,e),drizzleOrm.or(drizzleOrm.isNull(E.parent_task_id),drizzleOrm.eq(E.parent_task_id,""))),m=t?drizzleOrm.and(g,drizzleOrm.eq(E.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(E).where(m).get();y&&(n+=y.cnt,s+=y.total_input,i+=y.total_output,a+=y.total_cached,d+=y.total_cost);let w=p.db.all(drizzleOrm.sql`
|
|
50
50
|
SELECT DISTINCT agent_id FROM tasks
|
|
51
51
|
WHERE thread_id = ${e}
|
|
52
52
|
AND agent_id IS NOT NULL AND agent_id != ''
|
|
53
53
|
AND (parent_task_id IS NULL OR parent_task_id = '')
|
|
54
54
|
${t?drizzleOrm.sql`AND workspace_id = ${t}`:drizzleOrm.sql``}
|
|
55
|
-
`);for(let h of w)c.add(h.agent_id);}catch(g){throw new L("DB_ERROR","Failed to aggregate task stats",g)}finally{p.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.existsSync(i))continue;let a=se(i);try{let d=drizzleOrm.and(drizzleOrm.eq(
|
|
55
|
+
`);for(let h of w)c.add(h.agent_id);}catch(g){throw new L("DB_ERROR","Failed to aggregate task stats",g)}finally{p.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.existsSync(i))continue;let a=se(i);try{let d=drizzleOrm.and(drizzleOrm.eq(E.thread_id,e),drizzleOrm.or(drizzleOrm.isNull(E.parent_task_id),drizzleOrm.eq(E.parent_task_id,""))),c=t?drizzleOrm.and(d,drizzleOrm.eq(E.workspace_id,t)):d,u=a.db.select().from(E).where(c).orderBy(drizzleOrm.asc(E.started_at)).all();for(let p of u)n.has(p.id)||(n.add(p.id),s.push(p));}catch(d){throw new L("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.existsSync(i))continue;let a=se(i);try{let d=drizzleOrm.eq(E.thread_id,e),c=t?drizzleOrm.and(d,drizzleOrm.eq(E.workspace_id,t)):d,u=a.db.select().from(E).where(c).orderBy(drizzleOrm.asc(E.started_at)).all();for(let p of u)n.has(p.id)||(n.add(p.id),s.push(p));}catch(d){throw new L("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.existsSync(s))continue;let i=se(s);try{let a=drizzleOrm.and(drizzleOrm.eq(E.id,t),drizzleOrm.eq(E.thread_id,e)),d=r?drizzleOrm.and(a,drizzleOrm.eq(E.workspace_id,r)):a,c=i.db.select().from(E).where(d).limit(1).get();if(!c)continue;let u=i.db.select().from(E).where(drizzleOrm.eq(E.parent_task_id,c.id)).orderBy(drizzleOrm.asc(E.started_at)).all();return {task:c,children:u}}catch(a){throw new L("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.existsSync(s))continue;let i=se(s);try{let a=drizzleOrm.and(drizzleOrm.inArray(E.thread_id,e),drizzleOrm.or(drizzleOrm.isNull(E.parent_task_id),drizzleOrm.eq(E.parent_task_id,""))),d=t?drizzleOrm.and(a,drizzleOrm.eq(E.workspace_id,t)):a,c=i.db.select().from(E).where(d).orderBy(drizzleOrm.asc(E.started_at)).all();for(let u of c){let p=u.thread_id;r.has(p)||r.set(p,[]),r.get(p).push(u);}}catch(a){throw new L("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 L?s:new L("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 L?n:new L("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 L?s:new L("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`
|
|
56
56
|
UPDATE threads
|
|
57
57
|
SET first_message = COALESCE(first_message, ${t}),
|
|
58
58
|
title = CASE WHEN title_locked = 0 AND title IS NULL THEN substr(${t}, 1, 60) ELSE title END,
|
|
@@ -60,14 +60,14 @@ ${r.join(`
|
|
|
60
60
|
message_count = message_count + 1,
|
|
61
61
|
updated_at = ${s}
|
|
62
62
|
WHERE id = ${e}
|
|
63
|
-
`);}catch(s){throw s instanceof L?s:new L("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 L?s:new L("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 L?n:new L("DB_ERROR","Failed to update thread",n)}finally{r.close();}}};function
|
|
63
|
+
`);}catch(s){throw s instanceof L?s:new L("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 L?s:new L("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 L?n:new L("DB_ERROR","Failed to update thread",n)}finally{r.close();}}};function Ns(o){return o.replace(/<conversation_history[^>]*>[\s\S]*?<\/conversation_history>/g,"").split(`
|
|
64
64
|
`).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(`
|
|
65
|
-
`).trim()}function
|
|
66
|
-
`):t&&typeof t=="object"&&t.result!==void 0&&(e=t.result||"");}catch{e=
|
|
67
|
-
${i.message}`)}let s=ct(n);if(s.documents&&typeof s.documents=="object"){let i={};for(let[a,d]of Object.entries(s.documents))if(d&&typeof d=="object"){let c=d;typeof c.path=="string"&&!F.isAbsolute(c.path)?i[a]={...c,path:F.resolve(r,c.path)}:i[a]=c;}else i[a]=d;return {...s,documents:i}}return s}static mergeCrewxConfig(e,t){let r=new Map;for(let v of e.agents??[])r.set(v.id,v);for(let v of t.agents??[])r.has(v.id)&&console.warn(`[agent-loader] User agent "${v.id}" overrides built-in`),r.set(v.id,v);let n=Array.from(r.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,d=t,c=Mn(a.vars,d.vars),u=Mn(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??[]],m=ci(a.providers,d.providers),y={...e},w={...t};for(let v of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete y[v],delete w[v];let _={...{...y,...w},agents:n,layouts:s,documents:i,skills:p};return g.length>0&&(_.hooks=g),c!==void 0&&(_.vars=c),u!==void 0&&(_.settings=u),m!==void 0&&(_.providers=m),_}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 p=ut(e);s=o.mergeCrewxConfig(u,p),i=F.dirname(e);}else s=u,i=process.cwd();}else {if(e===void 0)throw new Error("[@crewx/sdk] loadYaml: path is required when includeBuiltIns is false");s=ut(e),i=F.dirname(e);}let a=new Ae(r);await a.load(s.documents,i);let d=s.agents??[];await Nn(d,s,t);let c=new o(d,t??{},s,a,i);return await c.use(new Ge),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 Ae(n);await a.load(i.documents,r??(typeof process<"u"?process.cwd():"/"));let d=i.agents??[];await Nn(d,i,t);let c=new o(d,t??{},i,a,r);return await c.use(new Ge),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=tr(t);return F.join(this._projectRoot,".crewx","logs",`${r}_${e}.log`)}registerTool(e,t){this._tools.set(e,{name:e,...t});}async use(e){this._plugins.includes(e)||(await e.attach(this),this._plugins.push(e));}handler(e){return ir(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??rr(r),a=e.defaultMode??"query",d=t.manifest.platform,c=e.agentRunner??{run:async(m,y,w)=>{let _=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${m}`,y,{threadId:w?.threadId,platform:d});return {output:_.ok?_.data:_.error?.message??""}}},u=e.onInbound??(async m=>{let y=m.routingHints?.agentId??e.defaultAgent;if(!y)return {accepted:false,reason:"no_agent"};let{output:w}=await c.run(y,m.text,{threadId:m.threadId});return {accepted:true,output:w}}),p=or({instanceId:r,config:n,capabilities:s,db:i,agentRunner:c,onInbound:u}),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(m){throw g.state="failed",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"failed",error:m instanceof Error?m:new Error(String(m)),timestamp:new Date}),this._activeAdapters.delete(r),m}}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=>re(a.role.toLowerCase(),d)))),n&&(i=i.filter(a=>a.team&&n.some(d=>re(a.team.toLowerCase(),d)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(c=>s.some(u=>re(c.toLowerCase(),u))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,r=this._agents.get(t);if(!r)throw new de(t,Array.from(this._agents.keys()));return r.inline?.prompt??r.inline?.system_prompt??r.description??`You are an expert ${t}.`}async renderPrompt(e,t){let n={...await this._documentLoader.buildContext(),...t?.documents??{}},s={...t,documents:n};return this._templateEngine.render(e,s)}registerLayout(e,t){this._layoutLoader.registerLayout(e,t);}async renderAgentPromptFull(e,t){let r=e.startsWith("@")?e.slice(1):e,n=this._agents.get(r);if(!n)throw new de(r,Array.from(this._agents.keys()));let s=this._resolveLayoutSpec(n,t?.layout),i=this._extractLayoutId(s),a=this._extractLayoutProps(n,s,t?.layout),d=this._layoutLoader.load(i,a),c=n.inline?.prompt??n.inline?.system_prompt??n.description??`You are an expert ${r}.`,u=await this._documentLoader.buildContext(),p=t?.env??(typeof process<"u"?process.env:{}),g=t?.vars?.security_key??li(),m={...t?.vars??{},documents:u,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(c,m),w={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},h=n.provider,_=Array.isArray(h)?h:typeof h=="string"&&h.length>0?[h]:[],v=_.join(", ")||(typeof h=="string"?h:""),A=n.options,E=!Array.isArray(A)&&typeof A=="object"&&A!==null?A:void 0,I=Array.isArray(A)?A:void 0,H={};for(let[O,k]of Object.entries(u))H[O]={content:k.content??"",toc:k.toc,summary:k.summary,path:k.path};let b={user_input:t?.vars?.user_input??void 0,agent:{id:n.id,name:n.name??n.id,role:n.role??"",team:n.team??"",description:n.description??"",provider:v,providerList:_,model:n.inline?.model,workingDirectory:n.working_directory??n.workingDirectory??".",inline:{...n.inline??{},prompt:y},specialties:n.specialties??[],capabilities:n.capabilities??[],remote:n.remote??null,optionsByMode:E,optionsArray:I},agentMetadata:{specialties:n.specialties??[],capabilities:n.capabilities??[],description:n.description??""},documents:H,skills:t?.skills??[],session:w,env:p,vars:{security_key:g,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:w.platform,mode:w.mode,messages:t?.messages??[],tools:this._tools.size>0?{list:Array.from(this._tools.values()).map(O=>({name:O.name,description:O.description,parameters:O.parameters})),json:JSON.stringify(Array.from(this._tools.values()).map(O=>({name:O.name,description:O.description,parameters:O.parameters})),null,2),count:this._tools.size}:null,metadata:{}};return this._layoutRenderer.render(d,b)}_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:sr(s)}catch{return}}_resolveTimeout(e){let t=zr();return e==="query"?t.queryMs:t.executeMs}emitToolEvents(e,t,r,n,s,i,a){try{let c=exports.BUILTIN_ADAPTERS[r]?.parseEvent?.(n)??Vt(new Date().toISOString(),n);for(let u of c)u.type==="tool_use"&&u.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName,rawName:u.toolName,input:u.toolInput?this.tryParseJson(u.toolInput):void 0,toolUseId:u.toolUseId}}),u.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName??"unknown",rawName:u.toolName??"unknown",toolUseId:u.toolUseId,result:u.resultPreview,isError:u.isError}});}catch{}}emitTaskLogEntries(e,t,r,n,s,i,a){try{for(let d of a)d.type==="tool_use"&&d.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:n,sessionId:s,provider:i,tool:{name:d.toolName,rawName:d.toolName,input:d.toolInput?this.tryParseJson(d.toolInput):void 0,toolUseId:d.toolUseId}}),d.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:n,sessionId:s,provider:i,tool:{name:d.toolName??"unknown",rawName:d.toolName??"unknown",toolUseId:d.toolUseId,result:d.resultPreview,isError:d.isError}});}catch{}}tryParseJson(e){try{return JSON.parse(e)}catch{return e}}async query(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.query(n.agentRef,t,r);let s=Date.now(),i=Ce("tsk"),a=new Date,d;try{d=gt(e,Array.from(this._agents.values()));}catch(k){if(k instanceof de){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let N=Date.now()-s,x={code:"AGENT_NOT_FOUND",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:N,error:x,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:x,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:N}}}throw k}let c=Array.isArray(d.provider)?d.provider[0]??"cli/claude":d.provider,u=r?.provider??c,p=r?.model??d.inline?.model;p&&p.includes("{{")&&(p=await this._templateEngine.render(p,{...r?.vars??{}}));let g;try{g=ce(u);}catch(k){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let N=Date.now()-s,x={code:"PROVIDER_ERROR",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:N,error:x,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:x,meta:{agentId:d.id,provider:u,model:p,durationMs:N}}}let m=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),y;try{y=await this.renderAgentPromptFull(e,{session:{mode:"query",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:m});}catch(k){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${k instanceof Error?k.message:String(k)}`);}let w,h,_,v=p,A=false,E=k=>{A||(A=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",pid:k,model:v,provider:u,codingAgentCommand:w,renderedPrompt:y,metadata:{...r?.metadata??{},provider:u},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},I=d.options,H=Array.isArray(I?.query?.tools)?I.query.tools:void 0,j=this._tools.size>0?this._filterToolsByMode(H):[],b=(()=>{let k=I?.query;if(!k||Array.isArray(k))return;let{tools:N,effort:x,mode:U,...xe}=k,ve=Object.entries(xe).filter(([,q])=>q!=null);if(ve.length!==0)return Object.fromEntries(ve.map(([q,X])=>[q,String(X)]))})(),O=d.inline?.max_steps;u.startsWith("api/")&&E();try{let k=await g.query(t,{model:p,effort:I?.query?.effort,mode:I?.query?.mode,context:r?.context,systemPrompt:y??d.inline?.system_prompt??d.inline?.prompt??d.description??`You are ${d.id}.`,additionalArgs:Array.isArray(I?.query)?I.query:void 0,tools:j.length>0?j:void 0,maxSteps:O,configOptions:b,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:x=>E(x),onOutput:(x,U)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:x,level:U}),U==="stdout"&&this.emitToolEvents(i,e,u,x,d.id,r?.threadId??"","");},onTaskLog:x=>{this.emitTaskLogEntries(i,e,d.id,r?.threadId??"","",u,x);for(let U of x)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(U),level:"info"});},onCommand:x=>{w=x;},onUsage:x=>{h=x;},onExitCode:x=>{_=x;},onModel:x=>{v||(v=x);}});E();let N=Date.now()-s;return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:k,durationMs:N,exitCode:_,inputTokens:h?.inputTokens,outputTokens:h?.outputTokens,cachedInputTokens:h?.cachedInputTokens,costUsd:h?.costUsd,model:v,metadata:{...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}}}),{ok:!0,data:k,meta:{agentId:d.id,provider:u,model:p,durationMs:N}}}catch(k){if(k instanceof exports.ClientToolCallRequiredError){let U=Ce("thd");return this._pendingThreads.set(U,{agentRef:d.id,providerStr:u,continuationState:k.continuationState,toolCall:k.toolCall,traceId:i,startMs:s,model:p}),{ok:true,status:"requires_action",data:"",toolCall:k.toolCall,threadId:U,meta:{agentId:d.id,provider:u,model:p,durationMs:Date.now()-s}}}E();let N=Date.now()-s,x={code:"QUERY_FAILED",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:N,error:x,exitCode:_,inputTokens:h?.inputTokens,outputTokens:h?.outputTokens,cachedInputTokens:h?.cachedInputTokens,costUsd:h?.costUsd,model:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:x,meta:{agentId:d.id,provider:u,model:p,durationMs:N}}}}async continueQuery(e,t){let r=this._pendingThreads.get(e);if(!r)return {ok:false,data:"",error:{code:"THREAD_NOT_FOUND",message:`No pending thread: ${e}`},meta:{agentId:"",provider:"",durationMs:0}};this._pendingThreads.delete(e);let n=ce(r.providerStr);if(!n.continueWithToolResults)return {ok:false,data:"",error:{code:"UNSUPPORTED",message:"Provider does not support client tool continuation"},meta:{agentId:r.agentRef,provider:r.providerStr,durationMs:0}};let s=t.map(i=>({...i,toolName:r.toolCall.toolCallId===i.toolCallId?r.toolCall.toolName:i.toolCallId}));try{let i=await n.continueWithToolResults(r.continuationState,s),a=Date.now()-r.startMs;return this.emit("task:end",{traceId:r.traceId,timestamp:new Date,agentRef:r.agentRef,mode:"query",result:i,durationMs:a}),{ok:!0,status:"complete",data:i,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}catch(i){if(i instanceof exports.ClientToolCallRequiredError)return this._pendingThreads.set(e,{...r,continuationState:i.continuationState,toolCall:i.toolCall}),{ok:true,status:"requires_action",data:"",toolCall:i.toolCall,threadId:e,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:Date.now()-r.startMs}};let a=Date.now()-r.startMs;return {ok:false,data:"",error:{code:"CONTINUE_FAILED",message:i.message},meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}}async execute(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.execute(n.agentRef,t,r);let s=Date.now(),i=Ce("tsk"),a=new Date,d;try{d=gt(e,Array.from(this._agents.values()));}catch(k){if(k instanceof de){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let N=Date.now()-s,x={code:"AGENT_NOT_FOUND",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:N,error:x,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:x,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:N}}}throw k}let c=Array.isArray(d.provider)?d.provider[0]??"cli/claude":d.provider,u=r?.provider??c,p=r?.model??d.inline?.model;p&&p.includes("{{")&&(p=await this._templateEngine.render(p,{...r?.vars??{}}));let g;try{g=ce(u);}catch(k){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let N=Date.now()-s,x={code:"PROVIDER_ERROR",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:N,error:x,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:x,meta:{agentId:d.id,provider:u,model:p,durationMs:N}}}let m=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),y;try{y=await this.renderAgentPromptFull(e,{session:{mode:"execute",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:m});}catch(k){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${k instanceof Error?k.message:String(k)}`);}let w,h,_,v=p,A=false,E=k=>{A||(A=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",pid:k,model:v,provider:u,codingAgentCommand:w,renderedPrompt:y,metadata:{...r?.metadata??{},provider:u},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},I=d.options,H=Array.isArray(I?.execute?.tools)?I.execute.tools:void 0,j=this._tools.size>0?this._filterToolsByMode(H):[],b=(()=>{let k=I?.execute;if(!k||Array.isArray(k))return;let{tools:N,effort:x,mode:U,...xe}=k,ve=Object.entries(xe).filter(([,q])=>q!=null);if(ve.length!==0)return Object.fromEntries(ve.map(([q,X])=>[q,String(X)]))})(),O=d.inline?.max_steps;u.startsWith("api/")&&E();try{let k=await g.execute(t,{model:p,effort:I?.execute?.effort,mode:I?.execute?.mode,context:r?.context,systemPrompt:y??d.inline?.system_prompt??d.inline?.prompt??d.description??`You are ${d.id}.`,additionalArgs:Array.isArray(I?.execute)?I.execute:void 0,tools:j.length>0?j:void 0,maxSteps:O,configOptions:b,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:x=>E(x),onOutput:(x,U)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:x,level:U}),U==="stdout"&&this.emitToolEvents(i,e,u,x,d.id,r?.threadId??"","");},onTaskLog:x=>{this.emitTaskLogEntries(i,e,d.id,r?.threadId??"","",u,x);for(let U of x)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(U),level:"info"});},onCommand:x=>{w=x;},onUsage:x=>{h=x;},onExitCode:x=>{_=x;},onModel:x=>{v||(v=x);}});E();let N=Date.now()-s;return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:k,durationMs:N,exitCode:_,inputTokens:h?.inputTokens,outputTokens:h?.outputTokens,cachedInputTokens:h?.cachedInputTokens,costUsd:h?.costUsd,model:v,metadata:{...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}}}),{ok:!0,data:k,meta:{agentId:d.id,provider:u,model:p,durationMs:N}}}catch(k){E();let N=Date.now()-s,x={code:"EXECUTE_FAILED",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:N,error:x,exitCode:_,inputTokens:h?.inputTokens,outputTokens:h?.outputTokens,cachedInputTokens:h?.cachedInputTokens,costUsd:h?.costUsd,model:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:x,meta:{agentId:d.id,provider:u,model:p,durationMs:N}}}}};function Mn(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 ci(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 Nn(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(()=>(ur(),xn));n(t?.api);}pi(o,e),gi(o,e),ui(o);}function ui(o){if(!o.some(r=>(Array.isArray(r.provider)?r.provider:[r.provider]).some(s=>s.startsWith("acp/"))))return;let{registerAcpProviders:t}=(_r(),jt(Pn));t();}function pi(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}=(Ar(),jt(Cn)),s=new Map;for(let i of r)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&le("remote",n(s,ce));}function gi(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}=(Cr(),jt(Sn)),s=new Map;for(let i of r)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&le("plugin",n(s));}l();var mi="crewx:fs:",Er=class{prefix;store;constructor(e){this.prefix=e?.prefix??mi,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 fi(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))}ne();cr();ur();l();gr();we();mr();fr();kr();_r();Ut();$e();l();var Sr=0;function yi(o){let e=Array.from(o.agents.keys());return {name:"delegate_to_agent",description:`Delegate a task to another agent. Available agents: ${e.join(", ")}`,parameters:{type:"object",properties:{agent:{type:"string",description:`Agent ID to delegate to. One of: ${e.join(", ")}`},message:{type:"string",description:"Task description for the target agent"},mode:{type:"string",description:'Execution mode: "query" for questions, "execute" for actions. Default: query'}},required:["agent","message"]},execute:async t=>{if(Sr>=3)return "Error: Maximum delegation depth (3) reached. Cannot delegate further.";let r=t.agent,n=t.message,s=t.mode??"query";if(!e.includes(r))return `Error: Unknown agent "${r}". Available: ${e.join(", ")}`;Sr++;try{if(s==="execute"){let a=await o.execute(r,n);return a.ok?a.data:`Error: ${a.error?.message??"Unknown error"}`}let i=await o.query(r,n);return i.ok?i.data:`Error: ${i.error?.message??"Unknown error"}`}finally{Sr--;}}}}l();var Dn=typeof process<"u"?process.env:{};function hi(){return Dn.CREWX_CLI||"npx crewx"}function wi(){return Dn.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}l();var xi=/^[a-zA-Z0-9._-]+$/,Ir=class{constructor(e){this.storage=e;}storage;listBoxes(e){this.validateId(e);let r=this.storage.listBoxes(e).map(n=>this.toBoxResponse(n));return {boxes:r,total:r.length}}getBox(e,t){this.validateId(e),this.validateId(t);let r=this.storage.findBox(e,t);return r?this.toBoxResponse(r):null}createBox(e,t){this.validateId(e);let r=this.generateBoxId(),n=new Date().toISOString(),s=this.storage.insertBox(e,{id:r,seq:t.seq,firstTaskId:t.firstTaskId,midTaskId:t.midTaskId,lastTaskId:t.lastTaskId,taskCount:t.taskCount,summary:t.summary??null,sourceTokens:t.sourceTokens,summaryTokens:t.summaryTokens??null,createdAt:n});return this.toBoxResponse(s)}toBoxResponse(e){return {id:e.id,threadId:e.thread_id,seq:e.seq,firstTaskId:e.first_task_id,lastTaskId:e.last_task_id,taskCount:e.task_count,sourceTokens:e.source_tokens,summaryTokens:e.summary_tokens,summary:e.summary,previewFirst:this.storage.getTaskPreview(e.first_task_id,200),previewMid:this.storage.getTaskPreview(e.mid_task_id,200),previewLast:this.storage.getTaskPreview(e.last_task_id,200),createdAt:e.created_at}}validateId(e){if(!xi.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return Ce("box")}};l();function vi(o,e,t,r,n){let{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}=r,d=s*i,c=s*a,u=d+c,p=e.getThreadMessages(o),g=[],m=0,y=false,w=[];for(let v=0;v<p.length;v+=2){let A=p[v],E=p[v+1],I=A?.content||"",H=E?.content||"",j=n.countTokens(I+H),b=[];A&&b.push(A),E&&b.push(E),w.push({messages:b,tokens:j});}for(let v=w.length-1;v>=0;v--){let A=w[v];if(m+A.tokens>d){y=true;break}m+=A.tokens,g.unshift(...A.messages);}let h=[],_=0;if(y&&c>0)try{let{boxes:v}=t.listBoxes(o);for(let A=v.length-1;A>=0;A--){let E=v[A],I=E.summaryTokens??E.sourceTokens;if(_+I>c)break;_+=I,h.unshift({boxId:E.id,seq:E.seq,taskCount:E.taskCount,sourceTokens:E.sourceTokens,summary:E.summary,previewFirst:E.previewFirst,previewMid:E.previewMid,previewLast:E.previewLast,createdAt:E.createdAt});}}catch(v){if(v instanceof Error&&!/not found/i.test(v.message))throw v}return {hot:g,warm:h,hotTokens:m,warmTokens:_,hotOverflow:y,totalBudget:u,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}$e();Pe();l();var Dt=class extends Error{constructor(t,r){super(`Task ${t} timed out after ${r}ms`);this.taskId=t;this.timeoutMs=r;this.name="ParallelRunnerTimeoutError";}taskId;timeoutMs},it=class{constructor(e={}){this.defaults=e;}defaults;metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0};async run(e,t={}){if(!Array.isArray(e))throw new TypeError("ParallelRunner.run expects an array of tasks");if(e.length===0)return this.metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0},[];let r=this.mergeOptions(t),n=Math.max(1,r.maxConcurrency??5),s=r.timeoutMs,i=r.failFast??false,a=r.callbacks,d=r.evaluateTaskSuccess??(()=>true),c=[],u=0,p=0,g=0,m=false,y=0,w=perf_hooks.performance.now(),h=async b=>{a?.onTaskStart&&await a.onTaskStart(b),g+=1;let O=new AbortController,k={signal:O.signal},N,x;typeof s=="number"&&Number.isFinite(s)&&s>0&&(x=new Promise((q,X)=>{N=setTimeout(()=>{let ke=new Dt(b.id,s);O.abort(ke),X(ke);},s);}));let U=perf_hooks.performance.now(),xe=b.run(k),ve=x?Promise.race([xe,x]):xe;try{let q=await ve,X=perf_hooks.performance.now(),ke=X-U,Ie=d(q,b),dt={taskId:b.id,success:Ie,value:q,durationMs:ke,startedAt:U,finishedAt:X,metadata:b.metadata,aborted:!1};c.push(dt),Ie?u+=1:p+=1,a?.onTaskComplete&&await a.onTaskComplete(dt),i&&!Ie&&(m=!0);}catch(q){let X=perf_hooks.performance.now(),ke=X-U,Ie=q instanceof Error?q:new Error(String(q)),dt={taskId:b.id,success:false,error:Ie,durationMs:ke,startedAt:U,finishedAt:X,metadata:b.metadata,aborted:O.signal.aborted};c.push(dt),p+=1,a?.onError&&await a.onError(b,Ie,ke),i&&(m=true);}finally{N&&clearTimeout(N),x&&xe.catch(()=>{});}},_=async()=>{for(;!m;){let b=y;if(b>=e.length)break;y+=1;let O=e[b];if(!O||(await h(O),m))break}},v=Math.min(n,e.length),A=[];for(let b=0;b<v;b++)A.push(_());await Promise.all(A);let I=perf_hooks.performance.now()-w,H=c.length?c.reduce((b,O)=>b+O.durationMs,0)/c.length:0,j=I>0?c.length/(I/1e3):c.length;return this.metrics={totalTasks:e.length,startedTasks:g,completedTasks:c.length,successCount:u,failureCount:p,totalDurationMs:I,averageDurationMs:H,throughput:j},c}getMetrics(){return this.metrics}mergeOptions(e){return {maxConcurrency:e.maxConcurrency??this.defaults.maxConcurrency,timeoutMs:e.timeoutMs??this.defaults.timeoutMs,failFast:e.failFast??this.defaults.failFast,evaluateTaskSuccess:e.evaluateTaskSuccess??this.defaults.evaluateTaskSuccess,callbacks:this.mergeCallbacks(this.defaults.callbacks,e.callbacks)}}mergeCallbacks(e,t){if(!(!e&&!t))return {onTaskStart:async r=>{e?.onTaskStart&&await e.onTaskStart(r),t?.onTaskStart&&await t.onTaskStart(r);},onTaskComplete:async r=>{e?.onTaskComplete&&await e.onTaskComplete(r),t?.onTaskComplete&&await t.onTaskComplete(r);},onError:async(r,n,s)=>{e?.onError&&await e.onError(r,n,s),t?.onError&&await t.onError(r,n,s);}}}};l();l();var at=class{async query(e){throw new Error("AgentRuntime.query is not implemented. Provide a subclass or mock AgentRuntime.prototype.query.")}async execute(e){throw new Error("AgentRuntime.execute is not implemented. Provide a subclass or mock AgentRuntime.prototype.execute.")}};var $n=3,Ln=3e4,jn=500,ki=o=>{if(typeof o!="number"||Number.isNaN(o)||!Number.isFinite(o))return $n;let e=Math.floor(o);return e>0?e:$n},_i=o=>o===void 0||typeof o!="number"||Number.isNaN(o)||o<=0?Ln:o,Ri=o=>{if(!o)return {maxRetries:0,retryDelay:jn};let e=Number.isInteger(o.maxRetries)&&o.maxRetries>=0?o.maxRetries:0,t=typeof o.retryDelay=="number"&&o.retryDelay>=0?o.retryDelay:jn;return {maxRetries:e,retryDelay:t}},Or=o=>{let e=o.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},Pi=(o,e)=>o<=0?Promise.resolve():new Promise((t,r)=>{let n=setTimeout(()=>{e.removeEventListener("abort",s),t();},o),s=()=>{clearTimeout(n),r(Or(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),Ai=async(o,e,t)=>{let r,n;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw Or(t);try{let i=await o();if(r=i,i.success||s===e.maxRetries)return i}catch(i){if(n=i,t.aborted)throw Or(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await Pi(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")},Hn=(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);}},Ci=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}}}),bi=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")}}),Ti=(o,e)=>({onTaskComplete:async t=>{Hn(e,o,t.success);},onError:async()=>{Hn(e,o,false);}}),Un=async(o,e,t={})=>{if(!Array.isArray(o))throw new TypeError("Parallel helpers expect an array of requests");if(o.length===0){let h={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?.(h),[]}let r=ki(t.concurrency),n=_i(t.timeout),s=Ri(t.retryPolicy),i=new it,a=new at,d=o.map((w,h)=>({id:`${e}:${w.agentId??"anonymous"}:${h}`,metadata:{index:h,mode:e,request:w},run:_=>Ai(()=>e==="query"?a.query(w):a.execute(w),s,_.signal)})),c={completed:0,success:0,failure:0,total:o.length},u=await i.run(d,{maxConcurrency:r,timeoutMs:n,evaluateTaskSuccess:w=>w.success,callbacks:Ti(c,t)}),p=Ci(u),g=bi(u),m=i.getMetrics(),y={total:o.length,completed:o.length,successCount:p.filter(w=>w.success).length,failureCount:p.filter(w=>!w.success).length,results:p,errors:g,metrics:m};return t.onComplete?.(y),p},Ei=(o,e)=>Un(o,"query",e),Si=(o,e)=>Un(o,"execute",e);Cr();Ar();Pr();Rr();l();l();var $t=class{capabilities={required:[]}};l();l();l();var qn=2e3;function Fn(o){let e=o.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f\u2028\u2029]/g,"");return e.length<=qn?e:e.slice(0,qn-11)+" [redacted]"}var ji=10*1024*1024,Hi={b:1,kb:1024,mb:1024*1024,gb:1024*1024*1024};function Mr(o,e){return o===void 0?true:Array.isArray(o)?o.includes(e):o===e}function Ui(o,e){return o===void 0?true:Array.isArray(o)?o.some(t=>e.includes(t)):e.includes(o)}function Bn(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*(Hi[r]??1))}function zn(o){return typeof o=="string"}function Vn(o){try{let e=fs.statSync(o);return e.size>ji?(process.stderr.write(`[YamlHookPlugin] File too large for line count: ${o} (${e.size} bytes)
|
|
65
|
+
`).trim()}function Ds(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(`
|
|
66
|
+
`):t&&typeof t=="object"&&t.result!==void 0&&(e=t.result||"");}catch{e=Ns(e);}return e}var St=class{dbPath;constructor(e){this.dbPath=e??F.join(cs.homedir(),".crewx","crewx.db");}getThreadRepo(){return new Tt({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=Ds(r.result);n&&t.push({id:`${r.id}-assistant`,text:n,isAssistant:true,timestamp:new Date(r.started_at).getTime()});}return t}};var Ze=class extends Ye{name="conversation";_provider;unsubStart=null;unsubEnd=null;constructor(e){super(),this._provider=new St(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 fn(o){let e=F__namespace.resolve(o);return process.platform==="win32"&&(e=e.replace(/\\/g,"/"),e=e.replace(/^([A-Z]):/,(t,r)=>`${r.toLowerCase()}:`)),e.length>1&&!/^[a-zA-Z]:\/$/.test(e)&&(e=e.replace(/\/+$/,"")),e}function ur(o){let e=fn(o);return crypto$1.createHash("sha256").update(e).digest("hex")}function li(o){return o?o.settings?.template?.exec:void 0}function ci(){try{let o=new Uint8Array(8);return globalThis.crypto.getRandomValues(o),Array.from(o,e=>e.toString(16).padStart(2,"0")).join("")}catch{let{randomBytes:o}=W("crypto");return o(8).toString("hex")}}var Cr=class o extends Qe{_agents;_templateEngine;_documentLoader;_layoutLoader;_layoutRenderer;_config;_projectRoot;_workspaceId;_workspaceName;_plugins=[];_tools=new Map;_activeAdapters=new Map;_pendingThreads=new Map;_remoteFactory;_remoteTargets=new Map;constructor(e,t={},r,n,s){super(),this._agents=new Map(e.map(d=>[d.id,d])),this._config=r,this._projectRoot=s??(typeof process<"u"?process.cwd():"/");let i=s??(typeof process<"u"?process.env.CREWX_WORKSPACE??process.cwd():"/");this._workspaceId=ur(i),this._workspaceName=F.basename(i);let a=li(r);this._templateEngine=new Ke({execPolicy:t.execPolicy??a}),this._documentLoader=n??new Ae,this._layoutLoader=new Je({templatesPath:Ne()}),this._layoutRenderer=new Ge,this._remoteFactory=t.remoteFactory;}async resolveFileRemoteTarget(e){let t=this.getAgent(e),r=Array.isArray(t?.provider)?t?.provider[0]:t?.provider;if(!r?.startsWith("remote/"))return null;let n=r.slice(7),s=this.getRemoteProviderConfig(n);if(!s?.location?.startsWith("file://"))return null;let i=F.resolve(s.location.replace("file://","")),a=s.external_agent_id??e.replace(/^@/,""),d=this._remoteTargets.get(i);d||(d=(this._remoteFactory??(m=>o.loadYaml(m)))(i),this._remoteTargets.set(i,d),d.catch(()=>this._remoteTargets.delete(i)));let c=await d,u=c.getAgent("@"+a),p=Array.isArray(u?.provider)?u?.provider[0]:u?.provider;if(p?.startsWith("remote/"))throw new Error(`Chained remotes not allowed: "${n}" \u2192 "${p}"`);return {target:c,agentRef:"@"+a}}static async loadBuiltInConfig(e){let{yamlPath:t,dir:r}=qt(),n;try{n=fs.readFileSync(t,"utf-8");}catch(i){throw new Error(`[@crewx/sdk] Cannot read built-in config: ${t}
|
|
67
|
+
${i.message}`)}let s=ut(n);if(s.documents&&typeof s.documents=="object"){let i={};for(let[a,d]of Object.entries(s.documents))if(d&&typeof d=="object"){let c=d;typeof c.path=="string"&&!F.isAbsolute(c.path)?i[a]={...c,path:F.resolve(r,c.path)}:i[a]=c;}else i[a]=d;return {...s,documents:i}}return s}static mergeCrewxConfig(e,t){let r=new Map;for(let v of e.agents??[])r.set(v.id,v);for(let v of t.agents??[])r.has(v.id)&&console.warn(`[agent-loader] User agent "${v.id}" overrides built-in`),r.set(v.id,v);let n=Array.from(r.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,d=t,c=Mn(a.vars,d.vars),u=Mn(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??[]],m=ui(a.providers,d.providers),y={...e},w={...t};for(let v of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete y[v],delete w[v];let _={...{...y,...w},agents:n,layouts:s,documents:i,skills:p};return g.length>0&&(_.hooks=g),c!==void 0&&(_.vars=c),u!==void 0&&(_.settings=u),m!==void 0&&(_.providers=m),_}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 p=pt(e);s=o.mergeCrewxConfig(u,p),i=F.dirname(e);}else s=u,i=process.cwd();}else {if(e===void 0)throw new Error("[@crewx/sdk] loadYaml: path is required when includeBuiltIns is false");s=pt(e),i=F.dirname(e);}let a=new Ae(r);await a.load(s.documents,i);let d=s.agents??[];await Nn(d,s,t);let c=new o(d,t??{},s,a,i);return await c.use(new Ze),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 Ae(n);await a.load(i.documents,r??(typeof process<"u"?process.cwd():"/"));let d=i.agents??[];await Nn(d,i,t);let c=new o(d,t??{},i,a,r);return await c.use(new Ze),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=nr(t);return F.join(this._projectRoot,".crewx","logs",`${r}_${e}.log`)}registerTool(e,t){this._tools.set(e,{name:e,...t});}async use(e){this._plugins.includes(e)||(await e.attach(this),this._plugins.push(e));}handler(e){return dr(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??or(r),a=e.defaultMode??"query",d=t.manifest.platform,c=e.agentRunner??{run:async(m,y,w)=>{let _=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${m}`,y,{threadId:w?.threadId,platform:d});return {output:_.ok?_.data:_.error?.message??""}}},u=e.onInbound??(async m=>{let y=m.routingHints?.agentId??e.defaultAgent;if(!y)return {accepted:false,reason:"no_agent"};let{output:w}=await c.run(y,m.text,{threadId:m.threadId});return {accepted:true,output:w}}),p=ir({instanceId:r,config:n,capabilities:s,db:i,agentRunner:c,onInbound:u}),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(m){throw g.state="failed",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"failed",error:m instanceof Error?m:new Error(String(m)),timestamp:new Date}),this._activeAdapters.delete(r),m}}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=>re(a.role.toLowerCase(),d)))),n&&(i=i.filter(a=>a.team&&n.some(d=>re(a.team.toLowerCase(),d)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(c=>s.some(u=>re(c.toLowerCase(),u))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,r=this._agents.get(t);if(!r)throw new de(t,Array.from(this._agents.keys()));return r.inline?.prompt??r.inline?.system_prompt??r.description??`You are an expert ${t}.`}async renderPrompt(e,t){let n={...await this._documentLoader.buildContext(),...t?.documents??{}},s={...t,documents:n};return this._templateEngine.render(e,s)}registerLayout(e,t){this._layoutLoader.registerLayout(e,t);}async renderAgentPromptFull(e,t){let r=e.startsWith("@")?e.slice(1):e,n=this._agents.get(r);if(!n)throw new de(r,Array.from(this._agents.keys()));let s=this._resolveLayoutSpec(n,t?.layout),i=this._extractLayoutId(s),a=this._extractLayoutProps(n,s,t?.layout),d=this._layoutLoader.load(i,a),c=n.inline?.prompt??n.inline?.system_prompt??n.description??`You are an expert ${r}.`,u=await this._documentLoader.buildContext(),p=t?.env??(typeof process<"u"?process.env:{}),g=t?.vars?.security_key??ci(),m={...t?.vars??{},documents:u,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(c,m),w={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},h=n.provider,_=Array.isArray(h)?h:typeof h=="string"&&h.length>0?[h]:[],v=_.join(", ")||(typeof h=="string"?h:""),A=n.options,S=!Array.isArray(A)&&typeof A=="object"&&A!==null?A:void 0,I=Array.isArray(A)?A:void 0,H={};for(let[O,k]of Object.entries(u))H[O]={content:k.content??"",toc:k.toc,summary:k.summary,path:k.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:v,providerList:_,model:n.inline?.model,workingDirectory:n.working_directory??n.workingDirectory??".",inline:{...n.inline??{},prompt:y},specialties:n.specialties??[],capabilities:n.capabilities??[],remote:n.remote??null,optionsByMode:S,optionsArray:I},agentMetadata:{specialties:n.specialties??[],capabilities:n.capabilities??[],description:n.description??""},documents:H,skills:t?.skills??[],session:w,env:p,vars:{security_key:g,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:w.platform,mode:w.mode,messages:t?.messages??[],tools:this._tools.size>0?{list:Array.from(this._tools.values()).map(O=>({name:O.name,description:O.description,parameters:O.parameters})),json:JSON.stringify(Array.from(this._tools.values()).map(O=>({name:O.name,description:O.description,parameters:O.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:ar(s)}catch{return}}_resolveTimeout(e){let t=zr();return e==="query"?t.queryMs:t.executeMs}emitToolEvents(e,t,r,n,s,i,a){try{let c=exports.BUILTIN_ADAPTERS[r]?.parseEvent?.(n)??Jt(new Date().toISOString(),n);for(let u of c)u.type==="tool_use"&&u.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName,rawName:u.toolName,input:u.toolInput?this.tryParseJson(u.toolInput):void 0,toolUseId:u.toolUseId}}),u.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName??"unknown",rawName:u.toolName??"unknown",toolUseId:u.toolUseId,result:u.resultPreview,isError:u.isError}});}catch{}}emitTaskLogEntries(e,t,r,n,s,i,a){try{for(let d of a)d.type==="tool_use"&&d.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:n,sessionId:s,provider:i,tool:{name:d.toolName,rawName:d.toolName,input:d.toolInput?this.tryParseJson(d.toolInput):void 0,toolUseId:d.toolUseId}}),d.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:n,sessionId:s,provider:i,tool:{name:d.toolName??"unknown",rawName:d.toolName??"unknown",toolUseId:d.toolUseId,result:d.resultPreview,isError:d.isError}});}catch{}}tryParseJson(e){try{return JSON.parse(e)}catch{return e}}async query(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.query(n.agentRef,t,r);let s=Date.now(),i=be("tsk"),a=new Date,d;try{d=mt(e,Array.from(this._agents.values()));}catch(k){if(k instanceof de){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let N=Date.now()-s,x={code:"AGENT_NOT_FOUND",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:N,error:x,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:x,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:N}}}throw k}let c=Array.isArray(d.provider)?d.provider[0]??"cli/claude":d.provider,u=r?.provider??c,p=r?.model??d.inline?.model;p&&p.includes("{{")&&(p=await this._templateEngine.render(p,{...r?.vars??{}}));let g;try{g=ce(u);}catch(k){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let N=Date.now()-s,x={code:"PROVIDER_ERROR",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:N,error:x,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:x,meta:{agentId:d.id,provider:u,model:p,durationMs:N}}}let m=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),y;try{y=await this.renderAgentPromptFull(e,{session:{mode:"query",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:m});}catch(k){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${k instanceof Error?k.message:String(k)}`);}let w,h,_,v=p,A=false,S=k=>{A||(A=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",pid:k,model:v,provider:u,codingAgentCommand:w,renderedPrompt:y,metadata:{...r?.metadata??{},provider:u},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},I=d.options,H=Array.isArray(I?.query?.tools)?I.query.tools:void 0,j=this._tools.size>0?this._filterToolsByMode(H):[],C=(()=>{let k=I?.query;if(!k||Array.isArray(k))return;let{tools:N,effort:x,mode:U,...xe}=k,ve=Object.entries(xe).filter(([,q])=>q!=null);if(ve.length!==0)return Object.fromEntries(ve.map(([q,X])=>[q,String(X)]))})(),O=d.inline?.max_steps;u.startsWith("api/")&&S();try{let k=await g.query(t,{model:p,effort:I?.query?.effort,mode:I?.query?.mode,context:r?.context,systemPrompt:y??d.inline?.system_prompt??d.inline?.prompt??d.description??`You are ${d.id}.`,additionalArgs:Array.isArray(I?.query)?I.query:void 0,tools:j.length>0?j:void 0,maxSteps:O,configOptions: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:x=>S(x),onOutput:(x,U)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:x,level:U}),U==="stdout"&&this.emitToolEvents(i,e,u,x,d.id,r?.threadId??"","");},onTaskLog:x=>{this.emitTaskLogEntries(i,e,d.id,r?.threadId??"","",u,x);for(let U of x)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(U),level:"info"});},onCommand:x=>{w=x;},onUsage:x=>{h=x;},onExitCode:x=>{_=x;},onModel:x=>{v||(v=x);}});S();let N=Date.now()-s;return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:k,durationMs:N,exitCode:_,inputTokens:h?.inputTokens,outputTokens:h?.outputTokens,cachedInputTokens:h?.cachedInputTokens,costUsd:h?.costUsd,model:v,metadata:{...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}}}),{ok:!0,data:k,meta:{agentId:d.id,provider:u,model:p,durationMs:N,taskId:i}}}catch(k){if(k instanceof exports.ClientToolCallRequiredError){let U=be("thd");return this._pendingThreads.set(U,{agentRef:d.id,providerStr:u,continuationState:k.continuationState,toolCall:k.toolCall,traceId:i,startMs:s,model:p}),{ok:true,status:"requires_action",data:"",toolCall:k.toolCall,threadId:U,meta:{agentId:d.id,provider:u,model:p,durationMs:Date.now()-s,taskId:i}}}S();let N=Date.now()-s,x={code:"QUERY_FAILED",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:N,error:x,exitCode:_,inputTokens:h?.inputTokens,outputTokens:h?.outputTokens,cachedInputTokens:h?.cachedInputTokens,costUsd:h?.costUsd,model:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:x,meta:{agentId:d.id,provider:u,model:p,durationMs:N,taskId:i}}}}async continueQuery(e,t){let r=this._pendingThreads.get(e);if(!r)return {ok:false,data:"",error:{code:"THREAD_NOT_FOUND",message:`No pending thread: ${e}`},meta:{agentId:"",provider:"",durationMs:0}};this._pendingThreads.delete(e);let n=ce(r.providerStr);if(!n.continueWithToolResults)return {ok:false,data:"",error:{code:"UNSUPPORTED",message:"Provider does not support client tool continuation"},meta:{agentId:r.agentRef,provider:r.providerStr,durationMs:0}};let s=t.map(i=>({...i,toolName:r.toolCall.toolCallId===i.toolCallId?r.toolCall.toolName:i.toolCallId}));try{let i=await n.continueWithToolResults(r.continuationState,s),a=Date.now()-r.startMs;return this.emit("task:end",{traceId:r.traceId,timestamp:new Date,agentRef:r.agentRef,mode:"query",result:i,durationMs:a}),{ok:!0,status:"complete",data:i,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}catch(i){if(i instanceof exports.ClientToolCallRequiredError)return this._pendingThreads.set(e,{...r,continuationState:i.continuationState,toolCall:i.toolCall}),{ok:true,status:"requires_action",data:"",toolCall:i.toolCall,threadId:e,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:Date.now()-r.startMs}};let a=Date.now()-r.startMs;return {ok:false,data:"",error:{code:"CONTINUE_FAILED",message:i.message},meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}}async execute(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.execute(n.agentRef,t,r);let s=Date.now(),i=be("tsk"),a=new Date,d;try{d=mt(e,Array.from(this._agents.values()));}catch(k){if(k instanceof de){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let N=Date.now()-s,x={code:"AGENT_NOT_FOUND",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:N,error:x,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:x,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:N}}}throw k}let c=Array.isArray(d.provider)?d.provider[0]??"cli/claude":d.provider,u=r?.provider??c,p=r?.model??d.inline?.model;p&&p.includes("{{")&&(p=await this._templateEngine.render(p,{...r?.vars??{}}));let g;try{g=ce(u);}catch(k){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let N=Date.now()-s,x={code:"PROVIDER_ERROR",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:N,error:x,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:x,meta:{agentId:d.id,provider:u,model:p,durationMs:N}}}let m=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),y;try{y=await this.renderAgentPromptFull(e,{session:{mode:"execute",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:m});}catch(k){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${k instanceof Error?k.message:String(k)}`);}let w,h,_,v=p,A=false,S=k=>{A||(A=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",pid:k,model:v,provider:u,codingAgentCommand:w,renderedPrompt:y,metadata:{...r?.metadata??{},provider:u},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},I=d.options,H=Array.isArray(I?.execute?.tools)?I.execute.tools:void 0,j=this._tools.size>0?this._filterToolsByMode(H):[],C=(()=>{let k=I?.execute;if(!k||Array.isArray(k))return;let{tools:N,effort:x,mode:U,...xe}=k,ve=Object.entries(xe).filter(([,q])=>q!=null);if(ve.length!==0)return Object.fromEntries(ve.map(([q,X])=>[q,String(X)]))})(),O=d.inline?.max_steps;u.startsWith("api/")&&S();try{let k=await g.execute(t,{model:p,effort:I?.execute?.effort,mode:I?.execute?.mode,context:r?.context,systemPrompt:y??d.inline?.system_prompt??d.inline?.prompt??d.description??`You are ${d.id}.`,additionalArgs:Array.isArray(I?.execute)?I.execute:void 0,tools:j.length>0?j:void 0,maxSteps:O,configOptions: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:x=>S(x),onOutput:(x,U)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:x,level:U}),U==="stdout"&&this.emitToolEvents(i,e,u,x,d.id,r?.threadId??"","");},onTaskLog:x=>{this.emitTaskLogEntries(i,e,d.id,r?.threadId??"","",u,x);for(let U of x)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(U),level:"info"});},onCommand:x=>{w=x;},onUsage:x=>{h=x;},onExitCode:x=>{_=x;},onModel:x=>{v||(v=x);}});S();let N=Date.now()-s;return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:k,durationMs:N,exitCode:_,inputTokens:h?.inputTokens,outputTokens:h?.outputTokens,cachedInputTokens:h?.cachedInputTokens,costUsd:h?.costUsd,model:v,metadata:{...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}}}),{ok:!0,data:k,meta:{agentId:d.id,provider:u,model:p,durationMs:N}}}catch(k){S();let N=Date.now()-s,x={code:"EXECUTE_FAILED",message:k.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:N,error:x,exitCode:_,inputTokens:h?.inputTokens,outputTokens:h?.outputTokens,cachedInputTokens:h?.cachedInputTokens,costUsd:h?.costUsd,model:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:x,meta:{agentId:d.id,provider:u,model:p,durationMs:N}}}}};function Mn(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 ui(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 Nn(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(()=>(gr(),xn));n(t?.api);}gi(o,e),mi(o,e),pi(o);}function pi(o){if(!o.some(r=>(Array.isArray(r.provider)?r.provider:[r.provider]).some(s=>s.startsWith("acp/"))))return;let{registerAcpProviders:t}=(_r(),Ut(Pn));t();}function gi(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}=(Ar(),Ut(bn)),s=new Map;for(let i of r)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&le("remote",n(s,ce));}function mi(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}=(br(),Ut(En)),s=new Map;for(let i of r)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&le("plugin",n(s));}l();var fi="crewx:fs:",Sr=class{prefix;store;constructor(e){this.prefix=e?.prefix??fi,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 yi(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))}ne();pr();gr();l();fr();we();l();Et();$t();function hi(o,e,t,r){let n=t.agentInfo?.name,s=e??n??o,a=(r.modes?.availableModes??[]).map(y=>({id:y.id,name:y.name,...y.description!=null?{description:y.description}:{}})),d=[],c=r.configOptions??[];for(let y of c)if(y.category==="thought_level"&&y.type==="select"){let w=y.options??[];if(w.length>0&&w[0]?.group!=null)for(let h of w)for(let _ of h.options??[])d.push(_.value);else for(let h of w)h.value!=null&&d.push(h.value);}let p=(r.models?.availableModels??[]).map(y=>({id:y.modelId})),g=t.agentCapabilities??{},m={loadSession:g.loadSession??false,image:g.promptCapabilities?.image??false,audio:g.promptCapabilities?.audio??false,mcp:g.mcpCapabilities!=null};return {id:`acp/${o}`,name:s,modes:a,effort:d,models:p,capabilities:m}}async function Dn(o){let e=exports.ACP_ADAPTERS[o];if(!e)return null;let t=e.meta?.displayName,r=new exports.AcpConnection({spawn:e.spawn,cwd:process.cwd()});try{await r.connect(e.clientInfo);let n=r.initResponse;if(!n)return null;let s=e.buildSessionParams({cwd:process.cwd()}),i=await r.newSessionRaw(s);return hi(o,t,n,i)}catch{return null}finally{await r.dispose();}}async function wi(){let o=Object.keys(exports.ACP_ADAPTERS),e=await Promise.allSettled(o.map(r=>Dn(r))),t=[];for(let r of e)r.status==="fulfilled"&&r.value!==null&&t.push(r.value);return t}Et();yr();$t();_r();Ft();je();l();var Er=0;function xi(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(Er>=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(", ")}`;Er++;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{Er--;}}}}l();var $n=typeof process<"u"?process.env:{};function vi(){return $n.CREWX_CLI||"npx crewx"}function ki(){return $n.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}l();var _i=/^[a-zA-Z0-9._-]+$/,Ir=class{constructor(e){this.storage=e;}storage;listBoxes(e){this.validateId(e);let r=this.storage.listBoxes(e).map(n=>this.toBoxResponse(n));return {boxes:r,total:r.length}}getBox(e,t){this.validateId(e),this.validateId(t);let r=this.storage.findBox(e,t);return r?this.toBoxResponse(r):null}createBox(e,t){this.validateId(e);let r=this.generateBoxId(),n=new Date().toISOString(),s=this.storage.insertBox(e,{id:r,seq:t.seq,firstTaskId:t.firstTaskId,midTaskId:t.midTaskId,lastTaskId:t.lastTaskId,taskCount:t.taskCount,summary:t.summary??null,sourceTokens:t.sourceTokens,summaryTokens:t.summaryTokens??null,createdAt:n});return this.toBoxResponse(s)}toBoxResponse(e){return {id:e.id,threadId:e.thread_id,seq:e.seq,firstTaskId:e.first_task_id,lastTaskId:e.last_task_id,taskCount:e.task_count,sourceTokens:e.source_tokens,summaryTokens:e.summary_tokens,summary:e.summary,previewFirst:this.storage.getTaskPreview(e.first_task_id,200),previewMid:this.storage.getTaskPreview(e.mid_task_id,200),previewLast:this.storage.getTaskPreview(e.last_task_id,200),createdAt:e.created_at}}validateId(e){if(!_i.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return be("box")}};l();function Ri(o,e,t,r,n){let{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}=r,d=s*i,c=s*a,u=d+c,p=e.getThreadMessages(o),g=[],m=0,y=false,w=[];for(let v=0;v<p.length;v+=2){let A=p[v],S=p[v+1],I=A?.content||"",H=S?.content||"",j=n.countTokens(I+H),C=[];A&&C.push(A),S&&C.push(S),w.push({messages:C,tokens:j});}for(let v=w.length-1;v>=0;v--){let A=w[v];if(m+A.tokens>d){y=true;break}m+=A.tokens,g.unshift(...A.messages);}let h=[],_=0;if(y&&c>0)try{let{boxes:v}=t.listBoxes(o);for(let A=v.length-1;A>=0;A--){let S=v[A],I=S.summaryTokens??S.sourceTokens;if(_+I>c)break;_+=I,h.unshift({boxId:S.id,seq:S.seq,taskCount:S.taskCount,sourceTokens:S.sourceTokens,summary:S.summary,previewFirst:S.previewFirst,previewMid:S.previewMid,previewLast:S.previewLast,createdAt:S.createdAt});}}catch(v){if(v instanceof Error&&!/not found/i.test(v.message))throw v}return {hot:g,warm:h,hotTokens:m,warmTokens:_,hotOverflow:y,totalBudget:u,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}je();Pe();l();var Lt=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},at=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,p=0,g=0,m=false,y=0,w=perf_hooks.performance.now(),h=async C=>{a?.onTaskStart&&await a.onTaskStart(C),g+=1;let O=new AbortController,k={signal:O.signal},N,x;typeof s=="number"&&Number.isFinite(s)&&s>0&&(x=new Promise((q,X)=>{N=setTimeout(()=>{let ke=new Lt(C.id,s);O.abort(ke),X(ke);},s);}));let U=perf_hooks.performance.now(),xe=C.run(k),ve=x?Promise.race([xe,x]):xe;try{let q=await ve,X=perf_hooks.performance.now(),ke=X-U,Me=d(q,C),lt={taskId:C.id,success:Me,value:q,durationMs:ke,startedAt:U,finishedAt:X,metadata:C.metadata,aborted:!1};c.push(lt),Me?u+=1:p+=1,a?.onTaskComplete&&await a.onTaskComplete(lt),i&&!Me&&(m=!0);}catch(q){let X=perf_hooks.performance.now(),ke=X-U,Me=q instanceof Error?q:new Error(String(q)),lt={taskId:C.id,success:false,error:Me,durationMs:ke,startedAt:U,finishedAt:X,metadata:C.metadata,aborted:O.signal.aborted};c.push(lt),p+=1,a?.onError&&await a.onError(C,Me,ke),i&&(m=true);}finally{N&&clearTimeout(N),x&&xe.catch(()=>{});}},_=async()=>{for(;!m;){let C=y;if(C>=e.length)break;y+=1;let O=e[C];if(!O||(await h(O),m))break}},v=Math.min(n,e.length),A=[];for(let C=0;C<v;C++)A.push(_());await Promise.all(A);let I=perf_hooks.performance.now()-w,H=c.length?c.reduce((C,O)=>C+O.durationMs,0)/c.length:0,j=I>0?c.length/(I/1e3):c.length;return this.metrics={totalTasks:e.length,startedTasks:g,completedTasks:c.length,successCount:u,failureCount:p,totalDurationMs:I,averageDurationMs:H,throughput:j},c}getMetrics(){return this.metrics}mergeOptions(e){return {maxConcurrency:e.maxConcurrency??this.defaults.maxConcurrency,timeoutMs:e.timeoutMs??this.defaults.timeoutMs,failFast:e.failFast??this.defaults.failFast,evaluateTaskSuccess:e.evaluateTaskSuccess??this.defaults.evaluateTaskSuccess,callbacks:this.mergeCallbacks(this.defaults.callbacks,e.callbacks)}}mergeCallbacks(e,t){if(!(!e&&!t))return {onTaskStart:async r=>{e?.onTaskStart&&await e.onTaskStart(r),t?.onTaskStart&&await t.onTaskStart(r);},onTaskComplete:async r=>{e?.onTaskComplete&&await e.onTaskComplete(r),t?.onTaskComplete&&await t.onTaskComplete(r);},onError:async(r,n,s)=>{e?.onError&&await e.onError(r,n,s),t?.onError&&await t.onError(r,n,s);}}}};l();l();var dt=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 Ln=3,jn=3e4,Hn=500,Pi=o=>{if(typeof o!="number"||Number.isNaN(o)||!Number.isFinite(o))return Ln;let e=Math.floor(o);return e>0?e:Ln},Ai=o=>o===void 0||typeof o!="number"||Number.isNaN(o)||o<=0?jn:o,bi=o=>{if(!o)return {maxRetries:0,retryDelay:Hn};let e=Number.isInteger(o.maxRetries)&&o.maxRetries>=0?o.maxRetries:0,t=typeof o.retryDelay=="number"&&o.retryDelay>=0?o.retryDelay:Hn;return {maxRetries:e,retryDelay:t}},Or=o=>{let e=o.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},Ci=(o,e)=>o<=0?Promise.resolve():new Promise((t,r)=>{let n=setTimeout(()=>{e.removeEventListener("abort",s),t();},o),s=()=>{clearTimeout(n),r(Or(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),Ti=async(o,e,t)=>{let r,n;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw Or(t);try{let i=await o();if(r=i,i.success||s===e.maxRetries)return i}catch(i){if(n=i,t.aborted)throw Or(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await Ci(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")},Un=(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);}},Si=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}}}),Ei=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")}}),Ii=(o,e)=>({onTaskComplete:async t=>{Un(e,o,t.success);},onError:async()=>{Un(e,o,false);}}),qn=async(o,e,t={})=>{if(!Array.isArray(o))throw new TypeError("Parallel helpers expect an array of requests");if(o.length===0){let h={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?.(h),[]}let r=Pi(t.concurrency),n=Ai(t.timeout),s=bi(t.retryPolicy),i=new at,a=new dt,d=o.map((w,h)=>({id:`${e}:${w.agentId??"anonymous"}:${h}`,metadata:{index:h,mode:e,request:w},run:_=>Ti(()=>e==="query"?a.query(w):a.execute(w),s,_.signal)})),c={completed:0,success:0,failure:0,total:o.length},u=await i.run(d,{maxConcurrency:r,timeoutMs:n,evaluateTaskSuccess:w=>w.success,callbacks:Ii(c,t)}),p=Si(u),g=Ei(u),m=i.getMetrics(),y={total:o.length,completed:o.length,successCount:p.filter(w=>w.success).length,failureCount:p.filter(w=>!w.success).length,results:p,errors:g,metrics:m};return t.onComplete?.(y),p},Oi=(o,e)=>qn(o,"query",e),Mi=(o,e)=>qn(o,"execute",e);br();Ar();Pr();Rr();l();l();var jt=class{capabilities={required:[]}};l();l();l();var Fn=2e3;function Wn(o){let e=o.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f\u2028\u2029]/g,"");return e.length<=Fn?e:e.slice(0,Fn-11)+" [redacted]"}var qi=10*1024*1024,Fi={b:1,kb:1024,mb:1024*1024,gb:1024*1024*1024};function Mr(o,e){return o===void 0?true:Array.isArray(o)?o.includes(e):o===e}function Wi(o,e){return o===void 0?true:Array.isArray(o)?o.some(t=>e.includes(t)):e.includes(o)}function zn(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*(Fi[r]??1))}function Vn(o){return typeof o=="string"}function Kn(o){try{let e=fs.statSync(o);return e.size>qi?(process.stderr.write(`[YamlHookPlugin] File too large for line count: ${o} (${e.size} bytes)
|
|
68
68
|
`),null):fs.readFileSync(o,"utf8").split(`
|
|
69
|
-
`).length}catch{return null}}function
|
|
69
|
+
`).length}catch{return null}}function Jn(o){try{return fs.statSync(o).size}catch{return null}}function Bi(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(re(n,o))return true;if(t&&n.startsWith("/")){let{relative:s,isAbsolute:i}=W("path");if(i(n)){let a=s(t,n);if(a&&!a.startsWith("..")&&re(a,o))return true}}return false}function zi(o,e){return o?JSON.stringify(e).includes(o):true}function Vi(o,e){if(!o)return true;try{let t=new RegExp(o),r=JSON.stringify(e);return t.test(r)}catch{return false}}function Ki(o,e){if(!o)return true;try{let t=new RegExp(o),r=JSON.stringify(e);return t.test(r)}catch{return false}}function Ji(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(Vn(o.pathSizeMin)){let n=Jn(r);if(n===null||n<zn(o.pathSizeMin))return false}else {let n=Kn(r);if(n===null||n<o.pathSizeMin)return false}if(o.pathSizeMax!==void 0)if(Vn(o.pathSizeMax)){let n=Jn(r);if(n===null||n>zn(o.pathSizeMax))return false}else {let n=Kn(r);if(n===null||n>o.pathSizeMax)return false}return true}function Xi(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 jt{name="@crewx/yaml-hook-plugin";version="0.1.0";capabilities={required:["inject"]};hooks;agentMap;constructor(e){super(),this.hooks=e.hooks,this.agentMap=new Map((e.agents??[]).map(t=>[t.id,t]));}async run(e){let t=[],r=process.env.CREWX_TASK_LOG_PATH,n=process.env.CREWX_HOOK_LOG_VERBOSE==="1";for(let s of this.hooks)if(this.matchEntryLevel(s,e)&&s.guide){if(!this.matchRuleLevel(s.guide,e)){n&&r&&this.appendHookLog(r,{rule:s.name,action:"pass",once:s.guide.once??false,ctx:e,matched:false});continue}s.guide.once&&this.hasFired(e.sessionId,s.name)||(s.guide.once&&this.markFired(e.sessionId,s.name),t.push(s.guide.say),r&&this.appendHookLog(r,{rule:s.name,action:"inject",once:s.guide.once??false,ctx:e,matched:true,message:s.guide.say}));}return t.length?e.inject(t.join(`
|
|
70
70
|
|
|
71
|
-
`)):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=
|
|
72
|
-
`;fs.appendFileSync(e,n,{encoding:"utf8",mode:384});}catch{}}matchEntryLevel(e,t){if(e.provider!==void 0){let r=t.provider.replace(/^cli\//,"");if(!Mr(e.provider,r))return false}if(e.team!==void 0){let n=this.agentMap.get(t.agent.id)?.team??t.agent.team;if(!Mr(e.team,n))return false}if(e.role!==void 0){let n=this.agentMap.get(t.agent.id)?.role??t.agent.role;if(!Mr(e.role,n))return false}if(e.tag!==void 0){let n=this.agentMap.get(t.agent.id)?.tags??[];if(!
|
|
73
|
-
`);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return F.join(
|
|
71
|
+
`)):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=Wn(t.message).slice(0,500)));let n=`[${new Date().toISOString()}] HOOK: ${JSON.stringify(r)}
|
|
72
|
+
`;fs.appendFileSync(e,n,{encoding:"utf8",mode:384});}catch{}}matchEntryLevel(e,t){if(e.provider!==void 0){let r=t.provider.replace(/^cli\//,"");if(!Mr(e.provider,r))return false}if(e.team!==void 0){let n=this.agentMap.get(t.agent.id)?.team??t.agent.team;if(!Mr(e.team,n))return false}if(e.role!==void 0){let n=this.agentMap.get(t.agent.id)?.role??t.agent.role;if(!Mr(e.role,n))return false}if(e.tag!==void 0){let n=this.agentMap.get(t.agent.id)?.tags??[];if(!Wi(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)||!zi(e.pattern,t.tool.input)||!Vi(e.regex,t.tool.input)||!Bi(e.pathPattern,t.tool.input,t.cwd)||!Ji(e,t.tool.input)||!Ki(e.whenInputRegex,t.tool.input))}hasFired(e,t){try{let r=this.firedFilePath(e);if(!fs.existsSync(r))return !1;let n=JSON.parse(fs.readFileSync(r,"utf8"));return Array.isArray(n.fired)&&n.fired.includes(t)}catch{return false}}markFired(e,t){try{let r=this.firedFilePath(e);fs.mkdirSync(F.dirname(r),{recursive:!0,mode:448});let n=fs.existsSync(r)?JSON.parse(fs.readFileSync(r,"utf8")):{fired:[]};Array.isArray(n.fired)||(n.fired=[]),n.fired.includes(t)||(n.fired.push(t),fs.writeFileSync(r,JSON.stringify(n),{mode:384}));}catch(r){process.stderr.write(`[YamlHookPlugin] once state write failed: ${r}
|
|
73
|
+
`);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return F.join(cs.homedir(),".crewx","sessions",t,"fired-rules.json")}};l();l();l();function Gi(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 $r=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 Qi(o){return o}function Yi(o){return {name:o.name,async attach(e){let t=await o.configFactory(e),n=e.registerChannelAdapter,s=o.instanceId??o.name;n&&await n({adapter:o.adapter,instanceId:s,config:t}),o.onAttach&&await o.onAttach(e);},async detach(e){let r=e.unregisterChannelAdapter;r&&await r(o.instanceId??o.name),o.onDetach&&await o.onDetach(e);}}}ht();exports.AdapterError=$r;exports.AgentNotFoundError=de;exports.AgentRuntime=dt;exports.AgentSkillsSchema=Lr;exports.BrowserFsAdapter=Sr;exports.ConfigLoadError=_e;exports.Crewx=Cr;exports.CrewxPlugin=Ye;exports.DocumentLoader=Ae;exports.LayoutLoadError=B;exports.LayoutLoader=Je;exports.LayoutRenderer=Ge;exports.NodeFsAdapter=Rt;exports.ParallelRunner=at;exports.ParallelRunnerTimeoutError=Lt;exports.PropsValidationError=ue;exports.PropsValidator=Xe;exports.SdkBoxService=Ir;exports.TemplateEngine=Ke;exports.TypedEventEmitter=Qe;exports.YamlHookPlugin=Dr;exports.buildContext=Ri;exports.createAdapterContext=ir;exports.createDelegateTool=xi;exports.createHandler=dr;exports.createPluginProviderFactory=Sn;exports.createProvider=ce;exports.createRemoteProviderFactory=An;exports.createScopedAdapterStore=or;exports.defaultExtractText=mr;exports.defaultFsAdapter=tr;exports.defaultParseEvent=te;exports.defineChannelAdapter=Qi;exports.defineChannelAdapterPlugin=Yi;exports.escapeHandlebarsHelper=Yt;exports.formatFileSizeHelper=Zt;exports.formatTimestamp=nr;exports.formatTimestampHelper=er;exports.generateFingerprint=Qo;exports.generateId=be;exports.getSyncWindowStore=es;exports.hashWorkspaceId=ur;exports.lengthHelper=Qt;exports.loadYamlFile=pt;exports.materializeWindowsSpawnProgram=We;exports.normalizeWorkspacePath=fn;exports.parseStdoutEvent=Jt;exports.parseUsage=G;exports.parseYamlContent=ut;exports.queryAcpProviderMeta=Dn;exports.queryAllAcpProviderMetas=wi;exports.registerAcpProviders=Rn;exports.registerApiProviders=wn;exports.registerProviderFactory=le;exports.resolveAgent=mt;exports.resolveAgentSkills=yi;exports.resolveCrewxCli=vi;exports.resolveCrewxWorkspace=ki;exports.resolveDefaultAgentsYaml=qt;exports.resolveTemplatesPath=Ne;exports.resolveWindowsExecutablePath=Ur;exports.resolveWindowsSpawnProgram=Fe;exports.runExecutesParallel=Mi;exports.runInSyncWindow=ts;exports.runQueriesParallel=Oi;exports.setAuditVerbose=jo;exports.toTaskReader=Gi;exports.toTemplateMessages=ar;exports.truncateHelper=Gt;exports.validateHooksSchema=Xi;
|