@crewx/sdk 0.8.8-rc.41 → 0.8.8-rc.42
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 +11 -15
- package/dist/index.js +11 -15
- package/dist/provider/acp/adapter.d.ts +0 -1
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
'use strict';var fs$1=require('fs'),W=require('path'),child_process=require('child_process'),sdk=require('@agentclientprotocol/sdk'),jsYaml=require('js-yaml'),zod=require('zod'),module$1=require('module'),de=require('handlebars'),promises=require('fs/promises'),crypto$1=require('crypto'),events=require('events'),async_hooks=require('async_hooks'),mcp_js=require('@modelcontextprotocol/sdk/server/mcp.js'),webStandardStreamableHttp_js=require('@modelcontextprotocol/sdk/server/webStandardStreamableHttp.js'),perf_hooks=require('perf_hooks'),drizzleOrm=require('drizzle-orm')
|
|
1
|
+
'use strict';var fs$1=require('fs'),W=require('path'),child_process=require('child_process'),sdk=require('@agentclientprotocol/sdk'),jsYaml=require('js-yaml'),zod=require('zod'),module$1=require('module'),de=require('handlebars'),promises=require('fs/promises'),crypto$1=require('crypto'),events=require('events'),async_hooks=require('async_hooks'),mcp_js=require('@modelcontextprotocol/sdk/server/mcp.js'),webStandardStreamableHttp_js=require('@modelcontextprotocol/sdk/server/webStandardStreamableHttp.js'),perf_hooks=require('perf_hooks'),drizzleOrm=require('drizzle-orm'),Ni=require('os'),sqliteCore=require('drizzle-orm/sqlite-core');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var W__namespace=/*#__PURE__*/_interopNamespace(W);var de__namespace=/*#__PURE__*/_interopNamespace(de);var Ni__default=/*#__PURE__*/_interopDefault(Ni);var Bt=Object.defineProperty;var yo=Object.getOwnPropertyDescriptor;var ho=Object.getOwnPropertyNames;var wo=Object.prototype.hasOwnProperty;var z=(n=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(n,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):n)(function(n){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+n+'" is not supported')});var N=(n,e)=>()=>(n&&(e=n(n=0)),e);var pt=(n,e)=>{for(var t in e)Bt(n,t,{get:e[t],enumerable:true});},xo=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of ho(e))!wo.call(n,o)&&o!==t&&Bt(n,o,{get:()=>e[o],enumerable:!(r=yo(e,o))||r.enumerable});return n};var Wt=n=>xo(Bt({},"__esModule",{value:true}),n);var l=N(()=>{});function ht(n){return typeof n!="string"?void 0:n.trim()||void 0}function wt(n){return ht(n)?.toLowerCase()??""}function Le(n){try{return fs$1.statSync(n).isFile()}catch{return false}}function Gr(n,e){if(n.includes("/")||n.includes("\\")||W__namespace.default.isAbsolute(n))return n;let r=(e.PATH??e.Path??process.env.PATH??process.env.Path??"").split(";").map(a=>a.trim()).filter(Boolean),o=W__namespace.default.extname(n).length>0,s=e.PATHEXT??e.Pathext??process.env.PATHEXT??process.env.Pathext??".EXE;.CMD;.BAT;.COM",i=o?[""]:s.split(";").map(a=>a.trim()).filter(Boolean).map(a=>a.startsWith(".")?a:`.${a}`);for(let a of r)for(let d of i){let c=wt(d),u=d.toUpperCase();for(let g of [d,c,u]){let y=W__namespace.default.join(a,`${n}${g}`);if(Le(y))return y}}return n}function Io(n){if(!Le(n))return null;try{let e=fs$1.readFileSync(n,"utf8"),t=W__namespace.default.dirname(n),r=[];for(let a of e.matchAll(/"([^"\r\n]*)"/g)){let u=(a[1]??"").match(/%~?dp0%?\s*[\\/]*(.*)$/i)?.[1]?.trim();if(!u)continue;let g=u.replace(/[\\/]+/g,W__namespace.default.sep).replace(/^[\\/]+/,""),y=W__namespace.default.resolve(t,g);Le(y)&&r.push(y);}let o=[],s=new Map;for(let a of e.matchAll(/SET\s+"(\w+)=%~?dp0%?[\\/]?([^"]+)"/gi)){let d=a[1].toUpperCase(),c=a[2].trim().replace(/[\\/]+/g,W__namespace.default.sep).replace(/^[\\/]+/,"");s.set(d,W__namespace.default.resolve(t,c));}for(let a of e.split(/\r?\n/))if(a.includes("%*"))for(let d of a.matchAll(/"%(\w+)%"/g)){let c=s.get(d[1].toUpperCase());c&&Le(c)&&o.push(c);}let i=a=>a.find(d=>{let c=wt(W__namespace.default.basename(d));return c!=="node.exe"&&c!=="node"})??null;return i(o)??i(r)}catch{return null}}function Oo(n,e){if(typeof e=="string")return ht(e)||null;if(!e||typeof e!="object")return null;if(n){let t=e[n],r=typeof t=="string"?ht(t):void 0;if(r)return r}for(let t of Object.values(e)){let r=typeof t=="string"?ht(t):void 0;if(r)return r}return null}function Mo(n,e){if(!e)return null;let t=W__namespace.default.dirname(n),r=[W__namespace.default.resolve(t,"..",e),W__namespace.default.resolve(t,"node_modules",e)];for(let o of r){let s=W__namespace.default.join(o,"package.json");if(Le(s))try{let i=JSON.parse(fs$1.readFileSync(s,"utf8")),a=Oo(e,i.bin);if(!a)continue;let d=W__namespace.default.resolve(o,a);if(Le(d))return d}catch{}}return null}function No(n){let e=n.platform??process.platform,t=n.env??process.env,r=n.execPath??process.execPath;if(e!=="win32")return {command:n.command,leadingArgv:[],resolution:"direct"};let o=Gr(n.command,t),s=wt(W__namespace.default.extname(o));if(s===".js"||s===".cjs"||s===".mjs")return {command:r,leadingArgv:[o],resolution:"node-entrypoint",windowsHide:true};if(s===".cmd"||s===".bat"){let i=Io(o)??Mo(o,n.packageName);return i?wt(W__namespace.default.extname(i))===".exe"?{command:i,leadingArgv:[],resolution:"exe-entrypoint",windowsHide:true}:{command:r,leadingArgv:[i],resolution:"node-entrypoint",windowsHide:true}:{command:o,leadingArgv:[],resolution:"unresolved-wrapper"}}return {command:o,leadingArgv:[],resolution:"direct"}}function Do(n){if(n.candidate.resolution!=="unresolved-wrapper")return {command:n.candidate.command,leadingArgv:n.candidate.leadingArgv,resolution:n.candidate.resolution,windowsHide:n.candidate.windowsHide};if(n.allowShellFallback===true)return {command:n.candidate.command,leadingArgv:[],resolution:"shell-fallback",shell:true};throw new Error(`${W__namespace.default.basename(n.candidate.command)} wrapper resolved, but no executable/Node entrypoint could be resolved without shell execution.`)}function ze(n){let e=No(n);return Do({candidate:e,allowShellFallback:n.allowShellFallback})}function Ve(n,e){return {command:n.command,argv:[...n.leadingArgv,...e],resolution:n.resolution,shell:n.shell,windowsHide:n.windowsHide}}var xt=N(()=>{l();});function $o(n){if(n.type!=="usage"||!("input_tokens"in n))return null;let e=Number(n.input_tokens??0),t=Number(n.output_tokens??0),o="cache_read_input_tokens"in n?Number(n.cache_read_input_tokens):void 0,s="cached_input_tokens"in n?Number(n.cached_input_tokens):void 0,i=o!==void 0?o:s??0;return {inputTokens:o!==void 0?e+o:e,outputTokens:t,cachedInputTokens:i}}function Lo(n){let e=n.usage;if(!e||typeof e!="object"||Array.isArray(e))return null;let t=e;if(!("input_tokens"in t))return null;let r=Number(t.input_tokens??0),o=Number(t.output_tokens??0),i="cache_read_input_tokens"in t?Number(t.cache_read_input_tokens):void 0,a="cached_input_tokens"in t?Number(t.cached_input_tokens):void 0,d=i!==void 0?i:a??0;return {inputTokens:i!==void 0?r+i:r,outputTokens:o,cachedInputTokens:d}}function jo(n){if(n.type!=="step_finish")return null;let t=n.part?.tokens;if(!t)return null;let r=Number(t.input??0),o=Number(t.output??0),s=t.cache,i=s?Number(s.read??0):0;return {inputTokens:r+i,outputTokens:o,cachedInputTokens:i}}function ee(n){if(!n||!n.trim())return;let e=null;for(let t of n.split(`
|
|
2
2
|
`))if(t.trim())try{let r=JSON.parse(t),o=$o(r)??Lo(r)??jo(r);o&&(e=o);}catch{}return e??void 0}var Ae=N(()=>{l();});exports.RateLimitError=void 0;var Vt=N(()=>{l();exports.RateLimitError=class extends Error{name="RateLimitError";constructor(e){super(e);}};});function te(n){return /crewx\s+(x|execute)\s/.test(n)}function re(n,e){let t=e.match(/@(\S+)/);return {timestamp:n,type:"agent_call",targetAgent:t?.[1]?.replace(/["']/g,""),toolInput:e}}var je=N(()=>{l();});function ne(n){if(typeof n=="string")return n;if(!n||typeof n!="object")return JSON.stringify(n??{});let e=n;return typeof e.command=="string"?e.command:typeof e.file_path=="string"?e.file_path:typeof e.filePath=="string"?e.filePath:typeof e.path=="string"?e.path:typeof e.query=="string"?e.query:typeof e.pattern=="string"?e.pattern:typeof e.url=="string"?e.url:typeof e.prompt=="string"?e.prompt.length>200?e.prompt.slice(0,200)+"\u2026":e.prompt:typeof e.description=="string"?e.description:JSON.stringify(e)}var Ue=N(()=>{l();});function Uo(n,e){let t=e.type;if(t==="text"){let r=String(e.text||"");return r?{timestamp:n,type:"text",content:r}:null}if(t==="thinking"){let r=String(e.thinking||"");return {timestamp:n,type:"thinking",content:r||"(thinking)"}}if(t==="tool_use"){let r=String(e.name||""),o=e.id,s=e.input,i=ne(s);return r==="Bash"&&te(i)?re(n,i):{timestamp:n,type:"tool_use",toolUseId:o,toolName:r,toolInput:i}}if(t==="tool_result"){let r=!!e.is_error,o=e.tool_use_id,s=e.output??e.content??"",i;return typeof s=="string"?i=s:Array.isArray(s)?i=s.filter(a=>a.type==="text"&&typeof a.text=="string").map(a=>a.text).join(`
|
|
3
3
|
`):i=JSON.stringify(s),{timestamp:n,type:"tool_result",toolUseId:o,resultPreview:i,isError:r}}return null}exports.claudeAdapter=void 0;var Kt=N(()=>{l();Vt();je();Ue();exports.claudeAdapter={command:"claude",buildArgs(n,e,t){if(e.additionalArgs!==void 0){let o=[...e.additionalArgs],s=o.indexOf("-p");return s!==-1?(o.splice(s+1,0,n),e.model&&o.push("--model",e.model),{args:o}):(e.model&&o.push("--model",e.model),{args:o,stdinMessage:n})}let r=["-p",n,"--output-format","stream-json","--verbose"];return e.model&&r.push("--model",e.model),{args:r}},extractText(n){let e=n.split(`
|
|
4
4
|
`).filter(o=>o.trim()),t=[],r=null;for(let o of e)try{let s=JSON.parse(o);if(s.type==="assistant"&&Array.isArray(s.message?.content))for(let i of s.message.content)i.type==="text"&&typeof i.text=="string"&&i.text.trim()&&t.push(i.text.trim());s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(`
|
|
@@ -26,16 +26,12 @@
|
|
|
26
26
|
---
|
|
27
27
|
|
|
28
28
|
${e}`:e}async runProcess(e,t,r){try{return await Qr(this.adapter.command,e,this.providerStr,this.providerId,t,r,this.adapter)}catch(o){if(Vo(this.providerId,o)){let s=e[0]==="copilot"?e:["copilot",...e];return Qr("gh",s,this.providerStr,this.providerId,t,r,this.adapter)}throw o}}handleResultMeta(e,t){if(!this.adapter.parseResultMeta){let i=zo(e);i&&t?.onUsage&&t.onUsage(i);return}let{usage:r,model:o}=this.adapter.parseResultMeta(e);r&&t?.onUsage&&t.onUsage(r);let s=o??(this.providerId==="opencode"?t?.model??null:null);s&&t?.onModel&&t.onModel(s);}};});var _n,An;exports.VercelProviderRuntime=void 0;var yr=N(()=>{l();ae();_n=10,An=50,exports.VercelProviderRuntime=class{config;constructor(e){this.config=e;}async query(e,t){return this._run(e,"query",t)}async execute(e,t){return this._run(e,"execute",t)}async _run(e,t,r){let{generateText:o,tool:s}=await import('ai'),i=this.convertTools(r?.tools??[],s),a=this.createModel(r?.model),d=Math.min(r?.maxSteps??this.config.maxSteps??_n,An);try{let c=0,u=await o({model:a,system:r?.systemPrompt??void 0,prompt:e,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens},onStepFinish:y=>{if(c++,!!r?.onOutput){if(y.toolCalls&&y.toolCalls.length>0)for(let p of y.toolCalls)r.onOutput(JSON.stringify({type:"assistant",message:{content:[{type:"tool_use",id:p.toolCallId,name:p.toolName,input:p.args}]}}),"stdout");if(y.toolResults&&y.toolResults.length>0)for(let p of y.toolResults){let m=typeof p.result=="string"?p.result:JSON.stringify(p.result);r.onOutput(JSON.stringify({type:"user",message:{content:[{type:"tool_result",tool_use_id:p.toolCallId,output:m,is_error:!1}]}}),"stdout");}}}}),g=new Set((r?.tools??[]).filter(y=>!y.execute).map(y=>y.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let y=u.toolCalls.filter(p=>g.has(p.toolName));if(y.length>0){let p=y[0];throw new exports.ClientToolCallRequiredError({toolCallId:p.toolCallId,toolName:p.toolName,args:p.args},{userMessage:e,responseMessages:u.response?.messages??[],toolDefinitions:r?.tools??[],maxSteps:d,systemPrompt:r?.systemPrompt,modelOverride:r?.model})}}if(r?.onUsage&&u.usage){let y={inputTokens:u.usage.promptTokens??0,outputTokens:u.usage.completionTokens??0,cachedInputTokens:0,costUsd:0};r.onUsage(y);}return r?.onModel&&r.onModel(r.model??this.config.model),u.text??""}catch(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:o,tool:s}=await import('ai'),i=this.convertTools(e.toolDefinitions,s),a=this.createModel(e.modelOverride),d=Math.min(e.maxSteps??this.config.maxSteps??_n,An),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 o({model:a,system:e.systemPrompt??void 0,messages:c,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens}}),g=new Set(e.toolDefinitions.filter(y=>!y.execute).map(y=>y.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let y=u.toolCalls.filter(p=>g.has(p.toolName));if(y.length>0){let p=y[0];throw new exports.ClientToolCallRequiredError({toolCallId:p.toolCallId,toolName:p.toolName,args:p.args},{userMessage:e.userMessage,responseMessages:[...e.responseMessages,{role:"tool",content:t.map(m=>({type:"tool-result",toolCallId:m.toolCallId,toolName:m.toolName,result:typeof m.result=="string"?m.result:JSON.stringify(m.result)}))},...u.response?.messages??[]],toolDefinitions:e.toolDefinitions,maxSteps:e.maxSteps,systemPrompt:e.systemPrompt,modelOverride:e.modelOverride})}}return r?.onUsage&&u.usage&&r.onUsage({inputTokens:u.usage.promptTokens??0,outputTokens:u.usage.completionTokens??0,cachedInputTokens:0,costUsd:0}),r?.onModel&&r.onModel(e.modelOverride??this.config.model),u.text??""}catch(u){throw u instanceof exports.ClientToolCallRequiredError?u:new exports.ProviderError(`Provider error: ${u.message}`,this.config.provider)}}convertTools(e,t){let{z:r}=z("zod"),o={};for(let s of e){let i=this.jsonSchemaToZod(s.parameters??{},r);s.execute?o[s.name]=t({description:s.description,parameters:i,execute:async a=>s.execute(a)}):o[s.name]=t({description:s.description,parameters:i});}return o}jsonSchemaToZod(e,t){if(!e||!e.properties)return t.object({});let r={},o=e.properties,s=e.required??[];for(let[i,a]of Object.entries(o)){let d;switch(a.type){case "string":d=t.string();break;case "number":d=t.number();break;case "integer":d=t.number().int();break;case "boolean":d=t.boolean();break;case "array":d=t.array(t.any());break;default:d=t.any();}a.description&&(d=d.describe(a.description)),s.includes(i)||(d=d.optional()),r[i]=d;}return t.object(r)}createModel(e){let{provider:t,apiKey:r,baseURL:o}=this.config,s=e||this.config.model;switch(t){case "api/openrouter":{let{createOpenAI:i}=z("@ai-sdk/openai");return i({apiKey:r||process.env.OPENROUTER_API_KEY,baseURL:o||"https://openrouter.ai/api/v1"})(s)}case "api/openai":{let{createOpenAI:i}=z("@ai-sdk/openai");return i({apiKey:r||process.env.OPENAI_API_KEY,...o&&{baseURL:o}})(s)}case "api/anthropic":{let{createAnthropic:i}=z("@ai-sdk/anthropic");return i({apiKey:r||process.env.ANTHROPIC_API_KEY,...o&&{baseURL:o}})(s)}case "api/google":{let{createGoogleGenerativeAI:i}=z("@ai-sdk/google");return i({apiKey:r||process.env.GOOGLE_API_KEY})(s)}default:throw new exports.ProviderError(`Unsupported API provider: ${t}`,t)}}};});var Pn={};pt(Pn,{registerApiProviders:()=>Rn});function Rn(n){ue("api",(e,t)=>{let r=n?.apiKeys?.[e];return new exports.VercelProviderRuntime({provider:t,model:"",apiKey:r,maxSteps:n?.defaults?.maxSteps,temperature:n?.defaults?.temperature})});}var hr=N(()=>{l();ae();yr();});function wr(n){let e=n.update;if(e.sessionUpdate==="agent_message_chunk"){let t=e.content;if(t.type==="text"&&typeof t.text=="string")return t.text}return null}function se(n,e){try{let t=JSON.parse(n);if(t!=null&&typeof t=="object"&&typeof t.type=="string"&&Ds.has(t.type)){let r=e??new Date().toISOString();return [{...t,timestamp:t.timestamp||r}]}}catch{}return []}var Ds,xe=N(()=>{l();Ds=new Set(["text","tool_use","tool_result","error","agent_call"]);});exports.AcpProtocolError=void 0;var xr=N(()=>{l();exports.AcpProtocolError=class extends Error{constructor(t,r,o){super(t);this.code=r;this.data=o;}code;data;name="AcpProtocolError"};});var Us,Fs,Cn,Tn,Hs;exports.AcpConnection=void 0;var Ct=N(()=>{l();xr();ae();Us=-32e3,Fs=2e3,Cn=3e4,Tn=1e4,Hs=8*36e5,exports.AcpConnection=class{constructor(e){this.options=e;}options;proc=null;sdkConnection=null;disposed=false;stderrBuffer="";collectedStderr="";pendingUpdateCallback=null;authMethods=[];_initResponse=null;get initResponse(){return this._initResponse}async connect(e){if(this.disposed)throw new exports.ProviderError("AcpConnection has been disposed","acp");let t=this.options.spawn,r=process.platform==="win32"&&(t.shellOnWindows??true),o=child_process.spawn(t.command,t.args,{stdio:["pipe","pipe","pipe"],env:{...process.env,...this.options.env??{}},cwd:this.options.cwd,shell:r,windowsHide:true,detached:process.platform!=="win32"});o.pid!==void 0&&this.options.onPid?.(o.pid),o.stderr.on("data",p=>{let m=p.toString();this.collectedStderr+=m,this.stderrBuffer+=m;let w=this.stderrBuffer.split(`
|
|
29
|
-
`);this.stderrBuffer=w.pop()??"";for(let A of w)A.trim()&&this.options.onStderr?.(A);}),this.proc=o;let s=new WritableStream({write:p=>new Promise((m,w)=>{o.stdin.write(p,A=>{A?w(A):m();});}),close:()=>{o.stdin.end();}}),i=new ReadableStream({start:p=>{o.stdout.on("data",m=>{p.enqueue(new Uint8Array(m));}),o.stdout.on("end",()=>{p.close();}),o.stdout.on("error",m=>{p.error(m);});}}),a=sdk.ndJsonStream(s,i),d=this,c=new sdk.ClientSideConnection(p=>({requestPermission:async m=>{if(d.options.configOptions?.allow_all!==void 0){let w=m.options;if(Array.isArray(w)&&w.length>0)return {outcome:{outcome:"selected",optionId:(w.find(v=>v.kind==="allow_once")??w.find(v=>v.kind?.startsWith("allow_"))??w[0]).optionId}}}return {outcome:{outcome:"cancelled"}}},sessionUpdate:async m=>{d.pendingUpdateCallback?.(m);}}),a);this.sdkConnection=c;let u=new Promise((p,m)=>{o.on("error",w=>{if(w.code==="ENOENT"){let v=t.command==="npx"&&t.args.length>0?`@agentclientprotocol/${t.args[0]}`:t.command;m(new exports.ProviderError(`ACP command "${t.command}" not found. Is the ACP adapter installed? Try: npm install -g ${v}`,"acp"));}else m(new exports.ProviderError(`ACP spawn error: ${w.message}`,"acp"));});}),g=this.doInitialize(c,e),y=new Promise((p,m)=>{setTimeout(()=>{m(new exports.AcpProtocolError(`ACP connect timeout after ${Cn}ms. The ACP adapter may not be installed or may require interactive setup.`));},Cn).unref();});await Promise.race([g,y,u]);}async doInitialize(e,t){let r=await e.initialize({protocolVersion:1,clientCapabilities:{auth:{}},clientInfo:{name:t?.name??"crewx-sdk",version:t?.version??"0.8.4"}});this._initResponse=r,this.authMethods=r.authMethods??[];}async newSession(e){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");try{return await this.newSessionWithTimeout(e)}catch(t){if(!this.isAuthError(t))throw t;return await this.tryAuthenticate(),this.newSessionWithTimeout(e)}}async newSessionWithTimeout(e){return (await this.newSessionRawTimeout(e)).sessionId}async newSessionRaw(e){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");try{return await this.newSessionRawTimeout(e)}catch(t){if(!this.isAuthError(t))throw t;return await this.tryAuthenticate(),this.newSessionRawTimeout(e)}}async newSessionRawTimeout(e){let t=this.sdkConnection.newSession(e),r=new Promise((o,s)=>{setTimeout(()=>{s(new exports.AcpProtocolError(`ACP session/new timeout after ${Tn}ms`));},Tn).unref();});return Promise.race([t,r])}isAuthError(e){return typeof e=="object"&&e!==null&&"code"in e&&e.code===Us}async tryAuthenticate(){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected.","acp");let e=this.authMethods.find(r=>r.type==="env_var"&&this.hasEnvVarsFor(r));if(e){await this.sdkConnection.authenticate({methodId:e.id});return}let t=this.authMethods.map(r=>`${r.id} (${r.type??"agent"})`).join(", ");if(this.authMethods.length>0){let r=this.authMethods.filter(o=>o.type==="env_var");if(r.length>0){let o=r.flatMap(s=>(s.vars??[]).filter(i=>!i.optional&&!process.env[i.name]).map(i=>i.name));throw new exports.AcpProtocolError(`ACP authentication required. Missing environment variables: ${o.join(", ")}. Set them in your shell or crewx.yaml env block.`)}throw new exports.AcpProtocolError(`ACP authentication required but no supported method found. Available methods: ${t}. CrewX currently supports env_var authentication only.`)}throw new exports.AcpProtocolError("ACP agent requires authentication but advertised no auth methods.")}hasEnvVarsFor(e){return !e.vars||e.vars.length===0?true:e.vars.filter(t=>!t.optional).every(t=>!!process.env[t.name])}async setModel(e,t){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.unstable_setSessionModel({sessionId:e,modelId:t});}async setMode(e,t){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.setSessionMode({sessionId:e,modeId:t});}async setConfigOption(e,t,r){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.setSessionConfigOption({sessionId:e,configId:t,value:r});}async prompt(e,t,r,o){if(!this.sdkConnection||!this.proc)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");this.pendingUpdateCallback=r??null;let s=this.sdkConnection,i=this.proc,a=o??Hs,d=false,c=s.prompt({sessionId:e,prompt:t}).finally(()=>{d=true;}),u=new Promise((y,p)=>{setTimeout(()=>{s.cancel({sessionId:e}).catch(()=>{}),p(new Je(`ACP prompt timeout after ${a}ms`,"acp"));},a).unref();}),g=new Promise((y,p)=>{let m=(k,x,S)=>{if(d)return;let T=x!=null?`signal=${x}`:`code=${String(k)}`;p(new exports.ProviderError(`ACP process terminated unexpectedly (${T}) [${S}]: ${this.collectedStderr.slice(-500)}`,"acp"));},w=(k,x)=>m(k,x,"exit"),A=(k,x)=>m(k,x,"close");i.once("exit",w),i.once("close",A);let v=()=>{i.off("exit",w),i.off("close",A);};c.then(v,v);});try{return await Promise.race([c,u,g])}finally{this.pendingUpdateCallback=null;}}async dispose(){if(this.disposed)return;this.disposed=true,this.pendingUpdateCallback=null,this.sdkConnection=null;let e=this.proc;if(!e)return;this.proc=null,this.stderrBuffer.trim()&&(this.options.onStderr?.(this.stderrBuffer),this.stderrBuffer="");let t=e.pid,r=o=>{if(t!==void 0&&process.platform!=="win32")try{process.kill(-t,o);}catch{}else try{e.kill(o);}catch{}};await new Promise(o=>{let s=()=>{clearTimeout(i),o();};e.once("close",s),e.once("error",s);try{r("SIGTERM");}catch{s();return}let i=setTimeout(()=>{r("SIGKILL");},Fs);});}get isConnected(){return !this.disposed&&this.sdkConnection!==null&&this.proc!==null}};});function bn(n,e){if(n!=null&&typeof n=="object"){let t=n;if(typeof t.command=="string")return t.command;if(typeof t.file_path=="string")return t.file_path;if(typeof t.filePath=="string")return t.filePath;if(typeof t.path=="string")return t.path;if(typeof t.query=="string")return t.query;if(typeof t.pattern=="string")return t.pattern;if(typeof t.url=="string")return t.url;if(Object.keys(t).length>0)return JSON.stringify(t)}if(e&&e.length>0)return e.map(t=>t.path).join(", ")}var qs;exports.AcpProviderRuntime=void 0;var kr=N(()=>{l();xe();Ct();qs={read:"Read",edit:"Edit",delete:"Delete",move:"Move",search:"Search",execute:"Bash",think:"Think",fetch:"WebFetch",switch_mode:"SwitchMode"};exports.AcpProviderRuntime=class{constructor(e,t,r){this.adapter=t;}adapter;async query(e,t){return this.runPrompt(e,t)}async execute(e,t){return this.runPrompt(e,t)}async dispose(){}async runPrompt(e,t){let{command:r,args:o}=this.adapter.spawn;t?.onCommand?.(`${r} ${o.join(" ")}`);let s=this.adapter.buildSpawnEnv?.(t?.model??""),i=s?{...t?.env,...s}:t?.env,a=new exports.AcpConnection({spawn:this.adapter.spawn,env:i,cwd:t?.cwd,timeoutMs:t?.timeoutMs,onPid:t?.onPid,onStderr:d=>t?.onOutput?.(d,"stderr"),configOptions:t?.configOptions});try{await a.connect(this.adapter.clientInfo);let d=this.adapter.buildSessionParams({cwd:t?.cwd,env:t?.env,model:t?.model,systemPrompt:t?.systemPrompt}),c=await a.newSession(d);await this.applySessionOptions(a,c,t);let u=this.composePrompt(e,t),g=[],y=await a.prompt(c,u,p=>this.handleUpdate(p,t,g),t?.timeoutMs);return this.handleUsage(y,t),
|
|
29
|
+
`);this.stderrBuffer=w.pop()??"";for(let A of w)A.trim()&&this.options.onStderr?.(A);}),this.proc=o;let s=new WritableStream({write:p=>new Promise((m,w)=>{o.stdin.write(p,A=>{A?w(A):m();});}),close:()=>{o.stdin.end();}}),i=new ReadableStream({start:p=>{o.stdout.on("data",m=>{p.enqueue(new Uint8Array(m));}),o.stdout.on("end",()=>{p.close();}),o.stdout.on("error",m=>{p.error(m);});}}),a=sdk.ndJsonStream(s,i),d=this,c=new sdk.ClientSideConnection(p=>({requestPermission:async m=>{if(d.options.configOptions?.allow_all!==void 0){let w=m.options;if(Array.isArray(w)&&w.length>0)return {outcome:{outcome:"selected",optionId:(w.find(v=>v.kind==="allow_once")??w.find(v=>v.kind?.startsWith("allow_"))??w[0]).optionId}}}return {outcome:{outcome:"cancelled"}}},sessionUpdate:async m=>{d.pendingUpdateCallback?.(m);}}),a);this.sdkConnection=c;let u=new Promise((p,m)=>{o.on("error",w=>{if(w.code==="ENOENT"){let v=t.command==="npx"&&t.args.length>0?`@agentclientprotocol/${t.args[0]}`:t.command;m(new exports.ProviderError(`ACP command "${t.command}" not found. Is the ACP adapter installed? Try: npm install -g ${v}`,"acp"));}else m(new exports.ProviderError(`ACP spawn error: ${w.message}`,"acp"));});}),g=this.doInitialize(c,e),y=new Promise((p,m)=>{setTimeout(()=>{m(new exports.AcpProtocolError(`ACP connect timeout after ${Cn}ms. The ACP adapter may not be installed or may require interactive setup.`));},Cn).unref();});await Promise.race([g,y,u]);}async doInitialize(e,t){let r=await e.initialize({protocolVersion:1,clientCapabilities:{auth:{}},clientInfo:{name:t?.name??"crewx-sdk",version:t?.version??"0.8.4"}});this._initResponse=r,this.authMethods=r.authMethods??[];}async newSession(e){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");try{return await this.newSessionWithTimeout(e)}catch(t){if(!this.isAuthError(t))throw t;return await this.tryAuthenticate(),this.newSessionWithTimeout(e)}}async newSessionWithTimeout(e){return (await this.newSessionRawTimeout(e)).sessionId}async newSessionRaw(e){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");try{return await this.newSessionRawTimeout(e)}catch(t){if(!this.isAuthError(t))throw t;return await this.tryAuthenticate(),this.newSessionRawTimeout(e)}}async newSessionRawTimeout(e){let t=this.sdkConnection.newSession(e),r=new Promise((o,s)=>{setTimeout(()=>{s(new exports.AcpProtocolError(`ACP session/new timeout after ${Tn}ms`));},Tn).unref();});return Promise.race([t,r])}isAuthError(e){return typeof e=="object"&&e!==null&&"code"in e&&e.code===Us}async tryAuthenticate(){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected.","acp");let e=this.authMethods.find(r=>r.type==="env_var"&&this.hasEnvVarsFor(r));if(e){await this.sdkConnection.authenticate({methodId:e.id});return}let t=this.authMethods.map(r=>`${r.id} (${r.type??"agent"})`).join(", ");if(this.authMethods.length>0){let r=this.authMethods.filter(o=>o.type==="env_var");if(r.length>0){let o=r.flatMap(s=>(s.vars??[]).filter(i=>!i.optional&&!process.env[i.name]).map(i=>i.name));throw new exports.AcpProtocolError(`ACP authentication required. Missing environment variables: ${o.join(", ")}. Set them in your shell or crewx.yaml env block.`)}throw new exports.AcpProtocolError(`ACP authentication required but no supported method found. Available methods: ${t}. CrewX currently supports env_var authentication only.`)}throw new exports.AcpProtocolError("ACP agent requires authentication but advertised no auth methods.")}hasEnvVarsFor(e){return !e.vars||e.vars.length===0?true:e.vars.filter(t=>!t.optional).every(t=>!!process.env[t.name])}async setModel(e,t){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.unstable_setSessionModel({sessionId:e,modelId:t});}async setMode(e,t){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.setSessionMode({sessionId:e,modeId:t});}async setConfigOption(e,t,r){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.setSessionConfigOption({sessionId:e,configId:t,value:r});}async prompt(e,t,r,o){if(!this.sdkConnection||!this.proc)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");this.pendingUpdateCallback=r??null;let s=this.sdkConnection,i=this.proc,a=o??Hs,d=false,c=s.prompt({sessionId:e,prompt:t}).finally(()=>{d=true;}),u=new Promise((y,p)=>{setTimeout(()=>{s.cancel({sessionId:e}).catch(()=>{}),p(new Je(`ACP prompt timeout after ${a}ms`,"acp"));},a).unref();}),g=new Promise((y,p)=>{let m=(k,x,S)=>{if(d)return;let T=x!=null?`signal=${x}`:`code=${String(k)}`;p(new exports.ProviderError(`ACP process terminated unexpectedly (${T}) [${S}]: ${this.collectedStderr.slice(-500)}`,"acp"));},w=(k,x)=>m(k,x,"exit"),A=(k,x)=>m(k,x,"close");i.once("exit",w),i.once("close",A);let v=()=>{i.off("exit",w),i.off("close",A);};c.then(v,v);});try{return await Promise.race([c,u,g])}finally{this.pendingUpdateCallback=null;}}async dispose(){if(this.disposed)return;this.disposed=true,this.pendingUpdateCallback=null,this.sdkConnection=null;let e=this.proc;if(!e)return;this.proc=null,this.stderrBuffer.trim()&&(this.options.onStderr?.(this.stderrBuffer),this.stderrBuffer="");let t=e.pid,r=o=>{if(t!==void 0&&process.platform!=="win32")try{process.kill(-t,o);}catch{}else try{e.kill(o);}catch{}};await new Promise(o=>{let s=()=>{clearTimeout(i),o();};e.once("close",s),e.once("error",s);try{r("SIGTERM");}catch{s();return}let i=setTimeout(()=>{r("SIGKILL");},Fs);});}get isConnected(){return !this.disposed&&this.sdkConnection!==null&&this.proc!==null}};});function bn(n,e){if(n!=null&&typeof n=="object"){let t=n;if(typeof t.command=="string")return t.command;if(typeof t.file_path=="string")return t.file_path;if(typeof t.filePath=="string")return t.filePath;if(typeof t.path=="string")return t.path;if(typeof t.query=="string")return t.query;if(typeof t.pattern=="string")return t.pattern;if(typeof t.url=="string")return t.url;if(Object.keys(t).length>0)return JSON.stringify(t)}if(e&&e.length>0)return e.map(t=>t.path).join(", ")}var qs;exports.AcpProviderRuntime=void 0;var kr=N(()=>{l();xe();Ct();qs={read:"Read",edit:"Edit",delete:"Delete",move:"Move",search:"Search",execute:"Bash",think:"Think",fetch:"WebFetch",switch_mode:"SwitchMode"};exports.AcpProviderRuntime=class{constructor(e,t,r){this.adapter=t;}adapter;async query(e,t){return this.runPrompt(e,t)}async execute(e,t){return this.runPrompt(e,t)}async dispose(){}async runPrompt(e,t){let{command:r,args:o}=this.adapter.spawn;t?.onCommand?.(`${r} ${o.join(" ")}`);let s=this.adapter.buildSpawnEnv?.(t?.model??""),i=s?{...t?.env,...s}:t?.env,a=new exports.AcpConnection({spawn:this.adapter.spawn,env:i,cwd:t?.cwd,timeoutMs:t?.timeoutMs,onPid:t?.onPid,onStderr:d=>t?.onOutput?.(d,"stderr"),configOptions:t?.configOptions});try{await a.connect(this.adapter.clientInfo);let d=this.adapter.buildSessionParams({cwd:t?.cwd,env:t?.env,model:t?.model,systemPrompt:t?.systemPrompt}),c=await a.newSession(d);await this.applySessionOptions(a,c,t);let u=this.composePrompt(e,t),g=[],y=await a.prompt(c,u,p=>this.handleUpdate(p,t,g),t?.timeoutMs);return this.handleUsage(y,t),g.join("")}finally{await a.dispose().catch(()=>{});}}async applySessionOptions(e,t,r){if(r?.model&&r.model!=="default"&&!this.adapter.buildSpawnEnv){let o=this.adapter.buildEffortAction?.(r.effort??"",r.model);try{o?.type==="set_model"?await e.setModel(t,o.modelId):await e.setModel(t,r.model);}catch(s){console.warn(`[acp] setModel(${r.model}) failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.mode){let o=this.adapter.resolveMode?.(r.mode)??r.mode;if(o)try{await e.setMode(t,o);}catch(s){console.warn(`[acp] setMode(${o}) failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.effort){let o=this.adapter.buildEffortAction?.(r.effort,r.model);if(o&&o.type==="set_config_option")try{await e.setConfigOption(t,o.configId,o.value);}catch(s){console.warn(`[acp] setConfigOption(${o.configId}) effort failed: ${s instanceof Error?s.message:String(s)}`);}}if(r?.configOptions)for(let[o,s]of Object.entries(r.configOptions))try{await e.setConfigOption(t,o,s);}catch(i){console.warn(`[acp] setConfigOption(${o}) failed, retrying: ${i instanceof Error?i.message:String(i)}`);try{await new Promise(a=>setTimeout(a,500)),await e.setConfigOption(t,o,s);}catch(a){console.warn(`[acp] setConfigOption(${o}) retry failed: ${a instanceof Error?a.message:String(a)}`);}}}composePrompt(e,t){let r=[];return t?.systemPrompt?.trim()&&(r.push(t.systemPrompt),r.push("---")),t?.context&&(r.push(t.context),r.push("---")),r.push(e),[{type:"text",text:r.join(`
|
|
30
30
|
|
|
31
31
|
`)}]}handleUpdate(e,t,r){let o=e.update;if(o.sessionUpdate==="agent_message_chunk"){let s=null;this.adapter.extractTextFromUpdate?s=this.adapter.extractTextFromUpdate(e):s=wr(e),s!==null&&(r.push(s),t?.onOutput?.(s,"stdout"));}else if(o.sessionUpdate==="tool_call"){let s=new Date().toISOString(),i=o,a={title:i.title??"",kind:i.kind,rawInput:i.rawInput,rawOutput:i.rawOutput,locations:i.locations,_meta:i._meta},d=this.resolveToolCall(a),c={timestamp:s,type:"tool_use",toolUseId:i.toolCallId,toolName:d.toolName,toolInput:d.toolInput};t?.onTaskLog?.([c]);}else if(o.sessionUpdate==="tool_call_update"){let s=new Date().toISOString(),i=o;if(i.status==="completed"||i.status==="failed"){let d=this.extractResultPreview(i.rawOutput),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 o.sessionUpdate;}resolveToolCall(e){let t=e._meta;if(t?.claudeCode?.toolName)return {toolName:t.claudeCode.toolName,toolInput:bn(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=qs[e.kind??""]??e.title??"unknown",o=bn(e.rawInput,e.locations)??(e.title||void 0);return {toolName:r,toolInput:o}}extractResultPreview(e){if(e!=null){if(typeof e=="string")return e;if(Array.isArray(e)){let t=e.filter(r=>r!=null&&typeof r=="object"&&r.type==="text"&&typeof r.text=="string").map(r=>r.text);if(t.length>0)return t.join(`
|
|
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 o=this.adapter.extractUsage(e);if(o){t.onUsage(o);return}}let r=e.usage;r&&t.onUsage({inputTokens:r.inputTokens??0,outputTokens:r.outputTokens??0,cachedInputTokens:r.cachedReadTokens??0,costUsd:0});}};});var En;exports.claudeAcpAdapter=void 0;var bt=N(()=>{l();xe();En=[{id:"claude-opus-4-8[1m]",name:"Claude Opus 4.8 (Extended)"},{id:"claude-opus-4-8",name:"Claude Opus 4.8"},{id:"claude-opus-4-7[1m]",name:"Claude Opus 4.7 (Extended)"},{id:"claude-opus-4-7",name:"Claude Opus 4.7"},{id:"claude-opus-4-6[1m]",name:"Claude Opus 4.6 (Extended)"},{id:"claude-opus-4-6",name:"Claude Opus 4.6"},{id:"claude-sonnet-4-6[1m]",name:"Claude Sonnet 4.6 (Extended)"},{id:"claude-sonnet-4-6",name:"Claude Sonnet 4.6"},{id:"claude-haiku-4-5",name:"Claude Haiku 4.5"}],exports.claudeAcpAdapter={spawn:{command:"npx",args:["-y","@agentclientprotocol/claude-agent-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/claude-agent-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Claude",defaultMode:"default"},buildSessionParams(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},extractUsage(n){let e=n.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"bypassPermissions",buildEffortAction(n){return n?{type:"set_config_option",configId:"effort",value:n}:null},buildSpawnEnv(n){if(!(!n||n==="default"))return {ANTHROPIC_MODEL:n}},resolveMode(n){return {yolo:"bypassPermissions"}[n]??n},parseEvent:se};});function Bs(n){let e=n.filter(r=>r.length>0);if(e.length===0)return "";let t=e[0]??"";for(let r of e.slice(1))t+=Ws(t,r)?`
|
|
33
|
-
|
|
34
|
-
${r}`:r;return t}function Ws(n,e){if(!n||!e||/\s$/.test(n)||/^\s/.test(e)||n.endsWith(`
|
|
35
|
-
`)||e.startsWith(`
|
|
36
|
-
`))return false;let t=n.trimEnd(),r=e.trimStart();return !t||!r?false:/^(#{1,6}\s|[-*]\s|\d+\.\s|```|>|<crewx_card\b)/.test(r)?true:/[.!?。!?…::]$/.test(t)}exports.codexAcpAdapter=void 0;var vr=N(()=>{l();xe();exports.codexAcpAdapter={spawn:{command:"npx",args:["-y","@agentclientprotocol/codex-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/codex-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Codex",defaultMode:"agent"},buildSessionParams(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},extractUsage(n){let e=n.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},joinTextChunks(n){return Bs(n)},yoloModeId:"agent-full-access",buildEffortAction(n,e){if(!e)return null;let t=e.match(/^(.+?)\[([^\]]+)\]$/),r=t?t[1]:e,o=t?t[2]:void 0;return {type:"set_model",modelId:`${r}[${n||o||"medium"}]`}},resolveMode(n){return {yolo:"agent-full-access",default:"agent",plan:"read-only"}[n]??n},parseEvent:se};});exports.geminiAcpAdapter=void 0;var _r=N(()=>{l();xe();exports.geminiAcpAdapter={spawn:{command:"gemini",args:["--acp","--skip-trust"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Gemini"},buildSessionParams(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},yoloModeId:"yolo",buildEffortAction(n){return null},resolveMode(n){return {acceptEdits:"autoEdit"}[n]??n},parseEvent:se};});var He;exports.copilotAcpAdapter=void 0;var Ar=N(()=>{l();xe();He="https://agentclientprotocol.com/protocol/session-modes",exports.copilotAcpAdapter={spawn:{command:"copilot",args:["--acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"GitHub Copilot"},buildSessionParams(n){return {cwd:n.cwd?W.resolve(n.cwd):process.cwd(),mcpServers:[]}},yoloModeId:`${He}#autopilot`,buildEffortAction(n){return n?{type:"set_config_option",configId:"reasoning_effort",value:n}:null},resolveMode(n){return n.startsWith("https://")?n:{yolo:`${He}#autopilot`,default:`${He}#agent`,agent:`${He}#agent`,plan:`${He}#plan`,autopilot:`${He}#autopilot`}[n]??null},parseEvent:se};});exports.opencodeAcpAdapter=void 0;var Rr=N(()=>{l();xe();exports.opencodeAcpAdapter={spawn:{command:"opencode",args:["acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"OpenCode"},buildSessionParams(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},yoloModeId:void 0,buildEffortAction(n){return null},resolveMode(n){let e={default:"build"};return n==="yolo"?null:e[n]??n},parseEvent:se};});exports.ACP_ADAPTERS=void 0;var Mt=N(()=>{l();bt();vr();_r();Ar();Rr();bt();vr();_r();Ar();Rr();exports.ACP_ADAPTERS={claude:exports.claudeAcpAdapter,codex:exports.codexAcpAdapter,gemini:exports.geminiAcpAdapter,copilot:exports.copilotAcpAdapter,opencode:exports.opencodeAcpAdapter};});var In={};pt(In,{registerAcpProviders:()=>Sn});function Sn(n){if(n){ue("acp",n);return}ue("acp",(e,t)=>{let r=exports.ACP_ADAPTERS[e];if(!r)throw new exports.ProviderError(`Unknown ACP provider id: "${e}". Supported: ${Object.keys(exports.ACP_ADAPTERS).join(", ")}`,t);return new exports.AcpProviderRuntime(e,r,t)});}var Pr=N(()=>{l();ae();kr();Mt();ae();});function Vs(n){if(!n)return n;let e=n.trim().replace(/\/+$/,"");return e.toLowerCase().endsWith("/mcp")?e.slice(0,-4):e}exports.McpHttpTransport=void 0;var Cr=N(()=>{l();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=Vs(e.url);this.endpoint=`${t}/mcp`,this.headers={"Content-Type":"application/json",...e.headers??{}},e.apiKey&&(this.headers.Authorization=`Bearer ${e.apiKey}`),this.timeoutMs=e.timeoutMs??3e4;}async send(e){let t=new AbortController,r=setTimeout(()=>t.abort(),this.timeoutMs);try{let o=await fetch(this.endpoint,{method:"POST",headers:this.headers,body:JSON.stringify(e),signal:t.signal});if(clearTimeout(r),!o.ok){let a=await o.text();throw new Error(`HTTP ${o.status}: ${o.statusText}${a?` - ${a}`:""}`)}let s=o.headers.get("content-type");if(s?.includes("application/json"))return await o.json();let i=await o.text();return {jsonrpc:"2.0",id:e.id,error:{code:-32600,message:`Unexpected response content-type: ${s}`,data:i}}}catch(o){throw clearTimeout(r),o instanceof Error&&o.name==="AbortError"?new Error(`MCP-HTTP request timeout after ${this.timeoutMs}ms to ${this.endpoint}`):o}}async close(){}};});exports.RemoteAgentManager=void 0;var Tr=N(()=>{l();Cr();exports.RemoteAgentManager=class{logger;configs=new Map;transports=new Map;constructor(e={}){this.logger=e.logger??(()=>{});}loadConfig(e,t){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,new exports.McpHttpTransport({url:t.url,apiKey:t.apiKey,headers:t.headers,timeoutMs:t.timeoutMs})),this.logger(`Loaded remote agent config for: ${e}`,"debug");}loadConfigWithTransport(e,t,r){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,r),this.logger(`Loaded remote agent config for: ${e} (custom transport)`,"debug");}getConfig(e){return this.configs.get(e)}isRemoteAgent(e){return this.configs.has(e)}getRemoteAgentIds(){return Array.from(this.configs.keys())}async query(e,t){let r=this.requireConfig(e),o=r.tools?.query??"crewx_queryAgent",i={agentId:r.agentId??e,query:t.query};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,o,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote query failed for agent ${e}: ${d}`,"error"),a}}async execute(e,t){let r=this.requireConfig(e),o=r.tools?.execute??"crewx_executeAgent",i={agentId:r.agentId??e,task:t.task};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,o,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote execute failed for agent ${e}: ${d}`,"error"),a}}mapToolNames(e,t){let r=this.requireConfig(e);r.tools={query:t.query??r.tools?.query??"crewx_queryAgent",execute:t.execute??r.tools?.execute??"crewx_executeAgent"},this.logger(`Updated tool name mapping for agent ${e}`,"debug");}async clearConfigs(){for(let e of this.transports.values())await e.close();this.configs.clear(),this.transports.clear(),this.logger("Cleared all remote agent configurations","debug");}requireConfig(e){let t=this.configs.get(e);if(!t)throw new Error(`Agent ${e} is not configured as a remote agent`);return t}async callRemoteTool(e,t,r){let o=this.transports.get(e);if(!o)throw new Error(`No transport available for agent ${e}`);let s={jsonrpc:"2.0",id:`${t}-${Date.now()}`,method:"tools/call",params:{name:t,arguments:r}};this.logger(`Calling remote MCP tool ${t} for agent ${e}`,"debug");let i=await o.send(s);if(i.error)throw new Error(i.error.message||"MCP server returned an error");return i.result}normalizeResponse(e){if(!e)return {success:false,content:[{type:"text",text:"Remote agent returned no response."}]};let t=e;if(Array.isArray(t.content)&&t.content.length>0)return t;let r=t.response??t.implementation??t.message??t.output,o=typeof r=="string"?r:JSON.stringify(r??e,null,2);return {...t,content:[{type:"text",text:o}]}}validateConfig(e){if(!e.url)throw new Error("Remote agent configuration requires a URL");if(!e.url.startsWith("http://")&&!e.url.startsWith("https://"))throw new Error("Remote agent URL must start with http:// or https://");if(e.type!=="mcp-http")throw new Error(`Unsupported remote agent type: ${e.type}`)}};});var Mn={};pt(Mn,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>On,resolveFileRemoteAgent:()=>ei});function Qs(n){let e=fs$1.readFileSync(n,"utf-8"),t=jsYaml.load(e);return {agents:Array.isArray(t?.agents)?t.agents:void 0}}function Zs(n){let e=Array.isArray(n.provider)?n.provider[0]:n.provider;return e||(Array.isArray(n.inline?.provider)?n.inline.provider[0]:n.inline?.provider)}function ei(n,e=Qs,t=fs$1.existsSync){let r=n.location.replace("file://","");if(!t(r))throw new Error(`Remote config file not found: ${r}`);if(!n.external_agent_id)throw new Error(`external_agent_id is required for file:// remote provider "${n.id}"`);let s=e(r).agents?.find(d=>d.id===n.external_agent_id);if(!s)throw new Error(`Agent "${n.external_agent_id}" not found in ${r}`);let i=Zs(s);if(!i)throw new Error(`Agent "${n.external_agent_id}" in ${r} has no provider configured`);if(i.startsWith("remote/"))throw new Error(`Chained remotes not allowed: ${n.id} \u2192 ${i}`);let a=W.resolve(W.dirname(r),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function On(n,e=pe){return (t,r)=>{let o=n.get(t);if(!o)throw new Error(`Remote provider "${t}" not found. Available: ${Array.from(n.keys()).join(", ")||"(none)"}`);if(o.location.startsWith("file://"))throw new Error(`Remote provider "${t}" uses file:// location which is not supported at the SDK level. Use the CLI commands (crewx query / crewx execute) which handle file:// remotes automatically.`);return new exports.RemoteProviderRuntime(t,o,e)}}function ti(n,e){let t=e.location;if(!t)throw new Error("Remote provider config requires a location");if(!t.startsWith("http://")&&!t.startsWith("https://"))throw new Error(`Unsupported remote location protocol for MCP-HTTP: ${t}`);return {type:"mcp-http",url:t,apiKey:e.apiKey,headers:e.headers,timeoutMs:e.timeout?.query??3e4,agentId:e.external_agent_id??n}}exports.RemoteProviderRuntime=void 0;var br=N(()=>{l();ae();Tr();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,r=pe){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let o=ti(e,t);this.manager.loadConfig(this.agentId,o);}async query(e,t){return (await this.manager.query(this.agentId,{agentId:this.agentId,query:e,model:t?.model,context:t?.context??t?.systemPrompt})).content.map(o=>o.text).join(`
|
|
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 o=this.adapter.extractUsage(e);if(o){t.onUsage(o);return}}let r=e.usage;r&&t.onUsage({inputTokens:r.inputTokens??0,outputTokens:r.outputTokens??0,cachedInputTokens:r.cachedReadTokens??0,costUsd:0});}};});var En;exports.claudeAcpAdapter=void 0;var bt=N(()=>{l();xe();En=[{id:"claude-opus-4-8[1m]",name:"Claude Opus 4.8 (Extended)"},{id:"claude-opus-4-8",name:"Claude Opus 4.8"},{id:"claude-opus-4-7[1m]",name:"Claude Opus 4.7 (Extended)"},{id:"claude-opus-4-7",name:"Claude Opus 4.7"},{id:"claude-opus-4-6[1m]",name:"Claude Opus 4.6 (Extended)"},{id:"claude-opus-4-6",name:"Claude Opus 4.6"},{id:"claude-sonnet-4-6[1m]",name:"Claude Sonnet 4.6 (Extended)"},{id:"claude-sonnet-4-6",name:"Claude Sonnet 4.6"},{id:"claude-haiku-4-5",name:"Claude Haiku 4.5"}],exports.claudeAcpAdapter={spawn:{command:"npx",args:["-y","@agentclientprotocol/claude-agent-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/claude-agent-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Claude",defaultMode:"default"},buildSessionParams(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},extractUsage(n){let e=n.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"bypassPermissions",buildEffortAction(n){return n?{type:"set_config_option",configId:"effort",value:n}:null},buildSpawnEnv(n){if(!(!n||n==="default"))return {ANTHROPIC_MODEL:n}},resolveMode(n){return {yolo:"bypassPermissions"}[n]??n},parseEvent:se};});exports.codexAcpAdapter=void 0;var vr=N(()=>{l();xe();exports.codexAcpAdapter={spawn:{command:"npx",args:["-y","@agentclientprotocol/codex-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/codex-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Codex",defaultMode:"agent"},buildSessionParams(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},extractUsage(n){let e=n.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"agent-full-access",buildEffortAction(n,e){if(!e)return null;let t=e.match(/^(.+?)\[([^\]]+)\]$/),r=t?t[1]:e,o=t?t[2]:void 0;return {type:"set_model",modelId:`${r}[${n||o||"medium"}]`}},resolveMode(n){return {yolo:"agent-full-access",default:"agent",plan:"read-only"}[n]??n},parseEvent:se};});exports.geminiAcpAdapter=void 0;var _r=N(()=>{l();xe();exports.geminiAcpAdapter={spawn:{command:"gemini",args:["--acp","--skip-trust"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"Gemini"},buildSessionParams(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},yoloModeId:"yolo",buildEffortAction(n){return null},resolveMode(n){return {acceptEdits:"autoEdit"}[n]??n},parseEvent:se};});var He;exports.copilotAcpAdapter=void 0;var Ar=N(()=>{l();xe();He="https://agentclientprotocol.com/protocol/session-modes",exports.copilotAcpAdapter={spawn:{command:"copilot",args:["--acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"GitHub Copilot"},buildSessionParams(n){return {cwd:n.cwd?W.resolve(n.cwd):process.cwd(),mcpServers:[]}},yoloModeId:`${He}#autopilot`,buildEffortAction(n){return n?{type:"set_config_option",configId:"reasoning_effort",value:n}:null},resolveMode(n){return n.startsWith("https://")?n:{yolo:`${He}#autopilot`,default:`${He}#agent`,agent:`${He}#agent`,plan:`${He}#plan`,autopilot:`${He}#autopilot`}[n]??null},parseEvent:se};});exports.opencodeAcpAdapter=void 0;var Rr=N(()=>{l();xe();exports.opencodeAcpAdapter={spawn:{command:"opencode",args:["acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},meta:{displayName:"OpenCode"},buildSessionParams(n){return {cwd:n.cwd??process.cwd(),mcpServers:[]}},yoloModeId:void 0,buildEffortAction(n){return null},resolveMode(n){let e={default:"build"};return n==="yolo"?null:e[n]??n},parseEvent:se};});exports.ACP_ADAPTERS=void 0;var Mt=N(()=>{l();bt();vr();_r();Ar();Rr();bt();vr();_r();Ar();Rr();exports.ACP_ADAPTERS={claude:exports.claudeAcpAdapter,codex:exports.codexAcpAdapter,gemini:exports.geminiAcpAdapter,copilot:exports.copilotAcpAdapter,opencode:exports.opencodeAcpAdapter};});var In={};pt(In,{registerAcpProviders:()=>Sn});function Sn(n){if(n){ue("acp",n);return}ue("acp",(e,t)=>{let r=exports.ACP_ADAPTERS[e];if(!r)throw new exports.ProviderError(`Unknown ACP provider id: "${e}". Supported: ${Object.keys(exports.ACP_ADAPTERS).join(", ")}`,t);return new exports.AcpProviderRuntime(e,r,t)});}var Pr=N(()=>{l();ae();kr();Mt();ae();});function Ws(n){if(!n)return n;let e=n.trim().replace(/\/+$/,"");return e.toLowerCase().endsWith("/mcp")?e.slice(0,-4):e}exports.McpHttpTransport=void 0;var Cr=N(()=>{l();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=Ws(e.url);this.endpoint=`${t}/mcp`,this.headers={"Content-Type":"application/json",...e.headers??{}},e.apiKey&&(this.headers.Authorization=`Bearer ${e.apiKey}`),this.timeoutMs=e.timeoutMs??3e4;}async send(e){let t=new AbortController,r=setTimeout(()=>t.abort(),this.timeoutMs);try{let o=await fetch(this.endpoint,{method:"POST",headers:this.headers,body:JSON.stringify(e),signal:t.signal});if(clearTimeout(r),!o.ok){let a=await o.text();throw new Error(`HTTP ${o.status}: ${o.statusText}${a?` - ${a}`:""}`)}let s=o.headers.get("content-type");if(s?.includes("application/json"))return await o.json();let i=await o.text();return {jsonrpc:"2.0",id:e.id,error:{code:-32600,message:`Unexpected response content-type: ${s}`,data:i}}}catch(o){throw clearTimeout(r),o instanceof Error&&o.name==="AbortError"?new Error(`MCP-HTTP request timeout after ${this.timeoutMs}ms to ${this.endpoint}`):o}}async close(){}};});exports.RemoteAgentManager=void 0;var Tr=N(()=>{l();Cr();exports.RemoteAgentManager=class{logger;configs=new Map;transports=new Map;constructor(e={}){this.logger=e.logger??(()=>{});}loadConfig(e,t){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,new exports.McpHttpTransport({url:t.url,apiKey:t.apiKey,headers:t.headers,timeoutMs:t.timeoutMs})),this.logger(`Loaded remote agent config for: ${e}`,"debug");}loadConfigWithTransport(e,t,r){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,r),this.logger(`Loaded remote agent config for: ${e} (custom transport)`,"debug");}getConfig(e){return this.configs.get(e)}isRemoteAgent(e){return this.configs.has(e)}getRemoteAgentIds(){return Array.from(this.configs.keys())}async query(e,t){let r=this.requireConfig(e),o=r.tools?.query??"crewx_queryAgent",i={agentId:r.agentId??e,query:t.query};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,o,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote query failed for agent ${e}: ${d}`,"error"),a}}async execute(e,t){let r=this.requireConfig(e),o=r.tools?.execute??"crewx_executeAgent",i={agentId:r.agentId??e,task:t.task};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,o,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote execute failed for agent ${e}: ${d}`,"error"),a}}mapToolNames(e,t){let r=this.requireConfig(e);r.tools={query:t.query??r.tools?.query??"crewx_queryAgent",execute:t.execute??r.tools?.execute??"crewx_executeAgent"},this.logger(`Updated tool name mapping for agent ${e}`,"debug");}async clearConfigs(){for(let e of this.transports.values())await e.close();this.configs.clear(),this.transports.clear(),this.logger("Cleared all remote agent configurations","debug");}requireConfig(e){let t=this.configs.get(e);if(!t)throw new Error(`Agent ${e} is not configured as a remote agent`);return t}async callRemoteTool(e,t,r){let o=this.transports.get(e);if(!o)throw new Error(`No transport available for agent ${e}`);let s={jsonrpc:"2.0",id:`${t}-${Date.now()}`,method:"tools/call",params:{name:t,arguments:r}};this.logger(`Calling remote MCP tool ${t} for agent ${e}`,"debug");let i=await o.send(s);if(i.error)throw new Error(i.error.message||"MCP server returned an error");return i.result}normalizeResponse(e){if(!e)return {success:false,content:[{type:"text",text:"Remote agent returned no response."}]};let t=e;if(Array.isArray(t.content)&&t.content.length>0)return t;let r=t.response??t.implementation??t.message??t.output,o=typeof r=="string"?r:JSON.stringify(r??e,null,2);return {...t,content:[{type:"text",text:o}]}}validateConfig(e){if(!e.url)throw new Error("Remote agent configuration requires a URL");if(!e.url.startsWith("http://")&&!e.url.startsWith("https://"))throw new Error("Remote agent URL must start with http:// or https://");if(e.type!=="mcp-http")throw new Error(`Unsupported remote agent type: ${e.type}`)}};});var Mn={};pt(Mn,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>On,resolveFileRemoteAgent:()=>Qs});function Gs(n){let e=fs$1.readFileSync(n,"utf-8"),t=jsYaml.load(e);return {agents:Array.isArray(t?.agents)?t.agents:void 0}}function Ys(n){let e=Array.isArray(n.provider)?n.provider[0]:n.provider;return e||(Array.isArray(n.inline?.provider)?n.inline.provider[0]:n.inline?.provider)}function Qs(n,e=Gs,t=fs$1.existsSync){let r=n.location.replace("file://","");if(!t(r))throw new Error(`Remote config file not found: ${r}`);if(!n.external_agent_id)throw new Error(`external_agent_id is required for file:// remote provider "${n.id}"`);let s=e(r).agents?.find(d=>d.id===n.external_agent_id);if(!s)throw new Error(`Agent "${n.external_agent_id}" not found in ${r}`);let i=Ys(s);if(!i)throw new Error(`Agent "${n.external_agent_id}" in ${r} has no provider configured`);if(i.startsWith("remote/"))throw new Error(`Chained remotes not allowed: ${n.id} \u2192 ${i}`);let a=W.resolve(W.dirname(r),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function On(n,e=pe){return (t,r)=>{let o=n.get(t);if(!o)throw new Error(`Remote provider "${t}" not found. Available: ${Array.from(n.keys()).join(", ")||"(none)"}`);if(o.location.startsWith("file://"))throw new Error(`Remote provider "${t}" uses file:// location which is not supported at the SDK level. Use the CLI commands (crewx query / crewx execute) which handle file:// remotes automatically.`);return new exports.RemoteProviderRuntime(t,o,e)}}function Zs(n,e){let t=e.location;if(!t)throw new Error("Remote provider config requires a location");if(!t.startsWith("http://")&&!t.startsWith("https://"))throw new Error(`Unsupported remote location protocol for MCP-HTTP: ${t}`);return {type:"mcp-http",url:t,apiKey:e.apiKey,headers:e.headers,timeoutMs:e.timeout?.query??3e4,agentId:e.external_agent_id??n}}exports.RemoteProviderRuntime=void 0;var br=N(()=>{l();ae();Tr();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,r=pe){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let o=Zs(e,t);this.manager.loadConfig(this.agentId,o);}async query(e,t){return (await this.manager.query(this.agentId,{agentId:this.agentId,query:e,model:t?.model,context:t?.context??t?.systemPrompt})).content.map(o=>o.text).join(`
|
|
37
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(o=>o.text).join(`
|
|
38
|
-
`)}};});var Ln={};pt(Ln,{PluginProviderRuntime:()=>exports.PluginProviderRuntime,createPluginProviderFactory:()=>$n});function $n(n){return (e,t)=>{let r=n.get(e);if(!r)throw new exports.ProviderError(`Plugin provider "${e}" not found. Available: ${Array.from(n.keys()).join(", ")||"(none)"}`,`plugin/${e}`);return new exports.PluginProviderRuntime(e,r)}}function Nn(n,e,t,r){let o=n.map(s=>s.replace(/\{model\}/g,e));return r&&o.push(t),o}function
|
|
34
|
+
`)}};});var Ln={};pt(Ln,{PluginProviderRuntime:()=>exports.PluginProviderRuntime,createPluginProviderFactory:()=>$n});function $n(n){return (e,t)=>{let r=n.get(e);if(!r)throw new exports.ProviderError(`Plugin provider "${e}" not found. Available: ${Array.from(n.keys()).join(", ")||"(none)"}`,`plugin/${e}`);return new exports.PluginProviderRuntime(e,r)}}function Nn(n,e,t,r){let o=n.map(s=>s.replace(/\{model\}/g,e));return r&&o.push(t),o}function ti(n){if(!n||typeof n!="string")throw new Error("Plugin provider requires a cli_command")}function Dn(n){if(!Array.isArray(n))throw new Error("CLI arguments must be an array");for(let e of n)if(typeof e!="string")throw new Error("Each CLI argument must be a string")}function ri(n){for(let{pattern:e}of n)if(typeof e!="string")throw new Error("Error pattern must be a string")}function ni(n){for(let[e,t]of Object.entries(n))if(typeof e!="string"||typeof t!="string")throw new Error("env entries must be string key/value pairs")}exports.PluginProviderRuntime=void 0;var Er=N(()=>{l();ae();xt();exports.PluginProviderRuntime=class{constructor(e,t){this.config=t;this.providerStr=`plugin/${e}`,ti(t.cli_command),Dn(t.query_args),Dn(t.execute_args),t.error_patterns&&ri(t.error_patterns),t.env&&ni(t.env);}config;providerStr;async query(e,t){let r=t?.model??this.config.default_model??"default",o=Nn(this.config.query_args,r,e,this.config.prompt_in_args),s=this.config.prompt_in_args?void 0:e;t?.onCommand?.(`${this.config.cli_command} ${o.join(" ")}`);let i=this.config.timeout?.query??6e5;return this.runProcess(o,t,s,i)}async execute(e,t){let r=t?.model??this.config.default_model??"default",o=Nn(this.config.execute_args,r,e,this.config.prompt_in_args),s=this.config.prompt_in_args?void 0:e;t?.onCommand?.(`${this.config.cli_command} ${o.join(" ")}`);let i=this.config.timeout?.execute??6e5;return this.runProcess(o,t,s,i)}runProcess(e,t,r,o){return new Promise((s,i)=>{let a={...process.env,...this.config.env??{}},d=ze({command:this.config.cli_command,allowShellFallback:true}),c=Ve(d,e),u=child_process.spawn(c.command,c.argv,{env:a,shell:c.shell??false,stdio:["pipe","pipe","pipe"],windowsHide:c.windowsHide});r!==void 0&&u.stdin.write(r),u.stdin.end(),u.pid!==void 0&&t?.onPid?.(u.pid);let g="",y="",p="",m="";u.stdout.on("data",A=>{let v=A.toString();g+=v,p+=v;let k=p.split(`
|
|
39
35
|
`);p=k.pop()??"";for(let x of k)x.trim()&&t?.onOutput?.(x,"stdout");}),u.stderr.on("data",A=>{let v=A.toString();y+=v,m+=v;let k=m.split(`
|
|
40
36
|
`);m=k.pop()??"";for(let x of k)x.trim()&&t?.onOutput?.(x,"stderr");});let w=setTimeout(()=>{u.kill("SIGTERM"),i(new exports.ProviderError(`Plugin provider "${this.providerStr}" timed out after ${o}ms`,this.providerStr));},o);u.on("error",A=>{if(clearTimeout(w),A.code==="ENOENT"){let v=this.config.not_installed_message??`CLI command "${this.config.cli_command}" not found. Is ${this.config.id} installed?`;i(new exports.ProviderError(v,this.providerStr));}else i(new exports.ProviderError(`Spawn error: ${A.message}`,this.providerStr));}),u.on("close",A=>{clearTimeout(w),p.trim()&&t?.onOutput?.(p,"stdout"),m.trim()&&t?.onOutput?.(m,"stderr");let v=A??0;if(t?.onExitCode?.(v),this.config.error_patterns){let k=y||g;for(let x of this.config.error_patterns)if(k.includes(x.pattern)){i(new exports.ProviderError(x.message,this.providerStr));return}}if(A!==0){i(new exports.ProviderError(`Process exited with code ${A}: ${y.slice(0,500)}`,this.providerStr));return}s(g.trim());});})}};});l();l();l();function ko(n){let e=o=>o.replace(/[.+^${}()|[\]\\]/g,"\\$&"),r=n.split("/").map(o=>o==="**"?".*":o.split("*").map(e).join("[^/]*"));return new RegExp(`^${r.join("\\/")}$`)}function ie(n,e){try{return ko(e).test(n)}catch{return false}}l();l();var vo=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()),Kr=zod.z.object({include:zod.z.array(zod.z.string()).optional()}).optional(),_o=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:vo.optional(),skills:Kr}).catchall(zod.z.unknown()),Jr=zod.z.object({agents:zod.z.array(_o).optional(),hooks:zod.z.array(zod.z.unknown()).optional(),settings:zod.z.record(zod.z.unknown()).optional(),skills:zod.z.unknown().optional(),layouts:zod.z.record(zod.z.unknown()).optional(),documents:zod.z.record(zod.z.unknown()).optional()}).catchall(zod.z.unknown());var ve=class extends Error{constructor(t,r){super(t);this.cause=r;this.name="ConfigLoadError";}cause};function gt(n){if(!n||typeof n!="string"||!n.trim())throw new ve("YAML content must be a non-empty string");let e;try{e=jsYaml.load(n);}catch(o){throw new ve(`YAML parse error: ${o.message}`,o)}let t=Po(e),r=Jr.safeParse(t);if(!r.success)throw new ve(`Config validation error: ${r.error.message}`);return r.data}function mt(n){let e;try{e=fs$1.readFileSync(n,"utf-8");}catch(t){throw new ve(`Cannot read file: ${n}`,t)}return gt(e)}function Po(n){if(!n||typeof n!="object")return {agents:[]};let e=n,t;if(e.agents&&typeof e.agents=="object"&&!Array.isArray(e.agents)){let o=e.agents;t=Object.entries(o).map(([s,i])=>({id:s,...i&&typeof i=="object"?i:{}}));}else if(Array.isArray(e.agents))t=e.agents;else return {...e,agents:[]};let r=t.map(o=>{if(o.provider===void 0&&o.inline&&typeof o.inline=="object"){let s=o.inline;if(s.provider!==void 0)return {...o,provider:s.provider}}return o});return {...e,agents:r}}l();var _e=W.join("templates","agents");function bo(){try{let e=(typeof z=="function"?z:module$1.createRequire(typeof __filename<"u"?__filename:process.cwd()+"/")).resolve("@crewx/sdk/package.json");return W.dirname(e)}catch{return null}}function $e(n){if(n&&fs$1.existsSync(n))return n;let e=process.env.CREWX_SDK_TEMPLATES_PATH;if(e&&fs$1.existsSync(e))return e;let t=bo();if(t){let o=W.join(t,_e);if(fs$1.existsSync(o))return o}let r=[W.join(__dirname,"..",_e),W.join(__dirname,"..","..",_e),W.join(__dirname,"..","..","..",_e),W.join(process.cwd(),"packages","sdk",_e),W.join(process.cwd(),_e)];for(let o of r)if(fs$1.existsSync(o))return o;throw new Error(`[@crewx/sdk] Templates directory not found.
|
|
41
37
|
`+(t?` package anchor: ${W.join(t,_e)}
|
|
@@ -52,10 +48,10 @@ ${n??""}
|
|
|
52
48
|
---
|
|
53
49
|
`)}let s=(await e.readdir(n)).filter(a=>a.endsWith(".md"));if(s.length===0)return "";let i=[];for(let a of s){let d=e.resolvePath(n,a),c=await e.readFile(d),u=Rs.exec(c);!u||!Ps.test(u[1])||As.test(c)&&i.push(c);}return i.join(`
|
|
54
50
|
---
|
|
55
|
-
`)}l();function Cs(){let n=new Date,e=n.getFullYear(),t=String(n.getMonth()+1).padStart(2,"0"),r=String(n.getDate()).padStart(2,"0");return `${e}-${t}-${r}`}async function yn(n,e=Re){let t=e.resolvePath(n,`${Cs()}.md`);return await e.exists(t)?e.readFile(t):""}Fe();l();var rt=new async_hooks.AsyncLocalStorage;function pr(n){if(n)return {parentTaskId:n.parentTaskId??null,rootTraceId:n.rootTraceId,callerAgentId:n.callerAgentId??null}}l();function bs(n){return typeof n!="string"?"":n.replace(/</g,"<").replace(/>/g,">")}function gr(n){return n.messages.map(e=>({text:bs(e.text),isAssistant:e.isAssistant,timestamp:e.timestamp,metadata:e.metadata,files:void 0}))}l();l();var Es={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")},Ss={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 hn(n,e,t){n.tool("crewx_listAgents","List available CrewX agents exposed by this server",async()=>{let r=[];for(let o of t){let s=e.agents.get(o);s&&r.push({id:s.id,name:s.name??s.id,description:s.description??""});}return {content:[{type:"text",text:JSON.stringify(r,null,2)}]}}),n.tool("crewx_queryAgent","Query a CrewX agent with a read-only question",Es,async({agentId:r,query:o,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.query(r,o,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Query failed"}],isError:true}}),n.tool("crewx_executeAgent","Execute a task on a CrewX agent (may modify state)",Ss,async({agentId:r,task:o,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.execute(r,o,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Execute failed"}],isError:true}});}l();function wn(n){return n.headers.get("Origin")?null:new Response(JSON.stringify({error:"Forbidden: Origin header required"}),{status:403,headers:{"Content-Type":"application/json"}})}async function xn(n,e){return e?await e(n)?null:new Response(JSON.stringify({error:"Unauthorized"}),{status:401,headers:{"Content-Type":"application/json"}}):null}function Ms(n,e){let t=new mcp_js.McpServer({name:"crewx-mcp-server",version:"1.0.0"},{capabilities:{tools:{}}});return hn(t,n,e),t}function mr(n,e){if(!e.agents||e.agents.length===0)throw new Error("crewx.handler() requires at least one agent in the agents option");let t=new Set(e.agents),r=new Map;return async o=>{let s=wn(o);if(s)return s;let i=await xn(o,e.auth);if(i)return i;let a=o.headers.get("mcp-session-id");if(a&&r.has(a))return r.get(a).transport.handleRequest(o);let d=Ms(n,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(o)}}l();function vn(n){let e=W__namespace.resolve(n);return process.platform==="win32"&&(e=e.replace(/\\/g,"/"),e=e.replace(/^([A-Z]):/,(t,r)=>`${r.toLowerCase()}:`)),e.length>1&&!/^[a-zA-Z]:\/$/.test(e)&&(e=e.replace(/\/+$/,"")),e}function fr(n){let e=vn(n);return crypto$1.createHash("sha256").update(e).digest("hex")}function
|
|
56
|
-
${i.message}`)}let s=gt(o);if(s.documents&&typeof s.documents=="object"){let i={};for(let[a,d]of Object.entries(s.documents))if(d&&typeof d=="object"){let c=d;typeof c.path=="string"&&!W.isAbsolute(c.path)?i[a]={...c,path:W.resolve(r,c.path)}:i[a]=c;}else i[a]=d;return {...s,documents:i}}return s}static mergeCrewxConfig(e,t){let r=new Map;for(let k of e.agents??[])r.set(k.id,k);for(let k of t.agents??[])r.has(k.id)&&console.warn(`[agent-loader] User agent "${k.id}" overrides built-in`),r.set(k.id,k);let o=Array.from(r.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,d=t,c=Fn(a.vars,d.vars),u=Fn(a.settings,d.settings),g;e.skills&&t.skills&&typeof e.skills=="object"&&typeof t.skills=="object"&&!Array.isArray(e.skills)&&!Array.isArray(t.skills)?g={...e.skills,...t.skills}:g=t.skills??e.skills;let y=[...e.hooks??[],...t.hooks??[]],p=ui(a.providers,d.providers),m={...e},w={...t};for(let k of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete m[k],delete w[k];let v={...{...m,...w},agents:o,layouts:s,documents:i,skills:g};return y.length>0&&(v.hooks=y),c!==void 0&&(v.vars=c),u!==void 0&&(v.settings=u),p!==void 0&&(v.providers=p),v}static async loadYaml(e,t,r){let o=t?.includeBuiltIns!==false,s,i;if(o){let u=await n.loadBuiltInConfig(r);if(e!==void 0){let g=mt(e);s=n.mergeCrewxConfig(u,g),i=W.dirname(e);}else s=u,i=process.cwd();}else {if(e===void 0)throw new Error("[@crewx/sdk] loadYaml: path is required when includeBuiltIns is false");s=mt(e),i=W.dirname(e);}let a=new Pe(r);await a.load(s.documents,i);let d=s.agents??[];return await Hn(d,s,t),new n(d,t??{},s,a,i)}static async fromConfig(e,t,r,o){let s=t?.includeBuiltIns===true,i=e;if(s){let u=await n.loadBuiltInConfig(o);i=n.mergeCrewxConfig(u,e);}let a=new Pe(o);await a.load(i.documents,r??(typeof process<"u"?process.cwd():"/"));let d=i.agents??[];return await Hn(d,i,t),new n(d,t??{},i,a,r)}get agents(){return this._agents}get config(){return this._config}get plugins(){return this._plugins}get tools(){return this._tools}get workspaceId(){return this._workspaceId}get workspaceName(){return this._workspaceName}getAgent(e){let t=e.startsWith("@")?e.slice(1):e;return this._agents.get(t)}getRemoteProviderConfig(e){let t=this._config?.providers;return Array.isArray(t)?t.find(o=>o.type==="remote"&&o.id===e):void 0}computeTaskLogPath(e,t){let r=dr(t);return W.join(this._projectRoot,".crewx","logs",`${r}_${e}.log`)}registerTool(e,t){this._tools.set(e,{name:e,...t});}async use(e){this._plugins.includes(e)||(await e.attach(this),this._plugins.push(e));}handler(e){return mr(this,e)}async registerChannelAdapter(e){let{adapter:t,instanceId:r,config:o}=e;if(this._activeAdapters.has(r))throw new Error(`Adapter instance already registered: ${r}`);let s=new Set(t.manifest.capabilities),i=e.store??lr(r),a=e.defaultMode??"query",d=t.manifest.platform,c=e.agentRunner??{run:async(p,m,w)=>{let v=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${p}`,m,{threadId:w?.threadId,platform:d});return {output:v.ok?v.data:v.error?.message??""}}},u=e.onInbound??(async p=>{let m=p.routingHints?.agentId??e.defaultAgent;if(!m)return {accepted:false,reason:"no_agent"};let{output:w}=await c.run(m,p.text,{threadId:p.threadId});return {accepted:true,output:w}}),g=ur({instanceId:r,config:o,capabilities:s,db:i,agentRunner:c,onInbound:u}),y={adapter:t,ctx:g,state:"starting"};this._activeAdapters.set(r,y),this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"starting",timestamp:new Date});try{await t.start(g),y.state="started",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"started",timestamp:new Date});}catch(p){throw y.state="failed",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"failed",error:p instanceof Error?p:new Error(String(p)),timestamp:new Date}),this._activeAdapters.delete(r),p}}async unregisterChannelAdapter(e){let t=this._activeAdapters.get(e);if(t){t.state="stopping",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopping",timestamp:new Date});try{await t.adapter.stop(t.ctx),t.state="stopped",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopped",timestamp:new Date});}catch(r){t.state="failed",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"failed",error:r instanceof Error?r:new Error(String(r)),timestamp:new Date});}finally{this._activeAdapters.delete(e);}}}async stopAllAdapters(e={}){let t=e.timeoutMs??1e4,r=Array.from(this._activeAdapters.keys()),o=await Promise.allSettled(r.map(s=>Promise.race([this.unregisterChannelAdapter(s),new Promise((i,a)=>setTimeout(()=>a(new Error(`Adapter stop timeout: ${s}`)),t))])));for(let s=0;s<o.length;s++)o[s].status==="rejected"&&console.error(`[crewx] adapter stop error (${r[s]}): ${o[s].reason}`);}async close(){await this.stopAllAdapters({timeoutMs:1e4});let e=[...this._remoteTargets.values()];this._remoteTargets.clear(),await Promise.allSettled(e.map(async r=>{try{await(await r).close();}catch(o){console.error(`[crewx] remote target close error: ${o instanceof Error?o.message:String(o)}`);}}));let t=[...this._plugins].reverse();for(let r of t)try{await r.detach(this);}catch(o){console.error(`[crewx] plugin ${r.name} detach error: ${o instanceof Error?o.message:String(o)}`);}this._plugins.length=0;}filterAgents(e){let t=a=>a?a.split(",").map(d=>d.trim().toLowerCase()).filter(Boolean):void 0,r=t(e.role),o=t(e.team),s=t(e.provider),i=Array.from(this._agents.values());return r&&(i=i.filter(a=>a.role&&r.some(d=>ie(a.role.toLowerCase(),d)))),o&&(i=i.filter(a=>a.team&&o.some(d=>ie(a.team.toLowerCase(),d)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(c=>s.some(u=>ie(c.toLowerCase(),u))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,r=this._agents.get(t);if(!r)throw new ce(t,Array.from(this._agents.keys()));return r.inline?.prompt??r.inline?.system_prompt??r.description??`You are an expert ${t}.`}async renderPrompt(e,t){let o={...await this._documentLoader.buildContext(),...t?.documents??{}},s={...t,documents:o};return this._templateEngine.render(e,s)}registerLayout(e,t){this._layoutLoader.registerLayout(e,t);}async renderAgentPromptFull(e,t){let r=e.startsWith("@")?e.slice(1):e,o=this._agents.get(r);if(!o)throw new ce(r,Array.from(this._agents.keys()));let s=this._resolveLayoutSpec(o,t?.layout),i=this._extractLayoutId(s),a=this._extractLayoutProps(o,s,t?.layout),d=this._layoutLoader.load(i,a),c=o.inline?.prompt??o.inline?.system_prompt??o.description??`You are an expert ${r}.`,u=await this._documentLoader.buildContext(),g=t?.env??(typeof process<"u"?process.env:{}),y=t?.vars?.security_key??ci(),p={...t?.vars??{},documents:u,env:g,agent:{id:o.id,name:o.name??o.id,role:o.role??"",team:o.team??"",description:o.description??""}},m=await this._templateEngine.render(c,p),w={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},A=o.provider,v=Array.isArray(A)?A:typeof A=="string"&&A.length>0?[A]:[],k=v.join(", ")||(typeof A=="string"?A:""),x=o.options,S=["goals","daily"],T={goals:false,daily:false},B;if(!Array.isArray(x)&&typeof x=="object"&&x!==null){let $=x;if("goals"in $){let U=$.goals;typeof U=="string"||Array.isArray(U)?T.goals=U:T.goals=!!U;}"daily"in $&&(T.daily=!!$.daily);let q={};for(let[U,_]of Object.entries($))S.includes(U)||(q[U]=_);if(Object.keys(q).length>0){let U=v.some(M=>M.startsWith("cli/")),_={};for(let[M,b]of Object.entries(q)){let R={};if(Array.isArray(b))U&&(R.rawArgs=b);else if(typeof b=="object"&&b!==null){let F=b;Object.keys(F).length>0&&(R.named=F);}(R.named||R.rawArgs&&R.rawArgs.length>0)&&(_[M]=R);}B=Object.keys(_).length>0?_:void 0;}}let L=Array.isArray(x)?x:void 0,P={};for(let[$,q]of Object.entries(u))P[$]={content:q.content??"",toc:q.toc,summary:q.summary,path:q.path};if(T.goals){let $=W.join(this._projectRoot,"docs","goal"),q=await fn($,void 0,T.goals);q&&(P.active_goals={content:q});}if(T.daily){let $=W.join(this._projectRoot,"docs","daily"),q=await yn($);q&&(P.today_daily={content:q});}let G={user_input:t?.vars?.user_input??void 0,agent:{id:o.id,name:o.name??o.id,role:o.role??"",team:o.team??"",description:o.description??"",provider:k,providerList:v,model:o.inline?.model,workingDirectory:o.working_directory??o.workingDirectory??".",inline:{...o.inline??{},prompt:m},specialties:o.specialties??[],capabilities:o.capabilities??[],remote:o.remote??null,optionsByMode:B,optionsArray:L},agentMetadata:{specialties:o.specialties??[],capabilities:o.capabilities??[],description:o.description??""},contextOptions:T,documents:P,skills:t?.skills??[],session:w,env:g,vars:{security_key:y,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:w.platform,mode:w.mode,thread_id:t?.threadId??"",now:Qe(new Date),messages:t?.messages??[],tools:this._tools.size>0?{list:Array.from(this._tools.values()).map($=>({name:$.name,description:$.description,parameters:$.parameters})),json:JSON.stringify(Array.from(this._tools.values()).map($=>({name:$.name,description:$.description,parameters:$.parameters})),null,2),count:this._tools.size}:null,metadata:{}};return this._layoutRenderer.render(d,G)}_filterToolsByMode(e){return e?e.map(t=>this._tools.get(t)).filter(t=>t!==void 0):Array.from(this._tools.values())}_resolveLayoutSpec(e,t){if(t!==void 0)return t;let r=e.inline?.layout;if(r!==void 0)return r;let o=this._config?.layouts?.default;return typeof o=="string"&&o?o:"crewx/default"}_extractLayoutId(e){if(typeof e=="string")return e;if("id"in e)return e.id;let t=`crewx/__inline_${Date.now()}`;return this._layoutLoader.registerLayout(t,e.template),t}_extractLayoutProps(e,t,r){let o=e.inline?.layout,s=o&&typeof o=="object"&&"props"in o?o.props:void 0,i=r&&typeof r=="object"&&"id"in r?r.props:void 0;if(s||i)return {...s??{},...i??{}}}_getConversationProvider(){return this._plugins.find(t=>t.name==="conversation")?.conversationProvider}async _fetchHistoryMessages(e,t,r){if(r&&r.length>0)return r;if(!e)return;let o=this._getConversationProvider();if(o)try{let s=await o.fetchHistory(e,{currentTraceId:t});return s.messages.length===0?void 0:gr(s)}catch{return}}_resolveTimeout(e){let t=tn();return e==="query"?t.queryMs:t.executeMs}emitToolEvents(e,t,r,o,s,i,a){try{let c=exports.BUILTIN_ADAPTERS[r]?.parseEvent?.(o)??er(new Date().toISOString(),o);for(let u of c)u.type==="tool_use"&&u.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName,rawName:u.toolName,input:u.toolInput?this.tryParseJson(u.toolInput):void 0,toolUseId:u.toolUseId}}),u.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName??"unknown",rawName:u.toolName??"unknown",toolUseId:u.toolUseId,result:u.resultPreview,isError:u.isError}});}catch{}}emitTaskLogEntries(e,t,r,o,s,i,a){try{for(let d of a)d.type==="tool_use"&&d.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:o,sessionId:s,provider:i,tool:{name:d.toolName,rawName:d.toolName,input:d.toolInput?this.tryParseJson(d.toolInput):void 0,toolUseId:d.toolUseId}}),d.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:o,sessionId:s,provider:i,tool:{name:d.toolName??"unknown",rawName:d.toolName??"unknown",toolUseId:d.toolUseId,result:d.resultPreview,isError:d.isError}});}catch{}}tryParseJson(e){try{return JSON.parse(e)}catch{return e}}async query(e,t,r){let o=await this.resolveFileRemoteTarget(e);if(o)return o.target.query(o.agentRef,t,r);let s=rt.getStore()??pr(r?.trace),i=r?.taskId??Te("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return rt.run(d,async()=>{let c=Date.now(),u=new Date,g;try{g=yt(e,Array.from(this._agents.values()));}catch(_){if(_ instanceof ce){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"AGENT_NOT_FOUND",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:M}}}throw _}d.callerAgentId=g.id;let y=Array.isArray(g.provider)?g.provider[0]??"cli/claude":g.provider,p=r?.provider??y,m=r?.model??g.inline?.model;m&&m.includes("{{")&&(m=await this._templateEngine.render(m,{...r?.vars??{}}));let w;try{w=pe(p);}catch(_){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"PROVIDER_ERROR",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M}}}let A=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),v;try{v=await this.renderAgentPromptFull(e,{session:{mode:"query",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:A,threadId:r?.threadId});}catch(_){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${_ instanceof Error?_.message:String(_)}`);}let k,x,S,T=m,B=false,L=_=>{B||(B=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",pid:_,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:T,provider:p,codingAgentCommand:k,renderedPrompt:v,metadata:{...r?.metadata??{},provider:p},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},P=g.options,H=Array.isArray(P?.query?.tools)?P.query.tools:void 0,G=this._tools.size>0?this._filterToolsByMode(H):[],$=(()=>{let _=P?.query;if(!_||Array.isArray(_))return;let{tools:M,effort:b,mode:R,...F}=_,Y=Object.entries(F).filter(([,K])=>K!=null);if(Y.length!==0)return Object.fromEntries(Y.map(([K,qt])=>[K,String(qt)]))})(),q=g.inline?.max_steps;p.startsWith("api/")&&L();let U=false;try{let _=await w.query(t,{model:m,effort:P?.query?.effort,mode:P?.query?.mode,context:r?.context,systemPrompt:v??g.inline?.system_prompt??g.inline?.prompt??g.description??`You are ${g.id}.`,additionalArgs:Array.isArray(P?.query)?P.query:void 0,tools:G.length>0?G:void 0,maxSteps:q,configOptions:$,timeoutMs:this._resolveTimeout("query"),cwd:r?.cwd,env:{CREWX_AGENT_ID:g.id,CREWX_AGENT_ROLE:g.role??"",CREWX_AGENT_TEAM:g.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:p,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,u)},onPid:R=>L(R),onOutput:(R,F)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:R,level:F}),F==="stdout"&&this.emitToolEvents(i,e,p,R,g.id,r?.threadId??"","");},onTaskLog:R=>{this.emitTaskLogEntries(i,e,g.id,r?.threadId??"","",p,R);for(let F of R)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(F),level:"info"});},onCommand:R=>{k=R;},onUsage:R=>{x=R;},onExitCode:R=>{S=R;},onModel:R=>{T||(T=R);}});L();let M=Date.now()-c,b={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:_,durationMs:M,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:Object.keys(b).length>0?b:void 0}),U=!0,{ok:!0,data:_,meta:{agentId:g.id,provider:p,model:m,durationMs:M,taskId:i}}}catch(_){if(_ instanceof exports.ClientToolCallRequiredError){let R=Te("thd");return this._pendingThreads.set(R,{agentRef:g.id,providerStr:p,continuationState:_.continuationState,toolCall:_.toolCall,traceId:i,startMs:c,model:m}),U=true,{ok:true,status:"requires_action",data:"",toolCall:_.toolCall,threadId:R,meta:{agentId:g.id,provider:p,model:m,durationMs:Date.now()-c,taskId:i}}}L();let M=Date.now()-c,b={code:"QUERY_FAILED",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:M,error:b,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:r?.metadata?{...r.metadata}:void 0}),U=true,{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M,taskId:i}}}finally{U||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:Date.now()-c,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:S??-1,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T});}})}async continueQuery(e,t){let r=this._pendingThreads.get(e);if(!r)return {ok:false,data:"",error:{code:"THREAD_NOT_FOUND",message:`No pending thread: ${e}`},meta:{agentId:"",provider:"",durationMs:0}};this._pendingThreads.delete(e);let o=pe(r.providerStr);if(!o.continueWithToolResults)return {ok:false,data:"",error:{code:"UNSUPPORTED",message:"Provider does not support client tool continuation"},meta:{agentId:r.agentRef,provider:r.providerStr,durationMs:0}};let s=t.map(i=>({...i,toolName:r.toolCall.toolCallId===i.toolCallId?r.toolCall.toolName:i.toolCallId}));try{let i=await o.continueWithToolResults(r.continuationState,s),a=Date.now()-r.startMs;return this.emit("task:end",{traceId:r.traceId,timestamp:new Date,agentRef:r.agentRef,mode:"query",result:i,durationMs:a}),{ok:!0,status:"complete",data:i,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}catch(i){if(i instanceof exports.ClientToolCallRequiredError)return this._pendingThreads.set(e,{...r,continuationState:i.continuationState,toolCall:i.toolCall}),{ok:true,status:"requires_action",data:"",toolCall:i.toolCall,threadId:e,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:Date.now()-r.startMs}};let a=Date.now()-r.startMs;return {ok:false,data:"",error:{code:"CONTINUE_FAILED",message:i.message},meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}}async execute(e,t,r){let o=await this.resolveFileRemoteTarget(e);if(o)return o.target.execute(o.agentRef,t,r);let s=rt.getStore()??pr(r?.trace),i=r?.taskId??Te("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return rt.run(d,async()=>{let c=Date.now(),u=new Date,g;try{g=yt(e,Array.from(this._agents.values()));}catch(_){if(_ instanceof ce){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"AGENT_NOT_FOUND",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:M}}}throw _}d.callerAgentId=g.id;let y=Array.isArray(g.provider)?g.provider[0]??"cli/claude":g.provider,p=r?.provider??y,m=r?.model??g.inline?.model;m&&m.includes("{{")&&(m=await this._templateEngine.render(m,{...r?.vars??{}}));let w;try{w=pe(p);}catch(_){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"PROVIDER_ERROR",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M}}}let A=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),v;try{v=await this.renderAgentPromptFull(e,{session:{mode:"execute",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:A,threadId:r?.threadId});}catch(_){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${_ instanceof Error?_.message:String(_)}`);}let k,x,S,T=m,B=false,L=_=>{B||(B=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",pid:_,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:T,provider:p,codingAgentCommand:k,renderedPrompt:v,metadata:{...r?.metadata??{},provider:p},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},P=g.options,H=Array.isArray(P?.execute?.tools)?P.execute.tools:void 0,G=this._tools.size>0?this._filterToolsByMode(H):[],$=(()=>{let _=P?.execute;if(!_||Array.isArray(_))return;let{tools:M,effort:b,mode:R,...F}=_,Y=Object.entries(F).filter(([,K])=>K!=null);if(Y.length!==0)return Object.fromEntries(Y.map(([K,qt])=>[K,String(qt)]))})(),q=g.inline?.max_steps;p.startsWith("api/")&&L();let U=false;try{let _=await w.execute(t,{model:m,effort:P?.execute?.effort,mode:P?.execute?.mode,context:r?.context,systemPrompt:v??g.inline?.system_prompt??g.inline?.prompt??g.description??`You are ${g.id}.`,additionalArgs:Array.isArray(P?.execute)?P.execute:void 0,tools:G.length>0?G:void 0,maxSteps:q,configOptions:$,timeoutMs:this._resolveTimeout("execute"),cwd:r?.cwd,env:{CREWX_AGENT_ID:g.id,CREWX_AGENT_ROLE:g.role??"",CREWX_AGENT_TEAM:g.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:p,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,u)},onPid:R=>L(R),onOutput:(R,F)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:R,level:F}),F==="stdout"&&this.emitToolEvents(i,e,p,R,g.id,r?.threadId??"","");},onTaskLog:R=>{this.emitTaskLogEntries(i,e,g.id,r?.threadId??"","",p,R);for(let F of R)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(F),level:"info"});},onCommand:R=>{k=R;},onUsage:R=>{x=R;},onExitCode:R=>{S=R;},onModel:R=>{T||(T=R);}});L();let M=Date.now()-c,b={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:_,durationMs:M,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:Object.keys(b).length>0?b:void 0}),U=!0,{ok:!0,data:_,meta:{agentId:g.id,provider:p,model:m,durationMs:M,taskId:i}}}catch(_){L();let M=Date.now()-c,b={code:"EXECUTE_FAILED",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:M,error:b,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:r?.metadata?{...r.metadata}:void 0}),U=true,{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M}}}finally{U||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:Date.now()-c,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:S??-1,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T});}})}};function Fn(n,e){let t=Or(n)?n:void 0,r=Or(e)?e:void 0;if(!(!t&&!r))return {...t??{},...r??{}}}function Or(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function ui(n,e){let t=Array.isArray(n)?n:void 0,r=Array.isArray(e)?e:void 0;if(!t&&!r)return;let o=a=>{if(!Or(a))return;let d=a.id;if(typeof d=="string")return `id:${d}`;let c=a.name;if(typeof c=="string")return `name:${c}`},s=new Set;for(let a of r??[]){let d=o(a);d&&s.add(d);}let i=[];for(let a of t??[]){let d=o(a);d&&s.has(d)||i.push(a);}for(let a of r??[])i.push(a);return i}async function Hn(n,e,t){if(n.some(o=>(Array.isArray(o.provider)?o.provider:[o.provider]).some(i=>i.startsWith("api/")))){let{registerApiProviders:o}=await Promise.resolve().then(()=>(hr(),Pn));o(t?.api);}gi(n,e),mi(n,e),pi(n);}function pi(n){if(!n.some(r=>(Array.isArray(r.provider)?r.provider:[r.provider]).some(s=>s.startsWith("acp/"))))return;let{registerAcpProviders:t}=(Pr(),Wt(In));t();}function gi(n,e){if(!n.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("remote/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createRemoteProviderFactory:o}=(br(),Wt(Mn)),s=new Map;for(let i of r)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&ue("remote",o(s,pe));}function mi(n,e){if(!n.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("plugin/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createPluginProviderFactory:o}=(Er(),Wt(Ln)),s=new Map;for(let i of r)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&ue("plugin",o(s));}l();var Mr=class{detach(e){}};l();var fi="crewx:fs:",Nr=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("/"),o=[];for(let i of r)i==="."||i===""||(i===".."?o.pop():o.push(i));let s=o.join("/");return t.startsWith("/")?`/${s}`:s}isAbsolute(e){return e.startsWith("/")}setItem(e,t){this.store.set(this.toKey(e),t);}removeItem(e){this.store.delete(this.toKey(e));}keys(){return Array.from(this.store.keys()).filter(e=>e.startsWith(this.prefix)).map(e=>e.slice(this.prefix.length))}async readdir(e){let t=e.replace(/\\/g,"/").replace(/\/$/,""),r=this.toKey(t+"/"),o=[];for(let s of this.store.keys())if(s.startsWith(r)){let a=s.slice(r.length).split("/")[0];a&&!o.includes(a)&&o.push(a);}return o}toKey(e){return `${this.prefix}${e.replace(/\\/g,"/")}`}};l();function yi(n,e){let t=n.skills?.include;if(t===void 0)return [...e];if(t.length===0)return [];let r=new Set(t);return e.filter(o=>r.has(o))}ae();yr();hr();l();xr();xe();l();Ct();Mt();bt();function hi(n,e,t,r){let o=t.agentInfo?.name,s=e??o??n,a=(r.modes?.availableModes??[]).map(m=>({id:m.id,name:m.name,...m.description!=null?{description:m.description}:{}})),d=[],c=r.configOptions??[];for(let m of c)if(m.category==="thought_level"&&m.type==="select"){let w=m.options??[];if(w.length>0&&w[0]?.group!=null)for(let A of w)for(let v of A.options??[])d.push(v.value);else for(let A of w)A.value!=null&&d.push(A.value);}let u=r.models?.availableModels??[],g=n==="claude"?En.map(m=>({id:m.id,name:m.name})):u.map(m=>({id:m.modelId})),y=t.agentCapabilities??{},p={loadSession:y.loadSession??false,image:y.promptCapabilities?.image??false,audio:y.promptCapabilities?.audio??false,mcp:y.mcpCapabilities!=null};return {id:`acp/${n}`,name:s,modes:a,effort:d,models:g,capabilities:p}}async function qn(n){let e=exports.ACP_ADAPTERS[n];if(!e)return null;let t=e.meta?.displayName,r=new exports.AcpConnection({spawn:e.spawn,cwd:process.cwd()});try{await r.connect(e.clientInfo);let o=r.initResponse;if(!o)return null;let s=e.buildSessionParams({cwd:process.cwd()}),i=await r.newSessionRaw(s);return hi(n,t,o,i)}catch{return null}finally{await r.dispose();}}async function wi(){let n=Object.keys(exports.ACP_ADAPTERS),e=await Promise.allSettled(n.map(r=>qn(r))),t=[];for(let r of e)r.status==="fulfilled"&&r.value!==null&&t.push(r.value);return t}Ct();kr();Mt();Pr();Vt();Fe();l();var Dr=0;function xi(n){let e=Array.from(n.agents.keys());return {name:"delegate_to_agent",description:`Delegate a task to another agent. Available agents: ${e.join(", ")}`,parameters:{type:"object",properties:{agent:{type:"string",description:`Agent ID to delegate to. One of: ${e.join(", ")}`},message:{type:"string",description:"Task description for the target agent"},mode:{type:"string",description:'Execution mode: "query" for questions, "execute" for actions. Default: query'}},required:["agent","message"]},execute:async t=>{if(Dr>=3)return "Error: Maximum delegation depth (3) reached. Cannot delegate further.";let r=t.agent,o=t.message,s=t.mode??"query";if(!e.includes(r))return `Error: Unknown agent "${r}". Available: ${e.join(", ")}`;Dr++;try{if(s==="execute"){let a=await n.execute(r,o);return a.ok?a.data:`Error: ${a.error?.message??"Unknown error"}`}let i=await n.query(r,o);return i.ok?i.data:`Error: ${i.error?.message??"Unknown error"}`}finally{Dr--;}}}}l();var Bn=typeof process<"u"?process.env:{};function ki(){return Bn.CREWX_CLI||"npx crewx"}function vi(){return Bn.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}l();var _i=/^[a-zA-Z0-9._-]+$/,$r=class{constructor(e){this.storage=e;}storage;listBoxes(e){this.validateId(e);let r=this.storage.listBoxes(e).map(o=>this.toBoxResponse(o));return {boxes:r,total:r.length}}getBox(e,t){this.validateId(e),this.validateId(t);let r=this.storage.findBox(e,t);return r?this.toBoxResponse(r):null}createBox(e,t){this.validateId(e);let r=this.generateBoxId(),o=new Date().toISOString(),s=this.storage.insertBox(e,{id:r,seq:t.seq,firstTaskId:t.firstTaskId,midTaskId:t.midTaskId,lastTaskId:t.lastTaskId,taskCount:t.taskCount,summary:t.summary??null,sourceTokens:t.sourceTokens,summaryTokens:t.summaryTokens??null,createdAt:o});return this.toBoxResponse(s)}toBoxResponse(e){return {id:e.id,threadId:e.thread_id,seq:e.seq,firstTaskId:e.first_task_id,lastTaskId:e.last_task_id,taskCount:e.task_count,sourceTokens:e.source_tokens,summaryTokens:e.summary_tokens,summary:e.summary,previewFirst:this.storage.getTaskPreview(e.first_task_id,200),previewMid:this.storage.getTaskPreview(e.mid_task_id,200),previewLast:this.storage.getTaskPreview(e.last_task_id,200),createdAt:e.created_at}}validateId(e){if(!_i.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return Te("box")}};l();function Ai(n,e,t,r,o){let{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}=r,d=s*i,c=s*a,u=d+c,g=e.getThreadMessages(n),y=[],p=0,m=false,w=[];for(let k=0;k<g.length;k+=2){let x=g[k],S=g[k+1],T=x?.content||"",B=S?.content||"",L=o.countTokens(T+B),P=[];x&&P.push(x),S&&P.push(S),w.push({messages:P,tokens:L});}for(let k=w.length-1;k>=0;k--){let x=w[k];if(p+x.tokens>d){m=true;break}p+=x.tokens,y.unshift(...x.messages);}let A=[],v=0;if(m&&c>0)try{let{boxes:k}=t.listBoxes(n);for(let x=k.length-1;x>=0;x--){let S=k[x],T=S.summaryTokens??S.sourceTokens;if(v+T>c)break;v+=T,A.unshift({boxId:S.id,seq:S.seq,taskCount:S.taskCount,sourceTokens:S.sourceTokens,summary:S.summary,previewFirst:S.previewFirst,previewMid:S.previewMid,previewLast:S.previewLast,createdAt:S.createdAt});}}catch(k){if(k instanceof Error&&!/not found/i.test(k.message))throw k}return {hot:y,warm:A,hotTokens:p,warmTokens:v,hotOverflow:m,totalBudget:u,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}Fe();Ae();l();var Nt=class extends Error{constructor(t,r){super(`Task ${t} timed out after ${r}ms`);this.taskId=t;this.timeoutMs=r;this.name="ParallelRunnerTimeoutError";}taskId;timeoutMs},ct=class{constructor(e={}){this.defaults=e;}defaults;metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0};async run(e,t={}){if(!Array.isArray(e))throw new TypeError("ParallelRunner.run expects an array of tasks");if(e.length===0)return this.metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0},[];let r=this.mergeOptions(t),o=Math.max(1,r.maxConcurrency??5),s=r.timeoutMs,i=r.failFast??false,a=r.callbacks,d=r.evaluateTaskSuccess??(()=>true),c=[],u=0,g=0,y=0,p=false,m=0,w=perf_hooks.performance.now(),A=async P=>{a?.onTaskStart&&await a.onTaskStart(P),y+=1;let H=new AbortController,G={signal:H.signal},$,q;typeof s=="number"&&Number.isFinite(s)&&s>0&&(q=new Promise((b,R)=>{$=setTimeout(()=>{let F=new Nt(P.id,s);H.abort(F),R(F);},s);}));let U=perf_hooks.performance.now(),_=P.run(G),M=q?Promise.race([_,q]):_;try{let b=await M,R=perf_hooks.performance.now(),F=R-U,Y=d(b,P),K={taskId:P.id,success:Y,value:b,durationMs:F,startedAt:U,finishedAt:R,metadata:P.metadata,aborted:!1};c.push(K),Y?u+=1:g+=1,a?.onTaskComplete&&await a.onTaskComplete(K),i&&!Y&&(p=!0);}catch(b){let R=perf_hooks.performance.now(),F=R-U,Y=b instanceof Error?b:new Error(String(b)),K={taskId:P.id,success:false,error:Y,durationMs:F,startedAt:U,finishedAt:R,metadata:P.metadata,aborted:H.signal.aborted};c.push(K),g+=1,a?.onError&&await a.onError(P,Y,F),i&&(p=true);}finally{$&&clearTimeout($),q&&_.catch(()=>{});}},v=async()=>{for(;!p;){let P=m;if(P>=e.length)break;m+=1;let H=e[P];if(!H||(await A(H),p))break}},k=Math.min(o,e.length),x=[];for(let P=0;P<k;P++)x.push(v());await Promise.all(x);let T=perf_hooks.performance.now()-w,B=c.length?c.reduce((P,H)=>P+H.durationMs,0)/c.length:0,L=T>0?c.length/(T/1e3):c.length;return this.metrics={totalTasks:e.length,startedTasks:y,completedTasks:c.length,successCount:u,failureCount:g,totalDurationMs:T,averageDurationMs:B,throughput:L},c}getMetrics(){return this.metrics}mergeOptions(e){return {maxConcurrency:e.maxConcurrency??this.defaults.maxConcurrency,timeoutMs:e.timeoutMs??this.defaults.timeoutMs,failFast:e.failFast??this.defaults.failFast,evaluateTaskSuccess:e.evaluateTaskSuccess??this.defaults.evaluateTaskSuccess,callbacks:this.mergeCallbacks(this.defaults.callbacks,e.callbacks)}}mergeCallbacks(e,t){if(!(!e&&!t))return {onTaskStart:async r=>{e?.onTaskStart&&await e.onTaskStart(r),t?.onTaskStart&&await t.onTaskStart(r);},onTaskComplete:async r=>{e?.onTaskComplete&&await e.onTaskComplete(r),t?.onTaskComplete&&await t.onTaskComplete(r);},onError:async(r,o,s)=>{e?.onError&&await e.onError(r,o,s),t?.onError&&await t.onError(r,o,s);}}}};l();l();var ut=class{async query(e){throw new Error("AgentRuntime.query is not implemented. Provide a subclass or mock AgentRuntime.prototype.query.")}async execute(e){throw new Error("AgentRuntime.execute is not implemented. Provide a subclass or mock AgentRuntime.prototype.execute.")}};var Wn=3,zn=3e4,Vn=500,Ri=n=>{if(typeof n!="number"||Number.isNaN(n)||!Number.isFinite(n))return Wn;let e=Math.floor(n);return e>0?e:Wn},Pi=n=>n===void 0||typeof n!="number"||Number.isNaN(n)||n<=0?zn:n,Ci=n=>{if(!n)return {maxRetries:0,retryDelay:Vn};let e=Number.isInteger(n.maxRetries)&&n.maxRetries>=0?n.maxRetries:0,t=typeof n.retryDelay=="number"&&n.retryDelay>=0?n.retryDelay:Vn;return {maxRetries:e,retryDelay:t}},Lr=n=>{let e=n.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},Ti=(n,e)=>n<=0?Promise.resolve():new Promise((t,r)=>{let o=setTimeout(()=>{e.removeEventListener("abort",s),t();},n),s=()=>{clearTimeout(o),r(Lr(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),bi=async(n,e,t)=>{let r,o;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw Lr(t);try{let i=await n();if(r=i,i.success||s===e.maxRetries)return i}catch(i){if(o=i,t.aborted)throw Lr(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await Ti(e.retryDelay,t);}if(r)return r;throw o?o instanceof Error?o:new Error(String(o)):new Error("Parallel helper encountered an unexpected state")},Kn=(n,e,t)=>{e.completed+=1,t?e.success+=1:e.failure+=1;try{n.onProgress?.(e.completed,e.total);}catch(r){process.env.NODE_ENV!=="production"&&console.warn("Parallel helper onProgress callback threw an error:",r);}},Ei=n=>n.map(t=>({metadata:t.metadata,taskResult:t})).slice().sort((t,r)=>t.metadata.index-r.metadata.index).map(({metadata:t,taskResult:r})=>{if(r.value){let s=r.value;return {...s,agentId:s.agentId??t.request.agentId,metadata:{...s.metadata,requestIndex:t.index,mode:t.mode}}}let o=r.error??new Error("Unknown error");return {agentId:t.request.agentId,content:o.message,success:false,metadata:{error:o.message,aborted:r.aborted??false,requestIndex:t.index,mode:t.mode}}}),Si=n=>n.filter(e=>!e.success).map(e=>{let t=e.metadata;if(e.error instanceof Error)return {index:t.index,error:e.error};if(e.value&&!e.value.success){let r=String(e.value.metadata?.error??e.value.content??"Agent returned unsuccessful result");return {index:t.index,error:new Error(r)}}return {index:t.index,error:new Error("Unknown failure")}}),Ii=(n,e)=>({onTaskComplete:async t=>{Kn(e,n,t.success);},onError:async()=>{Kn(e,n,false);}}),Jn=async(n,e,t={})=>{if(!Array.isArray(n))throw new TypeError("Parallel helpers expect an array of requests");if(n.length===0){let A={total:0,completed:0,successCount:0,failureCount:0,results:[],errors:[],metrics:{totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0}};return t.onComplete?.(A),[]}let r=Ri(t.concurrency),o=Pi(t.timeout),s=Ci(t.retryPolicy),i=new ct,a=new ut,d=n.map((w,A)=>({id:`${e}:${w.agentId??"anonymous"}:${A}`,metadata:{index:A,mode:e,request:w},run:v=>bi(()=>e==="query"?a.query(w):a.execute(w),s,v.signal)})),c={completed:0,success:0,failure:0,total:n.length},u=await i.run(d,{maxConcurrency:r,timeoutMs:o,evaluateTaskSuccess:w=>w.success,callbacks:Ii(c,t)}),g=Ei(u),y=Si(u),p=i.getMetrics(),m={total:n.length,completed:n.length,successCount:g.filter(w=>w.success).length,failureCount:g.filter(w=>!w.success).length,results:g,errors:y,metrics:p};return t.onComplete?.(m),g},Oi=(n,e)=>Jn(n,"query",e),Mi=(n,e)=>Jn(n,"execute",e);Er();l();l();var qe=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:W.join($i__default.default.homedir(),".crewx","crewx.db")}resolveDbPaths(){return [this.resolveDbPath()]}isMissingTableError(e){return e instanceof Error&&/no such table:/i.test(e.message)}dbExists(e){return fs$1.existsSync(e??this.resolveDbPath())}};l();function fe(n){let e=z("better-sqlite3"),{drizzle:t}=z("drizzle-orm/better-sqlite3"),r=new e(n);return r.exec("PRAGMA journal_mode = WAL"),r.exec("PRAGMA busy_timeout = 5000"),r.exec("PRAGMA foreign_keys = ON"),{db:t(r),runRaw:(o,s=[])=>r.prepare(o).run(...s),close:()=>r.close()}}l();var Gn=new Set,ji={agent_id:"TEXT",status:"TEXT DEFAULT 'running'",started_at:"TEXT",trace_id:"TEXT",parent_task_id:"TEXT",crewx_version:"TEXT",pid:"INTEGER",thread_id:"TEXT",workspace_id:"TEXT",workspace_ref:"TEXT",workspace_name:"TEXT",project_id:"TEXT",project_name:"TEXT"};function Ui(n,e){return (n.get(`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='${e}'`)?.cnt??0)>0}function Fi(n,e){if(e>0||!Ui(n,"tasks"))return;let t=n.all("PRAGMA table_info(tasks)"),r=new Set(t.map(o=>o.name));for(let[o,s]of Object.entries(ji))r.has(o)||n.run(`ALTER TABLE tasks ADD COLUMN ${o} ${s}`);}function Hi(n,e,t){let r=n.all(t`SELECT hash FROM __drizzle_migrations`),o=new Set(r.map(i=>i.hash)),s=JSON.parse(fs$1.readFileSync(W__namespace.default.join(e,"meta/_journal.json"),"utf-8"));for(let i of s.entries){let a=W__namespace.default.join(e,`${i.tag}.sql`);if(!fs$1.existsSync(a))continue;let d=fs$1.readFileSync(a,"utf-8"),c=crypto$1.createHash("sha256").update(d).digest("hex");if(o.has(c))continue;let u=/ALTER\s+TABLE\s+[`"]?(\w+)[`"]?\s+ADD\s+[`"]?(\w+)[`"]?/gi,g=[],y;for(;(y=u.exec(d))!==null;)g.push({table:y[1],column:y[2]});if(g.length===0||!d.split(/-->\s*statement-breakpoint/).map(w=>w.trim()).filter(Boolean).every(w=>/^ALTER\s+TABLE\s+.+\s+ADD\s+/i.test(w)))continue;g.every(({table:w,column:A})=>n.all(`PRAGMA table_info("${w}")`).some(k=>k.name===A))&&n.run(t`INSERT INTO __drizzle_migrations (hash, created_at) VALUES (${c}, ${i.when})`);}}function qi(n){let{migrate:e}=z("drizzle-orm/better-sqlite3/migrator"),{sql:t}=z("drizzle-orm"),r=[W__namespace.default.join(__dirname,"../migrations"),W__namespace.default.join(__dirname,"migrations"),W__namespace.default.join(__dirname,"../../../../drizzle/migrations"),W__namespace.default.join(process.cwd(),"drizzle/migrations")],o=r.find(c=>fs$1.existsSync(W__namespace.default.join(c,"meta/_journal.json")));if(!o)throw new Error(`migrations folder not found. Searched:
|
|
51
|
+
`)}l();function Cs(){let n=new Date,e=n.getFullYear(),t=String(n.getMonth()+1).padStart(2,"0"),r=String(n.getDate()).padStart(2,"0");return `${e}-${t}-${r}`}async function yn(n,e=Re){let t=e.resolvePath(n,`${Cs()}.md`);return await e.exists(t)?e.readFile(t):""}Fe();l();var rt=new async_hooks.AsyncLocalStorage;function pr(n){if(n)return {parentTaskId:n.parentTaskId??null,rootTraceId:n.rootTraceId,callerAgentId:n.callerAgentId??null}}l();function bs(n){return typeof n!="string"?"":n.replace(/</g,"<").replace(/>/g,">")}function gr(n){return n.messages.map(e=>({text:bs(e.text),isAssistant:e.isAssistant,timestamp:e.timestamp,metadata:e.metadata,files:void 0}))}l();l();var Es={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")},Ss={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 hn(n,e,t){n.tool("crewx_listAgents","List available CrewX agents exposed by this server",async()=>{let r=[];for(let o of t){let s=e.agents.get(o);s&&r.push({id:s.id,name:s.name??s.id,description:s.description??""});}return {content:[{type:"text",text:JSON.stringify(r,null,2)}]}}),n.tool("crewx_queryAgent","Query a CrewX agent with a read-only question",Es,async({agentId:r,query:o,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.query(r,o,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Query failed"}],isError:true}}),n.tool("crewx_executeAgent","Execute a task on a CrewX agent (may modify state)",Ss,async({agentId:r,task:o,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.execute(r,o,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Execute failed"}],isError:true}});}l();function wn(n){return n.headers.get("Origin")?null:new Response(JSON.stringify({error:"Forbidden: Origin header required"}),{status:403,headers:{"Content-Type":"application/json"}})}async function xn(n,e){return e?await e(n)?null:new Response(JSON.stringify({error:"Unauthorized"}),{status:401,headers:{"Content-Type":"application/json"}}):null}function Ms(n,e){let t=new mcp_js.McpServer({name:"crewx-mcp-server",version:"1.0.0"},{capabilities:{tools:{}}});return hn(t,n,e),t}function mr(n,e){if(!e.agents||e.agents.length===0)throw new Error("crewx.handler() requires at least one agent in the agents option");let t=new Set(e.agents),r=new Map;return async o=>{let s=wn(o);if(s)return s;let i=await xn(o,e.auth);if(i)return i;let a=o.headers.get("mcp-session-id");if(a&&r.has(a))return r.get(a).transport.handleRequest(o);let d=Ms(n,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(o)}}l();function vn(n){let e=W__namespace.resolve(n);return process.platform==="win32"&&(e=e.replace(/\\/g,"/"),e=e.replace(/^([A-Z]):/,(t,r)=>`${r.toLowerCase()}:`)),e.length>1&&!/^[a-zA-Z]:\/$/.test(e)&&(e=e.replace(/\/+$/,"")),e}function fr(n){let e=vn(n);return crypto$1.createHash("sha256").update(e).digest("hex")}function ai(n){return n?n.settings?.template?.exec:void 0}function di(){try{let n=new Uint8Array(8);return globalThis.crypto.getRandomValues(n),Array.from(n,e=>e.toString(16).padStart(2,"0")).join("")}catch{let{randomBytes:n}=z("crypto");return n(8).toString("hex")}}var Ir=class n extends tt{_agents;_templateEngine;_documentLoader;_layoutLoader;_layoutRenderer;_config;_projectRoot;_workspaceId;_workspaceName;_plugins=[];_tools=new Map;_activeAdapters=new Map;_pendingThreads=new Map;_remoteFactory;_remoteTargets=new Map;constructor(e,t={},r,o,s){super(),this._agents=new Map(e.map(d=>[d.id,d])),this._config=r,this._projectRoot=s??(typeof process<"u"?process.cwd():"/");let i=s??(typeof process<"u"?process.env.CREWX_WORKSPACE??process.cwd():"/");this._workspaceId=fr(i),this._workspaceName=W.basename(i);let a=ai(r);this._templateEngine=new Ge({execPolicy:t.execPolicy??a}),this._documentLoader=o??new Pe,this._layoutLoader=new Ye({templatesPath:$e()}),this._layoutRenderer=new et,this._remoteFactory=t.remoteFactory;}async resolveFileRemoteTarget(e){let t=this.getAgent(e),r=Array.isArray(t?.provider)?t?.provider[0]:t?.provider;if(!r?.startsWith("remote/"))return null;let o=r.slice(7),s=this.getRemoteProviderConfig(o);if(!s?.location?.startsWith("file://"))return null;let i=W.resolve(s.location.replace("file://","")),a=s.external_agent_id??e.replace(/^@/,""),d=this._remoteTargets.get(i);d||(d=(this._remoteFactory??(p=>n.loadYaml(p)))(i),this._remoteTargets.set(i,d),d.catch(()=>this._remoteTargets.delete(i)));let c=await d,u=c.getAgent("@"+a),g=Array.isArray(u?.provider)?u?.provider[0]:u?.provider;if(g?.startsWith("remote/"))throw new Error(`Chained remotes not allowed: "${o}" \u2192 "${g}"`);return {target:c,agentRef:"@"+a}}static async loadBuiltInConfig(e){let{yamlPath:t,dir:r}=zt(),o;try{o=fs$1.readFileSync(t,"utf-8");}catch(i){throw new Error(`[@crewx/sdk] Cannot read built-in config: ${t}
|
|
52
|
+
${i.message}`)}let s=gt(o);if(s.documents&&typeof s.documents=="object"){let i={};for(let[a,d]of Object.entries(s.documents))if(d&&typeof d=="object"){let c=d;typeof c.path=="string"&&!W.isAbsolute(c.path)?i[a]={...c,path:W.resolve(r,c.path)}:i[a]=c;}else i[a]=d;return {...s,documents:i}}return s}static mergeCrewxConfig(e,t){let r=new Map;for(let k of e.agents??[])r.set(k.id,k);for(let k of t.agents??[])r.has(k.id)&&console.warn(`[agent-loader] User agent "${k.id}" overrides built-in`),r.set(k.id,k);let o=Array.from(r.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,d=t,c=Fn(a.vars,d.vars),u=Fn(a.settings,d.settings),g;e.skills&&t.skills&&typeof e.skills=="object"&&typeof t.skills=="object"&&!Array.isArray(e.skills)&&!Array.isArray(t.skills)?g={...e.skills,...t.skills}:g=t.skills??e.skills;let y=[...e.hooks??[],...t.hooks??[]],p=li(a.providers,d.providers),m={...e},w={...t};for(let k of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete m[k],delete w[k];let v={...{...m,...w},agents:o,layouts:s,documents:i,skills:g};return y.length>0&&(v.hooks=y),c!==void 0&&(v.vars=c),u!==void 0&&(v.settings=u),p!==void 0&&(v.providers=p),v}static async loadYaml(e,t,r){let o=t?.includeBuiltIns!==false,s,i;if(o){let u=await n.loadBuiltInConfig(r);if(e!==void 0){let g=mt(e);s=n.mergeCrewxConfig(u,g),i=W.dirname(e);}else s=u,i=process.cwd();}else {if(e===void 0)throw new Error("[@crewx/sdk] loadYaml: path is required when includeBuiltIns is false");s=mt(e),i=W.dirname(e);}let a=new Pe(r);await a.load(s.documents,i);let d=s.agents??[];return await Hn(d,s,t),new n(d,t??{},s,a,i)}static async fromConfig(e,t,r,o){let s=t?.includeBuiltIns===true,i=e;if(s){let u=await n.loadBuiltInConfig(o);i=n.mergeCrewxConfig(u,e);}let a=new Pe(o);await a.load(i.documents,r??(typeof process<"u"?process.cwd():"/"));let d=i.agents??[];return await Hn(d,i,t),new n(d,t??{},i,a,r)}get agents(){return this._agents}get config(){return this._config}get plugins(){return this._plugins}get tools(){return this._tools}get workspaceId(){return this._workspaceId}get workspaceName(){return this._workspaceName}getAgent(e){let t=e.startsWith("@")?e.slice(1):e;return this._agents.get(t)}getRemoteProviderConfig(e){let t=this._config?.providers;return Array.isArray(t)?t.find(o=>o.type==="remote"&&o.id===e):void 0}computeTaskLogPath(e,t){let r=dr(t);return W.join(this._projectRoot,".crewx","logs",`${r}_${e}.log`)}registerTool(e,t){this._tools.set(e,{name:e,...t});}async use(e){this._plugins.includes(e)||(await e.attach(this),this._plugins.push(e));}handler(e){return mr(this,e)}async registerChannelAdapter(e){let{adapter:t,instanceId:r,config:o}=e;if(this._activeAdapters.has(r))throw new Error(`Adapter instance already registered: ${r}`);let s=new Set(t.manifest.capabilities),i=e.store??lr(r),a=e.defaultMode??"query",d=t.manifest.platform,c=e.agentRunner??{run:async(p,m,w)=>{let v=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${p}`,m,{threadId:w?.threadId,platform:d});return {output:v.ok?v.data:v.error?.message??""}}},u=e.onInbound??(async p=>{let m=p.routingHints?.agentId??e.defaultAgent;if(!m)return {accepted:false,reason:"no_agent"};let{output:w}=await c.run(m,p.text,{threadId:p.threadId});return {accepted:true,output:w}}),g=ur({instanceId:r,config:o,capabilities:s,db:i,agentRunner:c,onInbound:u}),y={adapter:t,ctx:g,state:"starting"};this._activeAdapters.set(r,y),this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"starting",timestamp:new Date});try{await t.start(g),y.state="started",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"started",timestamp:new Date});}catch(p){throw y.state="failed",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"failed",error:p instanceof Error?p:new Error(String(p)),timestamp:new Date}),this._activeAdapters.delete(r),p}}async unregisterChannelAdapter(e){let t=this._activeAdapters.get(e);if(t){t.state="stopping",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopping",timestamp:new Date});try{await t.adapter.stop(t.ctx),t.state="stopped",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopped",timestamp:new Date});}catch(r){t.state="failed",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"failed",error:r instanceof Error?r:new Error(String(r)),timestamp:new Date});}finally{this._activeAdapters.delete(e);}}}async stopAllAdapters(e={}){let t=e.timeoutMs??1e4,r=Array.from(this._activeAdapters.keys()),o=await Promise.allSettled(r.map(s=>Promise.race([this.unregisterChannelAdapter(s),new Promise((i,a)=>setTimeout(()=>a(new Error(`Adapter stop timeout: ${s}`)),t))])));for(let s=0;s<o.length;s++)o[s].status==="rejected"&&console.error(`[crewx] adapter stop error (${r[s]}): ${o[s].reason}`);}async close(){await this.stopAllAdapters({timeoutMs:1e4});let e=[...this._remoteTargets.values()];this._remoteTargets.clear(),await Promise.allSettled(e.map(async r=>{try{await(await r).close();}catch(o){console.error(`[crewx] remote target close error: ${o instanceof Error?o.message:String(o)}`);}}));let t=[...this._plugins].reverse();for(let r of t)try{await r.detach(this);}catch(o){console.error(`[crewx] plugin ${r.name} detach error: ${o instanceof Error?o.message:String(o)}`);}this._plugins.length=0;}filterAgents(e){let t=a=>a?a.split(",").map(d=>d.trim().toLowerCase()).filter(Boolean):void 0,r=t(e.role),o=t(e.team),s=t(e.provider),i=Array.from(this._agents.values());return r&&(i=i.filter(a=>a.role&&r.some(d=>ie(a.role.toLowerCase(),d)))),o&&(i=i.filter(a=>a.team&&o.some(d=>ie(a.team.toLowerCase(),d)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(c=>s.some(u=>ie(c.toLowerCase(),u))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,r=this._agents.get(t);if(!r)throw new ce(t,Array.from(this._agents.keys()));return r.inline?.prompt??r.inline?.system_prompt??r.description??`You are an expert ${t}.`}async renderPrompt(e,t){let o={...await this._documentLoader.buildContext(),...t?.documents??{}},s={...t,documents:o};return this._templateEngine.render(e,s)}registerLayout(e,t){this._layoutLoader.registerLayout(e,t);}async renderAgentPromptFull(e,t){let r=e.startsWith("@")?e.slice(1):e,o=this._agents.get(r);if(!o)throw new ce(r,Array.from(this._agents.keys()));let s=this._resolveLayoutSpec(o,t?.layout),i=this._extractLayoutId(s),a=this._extractLayoutProps(o,s,t?.layout),d=this._layoutLoader.load(i,a),c=o.inline?.prompt??o.inline?.system_prompt??o.description??`You are an expert ${r}.`,u=await this._documentLoader.buildContext(),g=t?.env??(typeof process<"u"?process.env:{}),y=t?.vars?.security_key??di(),p={...t?.vars??{},documents:u,env:g,agent:{id:o.id,name:o.name??o.id,role:o.role??"",team:o.team??"",description:o.description??""}},m=await this._templateEngine.render(c,p),w={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},A=o.provider,v=Array.isArray(A)?A:typeof A=="string"&&A.length>0?[A]:[],k=v.join(", ")||(typeof A=="string"?A:""),x=o.options,S=["goals","daily"],T={goals:false,daily:false},B;if(!Array.isArray(x)&&typeof x=="object"&&x!==null){let $=x;if("goals"in $){let U=$.goals;typeof U=="string"||Array.isArray(U)?T.goals=U:T.goals=!!U;}"daily"in $&&(T.daily=!!$.daily);let q={};for(let[U,_]of Object.entries($))S.includes(U)||(q[U]=_);if(Object.keys(q).length>0){let U=v.some(M=>M.startsWith("cli/")),_={};for(let[M,b]of Object.entries(q)){let R={};if(Array.isArray(b))U&&(R.rawArgs=b);else if(typeof b=="object"&&b!==null){let F=b;Object.keys(F).length>0&&(R.named=F);}(R.named||R.rawArgs&&R.rawArgs.length>0)&&(_[M]=R);}B=Object.keys(_).length>0?_:void 0;}}let L=Array.isArray(x)?x:void 0,P={};for(let[$,q]of Object.entries(u))P[$]={content:q.content??"",toc:q.toc,summary:q.summary,path:q.path};if(T.goals){let $=W.join(this._projectRoot,"docs","goal"),q=await fn($,void 0,T.goals);q&&(P.active_goals={content:q});}if(T.daily){let $=W.join(this._projectRoot,"docs","daily"),q=await yn($);q&&(P.today_daily={content:q});}let G={user_input:t?.vars?.user_input??void 0,agent:{id:o.id,name:o.name??o.id,role:o.role??"",team:o.team??"",description:o.description??"",provider:k,providerList:v,model:o.inline?.model,workingDirectory:o.working_directory??o.workingDirectory??".",inline:{...o.inline??{},prompt:m},specialties:o.specialties??[],capabilities:o.capabilities??[],remote:o.remote??null,optionsByMode:B,optionsArray:L},agentMetadata:{specialties:o.specialties??[],capabilities:o.capabilities??[],description:o.description??""},contextOptions:T,documents:P,skills:t?.skills??[],session:w,env:g,vars:{security_key:y,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:w.platform,mode:w.mode,thread_id:t?.threadId??"",now:Qe(new Date),messages:t?.messages??[],tools:this._tools.size>0?{list:Array.from(this._tools.values()).map($=>({name:$.name,description:$.description,parameters:$.parameters})),json:JSON.stringify(Array.from(this._tools.values()).map($=>({name:$.name,description:$.description,parameters:$.parameters})),null,2),count:this._tools.size}:null,metadata:{}};return this._layoutRenderer.render(d,G)}_filterToolsByMode(e){return e?e.map(t=>this._tools.get(t)).filter(t=>t!==void 0):Array.from(this._tools.values())}_resolveLayoutSpec(e,t){if(t!==void 0)return t;let r=e.inline?.layout;if(r!==void 0)return r;let o=this._config?.layouts?.default;return typeof o=="string"&&o?o:"crewx/default"}_extractLayoutId(e){if(typeof e=="string")return e;if("id"in e)return e.id;let t=`crewx/__inline_${Date.now()}`;return this._layoutLoader.registerLayout(t,e.template),t}_extractLayoutProps(e,t,r){let o=e.inline?.layout,s=o&&typeof o=="object"&&"props"in o?o.props:void 0,i=r&&typeof r=="object"&&"id"in r?r.props:void 0;if(s||i)return {...s??{},...i??{}}}_getConversationProvider(){return this._plugins.find(t=>t.name==="conversation")?.conversationProvider}async _fetchHistoryMessages(e,t,r){if(r&&r.length>0)return r;if(!e)return;let o=this._getConversationProvider();if(o)try{let s=await o.fetchHistory(e,{currentTraceId:t});return s.messages.length===0?void 0:gr(s)}catch{return}}_resolveTimeout(e){let t=tn();return e==="query"?t.queryMs:t.executeMs}emitToolEvents(e,t,r,o,s,i,a){try{let c=exports.BUILTIN_ADAPTERS[r]?.parseEvent?.(o)??er(new Date().toISOString(),o);for(let u of c)u.type==="tool_use"&&u.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName,rawName:u.toolName,input:u.toolInput?this.tryParseJson(u.toolInput):void 0,toolUseId:u.toolUseId}}),u.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName??"unknown",rawName:u.toolName??"unknown",toolUseId:u.toolUseId,result:u.resultPreview,isError:u.isError}});}catch{}}emitTaskLogEntries(e,t,r,o,s,i,a){try{for(let d of a)d.type==="tool_use"&&d.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:o,sessionId:s,provider:i,tool:{name:d.toolName,rawName:d.toolName,input:d.toolInput?this.tryParseJson(d.toolInput):void 0,toolUseId:d.toolUseId}}),d.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:o,sessionId:s,provider:i,tool:{name:d.toolName??"unknown",rawName:d.toolName??"unknown",toolUseId:d.toolUseId,result:d.resultPreview,isError:d.isError}});}catch{}}tryParseJson(e){try{return JSON.parse(e)}catch{return e}}async query(e,t,r){let o=await this.resolveFileRemoteTarget(e);if(o)return o.target.query(o.agentRef,t,r);let s=rt.getStore()??pr(r?.trace),i=r?.taskId??Te("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return rt.run(d,async()=>{let c=Date.now(),u=new Date,g;try{g=yt(e,Array.from(this._agents.values()));}catch(_){if(_ instanceof ce){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"AGENT_NOT_FOUND",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:M}}}throw _}d.callerAgentId=g.id;let y=Array.isArray(g.provider)?g.provider[0]??"cli/claude":g.provider,p=r?.provider??y,m=r?.model??g.inline?.model;m&&m.includes("{{")&&(m=await this._templateEngine.render(m,{...r?.vars??{}}));let w;try{w=pe(p);}catch(_){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"PROVIDER_ERROR",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M}}}let A=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),v;try{v=await this.renderAgentPromptFull(e,{session:{mode:"query",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:A,threadId:r?.threadId});}catch(_){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${_ instanceof Error?_.message:String(_)}`);}let k,x,S,T=m,B=false,L=_=>{B||(B=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"query",pid:_,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:T,provider:p,codingAgentCommand:k,renderedPrompt:v,metadata:{...r?.metadata??{},provider:p},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},P=g.options,H=Array.isArray(P?.query?.tools)?P.query.tools:void 0,G=this._tools.size>0?this._filterToolsByMode(H):[],$=(()=>{let _=P?.query;if(!_||Array.isArray(_))return;let{tools:M,effort:b,mode:R,...F}=_,Y=Object.entries(F).filter(([,K])=>K!=null);if(Y.length!==0)return Object.fromEntries(Y.map(([K,qt])=>[K,String(qt)]))})(),q=g.inline?.max_steps;p.startsWith("api/")&&L();let U=false;try{let _=await w.query(t,{model:m,effort:P?.query?.effort,mode:P?.query?.mode,context:r?.context,systemPrompt:v??g.inline?.system_prompt??g.inline?.prompt??g.description??`You are ${g.id}.`,additionalArgs:Array.isArray(P?.query)?P.query:void 0,tools:G.length>0?G:void 0,maxSteps:q,configOptions:$,timeoutMs:this._resolveTimeout("query"),cwd:r?.cwd,env:{CREWX_AGENT_ID:g.id,CREWX_AGENT_ROLE:g.role??"",CREWX_AGENT_TEAM:g.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:p,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,u)},onPid:R=>L(R),onOutput:(R,F)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:R,level:F}),F==="stdout"&&this.emitToolEvents(i,e,p,R,g.id,r?.threadId??"","");},onTaskLog:R=>{this.emitTaskLogEntries(i,e,g.id,r?.threadId??"","",p,R);for(let F of R)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(F),level:"info"});},onCommand:R=>{k=R;},onUsage:R=>{x=R;},onExitCode:R=>{S=R;},onModel:R=>{T||(T=R);}});L();let M=Date.now()-c,b={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:_,durationMs:M,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:Object.keys(b).length>0?b:void 0}),U=!0,{ok:!0,data:_,meta:{agentId:g.id,provider:p,model:m,durationMs:M,taskId:i}}}catch(_){if(_ instanceof exports.ClientToolCallRequiredError){let R=Te("thd");return this._pendingThreads.set(R,{agentRef:g.id,providerStr:p,continuationState:_.continuationState,toolCall:_.toolCall,traceId:i,startMs:c,model:m}),U=true,{ok:true,status:"requires_action",data:"",toolCall:_.toolCall,threadId:R,meta:{agentId:g.id,provider:p,model:m,durationMs:Date.now()-c,taskId:i}}}L();let M=Date.now()-c,b={code:"QUERY_FAILED",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:M,error:b,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:r?.metadata?{...r.metadata}:void 0}),U=true,{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M,taskId:i}}}finally{U||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:Date.now()-c,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:S??-1,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T});}})}async continueQuery(e,t){let r=this._pendingThreads.get(e);if(!r)return {ok:false,data:"",error:{code:"THREAD_NOT_FOUND",message:`No pending thread: ${e}`},meta:{agentId:"",provider:"",durationMs:0}};this._pendingThreads.delete(e);let o=pe(r.providerStr);if(!o.continueWithToolResults)return {ok:false,data:"",error:{code:"UNSUPPORTED",message:"Provider does not support client tool continuation"},meta:{agentId:r.agentRef,provider:r.providerStr,durationMs:0}};let s=t.map(i=>({...i,toolName:r.toolCall.toolCallId===i.toolCallId?r.toolCall.toolName:i.toolCallId}));try{let i=await o.continueWithToolResults(r.continuationState,s),a=Date.now()-r.startMs;return this.emit("task:end",{traceId:r.traceId,timestamp:new Date,agentRef:r.agentRef,mode:"query",result:i,durationMs:a}),{ok:!0,status:"complete",data:i,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}catch(i){if(i instanceof exports.ClientToolCallRequiredError)return this._pendingThreads.set(e,{...r,continuationState:i.continuationState,toolCall:i.toolCall}),{ok:true,status:"requires_action",data:"",toolCall:i.toolCall,threadId:e,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:Date.now()-r.startMs}};let a=Date.now()-r.startMs;return {ok:false,data:"",error:{code:"CONTINUE_FAILED",message:i.message},meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}}async execute(e,t,r){let o=await this.resolveFileRemoteTarget(e);if(o)return o.target.execute(o.agentRef,t,r);let s=rt.getStore()??pr(r?.trace),i=r?.taskId??Te("tsk"),a={parentTaskId:s?.parentTaskId??null,rootTraceId:s?.rootTraceId??i,callerAgentId:s?.callerAgentId??null},d={parentTaskId:i,rootTraceId:s?.rootTraceId??i,callerAgentId:null};return rt.run(d,async()=>{let c=Date.now(),u=new Date,g;try{g=yt(e,Array.from(this._agents.values()));}catch(_){if(_ instanceof ce){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"AGENT_NOT_FOUND",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:M}}}throw _}d.callerAgentId=g.id;let y=Array.isArray(g.provider)?g.provider[0]??"cli/claude":g.provider,p=r?.provider??y,m=r?.model??g.inline?.model;m&&m.includes("{{")&&(m=await this._templateEngine.render(m,{...r?.vars??{}}));let w;try{w=pe(p);}catch(_){this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let M=Date.now()-c,b={code:"PROVIDER_ERROR",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:M,error:b,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M}}}let A=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),v;try{v=await this.renderAgentPromptFull(e,{session:{mode:"execute",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:A,threadId:r?.threadId});}catch(_){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${_ instanceof Error?_.message:String(_)}`);}let k,x,S,T=m,B=false,L=_=>{B||(B=true,this.emit("task:start",{traceId:i,timestamp:u,agentRef:e,message:t,mode:"execute",pid:_,parentTaskId:a.parentTaskId,rootTraceId:a.rootTraceId,callerAgentId:a.callerAgentId,model:T,provider:p,codingAgentCommand:k,renderedPrompt:v,metadata:{...r?.metadata??{},provider:p},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},P=g.options,H=Array.isArray(P?.execute?.tools)?P.execute.tools:void 0,G=this._tools.size>0?this._filterToolsByMode(H):[],$=(()=>{let _=P?.execute;if(!_||Array.isArray(_))return;let{tools:M,effort:b,mode:R,...F}=_,Y=Object.entries(F).filter(([,K])=>K!=null);if(Y.length!==0)return Object.fromEntries(Y.map(([K,qt])=>[K,String(qt)]))})(),q=g.inline?.max_steps;p.startsWith("api/")&&L();let U=false;try{let _=await w.execute(t,{model:m,effort:P?.execute?.effort,mode:P?.execute?.mode,context:r?.context,systemPrompt:v??g.inline?.system_prompt??g.inline?.prompt??g.description??`You are ${g.id}.`,additionalArgs:Array.isArray(P?.execute)?P.execute:void 0,tools:G.length>0?G:void 0,maxSteps:q,configOptions:$,timeoutMs:this._resolveTimeout("execute"),cwd:r?.cwd,env:{CREWX_AGENT_ID:g.id,CREWX_AGENT_ROLE:g.role??"",CREWX_AGENT_TEAM:g.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:p,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,u)},onPid:R=>L(R),onOutput:(R,F)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:R,level:F}),F==="stdout"&&this.emitToolEvents(i,e,p,R,g.id,r?.threadId??"","");},onTaskLog:R=>{this.emitTaskLogEntries(i,e,g.id,r?.threadId??"","",p,R);for(let F of R)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(F),level:"info"});},onCommand:R=>{k=R;},onUsage:R=>{x=R;},onExitCode:R=>{S=R;},onModel:R=>{T||(T=R);}});L();let M=Date.now()-c,b={...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:_,durationMs:M,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:Object.keys(b).length>0?b:void 0}),U=!0,{ok:!0,data:_,meta:{agentId:g.id,provider:p,model:m,durationMs:M,taskId:i}}}catch(_){L();let M=Date.now()-c,b={code:"EXECUTE_FAILED",message:_.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:M,error:b,exitCode:S,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T,metadata:r?.metadata?{...r.metadata}:void 0}),U=true,{ok:false,data:"",error:b,meta:{agentId:g.id,provider:p,model:m,durationMs:M}}}finally{U||this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:Date.now()-c,error:{code:"TASK_END_GUARD",message:"task:end was not emitted normally"},exitCode:S??-1,inputTokens:x?.inputTokens,outputTokens:x?.outputTokens,cachedInputTokens:x?.cachedInputTokens,costUsd:x?.costUsd,model:T});}})}};function Fn(n,e){let t=Or(n)?n:void 0,r=Or(e)?e:void 0;if(!(!t&&!r))return {...t??{},...r??{}}}function Or(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function li(n,e){let t=Array.isArray(n)?n:void 0,r=Array.isArray(e)?e:void 0;if(!t&&!r)return;let o=a=>{if(!Or(a))return;let d=a.id;if(typeof d=="string")return `id:${d}`;let c=a.name;if(typeof c=="string")return `name:${c}`},s=new Set;for(let a of r??[]){let d=o(a);d&&s.add(d);}let i=[];for(let a of t??[]){let d=o(a);d&&s.has(d)||i.push(a);}for(let a of r??[])i.push(a);return i}async function Hn(n,e,t){if(n.some(o=>(Array.isArray(o.provider)?o.provider:[o.provider]).some(i=>i.startsWith("api/")))){let{registerApiProviders:o}=await Promise.resolve().then(()=>(hr(),Pn));o(t?.api);}ui(n,e),pi(n,e),ci(n);}function ci(n){if(!n.some(r=>(Array.isArray(r.provider)?r.provider:[r.provider]).some(s=>s.startsWith("acp/"))))return;let{registerAcpProviders:t}=(Pr(),Wt(In));t();}function ui(n,e){if(!n.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("remote/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createRemoteProviderFactory:o}=(br(),Wt(Mn)),s=new Map;for(let i of r)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&ue("remote",o(s,pe));}function pi(n,e){if(!n.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("plugin/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createPluginProviderFactory:o}=(Er(),Wt(Ln)),s=new Map;for(let i of r)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&ue("plugin",o(s));}l();var Mr=class{detach(e){}};l();var gi="crewx:fs:",Nr=class{prefix;store;constructor(e){this.prefix=e?.prefix??gi,this.store=e?.storage??new Map;}async readFile(e){let t=this.toKey(e),r=this.store.get(t);if(r===void 0)throw new Error(`BrowserFsAdapter: file not found: ${e}`);return r}async exists(e){return this.store.has(this.toKey(e))}resolvePath(...e){let t=e.map(i=>i.replace(/\\/g,"/")).join("/").replace(/\/+/g,"/"),r=t.split("/"),o=[];for(let i of r)i==="."||i===""||(i===".."?o.pop():o.push(i));let s=o.join("/");return t.startsWith("/")?`/${s}`:s}isAbsolute(e){return e.startsWith("/")}setItem(e,t){this.store.set(this.toKey(e),t);}removeItem(e){this.store.delete(this.toKey(e));}keys(){return Array.from(this.store.keys()).filter(e=>e.startsWith(this.prefix)).map(e=>e.slice(this.prefix.length))}async readdir(e){let t=e.replace(/\\/g,"/").replace(/\/$/,""),r=this.toKey(t+"/"),o=[];for(let s of this.store.keys())if(s.startsWith(r)){let a=s.slice(r.length).split("/")[0];a&&!o.includes(a)&&o.push(a);}return o}toKey(e){return `${this.prefix}${e.replace(/\\/g,"/")}`}};l();function mi(n,e){let t=n.skills?.include;if(t===void 0)return [...e];if(t.length===0)return [];let r=new Set(t);return e.filter(o=>r.has(o))}ae();yr();hr();l();xr();xe();l();Ct();Mt();bt();function fi(n,e,t,r){let o=t.agentInfo?.name,s=e??o??n,a=(r.modes?.availableModes??[]).map(m=>({id:m.id,name:m.name,...m.description!=null?{description:m.description}:{}})),d=[],c=r.configOptions??[];for(let m of c)if(m.category==="thought_level"&&m.type==="select"){let w=m.options??[];if(w.length>0&&w[0]?.group!=null)for(let A of w)for(let v of A.options??[])d.push(v.value);else for(let A of w)A.value!=null&&d.push(A.value);}let u=r.models?.availableModels??[],g=n==="claude"?En.map(m=>({id:m.id,name:m.name})):u.map(m=>({id:m.modelId})),y=t.agentCapabilities??{},p={loadSession:y.loadSession??false,image:y.promptCapabilities?.image??false,audio:y.promptCapabilities?.audio??false,mcp:y.mcpCapabilities!=null};return {id:`acp/${n}`,name:s,modes:a,effort:d,models:g,capabilities:p}}async function qn(n){let e=exports.ACP_ADAPTERS[n];if(!e)return null;let t=e.meta?.displayName,r=new exports.AcpConnection({spawn:e.spawn,cwd:process.cwd()});try{await r.connect(e.clientInfo);let o=r.initResponse;if(!o)return null;let s=e.buildSessionParams({cwd:process.cwd()}),i=await r.newSessionRaw(s);return fi(n,t,o,i)}catch{return null}finally{await r.dispose();}}async function yi(){let n=Object.keys(exports.ACP_ADAPTERS),e=await Promise.allSettled(n.map(r=>qn(r))),t=[];for(let r of e)r.status==="fulfilled"&&r.value!==null&&t.push(r.value);return t}Ct();kr();Mt();Pr();Vt();Fe();l();var Dr=0;function hi(n){let e=Array.from(n.agents.keys());return {name:"delegate_to_agent",description:`Delegate a task to another agent. Available agents: ${e.join(", ")}`,parameters:{type:"object",properties:{agent:{type:"string",description:`Agent ID to delegate to. One of: ${e.join(", ")}`},message:{type:"string",description:"Task description for the target agent"},mode:{type:"string",description:'Execution mode: "query" for questions, "execute" for actions. Default: query'}},required:["agent","message"]},execute:async t=>{if(Dr>=3)return "Error: Maximum delegation depth (3) reached. Cannot delegate further.";let r=t.agent,o=t.message,s=t.mode??"query";if(!e.includes(r))return `Error: Unknown agent "${r}". Available: ${e.join(", ")}`;Dr++;try{if(s==="execute"){let a=await n.execute(r,o);return a.ok?a.data:`Error: ${a.error?.message??"Unknown error"}`}let i=await n.query(r,o);return i.ok?i.data:`Error: ${i.error?.message??"Unknown error"}`}finally{Dr--;}}}}l();var Bn=typeof process<"u"?process.env:{};function wi(){return Bn.CREWX_CLI||"npx crewx"}function xi(){return Bn.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}l();var ki=/^[a-zA-Z0-9._-]+$/,$r=class{constructor(e){this.storage=e;}storage;listBoxes(e){this.validateId(e);let r=this.storage.listBoxes(e).map(o=>this.toBoxResponse(o));return {boxes:r,total:r.length}}getBox(e,t){this.validateId(e),this.validateId(t);let r=this.storage.findBox(e,t);return r?this.toBoxResponse(r):null}createBox(e,t){this.validateId(e);let r=this.generateBoxId(),o=new Date().toISOString(),s=this.storage.insertBox(e,{id:r,seq:t.seq,firstTaskId:t.firstTaskId,midTaskId:t.midTaskId,lastTaskId:t.lastTaskId,taskCount:t.taskCount,summary:t.summary??null,sourceTokens:t.sourceTokens,summaryTokens:t.summaryTokens??null,createdAt:o});return this.toBoxResponse(s)}toBoxResponse(e){return {id:e.id,threadId:e.thread_id,seq:e.seq,firstTaskId:e.first_task_id,lastTaskId:e.last_task_id,taskCount:e.task_count,sourceTokens:e.source_tokens,summaryTokens:e.summary_tokens,summary:e.summary,previewFirst:this.storage.getTaskPreview(e.first_task_id,200),previewMid:this.storage.getTaskPreview(e.mid_task_id,200),previewLast:this.storage.getTaskPreview(e.last_task_id,200),createdAt:e.created_at}}validateId(e){if(!ki.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return Te("box")}};l();function vi(n,e,t,r,o){let{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}=r,d=s*i,c=s*a,u=d+c,g=e.getThreadMessages(n),y=[],p=0,m=false,w=[];for(let k=0;k<g.length;k+=2){let x=g[k],S=g[k+1],T=x?.content||"",B=S?.content||"",L=o.countTokens(T+B),P=[];x&&P.push(x),S&&P.push(S),w.push({messages:P,tokens:L});}for(let k=w.length-1;k>=0;k--){let x=w[k];if(p+x.tokens>d){m=true;break}p+=x.tokens,y.unshift(...x.messages);}let A=[],v=0;if(m&&c>0)try{let{boxes:k}=t.listBoxes(n);for(let x=k.length-1;x>=0;x--){let S=k[x],T=S.summaryTokens??S.sourceTokens;if(v+T>c)break;v+=T,A.unshift({boxId:S.id,seq:S.seq,taskCount:S.taskCount,sourceTokens:S.sourceTokens,summary:S.summary,previewFirst:S.previewFirst,previewMid:S.previewMid,previewLast:S.previewLast,createdAt:S.createdAt});}}catch(k){if(k instanceof Error&&!/not found/i.test(k.message))throw k}return {hot:y,warm:A,hotTokens:p,warmTokens:v,hotOverflow:m,totalBudget:u,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}Fe();Ae();l();var Nt=class extends Error{constructor(t,r){super(`Task ${t} timed out after ${r}ms`);this.taskId=t;this.timeoutMs=r;this.name="ParallelRunnerTimeoutError";}taskId;timeoutMs},ct=class{constructor(e={}){this.defaults=e;}defaults;metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0};async run(e,t={}){if(!Array.isArray(e))throw new TypeError("ParallelRunner.run expects an array of tasks");if(e.length===0)return this.metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0},[];let r=this.mergeOptions(t),o=Math.max(1,r.maxConcurrency??5),s=r.timeoutMs,i=r.failFast??false,a=r.callbacks,d=r.evaluateTaskSuccess??(()=>true),c=[],u=0,g=0,y=0,p=false,m=0,w=perf_hooks.performance.now(),A=async P=>{a?.onTaskStart&&await a.onTaskStart(P),y+=1;let H=new AbortController,G={signal:H.signal},$,q;typeof s=="number"&&Number.isFinite(s)&&s>0&&(q=new Promise((b,R)=>{$=setTimeout(()=>{let F=new Nt(P.id,s);H.abort(F),R(F);},s);}));let U=perf_hooks.performance.now(),_=P.run(G),M=q?Promise.race([_,q]):_;try{let b=await M,R=perf_hooks.performance.now(),F=R-U,Y=d(b,P),K={taskId:P.id,success:Y,value:b,durationMs:F,startedAt:U,finishedAt:R,metadata:P.metadata,aborted:!1};c.push(K),Y?u+=1:g+=1,a?.onTaskComplete&&await a.onTaskComplete(K),i&&!Y&&(p=!0);}catch(b){let R=perf_hooks.performance.now(),F=R-U,Y=b instanceof Error?b:new Error(String(b)),K={taskId:P.id,success:false,error:Y,durationMs:F,startedAt:U,finishedAt:R,metadata:P.metadata,aborted:H.signal.aborted};c.push(K),g+=1,a?.onError&&await a.onError(P,Y,F),i&&(p=true);}finally{$&&clearTimeout($),q&&_.catch(()=>{});}},v=async()=>{for(;!p;){let P=m;if(P>=e.length)break;m+=1;let H=e[P];if(!H||(await A(H),p))break}},k=Math.min(o,e.length),x=[];for(let P=0;P<k;P++)x.push(v());await Promise.all(x);let T=perf_hooks.performance.now()-w,B=c.length?c.reduce((P,H)=>P+H.durationMs,0)/c.length:0,L=T>0?c.length/(T/1e3):c.length;return this.metrics={totalTasks:e.length,startedTasks:y,completedTasks:c.length,successCount:u,failureCount:g,totalDurationMs:T,averageDurationMs:B,throughput:L},c}getMetrics(){return this.metrics}mergeOptions(e){return {maxConcurrency:e.maxConcurrency??this.defaults.maxConcurrency,timeoutMs:e.timeoutMs??this.defaults.timeoutMs,failFast:e.failFast??this.defaults.failFast,evaluateTaskSuccess:e.evaluateTaskSuccess??this.defaults.evaluateTaskSuccess,callbacks:this.mergeCallbacks(this.defaults.callbacks,e.callbacks)}}mergeCallbacks(e,t){if(!(!e&&!t))return {onTaskStart:async r=>{e?.onTaskStart&&await e.onTaskStart(r),t?.onTaskStart&&await t.onTaskStart(r);},onTaskComplete:async r=>{e?.onTaskComplete&&await e.onTaskComplete(r),t?.onTaskComplete&&await t.onTaskComplete(r);},onError:async(r,o,s)=>{e?.onError&&await e.onError(r,o,s),t?.onError&&await t.onError(r,o,s);}}}};l();l();var ut=class{async query(e){throw new Error("AgentRuntime.query is not implemented. Provide a subclass or mock AgentRuntime.prototype.query.")}async execute(e){throw new Error("AgentRuntime.execute is not implemented. Provide a subclass or mock AgentRuntime.prototype.execute.")}};var Wn=3,zn=3e4,Vn=500,_i=n=>{if(typeof n!="number"||Number.isNaN(n)||!Number.isFinite(n))return Wn;let e=Math.floor(n);return e>0?e:Wn},Ai=n=>n===void 0||typeof n!="number"||Number.isNaN(n)||n<=0?zn:n,Ri=n=>{if(!n)return {maxRetries:0,retryDelay:Vn};let e=Number.isInteger(n.maxRetries)&&n.maxRetries>=0?n.maxRetries:0,t=typeof n.retryDelay=="number"&&n.retryDelay>=0?n.retryDelay:Vn;return {maxRetries:e,retryDelay:t}},Lr=n=>{let e=n.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},Pi=(n,e)=>n<=0?Promise.resolve():new Promise((t,r)=>{let o=setTimeout(()=>{e.removeEventListener("abort",s),t();},n),s=()=>{clearTimeout(o),r(Lr(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),Ci=async(n,e,t)=>{let r,o;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw Lr(t);try{let i=await n();if(r=i,i.success||s===e.maxRetries)return i}catch(i){if(o=i,t.aborted)throw Lr(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await Pi(e.retryDelay,t);}if(r)return r;throw o?o instanceof Error?o:new Error(String(o)):new Error("Parallel helper encountered an unexpected state")},Kn=(n,e,t)=>{e.completed+=1,t?e.success+=1:e.failure+=1;try{n.onProgress?.(e.completed,e.total);}catch(r){process.env.NODE_ENV!=="production"&&console.warn("Parallel helper onProgress callback threw an error:",r);}},Ti=n=>n.map(t=>({metadata:t.metadata,taskResult:t})).slice().sort((t,r)=>t.metadata.index-r.metadata.index).map(({metadata:t,taskResult:r})=>{if(r.value){let s=r.value;return {...s,agentId:s.agentId??t.request.agentId,metadata:{...s.metadata,requestIndex:t.index,mode:t.mode}}}let o=r.error??new Error("Unknown error");return {agentId:t.request.agentId,content:o.message,success:false,metadata:{error:o.message,aborted:r.aborted??false,requestIndex:t.index,mode:t.mode}}}),bi=n=>n.filter(e=>!e.success).map(e=>{let t=e.metadata;if(e.error instanceof Error)return {index:t.index,error:e.error};if(e.value&&!e.value.success){let r=String(e.value.metadata?.error??e.value.content??"Agent returned unsuccessful result");return {index:t.index,error:new Error(r)}}return {index:t.index,error:new Error("Unknown failure")}}),Ei=(n,e)=>({onTaskComplete:async t=>{Kn(e,n,t.success);},onError:async()=>{Kn(e,n,false);}}),Jn=async(n,e,t={})=>{if(!Array.isArray(n))throw new TypeError("Parallel helpers expect an array of requests");if(n.length===0){let A={total:0,completed:0,successCount:0,failureCount:0,results:[],errors:[],metrics:{totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0}};return t.onComplete?.(A),[]}let r=_i(t.concurrency),o=Ai(t.timeout),s=Ri(t.retryPolicy),i=new ct,a=new ut,d=n.map((w,A)=>({id:`${e}:${w.agentId??"anonymous"}:${A}`,metadata:{index:A,mode:e,request:w},run:v=>Ci(()=>e==="query"?a.query(w):a.execute(w),s,v.signal)})),c={completed:0,success:0,failure:0,total:n.length},u=await i.run(d,{maxConcurrency:r,timeoutMs:o,evaluateTaskSuccess:w=>w.success,callbacks:Ei(c,t)}),g=Ti(u),y=bi(u),p=i.getMetrics(),m={total:n.length,completed:n.length,successCount:g.filter(w=>w.success).length,failureCount:g.filter(w=>!w.success).length,results:g,errors:y,metrics:p};return t.onComplete?.(m),g},Si=(n,e)=>Jn(n,"query",e),Ii=(n,e)=>Jn(n,"execute",e);Er();l();l();var qe=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:W.join(Ni__default.default.homedir(),".crewx","crewx.db")}resolveDbPaths(){return [this.resolveDbPath()]}isMissingTableError(e){return e instanceof Error&&/no such table:/i.test(e.message)}dbExists(e){return fs$1.existsSync(e??this.resolveDbPath())}};l();function fe(n){let e=z("better-sqlite3"),{drizzle:t}=z("drizzle-orm/better-sqlite3"),r=new e(n);return r.exec("PRAGMA journal_mode = WAL"),r.exec("PRAGMA busy_timeout = 5000"),r.exec("PRAGMA foreign_keys = ON"),{db:t(r),runRaw:(o,s=[])=>r.prepare(o).run(...s),close:()=>r.close()}}l();var Gn=new Set,$i={agent_id:"TEXT",status:"TEXT DEFAULT 'running'",started_at:"TEXT",trace_id:"TEXT",parent_task_id:"TEXT",crewx_version:"TEXT",pid:"INTEGER",thread_id:"TEXT",workspace_id:"TEXT",workspace_ref:"TEXT",workspace_name:"TEXT",project_id:"TEXT",project_name:"TEXT"};function Li(n,e){return (n.get(`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='${e}'`)?.cnt??0)>0}function ji(n,e){if(e>0||!Li(n,"tasks"))return;let t=n.all("PRAGMA table_info(tasks)"),r=new Set(t.map(o=>o.name));for(let[o,s]of Object.entries($i))r.has(o)||n.run(`ALTER TABLE tasks ADD COLUMN ${o} ${s}`);}function Ui(n,e,t){let r=n.all(t`SELECT hash FROM __drizzle_migrations`),o=new Set(r.map(i=>i.hash)),s=JSON.parse(fs$1.readFileSync(W__namespace.default.join(e,"meta/_journal.json"),"utf-8"));for(let i of s.entries){let a=W__namespace.default.join(e,`${i.tag}.sql`);if(!fs$1.existsSync(a))continue;let d=fs$1.readFileSync(a,"utf-8"),c=crypto$1.createHash("sha256").update(d).digest("hex");if(o.has(c))continue;let u=/ALTER\s+TABLE\s+[`"]?(\w+)[`"]?\s+ADD\s+[`"]?(\w+)[`"]?/gi,g=[],y;for(;(y=u.exec(d))!==null;)g.push({table:y[1],column:y[2]});if(g.length===0||!d.split(/-->\s*statement-breakpoint/).map(w=>w.trim()).filter(Boolean).every(w=>/^ALTER\s+TABLE\s+.+\s+ADD\s+/i.test(w)))continue;g.every(({table:w,column:A})=>n.all(`PRAGMA table_info("${w}")`).some(k=>k.name===A))&&n.run(t`INSERT INTO __drizzle_migrations (hash, created_at) VALUES (${c}, ${i.when})`);}}function Fi(n){let{migrate:e}=z("drizzle-orm/better-sqlite3/migrator"),{sql:t}=z("drizzle-orm"),r=[W__namespace.default.join(__dirname,"../migrations"),W__namespace.default.join(__dirname,"migrations"),W__namespace.default.join(__dirname,"../../../../drizzle/migrations"),W__namespace.default.join(process.cwd(),"drizzle/migrations")],o=r.find(c=>fs$1.existsSync(W__namespace.default.join(c,"meta/_journal.json")));if(!o)throw new Error(`migrations folder not found. Searched:
|
|
57
53
|
${r.join(`
|
|
58
|
-
`)}`);let s=n.get(t`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='__drizzle_migrations'`),i=0;s?.cnt&&(i=n.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0),
|
|
54
|
+
`)}`);let s=n.get(t`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='__drizzle_migrations'`),i=0;s?.cnt&&(i=n.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0),ji(n,i),s?.cnt&&Ui(n,o,t),e(n,{migrationsFolder:o});let d=(n.get(t`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0)-i;if(d>0){let c=s?.cnt?"Database migrated":"Database initialized";console.log(`[crewx] ${c} (${d} migration${d>1?"s":""} applied).`);}}function Dt(n,e){Gn.has(e)||(Fi(n),Gn.add(e));}l();var O=class extends Error{code;cause;constructor(e,t,r){super(t),this.name="RepositoryError",this.code=e,this.cause=r,Object.setPrototypeOf(this,new.target.prototype);}};l();l();var Qn=sqliteCore.sqliteTable("workspaces",{id:sqliteCore.text("id").primaryKey(),slug:sqliteCore.text("slug").notNull().unique(),name:sqliteCore.text("name").notNull(),workspace_path:sqliteCore.text("workspace_path"),description:sqliteCore.text("description"),is_active:sqliteCore.integer("is_active").notNull().default(1),created_at:sqliteCore.text("created_at").notNull(),updated_at:sqliteCore.text("updated_at").notNull()});l();var h=sqliteCore.sqliteTable("tasks",{id:sqliteCore.text("id").primaryKey(),agent_id:sqliteCore.text("agent_id").notNull(),user_id:sqliteCore.text("user_id"),prompt:sqliteCore.text("prompt").notNull(),mode:sqliteCore.text("mode").notNull().default("execute"),status:sqliteCore.text("status").notNull().default("running"),result:sqliteCore.text("result"),error:sqliteCore.text("error"),started_at:sqliteCore.text("started_at").notNull(),completed_at:sqliteCore.text("completed_at"),duration_ms:sqliteCore.integer("duration_ms"),metadata:sqliteCore.text("metadata"),workspace_id:sqliteCore.text("workspace_id"),trace_id:sqliteCore.text("trace_id"),parent_task_id:sqliteCore.text("parent_task_id"),caller_agent_id:sqliteCore.text("caller_agent_id"),model:sqliteCore.text("model"),platform:sqliteCore.text("platform").default("cli"),crewx_version:sqliteCore.text("crewx_version"),input_tokens:sqliteCore.integer("input_tokens").default(0),output_tokens:sqliteCore.integer("output_tokens").default(0),cost_usd:sqliteCore.real("cost_usd").default(0),pid:sqliteCore.integer("pid"),rendered_prompt:sqliteCore.text("rendered_prompt"),command:sqliteCore.text("command"),coding_agent_command:sqliteCore.text("coding_agent_command"),exit_code:sqliteCore.integer("exit_code"),logs:sqliteCore.text("logs"),thread_id:sqliteCore.text("thread_id"),workspace_ref:sqliteCore.text("workspace_ref"),project_id:sqliteCore.text("project_id"),project_ref:sqliteCore.text("project_ref"),cached_input_tokens:sqliteCore.integer("cached_input_tokens").default(0)},n=>({idx_tasks_agent_id:sqliteCore.index("idx_tasks_agent_id").on(n.agent_id),idx_tasks_status:sqliteCore.index("idx_tasks_status").on(n.status),idx_tasks_started_at:sqliteCore.index("idx_tasks_started_at").on(n.started_at),idx_tasks_trace_id:sqliteCore.index("idx_tasks_trace_id").on(n.trace_id),idx_tasks_parent_task_id:sqliteCore.index("idx_tasks_parent_task_id").on(n.parent_task_id),idx_tasks_crewx_version:sqliteCore.index("idx_tasks_crewx_version").on(n.crewx_version),idx_tasks_pid:sqliteCore.index("idx_tasks_pid").on(n.pid),idx_tasks_thread_id:sqliteCore.index("idx_tasks_thread_id").on(n.thread_id),idx_tasks_workspace_id:sqliteCore.index("idx_tasks_workspace_id").on(n.workspace_id),idx_tasks_workspace_ref:sqliteCore.index("idx_tasks_workspace_ref").on(n.workspace_ref),idx_tasks_project_id:sqliteCore.index("idx_tasks_project_id").on(n.project_id),idx_tasks_ws_started:sqliteCore.index("idx_tasks_ws_started").on(n.workspace_id,n.started_at)}));l();var eo=sqliteCore.sqliteTable("threads",{id:sqliteCore.text("id").primaryKey(),workspace_id:sqliteCore.text("workspace_id").references(()=>Qn.id,{onDelete:"set null"}),platform:sqliteCore.text("platform").notNull().default("cli"),title:sqliteCore.text("title"),first_message:sqliteCore.text("first_message"),last_message:sqliteCore.text("last_message"),message_count:sqliteCore.integer("message_count").notNull().default(0),created_at:sqliteCore.text("created_at").notNull(),updated_at:sqliteCore.text("updated_at").notNull(),metadata:sqliteCore.text("metadata"),title_locked:sqliteCore.integer("title_locked").notNull().default(0),pinned:sqliteCore.integer("pinned").notNull().default(0),starred:sqliteCore.integer("starred").notNull().default(0)},n=>({idx_threads_updated_at:sqliteCore.index("idx_threads_updated_at").on(n.updated_at),idx_threads_workspace_id:sqliteCore.index("idx_threads_workspace_id").on(n.workspace_id)}));l();var Oe=sqliteCore.sqliteTable("spans",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>h.id,{onDelete:"set null"}),parent_span_id:sqliteCore.text("parent_span_id").references(()=>Oe.id,{onDelete:"set null"}),name:sqliteCore.text("name").notNull(),kind:sqliteCore.text("kind").notNull().default("internal"),status:sqliteCore.text("status").notNull().default("ok"),started_at:sqliteCore.text("started_at").notNull(),completed_at:sqliteCore.text("completed_at"),duration_ms:sqliteCore.integer("duration_ms"),input:sqliteCore.text("input"),output:sqliteCore.text("output"),error:sqliteCore.text("error"),attributes:sqliteCore.text("attributes")},n=>({idx_spans_task_id:sqliteCore.index("idx_spans_task_id").on(n.task_id),idx_spans_parent_span_id:sqliteCore.index("idx_spans_parent_span_id").on(n.parent_span_id)}));l();sqliteCore.sqliteTable("tool_calls",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>h.id,{onDelete:"cascade"}),session_id:sqliteCore.text("session_id"),tool_name:sqliteCore.text("tool_name").notNull(),files:sqliteCore.text("files"),input:sqliteCore.text("input"),output:sqliteCore.text("output"),duration_ms:sqliteCore.integer("duration_ms"),timestamp:sqliteCore.text("timestamp").notNull()},n=>({idx_tool_calls_task_id:sqliteCore.index("idx_tool_calls_task_id").on(n.task_id),idx_tool_calls_tool_name:sqliteCore.index("idx_tool_calls_tool_name").on(n.tool_name),idx_tool_calls_timestamp:sqliteCore.index("idx_tool_calls_timestamp").on(n.timestamp)}));l();sqliteCore.sqliteTable("thread_boxes",{id:sqliteCore.text("id").primaryKey(),thread_id:sqliteCore.text("thread_id").notNull().references(()=>eo.id,{onDelete:"cascade"}),seq:sqliteCore.integer("seq").notNull(),first_task_id:sqliteCore.text("first_task_id").notNull(),mid_task_id:sqliteCore.text("mid_task_id").notNull(),last_task_id:sqliteCore.text("last_task_id").notNull(),task_count:sqliteCore.integer("task_count").notNull(),summary:sqliteCore.text("summary"),source_tokens:sqliteCore.integer("source_tokens").notNull(),summary_tokens:sqliteCore.integer("summary_tokens"),created_at:sqliteCore.text("created_at").notNull()},n=>({idx_thread_boxes_thread_id:sqliteCore.index("idx_thread_boxes_thread_id").on(n.thread_id),idx_thread_boxes_seq:sqliteCore.index("idx_thread_boxes_seq").on(n.thread_id,n.seq),uniq_thread_boxes_thread_seq:sqliteCore.unique().on(n.thread_id,n.seq)}));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")},n=>({idx_request_logs_timestamp:sqliteCore.index("idx_request_logs_timestamp").on(n.timestamp),idx_request_logs_path:sqliteCore.index("idx_request_logs_path").on(n.path),idx_request_logs_status_code:sqliteCore.index("idx_request_logs_status_code").on(n.status_code),idx_request_logs_partition_key:sqliteCore.index("idx_request_logs_partition_key").on(n.partition_key)}));var Hr=class extends qe{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=W.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let o=W.dirname(t);fs$1.existsSync(o)||fs$1.mkdirSync(o,{recursive:true});}else if(!fs$1.existsSync(t))throw new O("NOT_FOUND","Database not found");let r=fe(t);if(e)try{Dt(r.db,t);}catch(o){throw r.close(),o}return r}startTask(e){let t=this.openHandle(true);try{t.db.insert(h).values({id:e.id,agent_id:e.agentId,prompt:e.prompt,mode:e.mode,status:e.status,started_at:e.startedAt,pid:e.pid??null,parent_task_id:e.parentTaskId??null,caller_agent_id:e.callerAgentId??null,trace_id:e.traceId??null,command:e.command??null,metadata:e.metadata??null,workspace_id:e.workspaceId??null,platform:e.platform??"cli",crewx_version:e.crewxVersion??null,thread_id:e.threadId??null,model:e.model??null,rendered_prompt:e.renderedPrompt??null,coding_agent_command:e.codingAgentCommand??null}).onConflictDoNothing().run();}catch(r){throw r instanceof O?r:new O("DB_ERROR","Failed to start task",r)}finally{t.close();}}finishTask(e){let t=this.openHandle(true);try{t.runRaw(`UPDATE tasks SET status=?, result=?, error=?, completed_at=?, duration_ms=?,
|
|
59
55
|
exit_code=?, input_tokens=?, output_tokens=?, cached_input_tokens=?, cost_usd=?,
|
|
60
56
|
model=COALESCE(?, model) WHERE id=?`,[e.status,e.result??null,e.error??null,e.completedAt,e.durationMs??null,e.exitCode??null,e.inputTokens??0,e.outputTokens??0,e.cachedInputTokens??0,e.costUsd??0,e.model??null,e.id]);}catch(r){throw r instanceof O?r:new O("DB_ERROR","Failed to finish task",r)}finally{t.close();}}appendLog(e,t){let r=this.openHandle(true);try{r.db.transaction(o=>{let s=o.select({logs:h.logs}).from(h).where(drizzleOrm.eq(h.id,e)).limit(1).get(),i=s?.logs?JSON.parse(s.logs):[];i.push(t),o.update(h).set({logs:JSON.stringify(i)}).where(drizzleOrm.eq(h.id,e)).run();},{behavior:"immediate"});}catch(o){throw o instanceof O?o:new O("DB_ERROR","Failed to append log",o)}finally{r.close();}}getRunningTasks(){if(!this.dbExists())return [];let e=this.openHandle(false);try{return e.db.select().from(h).where(drizzleOrm.eq(h.status,"running")).orderBy(drizzleOrm.desc(h.started_at)).all()}catch(t){throw new O("DB_ERROR","Failed to get running tasks",t)}finally{e.close();}}getAllTasks(){if(!this.dbExists())return [];let e=this.openHandle(false);try{return e.db.select().from(h).orderBy(drizzleOrm.desc(h.started_at)).limit(100).all()}catch(t){throw new O("DB_ERROR","Failed to get all tasks",t)}finally{e.close();}}getTask(e){if(!this.dbExists())return;let t=this.openHandle(false);try{return t.db.select().from(h).where(drizzleOrm.eq(h.id,e)).limit(1).get()??void 0}catch(r){throw new O("DB_ERROR","Failed to get task",r)}finally{t.close();}}killTask(e){if(!this.dbExists())return {killed:false};let t=this.openHandle(true);try{let r=t.db.select({id:h.id,status:h.status,pid:h.pid}).from(h).where(drizzleOrm.eq(h.id,e)).limit(1).get();if(!r||r.status!=="running")return {killed:!1};if(r.pid)try{process.kill(r.pid,"SIGTERM");}catch{}return t.db.update(h).set({status:"failed",error:"Killed by user",completed_at:new Date().toISOString()}).where(drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.status,"running"))).run(),{killed:!0,pid:r.pid??void 0}}catch(r){throw r instanceof O?r:new O("DB_ERROR","Failed to kill task",r)}finally{t.close();}}reapOrphanedTasks(){if(!this.dbExists())return 0;let e=this.openHandle(true);try{let t=e.db.select({id:h.id,pid:h.pid}).from(h).where(drizzleOrm.eq(h.status,"running")).all(),r=0;for(let o of t){if(!o.pid)continue;let s=!1;try{process.kill(o.pid,0),s=!0;}catch{}s||(e.db.update(h).set({status:"failed",error:"Reaped: process not found (orphaned task)",completed_at:new Date().toISOString()}).where(drizzleOrm.and(drizzleOrm.eq(h.id,o.id),drizzleOrm.eq(h.status,"running"))).run(),r++);}return r}finally{e.close();}}findTaskStatus(e,t){let r=this.resolveDbPaths();for(let o of r){if(!fs$1.existsSync(o))continue;let s=fe(o);try{let i=t?drizzleOrm.eq(h.workspace_id,t):void 0,a=i?drizzleOrm.and(drizzleOrm.eq(h.id,e),i):drizzleOrm.eq(h.id,e),d=s.db.select().from(h).where(a).limit(1).get()??void 0;if(!d){let c=drizzleOrm.or(drizzleOrm.eq(h.thread_id,e),drizzleOrm.and(drizzleOrm.isNull(h.thread_id),drizzleOrm.like(h.command,`%--thread=${e}%`))),u=i?drizzleOrm.and(c,i):c;d=s.db.select().from(h).where(u).orderBy(drizzleOrm.desc(h.started_at)).limit(1).get()??void 0;}if(d)return d}catch(i){throw new O("DB_ERROR","Failed to find task status",i)}finally{s.close();}}}findChildTasks(e,t){let r=this.resolveDbPaths(),o=new Set,s=[];for(let i of r){if(!fs$1.existsSync(i))continue;let a=fe(i);try{let d=t?drizzleOrm.and(drizzleOrm.eq(h.parent_task_id,e),drizzleOrm.eq(h.workspace_id,t)):drizzleOrm.eq(h.parent_task_id,e),c=a.db.select().from(h).where(d).orderBy(drizzleOrm.asc(h.started_at)).all();for(let u of c)o.has(u.id)||(o.add(u.id),s.push(u));}catch(d){throw new O("DB_ERROR","Failed to find child tasks",d)}finally{a.close();}}return s}getWorkspaceUsageSummary(e){if(!this.dbExists())return [];let t=this.openHandle(false);try{return t.db.all(e?drizzleOrm.sql`
|
|
61
57
|
SELECT
|
|
@@ -138,10 +134,10 @@ ${r.join(`
|
|
|
138
134
|
AND t.started_at < ${t}
|
|
139
135
|
GROUP BY date(t.started_at), t.agent_id
|
|
140
136
|
ORDER BY date(t.started_at) ASC
|
|
141
|
-
`).map(i=>({date:i.date,agentId:i.agent_id,inputTokens:i.input_tokens,outputTokens:i.output_tokens,cachedInputTokens:i.cached_input_tokens,costUsd:i.cost_usd}))}catch(s){throw new O("DB_ERROR","Failed to get agent usage trend",s)}finally{o.close();}}findTaskForStop(e,t){if(!this.dbExists())return;let r=this.openHandle(false);try{return r.db.select().from(h).where(drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.workspace_id,t))).limit(1).get()??void 0}catch(o){throw new O("DB_ERROR","Failed to find task for stop",o)}finally{r.close();}}markTaskFailed(e,t,r){if(!this.dbExists())return;let o=this.openHandle(true);try{let s=new Date().toISOString(),i=r?drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.status,"running"),drizzleOrm.eq(h.workspace_id,r)):drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.status,"running"));o.db.update(h).set({status:"failed",error:t,completed_at:s}).where(i).run();}catch(s){throw s instanceof O?s:new O("DB_ERROR","Failed to mark task failed",s)}finally{o.close();}}findTasksByPromptHint(e,t){let r=this.resolveDbPaths(),o=new Set,s=[];for(let i of r){if(!fs$1.existsSync(i))continue;let a=fe(i);try{let d=t?drizzleOrm.and(drizzleOrm.like(h.prompt,`%${e}%`),drizzleOrm.eq(h.workspace_id,t)):drizzleOrm.like(h.prompt,`%${e}%`),c=a.db.select().from(h).where(d).orderBy(drizzleOrm.asc(h.started_at)).all();for(let u of c)o.has(u.id)||(o.add(u.id),s.push(u));}catch(d){throw new O("DB_ERROR","Failed to find tasks by prompt hint",d)}finally{a.close();}}return s}};l();var qr=class extends qe{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=W.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let o=W.dirname(t);fs$1.existsSync(o)||fs$1.mkdirSync(o,{recursive:true});}else if(!fs$1.existsSync(t))throw new O("NOT_FOUND","Database not found");let r=fe(t);if(e)try{Dt(r.db,t);}catch(o){throw r.close(),o}return r}insertSpan(e){let t=this.openHandle(true);try{t.db.insert(Oe).values(e).run();}catch(r){throw r instanceof O?r:new O("DB_ERROR","Failed to insert span",r)}finally{t.close();}}findByTaskId(e){if(!this.dbExists())return [];let t=this.openHandle(false);try{return t.db.select().from(Oe).where(drizzleOrm.eq(Oe.task_id,e)).all()}catch(r){throw new O("DB_ERROR","Failed to find spans by task id",r)}finally{t.close();}}findById(e){if(!this.dbExists())return;let t=this.openHandle(false);try{return t.db.select().from(Oe).where(drizzleOrm.eq(Oe.id,e)).limit(1).get()??void 0}catch(r){throw new O("DB_ERROR","Failed to find span by id",r)}finally{t.close();}}};br();Tr();Cr();l();l();var Ht=class{capabilities={required:[]}};l();l();l();var ao=2e3;function lo(n){let e=n.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f\u2028\u2029]/g,"");return e.length<=ao?e:e.slice(0,ao-11)+" [redacted]"}var
|
|
137
|
+
`).map(i=>({date:i.date,agentId:i.agent_id,inputTokens:i.input_tokens,outputTokens:i.output_tokens,cachedInputTokens:i.cached_input_tokens,costUsd:i.cost_usd}))}catch(s){throw new O("DB_ERROR","Failed to get agent usage trend",s)}finally{o.close();}}findTaskForStop(e,t){if(!this.dbExists())return;let r=this.openHandle(false);try{return r.db.select().from(h).where(drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.workspace_id,t))).limit(1).get()??void 0}catch(o){throw new O("DB_ERROR","Failed to find task for stop",o)}finally{r.close();}}markTaskFailed(e,t,r){if(!this.dbExists())return;let o=this.openHandle(true);try{let s=new Date().toISOString(),i=r?drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.status,"running"),drizzleOrm.eq(h.workspace_id,r)):drizzleOrm.and(drizzleOrm.eq(h.id,e),drizzleOrm.eq(h.status,"running"));o.db.update(h).set({status:"failed",error:t,completed_at:s}).where(i).run();}catch(s){throw s instanceof O?s:new O("DB_ERROR","Failed to mark task failed",s)}finally{o.close();}}findTasksByPromptHint(e,t){let r=this.resolveDbPaths(),o=new Set,s=[];for(let i of r){if(!fs$1.existsSync(i))continue;let a=fe(i);try{let d=t?drizzleOrm.and(drizzleOrm.like(h.prompt,`%${e}%`),drizzleOrm.eq(h.workspace_id,t)):drizzleOrm.like(h.prompt,`%${e}%`),c=a.db.select().from(h).where(d).orderBy(drizzleOrm.asc(h.started_at)).all();for(let u of c)o.has(u.id)||(o.add(u.id),s.push(u));}catch(d){throw new O("DB_ERROR","Failed to find tasks by prompt hint",d)}finally{a.close();}}return s}};l();var qr=class extends qe{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=W.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let o=W.dirname(t);fs$1.existsSync(o)||fs$1.mkdirSync(o,{recursive:true});}else if(!fs$1.existsSync(t))throw new O("NOT_FOUND","Database not found");let r=fe(t);if(e)try{Dt(r.db,t);}catch(o){throw r.close(),o}return r}insertSpan(e){let t=this.openHandle(true);try{t.db.insert(Oe).values(e).run();}catch(r){throw r instanceof O?r:new O("DB_ERROR","Failed to insert span",r)}finally{t.close();}}findByTaskId(e){if(!this.dbExists())return [];let t=this.openHandle(false);try{return t.db.select().from(Oe).where(drizzleOrm.eq(Oe.task_id,e)).all()}catch(r){throw new O("DB_ERROR","Failed to find spans by task id",r)}finally{t.close();}}findById(e){if(!this.dbExists())return;let t=this.openHandle(false);try{return t.db.select().from(Oe).where(drizzleOrm.eq(Oe.id,e)).limit(1).get()??void 0}catch(r){throw new O("DB_ERROR","Failed to find span by id",r)}finally{t.close();}}};br();Tr();Cr();l();l();var Ht=class{capabilities={required:[]}};l();l();l();var ao=2e3;function lo(n){let e=n.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f\u2028\u2029]/g,"");return e.length<=ao?e:e.slice(0,ao-11)+" [redacted]"}var fa=10*1024*1024,ya={b:1,kb:1024,mb:1024*1024,gb:1024*1024*1024};function Br(n,e){return n===void 0?true:Array.isArray(n)?n.includes(e):n===e}function ha(n,e){return n===void 0?true:Array.isArray(n)?n.some(t=>e.includes(t)):e.includes(n)}function uo(n){if(typeof n=="number")return n;let e=n.match(/^(\d+(?:\.\d+)?)\s*(b|kb|mb|gb)?$/i);if(!e)return 0;let t=parseFloat(e[1]),r=(e[2]??"b").toLowerCase();return Math.floor(t*(ya[r]??1))}function po(n){return typeof n=="string"}function go(n){try{let e=fs$1.statSync(n);return e.size>fa?(process.stderr.write(`[YamlHookPlugin] File too large for line count: ${n} (${e.size} bytes)
|
|
142
138
|
`),null):fs$1.readFileSync(n,"utf8").split(`
|
|
143
|
-
`).length}catch{return null}}function mo(n){try{return fs$1.statSync(n).size}catch{return null}}function
|
|
139
|
+
`).length}catch{return null}}function mo(n){try{return fs$1.statSync(n).size}catch{return null}}function wa(n,e,t){if(!n)return true;let r=e,o=r?.path??r?.file_path??r?.filePath??r?.filename;if(typeof o!="string")return false;if(ie(o,n))return true;if(t&&o.startsWith("/")){let{relative:s,isAbsolute:i}=z("path");if(i(o)){let a=s(t,o);if(a&&!a.startsWith("..")&&ie(a,n))return true}}return false}function xa(n,e){return n?JSON.stringify(e).includes(n):true}function ka(n,e){if(!n)return true;try{let t=new RegExp(n),r=JSON.stringify(e);return t.test(r)}catch{return false}}function va(n,e){if(!n)return true;try{let t=new RegExp(n),r=JSON.stringify(e);return t.test(r)}catch{return false}}function _a(n,e){if(n.pathSizeMin===void 0&&n.pathSizeMax===void 0)return true;let t=e,r=t?.path??t?.file_path??t?.filePath??t?.filename;if(typeof r!="string")return false;if(n.pathSizeMin!==void 0)if(po(n.pathSizeMin)){let o=mo(r);if(o===null||o<uo(n.pathSizeMin))return false}else {let o=go(r);if(o===null||o<n.pathSizeMin)return false}if(n.pathSizeMax!==void 0)if(po(n.pathSizeMax)){let o=mo(r);if(o===null||o>uo(n.pathSizeMax))return false}else {let o=go(r);if(o===null||o>n.pathSizeMax)return false}return true}function Aa(n){let e=[],t=[];for(let r=0;r<n.length;r++){let o=n[r];if(!o||typeof o!="object"){t.push(`Hook at index ${r}: not an object, skipping`);continue}let s=o;if(typeof s.name!="string"||!s.name){t.push(`Hook at index ${r}: missing or invalid "name", skipping`);continue}let i=s.guide&&typeof s.guide=="object",a=s.deny&&typeof s.deny=="object",d=typeof s.plugin=="string";if(!i&&!a&&!d){t.push(`Hook "${s.name}": missing guide/deny/plugin, skipping`);continue}if(i&&typeof s.guide.say!="string"){t.push(`Hook "${s.name}": guide.say is required and must be string, skipping`);continue}if(a&&typeof s.deny.reason!="string"){t.push(`Hook "${s.name}": deny.reason is required and must be string, skipping`);continue}e.push(s);}return {valid:e,warnings:t}}var zr=class extends Ht{name="@crewx/yaml-hook-plugin";version="0.1.0";capabilities={required:["inject"]};hooks;agentMap;constructor(e){super(),this.hooks=e.hooks,this.agentMap=new Map((e.agents??[]).map(t=>[t.id,t]));}async run(e){let t=[],r=process.env.CREWX_TASK_LOG_PATH,o=process.env.CREWX_HOOK_LOG_VERBOSE==="1";for(let s of this.hooks)if(this.matchEntryLevel(s,e)&&s.guide){if(!this.matchRuleLevel(s.guide,e)){o&&r&&this.appendHookLog(r,{rule:s.name,action:"pass",once:s.guide.once??false,ctx:e,matched:false});continue}s.guide.once&&this.hasFired(e.sessionId,s.name)||(s.guide.once&&this.markFired(e.sessionId,s.name),t.push(s.guide.say),r&&this.appendHookLog(r,{rule:s.name,action:"inject",once:s.guide.once??false,ctx:e,matched:true,message:s.guide.say}));}return t.length?e.inject(t.join(`
|
|
144
140
|
|
|
145
141
|
`)):e.pass()}appendHookLog(e,t){try{let r={rule:t.rule,action:t.action,once:t.once,sessionId:t.ctx.sessionId,provider:t.ctx.provider,agent:t.ctx.agent.id,toolName:t.ctx.tool.name,rawToolName:t.ctx.tool.rawName};t.message&&(r.chars=t.message.length,process.env.CREWX_HOOK_LOG_VERBOSE==="1"&&(r.message=lo(t.message).slice(0,500)));let o=`[${new Date().toISOString()}] HOOK: ${JSON.stringify(r)}
|
|
146
|
-
`;fs$1.appendFileSync(e,o,{encoding:"utf8",mode:384});}catch{}}matchEntryLevel(e,t){if(e.provider!==void 0){let r=t.provider.replace(/^cli\//,"");if(!Br(e.provider,r))return false}if(e.team!==void 0){let o=this.agentMap.get(t.agent.id)?.team??t.agent.team;if(!Br(e.team,o))return false}if(e.role!==void 0){let o=this.agentMap.get(t.agent.id)?.role??t.agent.role;if(!Br(e.role,o))return false}if(e.tag!==void 0){let o=this.agentMap.get(t.agent.id)?.tags??[];if(!
|
|
147
|
-
`);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return W.join(
|
|
142
|
+
`;fs$1.appendFileSync(e,o,{encoding:"utf8",mode:384});}catch{}}matchEntryLevel(e,t){if(e.provider!==void 0){let r=t.provider.replace(/^cli\//,"");if(!Br(e.provider,r))return false}if(e.team!==void 0){let o=this.agentMap.get(t.agent.id)?.team??t.agent.team;if(!Br(e.team,o))return false}if(e.role!==void 0){let o=this.agentMap.get(t.agent.id)?.role??t.agent.role;if(!Br(e.role,o))return false}if(e.tag!==void 0){let o=this.agentMap.get(t.agent.id)?.tags??[];if(!ha(e.tag,o))return false}return !(e.agents!==void 0&&!e.agents.includes(t.agent.id))}matchRuleLevel(e,t){return !(e.when!==void 0&&e.when.length>0&&!e.when.includes(t.tool.name)&&!e.when.includes(t.tool.rawName)||!xa(e.pattern,t.tool.input)||!ka(e.regex,t.tool.input)||!wa(e.pathPattern,t.tool.input,t.cwd)||!_a(e,t.tool.input)||!va(e.whenInputRegex,t.tool.input))}hasFired(e,t){try{let r=this.firedFilePath(e);if(!fs$1.existsSync(r))return !1;let o=JSON.parse(fs$1.readFileSync(r,"utf8"));return Array.isArray(o.fired)&&o.fired.includes(t)}catch{return false}}markFired(e,t){try{let r=this.firedFilePath(e);fs$1.mkdirSync(W.dirname(r),{recursive:!0,mode:448});let o=fs$1.existsSync(r)?JSON.parse(fs$1.readFileSync(r,"utf8")):{fired:[]};Array.isArray(o.fired)||(o.fired=[]),o.fired.includes(t)||(o.fired.push(t),fs$1.writeFileSync(r,JSON.stringify(o),{mode:384}));}catch(r){process.stderr.write(`[YamlHookPlugin] once state write failed: ${r}
|
|
143
|
+
`);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return W.join(Ni.homedir(),".crewx","sessions",t,"fired-rules.json")}};l();l();l();function Ra(n){let e=n.messages.map(t=>({id:t.id,role:t.isAssistant?"assistant":"user",content:t.text,timestamp:new Date(t.timestamp).toISOString(),metadata:t.metadata??null}));return {getThreadMessages(t){return e}}}l();var Vr=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 Pa(n){return n}function Ca(n){return {name:n.name,async attach(e){let t=await n.configFactory(e),o=e.registerChannelAdapter,s=n.instanceId??n.name;o&&await o({adapter:n.adapter,instanceId:s,config:t}),n.onAttach&&await n.onAttach(e);},async detach(e){let r=e.unregisterChannelAdapter;r&&await r(n.instanceId??n.name),n.onDetach&&await n.onDetach(e);}}}xt();exports.AdapterError=Vr;exports.AgentNotFoundError=ce;exports.AgentRuntime=ut;exports.AgentSkillsSchema=Kr;exports.BrowserFsAdapter=Nr;exports.ConfigLoadError=ve;exports.Crewx=Ir;exports.CrewxPlugin=Mr;exports.DocumentLoader=Pe;exports.LayoutLoadError=J;exports.LayoutLoader=Ye;exports.LayoutRenderer=et;exports.NodeFsAdapter=Pt;exports.ParallelRunner=ct;exports.ParallelRunnerTimeoutError=Nt;exports.PropsValidationError=ge;exports.PropsValidator=Ze;exports.SdkBoxService=$r;exports.SpanRepository=qr;exports.TaskRepository=Hr;exports.TemplateEngine=Ge;exports.TypedEventEmitter=tt;exports.YamlHookPlugin=zr;exports.buildContext=vi;exports.createAdapterContext=ur;exports.createDelegateTool=hi;exports.createHandler=mr;exports.createPluginProviderFactory=$n;exports.createProvider=pe;exports.createRemoteProviderFactory=On;exports.createScopedAdapterStore=lr;exports.defaultExtractText=wr;exports.defaultFsAdapter=Re;exports.defaultParseEvent=se;exports.defineChannelAdapter=Pa;exports.defineChannelAdapterPlugin=Ca;exports.escapeHandlebarsHelper=or;exports.formatFileSizeHelper=sr;exports.formatTimestamp=dr;exports.formatTimestampHelper=ir;exports.generateFingerprint=ws;exports.generateId=Te;exports.getSyncWindowStore=vs;exports.hashWorkspaceId=fr;exports.lengthHelper=nr;exports.loadYamlFile=mt;exports.materializeWindowsSpawnProgram=Ve;exports.normalizeWorkspacePath=vn;exports.parseStdoutEvent=er;exports.parseUsage=ee;exports.parseYamlContent=gt;exports.queryAcpProviderMeta=qn;exports.queryAllAcpProviderMetas=yi;exports.registerAcpProviders=Sn;exports.registerApiProviders=Rn;exports.registerProviderFactory=ue;exports.resolveAgent=yt;exports.resolveAgentSkills=mi;exports.resolveCrewxCli=wi;exports.resolveCrewxWorkspace=xi;exports.resolveDefaultAgentsYaml=zt;exports.resolveTemplatesPath=$e;exports.resolveWindowsExecutablePath=Gr;exports.resolveWindowsSpawnProgram=ze;exports.runExecutesParallel=Ii;exports.runInSyncWindow=_s;exports.runQueriesParallel=Si;exports.setAuditVerbose=ns;exports.toTaskReader=Ra;exports.toTemplateMessages=gr;exports.truncateHelper=rr;exports.validateHooksSchema=Aa;
|