@crewx/sdk 0.8.3 → 0.8.4-rc.0
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 +46 -59
- package/dist/facade/Crewx.d.ts +1 -0
- package/dist/index.d.ts +5 -4
- package/dist/index.js +46 -59
- package/dist/provider/acp/adapter.d.ts +43 -0
- package/dist/provider/acp/adapters/claude.d.ts +2 -0
- package/dist/provider/acp/adapters/codex.d.ts +2 -0
- package/dist/provider/acp/adapters/copilot.d.ts +2 -0
- package/dist/provider/acp/adapters/gemini.d.ts +2 -0
- package/dist/provider/acp/adapters/index.d.ts +7 -0
- package/dist/provider/acp/adapters/opencode.d.ts +2 -0
- package/dist/provider/acp/connection.d.ts +39 -0
- package/dist/provider/acp/index.d.ts +9 -0
- package/dist/provider/acp/register.d.ts +2 -0
- package/dist/provider/acp/runtime.d.ts +16 -0
- package/dist/provider/acp/types.d.ts +24 -0
- package/dist/provider/bridge.d.ts +5 -1
- package/dist/provider/{adapter.types.d.ts → cli/adapter.types.d.ts} +2 -2
- package/dist/provider/{adapters → cli/adapters}/agent-call.util.d.ts +1 -1
- package/dist/provider/{adapters → cli/adapters}/index.d.ts +1 -1
- package/dist/provider/cli/index.d.ts +3 -0
- package/dist/types/index.d.ts +2 -0
- package/package.json +22 -1
- /package/dist/provider/{adapters → cli/adapters}/claude.d.ts +0 -0
- /package/dist/provider/{adapters → cli/adapters}/codex.d.ts +0 -0
- /package/dist/provider/{adapters → cli/adapters}/copilot.d.ts +0 -0
- /package/dist/provider/{adapters → cli/adapters}/gemini.d.ts +0 -0
- /package/dist/provider/{adapters → cli/adapters}/opencode.d.ts +0 -0
package/dist/index.js
CHANGED
|
@@ -1,71 +1,58 @@
|
|
|
1
|
-
'use strict';var fs=require('fs'),
|
|
2
|
-
`))if(t.trim())try{let
|
|
3
|
-
`):i=JSON.stringify(s),{timestamp:
|
|
4
|
-
`).filter(
|
|
1
|
+
'use strict';var fs=require('fs'),U=require('path'),child_process=require('child_process'),sdk=require('@agentclientprotocol/sdk'),jsYaml=require('js-yaml'),zod=require('zod'),module$1=require('module'),ee=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'),as=require('os'),drizzleOrm=require('drizzle-orm'),sqliteCore=require('drizzle-orm/sqlite-core'),perf_hooks=require('perf_hooks');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var U__namespace=/*#__PURE__*/_interopNamespace(U);var ee__namespace=/*#__PURE__*/_interopNamespace(ee);var as__default=/*#__PURE__*/_interopDefault(as);var Nt=Object.defineProperty;var Vn=Object.getOwnPropertyDescriptor;var Kn=Object.getOwnPropertyNames;var Jn=Object.prototype.hasOwnProperty;var F=(o=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(o,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):o)(function(o){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+o+'" is not supported')});var M=(o,e)=>()=>(o&&(e=o(o=0)),e);var st=(o,e)=>{for(var t in e)Nt(o,t,{get:e[t],enumerable:true});},Xn=(o,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of Kn(e))!Jn.call(o,n)&&n!==t&&Nt(o,n,{get:()=>e[n],enumerable:!(r=Vn(e,n))||r.enumerable});return o};var Dt=o=>Xn(Nt({},"__esModule",{value:true}),o);var l=M(()=>{});function ct(o){return typeof o!="string"?void 0:o.trim()||void 0}function ut(o){return ct(o)?.toLowerCase()??""}function Se(o){try{return fs.statSync(o).isFile()}catch{return false}}function $r(o,e){if(o.includes("/")||o.includes("\\")||U__namespace.default.isAbsolute(o))return o;let r=(e.PATH??e.Path??process.env.PATH??process.env.Path??"").split(";").map(a=>a.trim()).filter(Boolean),n=U__namespace.default.extname(o).length>0,s=e.PATHEXT??e.Pathext??process.env.PATHEXT??process.env.Pathext??".EXE;.CMD;.BAT;.COM",i=n?[""]:s.split(";").map(a=>a.trim()).filter(Boolean).map(a=>a.startsWith(".")?a:`.${a}`);for(let a of r)for(let d of i){let c=ut(d),u=d.toUpperCase();for(let p of [d,c,u]){let g=U__namespace.default.join(a,`${o}${p}`);if(Se(g))return g}}return o}function ao(o){if(!Se(o))return null;try{let e=fs.readFileSync(o,"utf8"),t=U__namespace.default.dirname(o),r=[];for(let a of e.matchAll(/"([^"\r\n]*)"/g)){let u=(a[1]??"").match(/%~?dp0%?\s*[\\/]*(.*)$/i)?.[1]?.trim();if(!u)continue;let p=u.replace(/[\\/]+/g,U__namespace.default.sep).replace(/^[\\/]+/,""),g=U__namespace.default.resolve(t,p);Se(g)&&r.push(g);}let n=[],s=new Map;for(let a of e.matchAll(/SET\s+"(\w+)=%~?dp0%?[\\/]?([^"]+)"/gi)){let d=a[1].toUpperCase(),c=a[2].trim().replace(/[\\/]+/g,U__namespace.default.sep).replace(/^[\\/]+/,"");s.set(d,U__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&&Se(c)&&n.push(c);}let i=a=>a.find(d=>{let c=ut(U__namespace.default.basename(d));return c!=="node.exe"&&c!=="node"})??null;return i(n)??i(r)}catch{return null}}function lo(o,e){if(typeof e=="string")return ct(e)||null;if(!e||typeof e!="object")return null;if(o){let t=e[o],r=typeof t=="string"?ct(t):void 0;if(r)return r}for(let t of Object.values(e)){let r=typeof t=="string"?ct(t):void 0;if(r)return r}return null}function co(o,e){if(!e)return null;let t=U__namespace.default.dirname(o),r=[U__namespace.default.resolve(t,"..",e),U__namespace.default.resolve(t,"node_modules",e)];for(let n of r){let s=U__namespace.default.join(n,"package.json");if(Se(s))try{let i=JSON.parse(fs.readFileSync(s,"utf8")),a=lo(e,i.bin);if(!a)continue;let d=U__namespace.default.resolve(n,a);if(Se(d))return d}catch{}}return null}function uo(o){let e=o.platform??process.platform,t=o.env??process.env,r=o.execPath??process.execPath;if(e!=="win32")return {command:o.command,leadingArgv:[],resolution:"direct"};let n=$r(o.command,t),s=ut(U__namespace.default.extname(n));if(s===".js"||s===".cjs"||s===".mjs")return {command:r,leadingArgv:[n],resolution:"node-entrypoint",windowsHide:true};if(s===".cmd"||s===".bat"){let i=ao(n)??co(n,o.packageName);return i?ut(U__namespace.default.extname(i))===".exe"?{command:i,leadingArgv:[],resolution:"exe-entrypoint",windowsHide:true}:{command:r,leadingArgv:[i],resolution:"node-entrypoint",windowsHide:true}:{command:n,leadingArgv:[],resolution:"unresolved-wrapper"}}return {command:n,leadingArgv:[],resolution:"direct"}}function po(o){if(o.candidate.resolution!=="unresolved-wrapper")return {command:o.candidate.command,leadingArgv:o.candidate.leadingArgv,resolution:o.candidate.resolution,windowsHide:o.candidate.windowsHide};if(o.allowShellFallback===true)return {command:o.candidate.command,leadingArgv:[],resolution:"shell-fallback",shell:true};throw new Error(`${U__namespace.default.basename(o.candidate.command)} wrapper resolved, but no executable/Node entrypoint could be resolved without shell execution.`)}function De(o){let e=uo(o);return po({candidate:e,allowShellFallback:o.allowShellFallback})}function Le(o,e){return {command:o.command,argv:[...o.leadingArgv,...e],resolution:o.resolution,shell:o.shell,windowsHide:o.windowsHide}}var pt=M(()=>{l();});function go(o){if(o.type!=="usage"||!("input_tokens"in o))return null;let e=Number(o.input_tokens??0),t=Number(o.output_tokens??0),n="cache_read_input_tokens"in o?Number(o.cache_read_input_tokens):void 0,s="cached_input_tokens"in o?Number(o.cached_input_tokens):void 0,i=n!==void 0?n:s??0;return {inputTokens:n!==void 0?e+n:e,outputTokens:t,cachedInputTokens:i}}function mo(o){let e=o.usage;if(!e||typeof e!="object"||Array.isArray(e))return null;let t=e;if(!("input_tokens"in t))return null;let r=Number(t.input_tokens??0),n=Number(t.output_tokens??0),i="cache_read_input_tokens"in t?Number(t.cache_read_input_tokens):void 0,a="cached_input_tokens"in t?Number(t.cached_input_tokens):void 0,d=i!==void 0?i:a??0;return {inputTokens:i!==void 0?r+i:r,outputTokens:n,cachedInputTokens:d}}function fo(o){if(o.type!=="step_finish")return null;let t=o.part?.tokens;if(!t)return null;let r=Number(t.input??0),n=Number(t.output??0),s=t.cache,i=s?Number(s.read??0):0;return {inputTokens:r+i,outputTokens:n,cachedInputTokens:i}}function K(o){if(!o||!o.trim())return;let e=null;for(let t of o.split(`
|
|
2
|
+
`))if(t.trim())try{let r=JSON.parse(t),n=go(r)??mo(r)??fo(r);n&&(e=n);}catch{}return e??void 0}var ve=M(()=>{l();});exports.RateLimitError=void 0;var $t=M(()=>{l();exports.RateLimitError=class extends Error{name="RateLimitError";constructor(e){super(e);}};});function J(o){return /crewx\s+(x|execute)\s/.test(o)}function X(o,e){let t=e.match(/@(\S+)/);return {timestamp:o,type:"agent_call",targetAgent:t?.[1]?.replace(/["']/g,""),toolInput:e}}var Ee=M(()=>{l();});function yo(o,e){let t=e.type;if(t==="text"){let r=String(e.text||"");return r?{timestamp:o,type:"text",content:r}:null}if(t==="tool_use"){let r=String(e.name||""),n=e.id,s=e.input,i=s?.command?String(s.command):JSON.stringify(s||{});return r==="Bash"&&J(i)?X(o,i):{timestamp:o,type:"tool_use",toolUseId:n,toolName:r,toolInput:i}}if(t==="tool_result"){let r=!!e.is_error,n=e.tool_use_id,s=e.output??e.content??"",i;return typeof s=="string"?i=s:Array.isArray(s)?i=s.filter(a=>a.type==="text"&&typeof a.text=="string").map(a=>a.text).join(`
|
|
3
|
+
`):i=JSON.stringify(s),{timestamp:o,type:"tool_result",toolUseId:n,resultPreview:i,isError:r}}return null}exports.claudeAdapter=void 0;var jt=M(()=>{l();$t();Ee();exports.claudeAdapter={command:"claude",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs],s=n.indexOf("-p");return s!==-1?(n.splice(s+1,0,o),e.model&&n.push("--model",e.model),{args:n}):(e.model&&n.push("--model",e.model),{args:n,stdinMessage:o})}let r=["-p",o,"--output-format","stream-json","--verbose"];return e.model&&r.push("--model",e.model),{args:r}},extractText(o){let e=o.split(`
|
|
4
|
+
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="assistant"&&Array.isArray(s.message?.content))for(let i of s.message.content)i.type==="text"&&typeof i.text=="string"&&i.text.trim()&&t.push(i.text.trim());s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(`
|
|
5
5
|
|
|
6
|
-
`):
|
|
7
|
-
`);for(let t of e)if(t.trim())try{let
|
|
8
|
-
`).filter(
|
|
9
|
-
`).filter(
|
|
6
|
+
`):r||o.trim()},extractFailure(o){if(o.includes('"rate_limit_event"'))try{let e=JSON.parse(o);if(e.type==="rate_limit_event"){let t=e.rate_limit_info??{};if(t.status==="rejected")return new exports.RateLimitError(`Claude rate limit: ${t.rateLimitType??"unknown"} (status: ${t.status})`)}}catch{}return null},parseResultMeta(o){let e=o.split(`
|
|
7
|
+
`);for(let t of e)if(t.trim())try{let r=JSON.parse(t);if(r.type==="result"){let n=r.usage,s=n?{inputTokens:Number(n.input_tokens??0)+Number(n.cache_read_input_tokens??0),outputTokens:Number(n.output_tokens??0),cachedInputTokens:Number(n.cache_read_input_tokens??0),costUsd:Number(r.total_cost_usd??0)}:null,i=r.modelUsage,a=i?Object.keys(i)[0]??null:null;return {usage:s,model:a}}}catch{}return {usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(r!=="assistant"&&r!=="user")return [];let s=t.message?.content;if(!Array.isArray(s))return [];let i=e??new Date().toISOString(),a=[];for(let d of s){let c=yo(i,d);c&&a.push(c);}return a}};});exports.geminiAdapter=void 0;var Ht=M(()=>{l();ve();Ee();exports.geminiAdapter={command:"gemini",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs],s=n.indexOf("-p");return s!==-1?(n.splice(s+1,0,o),e.model&&n.push("--model",e.model),{args:n}):(e.model&&n.push("--model",e.model),{args:n,stdinMessage:o})}let r=["-p",o,"--output-format","stream-json","--verbose"];return e.model&&r.push("--model",e.model),{args:r}},extractText(o){let e=o.split(`
|
|
8
|
+
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);s.type==="message"&&s.role==="assistant"&&s.delta===!0&&typeof s.content=="string"&&t.push(s.content),s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(""):r||o.trim()},parseResultMeta(o){let e=K(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(r!=="message"&&r!=="tool_use"&&r!=="tool_result")return [];let n=e??new Date().toISOString();if(r==="message"){if(t.role!=="assistant")return [];let i=t.content;return i?[{timestamp:n,type:"text",content:i}]:[]}if(r==="tool_use"){let s=String(t.tool_name||""),i=t.tool_id,a=t.parameters,d=a?.command?String(a.command):JSON.stringify(a||{});return /^bash$/i.test(s)&&J(d)?[X(n,d)]:[{timestamp:n,type:"tool_use",toolName:s,toolUseId:i,toolInput:d}]}if(r==="tool_result"){let s=t.tool_id,i=String(t.output||""),a=t.status!=="success";return [{timestamp:n,type:"tool_result",toolUseId:s,resultPreview:i,isError:a}]}return []}};});exports.copilotAdapter=void 0;var Ut=M(()=>{l();ve();Ee();exports.copilotAdapter={command:"copilot",buildArgs(o,e,t){let r=e.additionalArgs?[...e.additionalArgs]:[];return e.model&&r.push("--model",e.model),{args:r,stdinMessage:o}},extractText(o){let e=o.split(`
|
|
9
|
+
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="assistant.message"&&typeof s.data?.content=="string"){let i=s.data.content;i.trim()&&t.push(i.trim());}s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(`
|
|
10
10
|
|
|
11
|
-
`):
|
|
12
|
-
`).filter(
|
|
11
|
+
`):r||o.trim()},parseResultMeta(o){let e=K(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(!r.startsWith("tool.execution")&&!r.startsWith("assistant.")&&r!=="user.message")return [];let n=t.data;if(!n)return [];let s=e??new Date().toISOString(),i=n.toolCallId;if(r==="tool.execution_start"){let a=String(n.toolName||""),d=n.arguments,c=d?.command?String(d.command):JSON.stringify(d||{});return (a==="bash"||a==="Bash")&&J(c)?[X(s,c)]:[{timestamp:s,type:"tool_use",toolName:a,toolInput:c,...i&&{toolUseId:i}}]}if(r==="tool.execution_complete"){let a=n.error;if(a)return [{timestamp:s,type:"tool_result",isError:true,resultPreview:String(a.message||""),...i&&{toolUseId:i}}];let d=n.result,c=String(d?.content||"");return [{timestamp:s,type:"tool_result",resultPreview:c,isError:false,...i&&{toolUseId:i}}]}if(r==="assistant.message"){let a=String(n.content||"");return a?[{timestamp:s,type:"text",content:a}]:[]}return []}};});function ho(o,e){if(e.type==="command_execution"){let r=String(e.command||"");return J(r)?[X(o,r)]:[{timestamp:o,type:"tool_use",toolName:"Bash",toolInput:r}]}return []}function wo(o,e){let t=e.type;if(t==="message"||t==="text"){let r=e.content;if(Array.isArray(r))for(let n of r){let s=xo(o,n);if(s)return s}if(typeof e.text=="string")return {timestamp:o,type:"text",content:e.text}}if(t==="reasoning")return {timestamp:o,type:"text",content:String(e.text||"")};if(t==="command_execution"){let r=String(e.aggregated_output||e.output||""),n=!!e.is_error;return {timestamp:o,type:"tool_result",resultPreview:r,isError:n}}if(t==="tool_use"){let r=String(e.name||e.tool_name||""),n=e.input,s=n?.command?String(n.command):JSON.stringify(n||{});return r==="Bash"&&J(s)?X(o,s):{timestamp:o,type:"tool_use",toolName:r,toolInput:s}}if(t==="tool_result"){let r=!!e.is_error,n=String(e.output||e.content||"");return {timestamp:o,type:"tool_result",resultPreview:n,isError:r}}return null}function xo(o,e){let t=e.type;if(t==="text")return {timestamp:o,type:"text",content:String(e.text||"")};if(t==="tool_use"){let r=String(e.name||""),n=e.input,s=n?.command?String(n.command):JSON.stringify(n||{});return r==="Bash"&&J(s)?X(o,s):{timestamp:o,type:"tool_use",toolName:r,toolInput:s}}return null}exports.codexAdapter=void 0;var Ft=M(()=>{l();ve();Ee();exports.codexAdapter={command:"codex",buildArgs(o,e,t){if(e.additionalArgs!==void 0){let n=[...e.additionalArgs];return !n.includes("--json")&&!n.includes("--experimental-json")&&n.push("--json"),e.model&&n.push("--model",e.model),{args:n,stdinMessage:o}}let r=["exec","--json"];return e.model&&r.push("--model",e.model),{args:r,stdinMessage:o}},extractText(o){let e=o.split(`
|
|
12
|
+
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="item.completed"&&(s.item?.type==="message"||s.item?.type==="agent_message")&&typeof s.item?.text=="string"){let i=s.item.text;i.trim()&&t.push(i.trim());}s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(`
|
|
13
13
|
|
|
14
|
-
`):
|
|
15
|
-
`).filter(
|
|
16
|
-
`).filter(
|
|
14
|
+
`):r||o.trim()},parseResultMeta(o){let e=K(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];if(!r.startsWith("item.")&&!r.startsWith("turn.")&&!r.startsWith("thread."))return [];let n=t.item;if(!n)return [];let s=e??new Date().toISOString();if(r==="item.started")return ho(s,n);if(r==="item.completed"){let i=wo(s,n);return i?[i]:[]}return []}};});function vo(o){if(typeof o=="string")return o;if(!o||typeof o!="object")return JSON.stringify(o??{});let e=o;return e.command?String(e.command):e.filePath?String(e.filePath):e.pattern?String(e.pattern):JSON.stringify(e)}exports.opencodeAdapter=void 0;var qt=M(()=>{l();ve();exports.opencodeAdapter={command:"opencode",buildArgs(o,e,t){let r=e.additionalArgs,n=r!==void 0?[...r]:["run"];return n.includes("--format")||n.push("--format","json"),e.model&&n.push("--model",e.model),n.push(o),{args:n}},extractText(o){let e=o.split(`
|
|
15
|
+
`).filter(n=>n.trim()),t=[],r=null;for(let n of e)try{let s=JSON.parse(n);if(s.type==="text"&&typeof s.part?.text=="string"){let i=s.part.text;i.trim()&&t.push(i.trim());}s.type==="result"&&typeof s.result=="string"&&(r=s.result);}catch{}return t.length>0?t.join(""):r||o.trim()},parseResultMeta(o){let e=K(o);return e?{usage:{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0},model:null}:{usage:null,model:null}},parseEvent(o,e){let t;try{t=JSON.parse(o);}catch{return []}let r=t.type;if(!r)return [];let n=e??new Date().toISOString();if(r==="text"){let i=t.part?.text;return i?[{timestamp:n,type:"text",content:i}]:[]}if(r==="tool_use"){let s=t.part;if(!s)return [];let i=String(s.tool||""),a=String(s.callID||""),d=s.state,c=String(d?.status||""),u=d?.input,p=vo(u),g=[{timestamp:n,type:"tool_use",toolName:i,toolUseId:a,toolInput:p}];if(c==="completed"&&d?.output!==void 0){let m=d.output,y=typeof m=="string"?m:JSON.stringify(m);g.push({timestamp:n,type:"tool_result",toolUseId:a,resultPreview:y,isError:false});}else c==="error"&&g.push({timestamp:n,type:"tool_result",toolUseId:a,resultPreview:String(d?.error||"tool error"),isError:true});return g}return []}};});function Wt(o,e,t){if(t){let r=exports.BUILTIN_ADAPTERS[t];if(r?.parseEvent)return r.parseEvent(e,o)}for(let r of Object.values(exports.BUILTIN_ADAPTERS)){let n=r.parseEvent?.(e,o)??[];if(n.length>0)return n}return []}exports.BUILTIN_ADAPTERS=void 0;var Ie=M(()=>{l();jt();Ht();Ut();Ft();qt();jt();Ht();Ut();Ft();qt();Ee();exports.BUILTIN_ADAPTERS={claude:exports.claudeAdapter,gemini:exports.geminiAdapter,copilot:exports.copilotAdapter,codex:exports.codexAdapter,opencode:exports.opencodeAdapter};});function _o(o){let e=o.split(`
|
|
16
|
+
`).filter(d=>d.trim()),t=[],r=[],n=[],s=[],i=[],a=null;for(let d of e)try{let c=JSON.parse(d);if(c.type==="assistant"&&Array.isArray(c.message?.content))for(let u of c.message.content)u.type==="text"&&typeof u.text=="string"&&u.text.trim()&&t.push(u.text.trim());if(c.type==="message"&&c.role==="assistant"&&c.delta===!0&&typeof c.content=="string"&&r.push(c.content),c.type==="assistant.message"&&typeof c.data?.content=="string"){let u=c.data.content;u.trim()&&n.push(u.trim());}if(c.type==="item.completed"&&(c.item?.type==="message"||c.item?.type==="agent_message")&&typeof c.item?.text=="string"){let u=c.item.text;u.trim()&&s.push(u.trim());}if(c.type==="text"&&typeof c.part?.text=="string"){let u=c.part.text;u.trim()&&i.push(u.trim());}c.type==="result"&&typeof c.result=="string"&&(a=c.result);}catch{}return t.length>0?t.join(`
|
|
17
17
|
|
|
18
|
-
`):
|
|
18
|
+
`):r.length>0?r.join(""):n.length>0?n.join(`
|
|
19
19
|
|
|
20
20
|
`):s.length>0?s.join(`
|
|
21
21
|
|
|
22
|
-
`):i.length>0?i.join(""):a||
|
|
23
|
-
`);
|
|
24
|
-
`);
|
|
22
|
+
`):i.length>0?i.join(""):a||o.trim()}function Ro(o){let e=K(o);return e?{inputTokens:e.inputTokens,outputTokens:e.outputTokens,cachedInputTokens:e.cachedInputTokens,costUsd:0}:null}function Po(o,e,t,r,n,s,i){return new Promise((a,d)=>{let c=n?.timeoutMs??36e5,u=De({command:o,allowShellFallback:true}),p=Le(u,e),g=child_process.spawn(p.command,p.argv,{env:{...process.env,...n?.env??{}},cwd:n?.cwd,stdio:["pipe","pipe","pipe"],shell:p.shell??false,windowsHide:p.windowsHide});s!==void 0&&g.stdin.write(s),g.stdin.end(),g.pid!==void 0&&n?.onPid?.(g.pid);let m=false,y=false,k=()=>{try{g.kill("SIGKILL");}catch{}},_=setTimeout(()=>{if(!m){y=true;try{g.kill("SIGTERM");}catch{}setTimeout(k,jr).unref();}},c);_.unref();let x="",A="",S="",O="";g.stdout.on("data",j=>{let $=j.toString();x+=$,S+=$;let b=S.split(`
|
|
23
|
+
`);S=b.pop()??"";for(let h of b)if(h.trim()&&(n?.onOutput?.(h,"stdout"),i?.extractFailure)){let E=i.extractFailure(h);if(E){m=true,clearTimeout(_);try{g.kill("SIGTERM");}catch{}setTimeout(k,jr).unref(),d(E);return}}}),g.stderr.on("data",j=>{let $=j.toString();A+=$,O+=$;let b=O.split(`
|
|
24
|
+
`);O=b.pop()??"";for(let h of b)h.trim()&&n?.onOutput?.(h,"stderr");}),g.on("error",j=>{m=true,clearTimeout(_),j.code==="ENOENT"?d(new exports.ProviderError(`CLI command "${o}" not found. Is ${t} installed?`,t)):d(new exports.ProviderError(`Spawn error: ${j.message}`,t));}),g.on("close",j=>{if(m)return;m=true,clearTimeout(_),S.trim()&&n?.onOutput?.(S,"stdout"),O.trim()&&n?.onOutput?.(O,"stderr");let $=j??0;if(n?.onExitCode?.($),y&&j!==0)return d(new je(`Total runtime exceeded ${c}ms; process killed.`,t));if($!==0){if(i?.interpretExit){let h=i.interpretExit($,A);if(h){d(h);return}}d(new exports.ProviderError(`Process exited with code ${$}: ${A.slice(0,500)}`,t));return}let b=i?i.extractText(x):_o(x);a({stdout:x,parsed:b});});})}function se(o,e){Hr.set(o,e);}function ie(o){let e=o.split("/");if(e.length!==2)throw new exports.ProviderError(`Invalid provider format: "${o}". Expected namespace/id (e.g., cli/claude)`,o);let[t,r]=e,n=Hr.get(t);if(n)return n(r,o);if(t==="cli"){let s=exports.BUILTIN_ADAPTERS[r];if(!s)throw new exports.ProviderError(`Unknown CLI provider id: "${r}". Supported: ${Object.keys(exports.BUILTIN_ADAPTERS).join(", ")}`,o);return new Bt(r,s,o)}throw new exports.ProviderError(`Unsupported provider namespace: "${t}". Register a factory with registerProviderFactory('${t}', factory).`,o)}exports.ProviderError=void 0;var je,jr;exports.ClientToolCallRequiredError=void 0;var Hr,Bt,Z=M(()=>{l();pt();ve();Ie();exports.ProviderError=class extends Error{constructor(t,r){super(t);this.providerStr=r;this.name="ProviderError";}providerStr},je=class extends exports.ProviderError{constructor(e,t){super(e,t),this.name="TotalTimeoutError";}},jr=2e3;exports.ClientToolCallRequiredError=class extends Error{constructor(t,r){super(`Client tool call required: ${t.toolName}`);this.toolCall=t;this.continuationState=r;}toolCall;continuationState;name="ClientToolCallRequiredError"},Hr=new Map;Bt=class{constructor(e,t,r){this.providerId=e;this.adapter=t;this.providerStr=r;}providerId;adapter;providerStr;async execute(e,t){let r=this.composeMessage(e,t),{args:n,stdinMessage:s}=this.adapter.buildArgs(r,t??{},true);t?.onCommand?.(`${this.adapter.command} ${n.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(n,t,s);return this.handleResultMeta(i,t),a}async query(e,t){let r=this.composeMessage(e,t),{args:n,stdinMessage:s}=this.adapter.buildArgs(r,t??{},false);t?.onCommand?.(`${this.adapter.command} ${n.join(" ")}`);let{stdout:i,parsed:a}=await this.runProcess(n,t,s);return this.handleResultMeta(i,t),a}composeMessage(e,t){return t?.systemPrompt?`${t.systemPrompt}
|
|
25
25
|
|
|
26
26
|
---
|
|
27
27
|
|
|
28
|
-
${e}`:e}runProcess(e,t,
|
|
29
|
-
|
|
30
|
-
Error message: ${Br(t)}`,cause:t}),this[Bo]=true,this.value=e;}static isInstance(e){return U.hasMarker(e,Fo)}static wrap({value:e,cause:t}){return Ur.isInstance(t)&&t.value===e?t:new Ur({value:e,cause:t})}};Bo=Hl;var Ll=ql,Wo="AI_UnsupportedFunctionalityError",Jo=`vercel.ai.error.${Wo}`,Ul=Symbol.for(Jo),Vo,Fl=class extends U{constructor({functionality:r,message:e=`'${r}' functionality not supported.`}){super({name:Wo,message:e}),this[Vo]=true,this.functionality=r;}static isInstance(r){return U.hasMarker(r,Jo)}};Vo=Ul;function yt(r){return r===null||typeof r=="string"||typeof r=="number"||typeof r=="boolean"?true:Array.isArray(r)?r.every(yt):typeof r=="object"?Object.entries(r).every(([e,t])=>typeof e=="string"&&yt(t)):false}function Bl(r){return Array.isArray(r)&&r.every(yt)}function Wl(r){return r!=null&&typeof r=="object"&&Object.entries(r).every(([e,t])=>typeof e=="string"&&yt(t))}});var Xo=De((_y,Go)=>{g();var Jl="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict",Vl=(r,e=21)=>(t=e)=>{let n="",o=t|0;for(;o--;)n+=r[Math.random()*r.length|0];return n},Kl=(r=21)=>{let e="",t=r|0;for(;t--;)e+=Jl[Math.random()*64|0];return e};Go.exports={nanoid:Kl,customAlphabet:Vl};});var ts=De((by,nt)=>{g();var Gl=typeof Buffer<"u",Yo=/"(?:_|\\u005[Ff])(?:_|\\u005[Ff])(?:p|\\u0070)(?:r|\\u0072)(?:o|\\u006[Ff])(?:t|\\u0074)(?:o|\\u006[Ff])(?:_|\\u005[Ff])(?:_|\\u005[Ff])"\s*:/,Qo=/"(?:c|\\u0063)(?:o|\\u006[Ff])(?:n|\\u006[Ee])(?:s|\\u0073)(?:t|\\u0074)(?:r|\\u0072)(?:u|\\u0075)(?:c|\\u0063)(?:t|\\u0074)(?:o|\\u006[Ff])(?:r|\\u0072)"\s*:/;function Zo(r,e,t){t==null&&e!==null&&typeof e=="object"&&(t=e,e=void 0),Gl&&Buffer.isBuffer(r)&&(r=r.toString()),r&&r.charCodeAt(0)===65279&&(r=r.slice(1));let n=JSON.parse(r,e);if(n===null||typeof n!="object")return n;let o=t&&t.protoAction||"error",s=t&&t.constructorAction||"error";if(o==="ignore"&&s==="ignore")return n;if(o!=="ignore"&&s!=="ignore"){if(Yo.test(r)===false&&Qo.test(r)===false)return n}else if(o!=="ignore"&&s==="ignore"){if(Yo.test(r)===false)return n}else if(Qo.test(r)===false)return n;return es(n,{protoAction:o,constructorAction:s,safe:t&&t.safe})}function es(r,{protoAction:e="error",constructorAction:t="error",safe:n}={}){let o=[r];for(;o.length;){let s=o;o=[];for(let i of s){if(e!=="ignore"&&Object.prototype.hasOwnProperty.call(i,"__proto__")){if(n===true)return null;if(e==="error")throw new SyntaxError("Object contains forbidden prototype property");delete i.__proto__;}if(t!=="ignore"&&Object.prototype.hasOwnProperty.call(i,"constructor")&&Object.prototype.hasOwnProperty.call(i.constructor,"prototype")){if(n===true)return null;if(t==="error")throw new SyntaxError("Object contains forbidden prototype property");delete i.constructor;}for(let a in i){let l=i[a];l&&typeof l=="object"&&o.push(l);}}}return r}function Wr(r,e,t){let n=Error.stackTraceLimit;Error.stackTraceLimit=0;try{return Zo(r,e,t)}finally{Error.stackTraceLimit=n;}}function Xl(r,e){let t=Error.stackTraceLimit;Error.stackTraceLimit=0;try{return Zo(r,e,{safe:!0})}catch{return null}finally{Error.stackTraceLimit=t;}}nt.exports=Wr;nt.exports.default=Wr;nt.exports.parse=Wr;nt.exports.safeParse=Xl;nt.exports.scan=es;});var Q=De((ky,ps)=>{g();var Yl=Object.create,rr=Object.defineProperty,Ql=Object.getOwnPropertyDescriptor,Zl=Object.getOwnPropertyNames,eu=Object.getPrototypeOf,tu=Object.prototype.hasOwnProperty,ru=(r,e)=>{for(var t in e)rr(r,t,{get:e[t],enumerable:true});},rs=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Zl(e))!tu.call(r,o)&&o!==t&&rr(r,o,{get:()=>e[o],enumerable:!(n=Ql(e,o))||n.enumerable});return r},nu=(r,e,t)=>(t=r!=null?Yl(eu(r)):{},rs(!r||!r.__esModule?rr(t,"default",{value:r,enumerable:true}):t,r)),ou=r=>rs(rr({},"__esModule",{value:true}),r),ns={};ru(ns,{asValidator:()=>ls,combineHeaders:()=>su,convertAsyncIteratorToReadableStream:()=>iu,convertBase64ToUint8Array:()=>zu,convertUint8ArrayToBase64:()=>Mu,createBinaryResponseHandler:()=>Eu,createEventSourceParserStream:()=>os,createEventSourceResponseHandler:()=>Tu,createIdGenerator:()=>ss,createJsonErrorResponseHandler:()=>Cu,createJsonResponseHandler:()=>Au,createJsonStreamResponseHandler:()=>Pu,createStatusCodeErrorResponseHandler:()=>Su,delay:()=>au,extractResponseHeaders:()=>Ee,generateId:()=>cu,getErrorMessage:()=>pu,getFromApi:()=>mu,isAbortError:()=>Ke,isParsableJson:()=>vu,isValidator:()=>as,loadApiKey:()=>fu,loadOptionalSetting:()=>hu,loadSetting:()=>yu,parseJSON:()=>cs,parseProviderOptions:()=>wu,postFormDataToApi:()=>ku,postJsonToApi:()=>xu,postToApi:()=>Gr,removeUndefinedEntries:()=>Vr,resolve:()=>Ru,safeParseJSON:()=>or,safeValidateTypes:()=>nr,validateTypes:()=>ds,validator:()=>is,validatorSymbol:()=>tr,withoutTrailingSlash:()=>ju,zodValidator:()=>us});ps.exports=ou(ns);function su(...r){return r.reduce((e,t)=>({...e,...t??{}}),{})}function iu(r){return new ReadableStream({async pull(e){try{let{value:t,done:n}=await r.next();n?e.close():e.enqueue(t);}catch(t){e.error(t);}},cancel(){}})}async function au(r){return r==null?Promise.resolve():new Promise(e=>setTimeout(e,r))}function os(){let r="",e,t=[],n,o;function s(l,u){if(l===""){i(u);return}if(l.startsWith(":"))return;let d=l.indexOf(":");if(d===-1){a(l,"");return}let c=l.slice(0,d),p=d+1,f=p<l.length&&l[p]===" "?l.slice(p+1):l.slice(p);a(c,f);}function i(l){t.length>0&&(l.enqueue({event:e,data:t.join(`
|
|
31
|
-
`),id:n,retry:o}),t=[],e=void 0,o=void 0);}function a(l,u){switch(l){case "event":e=u;break;case "data":t.push(u);break;case "id":n=u;break;case "retry":let d=parseInt(u,10);isNaN(d)||(o=d);break}}return new TransformStream({transform(l,u){let{lines:d,incompleteLine:c}=lu(r,l);r=c;for(let p=0;p<d.length;p++)s(d[p],u);},flush(l){s(r,l),i(l);}})}function lu(r,e){let t=[],n=r;for(let o=0;o<e.length;){let s=e[o++];s===`
|
|
32
|
-
`?(t.push(n),n=""):s==="\r"?(t.push(n),n="",e[o]===`
|
|
33
|
-
`&&o++):n+=s;}return {lines:t,incompleteLine:n}}function Ee(r){let e={};return r.headers.forEach((t,n)=>{e[n]=t;}),e}var uu=B(),du=Xo(),ss=({prefix:r,size:e=16,alphabet:t="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",separator:n="-"}={})=>{let o=(0, du.customAlphabet)(t,e);if(r==null)return o;if(t.includes(n))throw new uu.InvalidArgumentError({argument:"separator",message:`The separator "${n}" must not be part of the alphabet "${t}".`});return s=>`${r}${n}${o(s)}`},cu=ss();function pu(r){return r==null?"unknown error":typeof r=="string"?r:r instanceof Error?r.message:JSON.stringify(r)}var vt=B();function Vr(r){return Object.fromEntries(Object.entries(r).filter(([e,t])=>t!=null))}function Ke(r){return r instanceof Error&&(r.name==="AbortError"||r.name==="TimeoutError")}var gu=()=>globalThis.fetch,mu=async({url:r,headers:e={},successfulResponseHandler:t,failedResponseHandler:n,abortSignal:o,fetch:s=gu()})=>{try{let i=await s(r,{method:"GET",headers:Vr(e),signal:o}),a=Ee(i);if(!i.ok){let l;try{l=await n({response:i,url:r,requestBodyValues:{}});}catch(u){throw Ke(u)||vt.APICallError.isInstance(u)?u:new vt.APICallError({message:"Failed to process error response",cause:u,statusCode:i.status,url:r,responseHeaders:a,requestBodyValues:{}})}throw l.value}try{return await t({response:i,url:r,requestBodyValues:{}})}catch(l){throw l instanceof Error&&(Ke(l)||vt.APICallError.isInstance(l))?l:new vt.APICallError({message:"Failed to process successful response",cause:l,statusCode:i.status,url:r,responseHeaders:a,requestBodyValues:{}})}}catch(i){if(Ke(i))throw i;if(i instanceof TypeError&&i.message==="fetch failed"){let a=i.cause;if(a!=null)throw new vt.APICallError({message:`Cannot connect to API: ${a.message}`,cause:a,url:r,isRetryable:true,requestBodyValues:{}})}throw i}},Zt=B();function fu({apiKey:r,environmentVariableName:e,apiKeyParameterName:t="apiKey",description:n}){if(typeof r=="string")return r;if(r!=null)throw new Zt.LoadAPIKeyError({message:`${n} API key must be a string.`});if(typeof process>"u")throw new Zt.LoadAPIKeyError({message:`${n} API key is missing. Pass it using the '${t}' parameter. Environment variables is not supported in this environment.`});if(r=process.env[e],r==null)throw new Zt.LoadAPIKeyError({message:`${n} API key is missing. Pass it using the '${t}' parameter or the ${e} environment variable.`});if(typeof r!="string")throw new Zt.LoadAPIKeyError({message:`${n} API key must be a string. The value of the ${e} environment variable is not a string.`});return r}function hu({settingValue:r,environmentVariableName:e}){if(typeof r=="string")return r;if(!(r!=null||typeof process>"u")&&(r=process.env[e],!(r==null||typeof r!="string")))return r}var er=B();function yu({settingValue:r,environmentVariableName:e,settingName:t,description:n}){if(typeof r=="string")return r;if(r!=null)throw new er.LoadSettingError({message:`${n} setting must be a string.`});if(typeof process>"u")throw new er.LoadSettingError({message:`${n} setting is missing. Pass it using the '${t}' parameter. Environment variables is not supported in this environment.`});if(r=process.env[e],r==null)throw new er.LoadSettingError({message:`${n} setting is missing. Pass it using the '${t}' parameter or the ${e} environment variable.`});if(typeof r!="string")throw new er.LoadSettingError({message:`${n} setting must be a string. The value of the ${e} environment variable is not a string.`});return r}var wt=B(),Kr=nu(ts()),Jr=B(),tr=Symbol.for("vercel.ai.validator");function is(r){return {[tr]:true,validate:r}}function as(r){return typeof r=="object"&&r!==null&&tr in r&&r[tr]===true&&"validate"in r}function ls(r){return as(r)?r:us(r)}function us(r){return is(e=>{let t=r.safeParse(e);return t.success?{success:true,value:t.data}:{success:false,error:t.error}})}function ds({value:r,schema:e}){let t=nr({value:r,schema:e});if(!t.success)throw Jr.TypeValidationError.wrap({value:r,cause:t.error});return t.value}function nr({value:r,schema:e}){let t=ls(e);try{if(t.validate==null)return {success:!0,value:r};let n=t.validate(r);return n.success?n:{success:!1,error:Jr.TypeValidationError.wrap({value:r,cause:n.error})}}catch(n){return {success:false,error:Jr.TypeValidationError.wrap({value:r,cause:n})}}}function cs({text:r,schema:e}){try{let t=Kr.default.parse(r);return e==null?t:ds({value:t,schema:e})}catch(t){throw wt.JSONParseError.isInstance(t)||wt.TypeValidationError.isInstance(t)?t:new wt.JSONParseError({text:r,cause:t})}}function or({text:r,schema:e}){try{let t=Kr.default.parse(r);if(e==null)return {success:!0,value:t,rawValue:t};let n=nr({value:t,schema:e});return n.success?{...n,rawValue:t}:n}catch(t){return {success:false,error:wt.JSONParseError.isInstance(t)?t:new wt.JSONParseError({text:r,cause:t})}}}function vu(r){try{return Kr.default.parse(r),!0}catch{return false}}var _u=B();function wu({provider:r,providerOptions:e,schema:t}){if(e?.[r]==null)return;let n=nr({value:e[r],schema:t});if(!n.success)throw new _u.InvalidArgumentError({argument:"providerOptions",message:`invalid ${r} provider options`,cause:n.error});return n.value}var _t=B(),bu=()=>globalThis.fetch,xu=async({url:r,headers:e,body:t,failedResponseHandler:n,successfulResponseHandler:o,abortSignal:s,fetch:i})=>Gr({url:r,headers:{"Content-Type":"application/json",...e},body:{content:JSON.stringify(t),values:t},failedResponseHandler:n,successfulResponseHandler:o,abortSignal:s,fetch:i}),ku=async({url:r,headers:e,formData:t,failedResponseHandler:n,successfulResponseHandler:o,abortSignal:s,fetch:i})=>Gr({url:r,headers:e,body:{content:t,values:Object.fromEntries(t.entries())},failedResponseHandler:n,successfulResponseHandler:o,abortSignal:s,fetch:i}),Gr=async({url:r,headers:e={},body:t,successfulResponseHandler:n,failedResponseHandler:o,abortSignal:s,fetch:i=bu()})=>{try{let a=await i(r,{method:"POST",headers:Vr(e),body:t.content,signal:s}),l=Ee(a);if(!a.ok){let u;try{u=await o({response:a,url:r,requestBodyValues:t.values});}catch(d){throw Ke(d)||_t.APICallError.isInstance(d)?d:new _t.APICallError({message:"Failed to process error response",cause:d,statusCode:a.status,url:r,responseHeaders:l,requestBodyValues:t.values})}throw u.value}try{return await n({response:a,url:r,requestBodyValues:t.values})}catch(u){throw u instanceof Error&&(Ke(u)||_t.APICallError.isInstance(u))?u:new _t.APICallError({message:"Failed to process successful response",cause:u,statusCode:a.status,url:r,responseHeaders:l,requestBodyValues:t.values})}}catch(a){if(Ke(a))throw a;if(a instanceof TypeError&&a.message==="fetch failed"){let l=a.cause;if(l!=null)throw new _t.APICallError({message:`Cannot connect to API: ${l.message}`,cause:l,url:r,requestBodyValues:t.values,isRetryable:true})}throw a}};async function Ru(r){return typeof r=="function"&&(r=r()),Promise.resolve(r)}var Ae=B(),Cu=({errorSchema:r,errorToMessage:e,isRetryable:t})=>async({response:n,url:o,requestBodyValues:s})=>{let i=await n.text(),a=Ee(n);if(i.trim()==="")return {responseHeaders:a,value:new Ae.APICallError({message:n.statusText,url:o,requestBodyValues:s,statusCode:n.status,responseHeaders:a,responseBody:i,isRetryable:t?.(n)})};try{let l=cs({text:i,schema:r});return {responseHeaders:a,value:new Ae.APICallError({message:e(l),url:o,requestBodyValues:s,statusCode:n.status,responseHeaders:a,responseBody:i,data:l,isRetryable:t?.(n,l)})}}catch{return {responseHeaders:a,value:new Ae.APICallError({message:n.statusText,url:o,requestBodyValues:s,statusCode:n.status,responseHeaders:a,responseBody:i,isRetryable:t?.(n)})}}},Tu=r=>async({response:e})=>{let t=Ee(e);if(e.body==null)throw new Ae.EmptyResponseBodyError({});return {responseHeaders:t,value:e.body.pipeThrough(new TextDecoderStream).pipeThrough(os()).pipeThrough(new TransformStream({transform({data:n},o){n!=="[DONE]"&&o.enqueue(or({text:n,schema:r}));}}))}},Pu=r=>async({response:e})=>{let t=Ee(e);if(e.body==null)throw new Ae.EmptyResponseBodyError({});let n="";return {responseHeaders:t,value:e.body.pipeThrough(new TextDecoderStream).pipeThrough(new TransformStream({transform(o,s){o.endsWith(`
|
|
34
|
-
`)?(s.enqueue(or({text:n+o,schema:r})),n=""):n+=o;}}))}},Au=r=>async({response:e,url:t,requestBodyValues:n})=>{let o=await e.text(),s=or({text:o,schema:r}),i=Ee(e);if(!s.success)throw new Ae.APICallError({message:"Invalid JSON response",cause:s.error,statusCode:e.status,responseHeaders:i,responseBody:o,url:t,requestBodyValues:n});return {responseHeaders:i,value:s.value,rawValue:s.rawValue}},Eu=()=>async({response:r,url:e,requestBodyValues:t})=>{let n=Ee(r);if(!r.body)throw new Ae.APICallError({message:"Response body is empty",url:e,requestBodyValues:t,statusCode:r.status,responseHeaders:n,responseBody:void 0});try{let o=await r.arrayBuffer();return {responseHeaders:n,value:new Uint8Array(o)}}catch(o){throw new Ae.APICallError({message:"Failed to read response as array buffer",url:e,requestBodyValues:t,statusCode:r.status,responseHeaders:n,responseBody:void 0,cause:o})}},Su=()=>async({response:r,url:e,requestBodyValues:t})=>{let n=Ee(r),o=await r.text();return {responseHeaders:n,value:new Ae.APICallError({message:r.statusText,url:e,requestBodyValues:t,statusCode:r.status,responseHeaders:n,responseBody:o})}},{btoa:Iu,atob:Ou}=globalThis;function zu(r){let e=r.replace(/-/g,"+").replace(/_/g,"/"),t=Ou(e);return Uint8Array.from(t,n=>n.codePointAt(0))}function Mu(r){let e="";for(let t=0;t<r.length;t++)e+=String.fromCodePoint(r[t]);return Iu(e)}function ju(r){return r?.replace(/\/$/,"")}});var nn=De((Cy,Rs)=>{g();var tn=Object.defineProperty,Nu=Object.getOwnPropertyDescriptor,Du=Object.getOwnPropertyNames,$u=Object.prototype.hasOwnProperty,Hu=(r,e)=>{for(var t in e)tn(r,t,{get:e[t],enumerable:true});},qu=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Du(e))!$u.call(r,o)&&o!==t&&tn(r,o,{get:()=>e[o],enumerable:!(n=Nu(e,o))||n.enumerable});return r},Lu=r=>qu(tn({},"__esModule",{value:true}),r),ws={};Hu(ws,{createOpenAI:()=>ks,openai:()=>Wd});Rs.exports=Lu(ws);var gs=Q(),bt=B(),ie=Q(),S=W("zod"),Xr=B(),Uu=Q();function Fu({prompt:r,useLegacyFunctionCalling:e=false,systemMessageMode:t="system"}){let n=[],o=[];for(let{role:s,content:i}of r)switch(s){case "system":{switch(t){case "system":{n.push({role:"system",content:i});break}case "developer":{n.push({role:"developer",content:i});break}case "remove":{o.push({type:"other",message:"system messages are removed for this model"});break}default:{let a=t;throw new Error(`Unsupported system message mode: ${a}`)}}break}case "user":{if(i.length===1&&i[0].type==="text"){n.push({role:"user",content:i[0].text});break}n.push({role:"user",content:i.map((a,l)=>{var u,d,c,p;switch(a.type){case "text":return {type:"text",text:a.text};case "image":return {type:"image_url",image_url:{url:a.image instanceof URL?a.image.toString():`data:${(u=a.mimeType)!=null?u:"image/jpeg"};base64,${(0, Uu.convertUint8ArrayToBase64)(a.image)}`,detail:(c=(d=a.providerMetadata)==null?void 0:d.openai)==null?void 0:c.imageDetail}};case "file":{if(a.data instanceof URL)throw new Xr.UnsupportedFunctionalityError({functionality:"'File content parts with URL data' functionality not supported."});switch(a.mimeType){case "audio/wav":return {type:"input_audio",input_audio:{data:a.data,format:"wav"}};case "audio/mp3":case "audio/mpeg":return {type:"input_audio",input_audio:{data:a.data,format:"mp3"}};case "application/pdf":return {type:"file",file:{filename:(p=a.filename)!=null?p:`part-${l}.pdf`,file_data:`data:application/pdf;base64,${a.data}`}};default:throw new Xr.UnsupportedFunctionalityError({functionality:`File content part type ${a.mimeType} in user messages`})}}}})});break}case "assistant":{let a="",l=[];for(let u of i)switch(u.type){case "text":{a+=u.text;break}case "tool-call":{l.push({id:u.toolCallId,type:"function",function:{name:u.toolName,arguments:JSON.stringify(u.args)}});break}}if(e){if(l.length>1)throw new Xr.UnsupportedFunctionalityError({functionality:"useLegacyFunctionCalling with multiple tool calls in one message"});n.push({role:"assistant",content:a,function_call:l.length>0?l[0].function:void 0});}else n.push({role:"assistant",content:a,tool_calls:l.length>0?l:void 0});break}case "tool":{for(let a of i)e?n.push({role:"function",name:a.toolName,content:JSON.stringify(a.result)}):n.push({role:"tool",tool_call_id:a.toolCallId,content:JSON.stringify(a.result)});break}default:{let a=s;throw new Error(`Unsupported role: ${a}`)}}return {messages:n,warnings:o}}function ms(r){var e,t;return (t=(e=r?.content)==null?void 0:e.map(({token:n,logprob:o,top_logprobs:s})=>({token:n,logprob:o,topLogprobs:s?s.map(({token:i,logprob:a})=>({token:i,logprob:a})):[]})))!=null?t:void 0}function ur(r){switch(r){case "stop":return "stop";case "length":return "length";case "content_filter":return "content-filter";case "function_call":case "tool_calls":return "tool-calls";default:return "unknown"}}var je=W("zod"),Bu=Q(),rn=je.z.object({error:je.z.object({message:je.z.string(),type:je.z.string().nullish(),param:je.z.any().nullish(),code:je.z.union([je.z.string(),je.z.number()]).nullish()})}),be=(0, Bu.createJsonErrorResponseHandler)({errorSchema:rn,errorToMessage:r=>r.error.message});function dr({id:r,model:e,created:t}){return {id:r??void 0,modelId:e??void 0,timestamp:t!=null?new Date(t*1e3):void 0}}var fs=B();function Wu({mode:r,useLegacyFunctionCalling:e=false,structuredOutputs:t}){var n;let o=(n=r.tools)!=null&&n.length?r.tools:void 0,s=[];if(o==null)return {tools:void 0,tool_choice:void 0,toolWarnings:s};let i=r.toolChoice;if(e){let u=[];for(let c of o)c.type==="provider-defined"?s.push({type:"unsupported-tool",tool:c}):u.push({name:c.name,description:c.description,parameters:c.parameters});if(i==null)return {functions:u,function_call:void 0,toolWarnings:s};switch(i.type){case "auto":case "none":case void 0:return {functions:u,function_call:void 0,toolWarnings:s};case "required":throw new fs.UnsupportedFunctionalityError({functionality:"useLegacyFunctionCalling and toolChoice: required"});default:return {functions:u,function_call:{name:i.toolName},toolWarnings:s}}}let a=[];for(let u of o)u.type==="provider-defined"?s.push({type:"unsupported-tool",tool:u}):a.push({type:"function",function:{name:u.name,description:u.description,parameters:u.parameters,strict:t?true:void 0}});if(i==null)return {tools:a,tool_choice:void 0,toolWarnings:s};let l=i.type;switch(l){case "auto":case "none":case "required":return {tools:a,tool_choice:l,toolWarnings:s};case "tool":return {tools:a,tool_choice:{type:"function",function:{name:i.toolName}},toolWarnings:s};default:{let u=l;throw new fs.UnsupportedFunctionalityError({functionality:`Unsupported tool choice type: ${u}`})}}}var Ju=class{constructor(r,e,t){this.specificationVersion="v1",this.modelId=r,this.settings=e,this.config=t;}get supportsStructuredOutputs(){var r;return (r=this.settings.structuredOutputs)!=null?r:en(this.modelId)}get defaultObjectGenerationMode(){return Gu(this.modelId)?"tool":this.supportsStructuredOutputs?"json":"tool"}get provider(){return this.config.provider}get supportsImageUrls(){return !this.settings.downloadImages}getArgs({mode:r,prompt:e,maxTokens:t,temperature:n,topP:o,topK:s,frequencyPenalty:i,presencePenalty:a,stopSequences:l,responseFormat:u,seed:d,providerMetadata:c}){var p,f,v,h,m,y,w,C;let _=r.type,k=[];s!=null&&k.push({type:"unsupported-setting",setting:"topK"}),u?.type==="json"&&u.schema!=null&&!this.supportsStructuredOutputs&&k.push({type:"unsupported-setting",setting:"responseFormat",details:"JSON response format schema is only supported with structuredOutputs"});let E=this.settings.useLegacyFunctionCalling;if(E&&this.settings.parallelToolCalls===true)throw new bt.UnsupportedFunctionalityError({functionality:"useLegacyFunctionCalling with parallelToolCalls"});if(E&&this.supportsStructuredOutputs)throw new bt.UnsupportedFunctionalityError({functionality:"structuredOutputs with useLegacyFunctionCalling"});let{messages:O,warnings:R}=Fu({prompt:e,useLegacyFunctionCalling:E,systemMessageMode:Xu(this.modelId)});k.push(...R);let x={model:this.modelId,logit_bias:this.settings.logitBias,logprobs:this.settings.logprobs===true||typeof this.settings.logprobs=="number"?true:void 0,top_logprobs:typeof this.settings.logprobs=="number"?this.settings.logprobs:typeof this.settings.logprobs=="boolean"&&this.settings.logprobs?0:void 0,user:this.settings.user,parallel_tool_calls:this.settings.parallelToolCalls,max_tokens:t,temperature:n,top_p:o,frequency_penalty:i,presence_penalty:a,response_format:u?.type==="json"?this.supportsStructuredOutputs&&u.schema!=null?{type:"json_schema",json_schema:{schema:u.schema,strict:true,name:(p=u.name)!=null?p:"response",description:u.description}}:{type:"json_object"}:void 0,stop:l,seed:d,max_completion_tokens:(f=c?.openai)==null?void 0:f.maxCompletionTokens,store:(v=c?.openai)==null?void 0:v.store,metadata:(h=c?.openai)==null?void 0:h.metadata,prediction:(m=c?.openai)==null?void 0:m.prediction,reasoning_effort:(w=(y=c?.openai)==null?void 0:y.reasoningEffort)!=null?w:this.settings.reasoningEffort,messages:O};switch(en(this.modelId)?(x.temperature!=null&&(x.temperature=void 0,k.push({type:"unsupported-setting",setting:"temperature",details:"temperature is not supported for reasoning models"})),x.top_p!=null&&(x.top_p=void 0,k.push({type:"unsupported-setting",setting:"topP",details:"topP is not supported for reasoning models"})),x.frequency_penalty!=null&&(x.frequency_penalty=void 0,k.push({type:"unsupported-setting",setting:"frequencyPenalty",details:"frequencyPenalty is not supported for reasoning models"})),x.presence_penalty!=null&&(x.presence_penalty=void 0,k.push({type:"unsupported-setting",setting:"presencePenalty",details:"presencePenalty is not supported for reasoning models"})),x.logit_bias!=null&&(x.logit_bias=void 0,k.push({type:"other",message:"logitBias is not supported for reasoning models"})),x.logprobs!=null&&(x.logprobs=void 0,k.push({type:"other",message:"logprobs is not supported for reasoning models"})),x.top_logprobs!=null&&(x.top_logprobs=void 0,k.push({type:"other",message:"topLogprobs is not supported for reasoning models"})),x.max_tokens!=null&&(x.max_completion_tokens==null&&(x.max_completion_tokens=x.max_tokens),x.max_tokens=void 0)):(this.modelId.startsWith("gpt-4o-search-preview")||this.modelId.startsWith("gpt-4o-mini-search-preview"))&&x.temperature!=null&&(x.temperature=void 0,k.push({type:"unsupported-setting",setting:"temperature",details:"temperature is not supported for the search preview models and has been removed."})),_){case "regular":{let{tools:z,tool_choice:I,functions:X,function_call:te,toolWarnings:F}=Wu({mode:r,useLegacyFunctionCalling:E,structuredOutputs:this.supportsStructuredOutputs});return {args:{...x,tools:z,tool_choice:I,functions:X,function_call:te},warnings:[...k,...F]}}case "object-json":return {args:{...x,response_format:this.supportsStructuredOutputs&&r.schema!=null?{type:"json_schema",json_schema:{schema:r.schema,strict:true,name:(C=r.name)!=null?C:"response",description:r.description}}:{type:"json_object"}},warnings:k};case "object-tool":return {args:E?{...x,function_call:{name:r.tool.name},functions:[{name:r.tool.name,description:r.tool.description,parameters:r.tool.parameters}]}:{...x,tool_choice:{type:"function",function:{name:r.tool.name}},tools:[{type:"function",function:{name:r.tool.name,description:r.tool.description,parameters:r.tool.parameters,strict:this.supportsStructuredOutputs?true:void 0}}]},warnings:k};default:{let z=_;throw new Error(`Unsupported type: ${z}`)}}}async doGenerate(r){var e,t,n,o,s,i,a,l;let{args:u,warnings:d}=this.getArgs(r),{responseHeaders:c,value:p,rawValue:f}=await(0, ie.postJsonToApi)({url:this.config.url({path:"/chat/completions",modelId:this.modelId}),headers:(0, ie.combineHeaders)(this.config.headers(),r.headers),body:u,failedResponseHandler:be,successfulResponseHandler:(0, ie.createJsonResponseHandler)(Vu),abortSignal:r.abortSignal,fetch:this.config.fetch}),{messages:v,...h}=u,m=p.choices[0],y=(e=p.usage)==null?void 0:e.completion_tokens_details,w=(t=p.usage)==null?void 0:t.prompt_tokens_details,C={openai:{}};return y?.reasoning_tokens!=null&&(C.openai.reasoningTokens=y?.reasoning_tokens),y?.accepted_prediction_tokens!=null&&(C.openai.acceptedPredictionTokens=y?.accepted_prediction_tokens),y?.rejected_prediction_tokens!=null&&(C.openai.rejectedPredictionTokens=y?.rejected_prediction_tokens),w?.cached_tokens!=null&&(C.openai.cachedPromptTokens=w?.cached_tokens),{text:(n=m.message.content)!=null?n:void 0,toolCalls:this.settings.useLegacyFunctionCalling&&m.message.function_call?[{toolCallType:"function",toolCallId:(0, ie.generateId)(),toolName:m.message.function_call.name,args:m.message.function_call.arguments}]:(o=m.message.tool_calls)==null?void 0:o.map(_=>{var k;return {toolCallType:"function",toolCallId:(k=_.id)!=null?k:(0, ie.generateId)(),toolName:_.function.name,args:_.function.arguments}}),finishReason:ur(m.finish_reason),usage:{promptTokens:(i=(s=p.usage)==null?void 0:s.prompt_tokens)!=null?i:NaN,completionTokens:(l=(a=p.usage)==null?void 0:a.completion_tokens)!=null?l:NaN},rawCall:{rawPrompt:v,rawSettings:h},rawResponse:{headers:c,body:f},request:{body:JSON.stringify(u)},response:dr(p),warnings:d,logprobs:ms(m.logprobs),providerMetadata:C}}async doStream(r){if(this.settings.simulateStreaming){let h=await this.doGenerate(r);return {stream:new ReadableStream({start(y){if(y.enqueue({type:"response-metadata",...h.response}),h.text&&y.enqueue({type:"text-delta",textDelta:h.text}),h.toolCalls)for(let w of h.toolCalls)y.enqueue({type:"tool-call-delta",toolCallType:"function",toolCallId:w.toolCallId,toolName:w.toolName,argsTextDelta:w.args}),y.enqueue({type:"tool-call",...w});y.enqueue({type:"finish",finishReason:h.finishReason,usage:h.usage,logprobs:h.logprobs,providerMetadata:h.providerMetadata}),y.close();}}),rawCall:h.rawCall,rawResponse:h.rawResponse,warnings:h.warnings}}let{args:e,warnings:t}=this.getArgs(r),n={...e,stream:true,stream_options:this.config.compatibility==="strict"?{include_usage:true}:void 0},{responseHeaders:o,value:s}=await(0, ie.postJsonToApi)({url:this.config.url({path:"/chat/completions",modelId:this.modelId}),headers:(0, ie.combineHeaders)(this.config.headers(),r.headers),body:n,failedResponseHandler:be,successfulResponseHandler:(0, ie.createEventSourceResponseHandler)(Ku),abortSignal:r.abortSignal,fetch:this.config.fetch}),{messages:i,...a}=e,l=[],u="unknown",d={promptTokens:void 0,completionTokens:void 0},c,p=true,{useLegacyFunctionCalling:f}=this.settings,v={openai:{}};return {stream:s.pipeThrough(new TransformStream({transform(h,m){var y,w,C,_,k,E,O,R,x,z,I,X;if(!h.success){u="error",m.enqueue({type:"error",error:h.error});return}let te=h.value;if("error"in te){u="error",m.enqueue({type:"error",error:te.error});return}if(p&&(p=false,m.enqueue({type:"response-metadata",...dr(te)})),te.usage!=null){let{prompt_tokens:J,completion_tokens:ne,prompt_tokens_details:Y,completion_tokens_details:V}=te.usage;d={promptTokens:J??void 0,completionTokens:ne??void 0},V?.reasoning_tokens!=null&&(v.openai.reasoningTokens=V?.reasoning_tokens),V?.accepted_prediction_tokens!=null&&(v.openai.acceptedPredictionTokens=V?.accepted_prediction_tokens),V?.rejected_prediction_tokens!=null&&(v.openai.rejectedPredictionTokens=V?.rejected_prediction_tokens),Y?.cached_tokens!=null&&(v.openai.cachedPromptTokens=Y?.cached_tokens);}let F=te.choices[0];if(F?.finish_reason!=null&&(u=ur(F.finish_reason)),F?.delta==null)return;let Ne=F.delta;Ne.content!=null&&m.enqueue({type:"text-delta",textDelta:Ne.content});let ce=ms(F?.logprobs);ce?.length&&(c===void 0&&(c=[]),c.push(...ce));let he=f&&Ne.function_call!=null?[{type:"function",id:(0, ie.generateId)(),function:Ne.function_call,index:0}]:Ne.tool_calls;if(he!=null)for(let J of he){let ne=J.index;if(l[ne]==null){if(J.type!=="function")throw new bt.InvalidResponseDataError({data:J,message:"Expected 'function' type."});if(J.id==null)throw new bt.InvalidResponseDataError({data:J,message:"Expected 'id' to be a string."});if(((y=J.function)==null?void 0:y.name)==null)throw new bt.InvalidResponseDataError({data:J,message:"Expected 'function.name' to be a string."});l[ne]={id:J.id,type:"function",function:{name:J.function.name,arguments:(w=J.function.arguments)!=null?w:""},hasFinished:false};let V=l[ne];((C=V.function)==null?void 0:C.name)!=null&&((_=V.function)==null?void 0:_.arguments)!=null&&(V.function.arguments.length>0&&m.enqueue({type:"tool-call-delta",toolCallType:"function",toolCallId:V.id,toolName:V.function.name,argsTextDelta:V.function.arguments}),(0, ie.isParsableJson)(V.function.arguments)&&(m.enqueue({type:"tool-call",toolCallType:"function",toolCallId:(k=V.id)!=null?k:(0, ie.generateId)(),toolName:V.function.name,args:V.function.arguments}),V.hasFinished=true));continue}let Y=l[ne];Y.hasFinished||(((E=J.function)==null?void 0:E.arguments)!=null&&(Y.function.arguments+=(R=(O=J.function)==null?void 0:O.arguments)!=null?R:""),m.enqueue({type:"tool-call-delta",toolCallType:"function",toolCallId:Y.id,toolName:Y.function.name,argsTextDelta:(x=J.function.arguments)!=null?x:""}),((z=Y.function)==null?void 0:z.name)!=null&&((I=Y.function)==null?void 0:I.arguments)!=null&&(0, ie.isParsableJson)(Y.function.arguments)&&(m.enqueue({type:"tool-call",toolCallType:"function",toolCallId:(X=Y.id)!=null?X:(0, ie.generateId)(),toolName:Y.function.name,args:Y.function.arguments}),Y.hasFinished=true));}},flush(h){var m,y;h.enqueue({type:"finish",finishReason:u,logprobs:c,usage:{promptTokens:(m=d.promptTokens)!=null?m:NaN,completionTokens:(y=d.completionTokens)!=null?y:NaN},...v!=null?{providerMetadata:v}:{}});}})),rawCall:{rawPrompt:i,rawSettings:a},rawResponse:{headers:o},request:{body:JSON.stringify(n)},warnings:t}}},bs=S.z.object({prompt_tokens:S.z.number().nullish(),completion_tokens:S.z.number().nullish(),prompt_tokens_details:S.z.object({cached_tokens:S.z.number().nullish()}).nullish(),completion_tokens_details:S.z.object({reasoning_tokens:S.z.number().nullish(),accepted_prediction_tokens:S.z.number().nullish(),rejected_prediction_tokens:S.z.number().nullish()}).nullish()}).nullish(),Vu=S.z.object({id:S.z.string().nullish(),created:S.z.number().nullish(),model:S.z.string().nullish(),choices:S.z.array(S.z.object({message:S.z.object({role:S.z.literal("assistant").nullish(),content:S.z.string().nullish(),function_call:S.z.object({arguments:S.z.string(),name:S.z.string()}).nullish(),tool_calls:S.z.array(S.z.object({id:S.z.string().nullish(),type:S.z.literal("function"),function:S.z.object({name:S.z.string(),arguments:S.z.string()})})).nullish()}),index:S.z.number(),logprobs:S.z.object({content:S.z.array(S.z.object({token:S.z.string(),logprob:S.z.number(),top_logprobs:S.z.array(S.z.object({token:S.z.string(),logprob:S.z.number()}))})).nullable()}).nullish(),finish_reason:S.z.string().nullish()})),usage:bs}),Ku=S.z.union([S.z.object({id:S.z.string().nullish(),created:S.z.number().nullish(),model:S.z.string().nullish(),choices:S.z.array(S.z.object({delta:S.z.object({role:S.z.enum(["assistant"]).nullish(),content:S.z.string().nullish(),function_call:S.z.object({name:S.z.string().optional(),arguments:S.z.string().optional()}).nullish(),tool_calls:S.z.array(S.z.object({index:S.z.number(),id:S.z.string().nullish(),type:S.z.literal("function").nullish(),function:S.z.object({name:S.z.string().nullish(),arguments:S.z.string().nullish()})})).nullish()}).nullish(),logprobs:S.z.object({content:S.z.array(S.z.object({token:S.z.string(),logprob:S.z.number(),top_logprobs:S.z.array(S.z.object({token:S.z.string(),logprob:S.z.number()}))})).nullable()}).nullish(),finish_reason:S.z.string().nullish(),index:S.z.number()})),usage:bs}),rn]);function en(r){return r.startsWith("o")||r.startsWith("gpt-5")}function Gu(r){return r.startsWith("gpt-4o-audio-preview")}function Xu(r){var e,t;return en(r)?(t=(e=Yu[r])==null?void 0:e.systemMessageMode)!=null?t:"developer":"system"}var Yu={"o1-mini":{systemMessageMode:"remove"},"o1-mini-2024-09-12":{systemMessageMode:"remove"},"o1-preview":{systemMessageMode:"remove"},"o1-preview-2024-09-12":{systemMessageMode:"remove"},o3:{systemMessageMode:"developer"},"o3-2025-04-16":{systemMessageMode:"developer"},"o3-mini":{systemMessageMode:"developer"},"o3-mini-2025-01-31":{systemMessageMode:"developer"},"o4-mini":{systemMessageMode:"developer"},"o4-mini-2025-04-16":{systemMessageMode:"developer"}},sr=B(),ot=Q(),N=W("zod"),ir=B();function Qu({prompt:r,inputFormat:e,user:t="user",assistant:n="assistant"}){if(e==="prompt"&&r.length===1&&r[0].role==="user"&&r[0].content.length===1&&r[0].content[0].type==="text")return {prompt:r[0].content[0].text};let o="";r[0].role==="system"&&(o+=`${r[0].content}
|
|
28
|
+
${e}`:e}runProcess(e,t,r){return Po(this.adapter.command,e,this.providerStr,this.providerId,t,r,this.adapter)}handleResultMeta(e,t){if(!this.adapter.parseResultMeta){let i=Ro(e);i&&t?.onUsage&&t.onUsage(i);return}let{usage:r,model:n}=this.adapter.parseResultMeta(e);r&&t?.onUsage&&t.onUsage(r);let s=n??(this.providerId==="opencode"?t?.model??null:null);s&&t?.onModel&&t.onModel(s);}};});var pn,gn;exports.VercelProviderRuntime=void 0;var ar=M(()=>{l();Z();pn=10,gn=50,exports.VercelProviderRuntime=class{config;constructor(e){this.config=e;}async query(e,t){return this._run(e,"query",t)}async execute(e,t){return this._run(e,"execute",t)}async _run(e,t,r){let{generateText:n,tool:s}=await import('ai'),i=this.convertTools(r?.tools??[],s),a=this.createModel(r?.model),d=Math.min(r?.maxSteps??this.config.maxSteps??pn,gn);try{let c=0,u=await n({model:a,system:r?.systemPrompt??void 0,prompt:e,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens},onStepFinish:g=>{if(c++,!!r?.onOutput){if(g.toolCalls&&g.toolCalls.length>0)for(let m of g.toolCalls)r.onOutput(JSON.stringify({type:"assistant",message:{content:[{type:"tool_use",id:m.toolCallId,name:m.toolName,input:m.args}]}}),"stdout");if(g.toolResults&&g.toolResults.length>0)for(let m of g.toolResults){let y=typeof m.result=="string"?m.result:JSON.stringify(m.result);r.onOutput(JSON.stringify({type:"user",message:{content:[{type:"tool_result",tool_use_id:m.toolCallId,output:y,is_error:!1}]}}),"stdout");}}}}),p=new Set((r?.tools??[]).filter(g=>!g.execute).map(g=>g.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let g=u.toolCalls.filter(m=>p.has(m.toolName));if(g.length>0){let m=g[0];throw new exports.ClientToolCallRequiredError({toolCallId:m.toolCallId,toolName:m.toolName,args:m.args},{userMessage:e,responseMessages:u.response?.messages??[],toolDefinitions:r?.tools??[],maxSteps:d,systemPrompt:r?.systemPrompt,modelOverride:r?.model})}}if(r?.onUsage&&u.usage){let g={inputTokens:u.usage.promptTokens??0,outputTokens:u.usage.completionTokens??0,cachedInputTokens:0,costUsd:0};r.onUsage(g);}return r?.onModel&&r.onModel(r.model??this.config.model),u.text??""}catch(c){throw c instanceof exports.ClientToolCallRequiredError?c:c.status===401?new exports.ProviderError(`Authentication failed for ${this.config.provider}. Check your API key.`,this.config.provider):c.status===429?new exports.ProviderError(`Rate limit exceeded for ${this.config.provider}.`,this.config.provider):new exports.ProviderError(`Provider error: ${c.message}`,this.config.provider)}}async continueWithToolResults(e,t,r){let{generateText:n,tool:s}=await import('ai'),i=this.convertTools(e.toolDefinitions,s),a=this.createModel(e.modelOverride),d=Math.min(e.maxSteps??this.config.maxSteps??pn,gn),c=[{role:"user",content:e.userMessage},...e.responseMessages,{role:"tool",content:t.map(u=>({type:"tool-result",toolCallId:u.toolCallId,toolName:u.toolName,result:typeof u.result=="string"?u.result:JSON.stringify(u.result)}))}];try{let u=await n({model:a,system:e.systemPrompt??void 0,messages:c,tools:i,maxSteps:d,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens}}),p=new Set(e.toolDefinitions.filter(g=>!g.execute).map(g=>g.name));if(u.finishReason==="tool-calls"&&Array.isArray(u.toolCalls)&&u.toolCalls.length>0){let g=u.toolCalls.filter(m=>p.has(m.toolName));if(g.length>0){let m=g[0];throw new exports.ClientToolCallRequiredError({toolCallId:m.toolCallId,toolName:m.toolName,args:m.args},{userMessage:e.userMessage,responseMessages:[...e.responseMessages,{role:"tool",content:t.map(y=>({type:"tool-result",toolCallId:y.toolCallId,toolName:y.toolName,result:typeof y.result=="string"?y.result:JSON.stringify(y.result)}))},...u.response?.messages??[]],toolDefinitions:e.toolDefinitions,maxSteps:e.maxSteps,systemPrompt:e.systemPrompt,modelOverride:e.modelOverride})}}return r?.onUsage&&u.usage&&r.onUsage({inputTokens:u.usage.promptTokens??0,outputTokens:u.usage.completionTokens??0,cachedInputTokens:0,costUsd:0}),r?.onModel&&r.onModel(e.modelOverride??this.config.model),u.text??""}catch(u){throw u instanceof exports.ClientToolCallRequiredError?u:new exports.ProviderError(`Provider error: ${u.message}`,this.config.provider)}}convertTools(e,t){let{z:r}=F("zod"),n={};for(let s of e){let i=this.jsonSchemaToZod(s.parameters??{},r);s.execute?n[s.name]=t({description:s.description,parameters:i,execute:async a=>s.execute(a)}):n[s.name]=t({description:s.description,parameters:i});}return n}jsonSchemaToZod(e,t){if(!e||!e.properties)return t.object({});let r={},n=e.properties,s=e.required??[];for(let[i,a]of Object.entries(n)){let d;switch(a.type){case "string":d=t.string();break;case "number":d=t.number();break;case "integer":d=t.number().int();break;case "boolean":d=t.boolean();break;case "array":d=t.array(t.any());break;default:d=t.any();}a.description&&(d=d.describe(a.description)),s.includes(i)||(d=d.optional()),r[i]=d;}return t.object(r)}createModel(e){let{provider:t,apiKey:r,baseURL:n}=this.config,s=e||this.config.model;switch(t){case "api/openrouter":{let{createOpenAI:i}=F("@ai-sdk/openai");return i({apiKey:r||process.env.OPENROUTER_API_KEY,baseURL:n||"https://openrouter.ai/api/v1"})(s)}case "api/openai":{let{createOpenAI:i}=F("@ai-sdk/openai");return i({apiKey:r||process.env.OPENAI_API_KEY,...n&&{baseURL:n}})(s)}case "api/anthropic":{let{createAnthropic:i}=F("@ai-sdk/anthropic");return i({apiKey:r||process.env.ANTHROPIC_API_KEY,...n&&{baseURL:n}})(s)}case "api/google":{let{createGoogleGenerativeAI:i}=F("@ai-sdk/google");return i({apiKey:r||process.env.GOOGLE_API_KEY})(s)}default:throw new exports.ProviderError(`Unsupported API provider: ${t}`,t)}}};});var fn={};st(fn,{registerApiProviders:()=>mn});function mn(o){se("api",(e,t)=>{let r=o?.apiKeys?.[e];return new exports.VercelProviderRuntime({provider:t,model:"",apiKey:r,maxSteps:o?.defaults?.maxSteps,temperature:o?.defaults?.temperature})});}var dr=M(()=>{l();Z();ar();});function lr(o){let e=o.update;if(e.sessionUpdate==="agent_message_chunk"){let t=e.content;if(t.type==="text"&&typeof t.text=="string")return t.text}return null}function G(o,e){try{let t=JSON.parse(o);if(t!=null&&typeof t=="object"&&typeof t.type=="string"&&Ns.has(t.type)){let r=e??new Date().toISOString();return [{...t,timestamp:t.timestamp||r}]}}catch{}return []}var Ns,me=M(()=>{l();Ns=new Set(["text","tool_use","tool_result","error","agent_call"]);});exports.AcpProtocolError=void 0;var cr=M(()=>{l();exports.AcpProtocolError=class extends Error{constructor(t,r,n){super(t);this.code=r;this.data=n;}code;data;name="AcpProtocolError"};});var js,Hs,yn,hn;exports.AcpConnection=void 0;var ur=M(()=>{l();cr();Z();js=-32e3,Hs=2e3,yn=3e4,hn=1e4,exports.AcpConnection=class{constructor(e){this.options=e;}options;proc=null;sdkConnection=null;disposed=false;stderrBuffer="";collectedStderr="";pendingUpdateCallback=null;authMethods=[];async connect(e){if(this.disposed)throw new exports.ProviderError("AcpConnection has been disposed","acp");let t=this.options.spawn,r=process.platform==="win32"&&(t.shellOnWindows??true),n=child_process.spawn(t.command,t.args,{stdio:["pipe","pipe","pipe"],env:{...process.env,...this.options.env??{}},cwd:this.options.cwd,shell:r,windowsHide:true});n.pid!==void 0&&this.options.onPid?.(n.pid),n.stderr.on("data",m=>{let y=m.toString();this.collectedStderr+=y,this.stderrBuffer+=y;let k=this.stderrBuffer.split(`
|
|
29
|
+
`);this.stderrBuffer=k.pop()??"";for(let w of k)w.trim()&&this.options.onStderr?.(w);}),this.proc=n;let s=new WritableStream({write:m=>new Promise((y,k)=>{n.stdin.write(m,w=>{w?k(w):y();});}),close:()=>{n.stdin.end();}}),i=new ReadableStream({start:m=>{n.stdout.on("data",y=>{m.enqueue(new Uint8Array(y));}),n.stdout.on("end",()=>{m.close();}),n.stdout.on("error",y=>{m.error(y);});}}),a=sdk.ndJsonStream(s,i),d=this,c=new sdk.ClientSideConnection(m=>({requestPermission:async y=>({outcome:{outcome:"cancelled"}}),sessionUpdate:async y=>{d.pendingUpdateCallback?.(y);}}),a);this.sdkConnection=c;let u=new Promise((m,y)=>{n.on("error",k=>{if(k.code==="ENOENT"){let _=t.command==="npx"&&t.args.length>0?`@agentclientprotocol/${t.args[0]}`:t.command;y(new exports.ProviderError(`ACP command "${t.command}" not found. Is the ACP adapter installed? Try: npm install -g ${_}`,"acp"));}else y(new exports.ProviderError(`ACP spawn error: ${k.message}`,"acp"));});}),p=this.doInitialize(c,e),g=new Promise((m,y)=>{setTimeout(()=>{y(new exports.AcpProtocolError(`ACP connect timeout after ${yn}ms. The ACP adapter may not be installed or may require interactive setup.`));},yn).unref();});await Promise.race([p,g,u]);}async doInitialize(e,t){let r=await e.initialize({protocolVersion:1,clientCapabilities:{auth:{}},clientInfo:{name:t?.name??"crewx-sdk",version:t?.version??"0.8.4"}});this.authMethods=r.authMethods??[];}async newSession(e){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");try{return await this.newSessionWithTimeout(e)}catch(t){if(!this.isAuthError(t))throw t;return await this.tryAuthenticate(),this.newSessionWithTimeout(e)}}async newSessionWithTimeout(e){let t=this.sdkConnection.newSession(e),r=new Promise((s,i)=>{setTimeout(()=>{i(new exports.AcpProtocolError(`ACP session/new timeout after ${hn}ms`));},hn).unref();});return (await Promise.race([t,r])).sessionId}isAuthError(e){return typeof e=="object"&&e!==null&&"code"in e&&e.code===js}async tryAuthenticate(){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected.","acp");let e=this.authMethods.find(r=>r.type==="env_var"&&this.hasEnvVarsFor(r));if(e){await this.sdkConnection.authenticate({methodId:e.id});return}let t=this.authMethods.map(r=>`${r.id} (${r.type??"agent"})`).join(", ");if(this.authMethods.length>0){let r=this.authMethods.filter(n=>n.type==="env_var");if(r.length>0){let n=r.flatMap(s=>(s.vars??[]).filter(i=>!i.optional&&!process.env[i.name]).map(i=>i.name));throw new exports.AcpProtocolError(`ACP authentication required. Missing environment variables: ${n.join(", ")}. Set them in your shell or crewx.yaml env block.`)}throw new exports.AcpProtocolError(`ACP authentication required but no supported method found. Available methods: ${t}. CrewX currently supports env_var authentication only.`)}throw new exports.AcpProtocolError("ACP agent requires authentication but advertised no auth methods.")}hasEnvVarsFor(e){return !e.vars||e.vars.length===0?true:e.vars.filter(t=>!t.optional).every(t=>!!process.env[t.name])}async setModel(e,t){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.unstable_setSessionModel({sessionId:e,modelId:t});}async setMode(e,t){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.setSessionMode({sessionId:e,modeId:t});}async setConfigOption(e,t,r){if(!this.sdkConnection)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");await this.sdkConnection.setSessionConfigOption({sessionId:e,configId:t,value:r});}async prompt(e,t,r,n){if(!this.sdkConnection||!this.proc)throw new exports.ProviderError("AcpConnection not connected. Call connect() first.","acp");this.pendingUpdateCallback=r??null;let s=this.sdkConnection,i=this.proc,a=n??36e5,d=s.prompt({sessionId:e,prompt:t}),c=new Promise((p,g)=>{setTimeout(()=>{s.cancel({sessionId:e}).catch(()=>{}),g(new je(`ACP prompt timeout after ${a}ms`,"acp"));},a).unref();}),u=new Promise((p,g)=>{let m=y=>{y!==0&&g(new exports.ProviderError(`ACP process exited unexpectedly (code=${String(y)}): ${this.collectedStderr.slice(0,500)}`,"acp"));};i.once("close",m),d.then(()=>i.off("close",m)).catch(()=>i.off("close",m));});try{return await Promise.race([d,c,u])}finally{this.pendingUpdateCallback=null;}}async dispose(){if(this.disposed)return;this.disposed=true,this.pendingUpdateCallback=null,this.sdkConnection=null;let e=this.proc;e&&(this.proc=null,this.stderrBuffer.trim()&&(this.options.onStderr?.(this.stderrBuffer),this.stderrBuffer=""),await new Promise(t=>{let r=()=>{clearTimeout(n),t();};e.once("close",r),e.once("error",r);try{e.kill("SIGTERM");}catch{r();return}let n=setTimeout(()=>{try{e.kill("SIGKILL");}catch{}},Hs);}));}get isConnected(){return !this.disposed&&this.sdkConnection!==null&&this.proc!==null}};});function wn(o,e){if(o!=null&&typeof o=="object"){let t=o;if(typeof t.command=="string")return t.command;if(typeof t.file_path=="string")return t.file_path;if(typeof t.filePath=="string")return t.filePath;if(typeof t.path=="string")return t.path;if(typeof t.query=="string")return t.query;if(typeof t.pattern=="string")return t.pattern;if(typeof t.url=="string")return t.url;if(Object.keys(t).length>0)return JSON.stringify(t)}if(e&&e.length>0)return e.map(t=>t.path).join(", ")}var Us;exports.AcpProviderRuntime=void 0;var pr=M(()=>{l();me();ur();Us={read:"Read",edit:"Edit",delete:"Delete",move:"Move",search:"Search",execute:"Bash",think:"Think",fetch:"WebFetch",switch_mode:"SwitchMode"};exports.AcpProviderRuntime=class{constructor(e,t,r){this.adapter=t;}adapter;async query(e,t){return this.runPrompt(e,t)}async execute(e,t){return this.runPrompt(e,t)}async dispose(){}async runPrompt(e,t){let{command:r,args:n}=this.adapter.spawn;t?.onCommand?.(`${r} ${n.join(" ")}`);let s=new exports.AcpConnection({spawn:this.adapter.spawn,env:t?.env,cwd:t?.cwd,timeoutMs:t?.timeoutMs,onPid:t?.onPid,onStderr:i=>t?.onOutput?.(i,"stderr")});try{await s.connect(this.adapter.clientInfo);let i=this.adapter.buildSessionParams({cwd:t?.cwd,env:t?.env,model:t?.model,systemPrompt:t?.systemPrompt}),a=await s.newSession(i);await this.applySessionOptions(s,a,t);let d=this.composePrompt(e,t),c=[],u=await s.prompt(a,d,p=>this.handleUpdate(p,t,c),t?.timeoutMs);return this.handleUsage(u,t),c.join("")}finally{await s.dispose().catch(()=>{});}}async applySessionOptions(e,t,r){if(r?.model){let n=this.adapter.buildEffortAction?.(r.effort??"",r.model);n?.type==="set_model"?await e.setModel(t,n.modelId):await e.setModel(t,r.model);}if(r?.mode){let n=this.adapter.resolveMode?.(r.mode)??r.mode;if(n)try{await e.setMode(t,n);}catch{}}if(r?.effort){let n=this.adapter.buildEffortAction?.(r.effort,r.model);if(n&&n.type==="set_config_option")try{await e.setConfigOption(t,n.configId,n.value);}catch{}}}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(`
|
|
35
30
|
|
|
36
|
-
|
|
37
|
-
${a}
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
`,{prompt:o,stopSequences:[`
|
|
44
|
-
${t}:`]}}function hs(r){return r?.tokens.map((e,t)=>({token:e,logprob:r.token_logprobs[t],topLogprobs:r.top_logprobs?Object.entries(r.top_logprobs[t]).map(([n,o])=>({token:n,logprob:o})):[]}))}var Zu=class{constructor(r,e,t){this.specificationVersion="v1",this.defaultObjectGenerationMode=void 0,this.modelId=r,this.settings=e,this.config=t;}get provider(){return this.config.provider}getArgs({mode:r,inputFormat:e,prompt:t,maxTokens:n,temperature:o,topP:s,topK:i,frequencyPenalty:a,presencePenalty:l,stopSequences:u,responseFormat:d,seed:c}){var p;let f=r.type,v=[];i!=null&&v.push({type:"unsupported-setting",setting:"topK"}),d!=null&&d.type!=="text"&&v.push({type:"unsupported-setting",setting:"responseFormat",details:"JSON response format is not supported."});let{prompt:h,stopSequences:m}=Qu({prompt:t,inputFormat:e}),y=[...m??[],...u??[]],w={model:this.modelId,echo:this.settings.echo,logit_bias:this.settings.logitBias,logprobs:typeof this.settings.logprobs=="number"?this.settings.logprobs:typeof this.settings.logprobs=="boolean"&&this.settings.logprobs?0:void 0,suffix:this.settings.suffix,user:this.settings.user,max_tokens:n,temperature:o,top_p:s,frequency_penalty:a,presence_penalty:l,seed:c,prompt:h,stop:y.length>0?y:void 0};switch(f){case "regular":{if((p=r.tools)!=null&&p.length)throw new sr.UnsupportedFunctionalityError({functionality:"tools"});if(r.toolChoice)throw new sr.UnsupportedFunctionalityError({functionality:"toolChoice"});return {args:w,warnings:v}}case "object-json":throw new sr.UnsupportedFunctionalityError({functionality:"object-json mode"});case "object-tool":throw new sr.UnsupportedFunctionalityError({functionality:"object-tool mode"});default:{let C=f;throw new Error(`Unsupported type: ${C}`)}}}async doGenerate(r){let{args:e,warnings:t}=this.getArgs(r),{responseHeaders:n,value:o,rawValue:s}=await(0, ot.postJsonToApi)({url:this.config.url({path:"/completions",modelId:this.modelId}),headers:(0, ot.combineHeaders)(this.config.headers(),r.headers),body:e,failedResponseHandler:be,successfulResponseHandler:(0, ot.createJsonResponseHandler)(ed),abortSignal:r.abortSignal,fetch:this.config.fetch}),{prompt:i,...a}=e,l=o.choices[0];return {text:l.text,usage:{promptTokens:o.usage.prompt_tokens,completionTokens:o.usage.completion_tokens},finishReason:ur(l.finish_reason),logprobs:hs(l.logprobs),rawCall:{rawPrompt:i,rawSettings:a},rawResponse:{headers:n,body:s},response:dr(o),warnings:t,request:{body:JSON.stringify(e)}}}async doStream(r){let{args:e,warnings:t}=this.getArgs(r),n={...e,stream:true,stream_options:this.config.compatibility==="strict"?{include_usage:true}:void 0},{responseHeaders:o,value:s}=await(0, ot.postJsonToApi)({url:this.config.url({path:"/completions",modelId:this.modelId}),headers:(0, ot.combineHeaders)(this.config.headers(),r.headers),body:n,failedResponseHandler:be,successfulResponseHandler:(0, ot.createEventSourceResponseHandler)(td),abortSignal:r.abortSignal,fetch:this.config.fetch}),{prompt:i,...a}=e,l="unknown",u={promptTokens:Number.NaN,completionTokens:Number.NaN},d,c=true;return {stream:s.pipeThrough(new TransformStream({transform(p,f){if(!p.success){l="error",f.enqueue({type:"error",error:p.error});return}let v=p.value;if("error"in v){l="error",f.enqueue({type:"error",error:v.error});return}c&&(c=false,f.enqueue({type:"response-metadata",...dr(v)})),v.usage!=null&&(u={promptTokens:v.usage.prompt_tokens,completionTokens:v.usage.completion_tokens});let h=v.choices[0];h?.finish_reason!=null&&(l=ur(h.finish_reason)),h?.text!=null&&f.enqueue({type:"text-delta",textDelta:h.text});let m=hs(h?.logprobs);m?.length&&(d===void 0&&(d=[]),d.push(...m));},flush(p){p.enqueue({type:"finish",finishReason:l,logprobs:d,usage:u});}})),rawCall:{rawPrompt:i,rawSettings:a},rawResponse:{headers:o},warnings:t,request:{body:JSON.stringify(n)}}}},ed=N.z.object({id:N.z.string().nullish(),created:N.z.number().nullish(),model:N.z.string().nullish(),choices:N.z.array(N.z.object({text:N.z.string(),finish_reason:N.z.string(),logprobs:N.z.object({tokens:N.z.array(N.z.string()),token_logprobs:N.z.array(N.z.number()),top_logprobs:N.z.array(N.z.record(N.z.string(),N.z.number())).nullable()}).nullish()})),usage:N.z.object({prompt_tokens:N.z.number(),completion_tokens:N.z.number()})}),td=N.z.union([N.z.object({id:N.z.string().nullish(),created:N.z.number().nullish(),model:N.z.string().nullish(),choices:N.z.array(N.z.object({text:N.z.string(),finish_reason:N.z.string().nullish(),index:N.z.number(),logprobs:N.z.object({tokens:N.z.array(N.z.string()),token_logprobs:N.z.array(N.z.number()),top_logprobs:N.z.array(N.z.record(N.z.string(),N.z.number())).nullable()}).nullish()})),usage:N.z.object({prompt_tokens:N.z.number(),completion_tokens:N.z.number()}).nullish()}),rn]),rd=B(),Yr=Q(),Ge=W("zod"),nd=class{constructor(r,e,t){this.specificationVersion="v1",this.modelId=r,this.settings=e,this.config=t;}get provider(){return this.config.provider}get maxEmbeddingsPerCall(){var r;return (r=this.settings.maxEmbeddingsPerCall)!=null?r:2048}get supportsParallelCalls(){var r;return (r=this.settings.supportsParallelCalls)!=null?r:true}async doEmbed({values:r,headers:e,abortSignal:t}){if(r.length>this.maxEmbeddingsPerCall)throw new rd.TooManyEmbeddingValuesForCallError({provider:this.provider,modelId:this.modelId,maxEmbeddingsPerCall:this.maxEmbeddingsPerCall,values:r});let{responseHeaders:n,value:o}=await(0, Yr.postJsonToApi)({url:this.config.url({path:"/embeddings",modelId:this.modelId}),headers:(0, Yr.combineHeaders)(this.config.headers(),e),body:{model:this.modelId,input:r,encoding_format:"float",dimensions:this.settings.dimensions,user:this.settings.user},failedResponseHandler:be,successfulResponseHandler:(0, Yr.createJsonResponseHandler)(od),abortSignal:t,fetch:this.config.fetch});return {embeddings:o.data.map(s=>s.embedding),usage:o.usage?{tokens:o.usage.prompt_tokens}:void 0,rawResponse:{headers:n}}}},od=Ge.z.object({data:Ge.z.array(Ge.z.object({embedding:Ge.z.array(Ge.z.number())})),usage:Ge.z.object({prompt_tokens:Ge.z.number()}).nullish()}),Qr=Q(),ar=W("zod"),sd={"dall-e-3":1,"dall-e-2":10,"gpt-image-1":10},id=new Set(["gpt-image-1"]),ad=class{constructor(r,e,t){this.modelId=r,this.settings=e,this.config=t,this.specificationVersion="v1";}get maxImagesPerCall(){var r,e;return (e=(r=this.settings.maxImagesPerCall)!=null?r:sd[this.modelId])!=null?e:1}get provider(){return this.config.provider}async doGenerate({prompt:r,n:e,size:t,aspectRatio:n,seed:o,providerOptions:s,headers:i,abortSignal:a}){var l,u,d,c;let p=[];n!=null&&p.push({type:"unsupported-setting",setting:"aspectRatio",details:"This model does not support aspect ratio. Use `size` instead."}),o!=null&&p.push({type:"unsupported-setting",setting:"seed"});let f=(d=(u=(l=this.config._internal)==null?void 0:l.currentDate)==null?void 0:u.call(l))!=null?d:new Date,{value:v,responseHeaders:h}=await(0, Qr.postJsonToApi)({url:this.config.url({path:"/images/generations",modelId:this.modelId}),headers:(0, Qr.combineHeaders)(this.config.headers(),i),body:{model:this.modelId,prompt:r,n:e,size:t,...(c=s.openai)!=null?c:{},...id.has(this.modelId)?{}:{response_format:"b64_json"}},failedResponseHandler:be,successfulResponseHandler:(0, Qr.createJsonResponseHandler)(ld),abortSignal:a,fetch:this.config.fetch});return {images:v.data.map(m=>m.b64_json),warnings:p,response:{timestamp:f,modelId:this.modelId,headers:h}}}},ld=ar.z.object({data:ar.z.array(ar.z.object({b64_json:ar.z.string()}))}),xt=Q(),ee=W("zod"),ud=ee.z.object({include:ee.z.array(ee.z.string()).nullish(),language:ee.z.string().nullish(),prompt:ee.z.string().nullish(),temperature:ee.z.number().min(0).max(1).nullish().default(0),timestampGranularities:ee.z.array(ee.z.enum(["word","segment"])).nullish().default(["segment"])}),ys={afrikaans:"af",arabic:"ar",armenian:"hy",azerbaijani:"az",belarusian:"be",bosnian:"bs",bulgarian:"bg",catalan:"ca",chinese:"zh",croatian:"hr",czech:"cs",danish:"da",dutch:"nl",english:"en",estonian:"et",finnish:"fi",french:"fr",galician:"gl",german:"de",greek:"el",hebrew:"he",hindi:"hi",hungarian:"hu",icelandic:"is",indonesian:"id",italian:"it",japanese:"ja",kannada:"kn",kazakh:"kk",korean:"ko",latvian:"lv",lithuanian:"lt",macedonian:"mk",malay:"ms",marathi:"mr",maori:"mi",nepali:"ne",norwegian:"no",persian:"fa",polish:"pl",portuguese:"pt",romanian:"ro",russian:"ru",serbian:"sr",slovak:"sk",slovenian:"sl",spanish:"es",swahili:"sw",swedish:"sv",tagalog:"tl",tamil:"ta",thai:"th",turkish:"tr",ukrainian:"uk",urdu:"ur",vietnamese:"vi",welsh:"cy"},dd=class{constructor(r,e){this.modelId=r,this.config=e,this.specificationVersion="v1";}get provider(){return this.config.provider}getArgs({audio:r,mediaType:e,providerOptions:t}){var n,o,s,i,a;let l=[],u=(0, xt.parseProviderOptions)({provider:"openai",providerOptions:t,schema:ud}),d=new FormData,c=r instanceof Uint8Array?new Blob([r]):new Blob([(0, xt.convertBase64ToUint8Array)(r)]);if(d.append("model",this.modelId),d.append("file",new File([c],"audio",{type:e})),u){let p={include:(n=u.include)!=null?n:void 0,language:(o=u.language)!=null?o:void 0,prompt:(s=u.prompt)!=null?s:void 0,temperature:(i=u.temperature)!=null?i:void 0,timestamp_granularities:(a=u.timestampGranularities)!=null?a:void 0};for(let f in p){let v=p[f];v!==void 0&&d.append(f,String(v));}}return {formData:d,warnings:l}}async doGenerate(r){var e,t,n,o,s,i;let a=(n=(t=(e=this.config._internal)==null?void 0:e.currentDate)==null?void 0:t.call(e))!=null?n:new Date,{formData:l,warnings:u}=this.getArgs(r),{value:d,responseHeaders:c,rawValue:p}=await(0, xt.postFormDataToApi)({url:this.config.url({path:"/audio/transcriptions",modelId:this.modelId}),headers:(0, xt.combineHeaders)(this.config.headers(),r.headers),formData:l,failedResponseHandler:be,successfulResponseHandler:(0, xt.createJsonResponseHandler)(cd),abortSignal:r.abortSignal,fetch:this.config.fetch}),f=d.language!=null&&d.language in ys?ys[d.language]:void 0;return {text:d.text,segments:(s=(o=d.words)==null?void 0:o.map(v=>({text:v.word,startSecond:v.start,endSecond:v.end})))!=null?s:[],language:f,durationInSeconds:(i=d.duration)!=null?i:void 0,warnings:u,response:{timestamp:a,modelId:this.modelId,headers:c,body:p}}}},cd=ee.z.object({text:ee.z.string(),language:ee.z.string().nullish(),duration:ee.z.number().nullish(),words:ee.z.array(ee.z.object({word:ee.z.string(),start:ee.z.number(),end:ee.z.number()})).nullish()}),pd=B(),Se=Q(),b=W("zod"),vs=B(),gd=Q();function md({prompt:r,systemMessageMode:e}){let t=[],n=[];for(let{role:o,content:s}of r)switch(o){case "system":{switch(e){case "system":{t.push({role:"system",content:s});break}case "developer":{t.push({role:"developer",content:s});break}case "remove":{n.push({type:"other",message:"system messages are removed for this model"});break}default:{let i=e;throw new Error(`Unsupported system message mode: ${i}`)}}break}case "user":{t.push({role:"user",content:s.map((i,a)=>{var l,u,d,c;switch(i.type){case "text":return {type:"input_text",text:i.text};case "image":return {type:"input_image",image_url:i.image instanceof URL?i.image.toString():`data:${(l=i.mimeType)!=null?l:"image/jpeg"};base64,${(0, gd.convertUint8ArrayToBase64)(i.image)}`,detail:(d=(u=i.providerMetadata)==null?void 0:u.openai)==null?void 0:d.imageDetail};case "file":{if(i.data instanceof URL)throw new vs.UnsupportedFunctionalityError({functionality:"File URLs in user messages"});if(i.mimeType==="application/pdf")return {type:"input_file",filename:(c=i.filename)!=null?c:`part-${a}.pdf`,file_data:`data:application/pdf;base64,${i.data}`};throw new vs.UnsupportedFunctionalityError({functionality:"Only PDF files are supported in user messages"})}}})});break}case "assistant":{for(let i of s)switch(i.type){case "text":{t.push({role:"assistant",content:[{type:"output_text",text:i.text}]});break}case "tool-call":{t.push({type:"function_call",call_id:i.toolCallId,name:i.toolName,arguments:JSON.stringify(i.args)});break}}break}case "tool":{for(let i of s)t.push({type:"function_call_output",call_id:i.toolCallId,output:JSON.stringify(i.result)});break}default:{let i=o;throw new Error(`Unsupported role: ${i}`)}}return {messages:t,warnings:n}}function _s({finishReason:r,hasToolCalls:e}){switch(r){case void 0:case null:return e?"tool-calls":"stop";case "max_output_tokens":return "length";case "content_filter":return "content-filter";default:return e?"tool-calls":"unknown"}}var fd=B();function hd({mode:r,strict:e}){var t;let n=(t=r.tools)!=null&&t.length?r.tools:void 0,o=[];if(n==null)return {tools:void 0,tool_choice:void 0,toolWarnings:o};let s=r.toolChoice,i=[];for(let l of n)switch(l.type){case "function":i.push({type:"function",name:l.name,description:l.description,parameters:l.parameters,strict:e?true:void 0});break;case "provider-defined":l.id==="openai.web_search_preview"?i.push({type:"web_search_preview",search_context_size:l.args.searchContextSize,user_location:l.args.userLocation}):o.push({type:"unsupported-tool",tool:l});break;default:o.push({type:"unsupported-tool",tool:l});break}if(s==null)return {tools:i,tool_choice:void 0,toolWarnings:o};let a=s.type;switch(a){case "auto":case "none":case "required":return {tools:i,tool_choice:a,toolWarnings:o};case "tool":return s.toolName==="web_search_preview"?{tools:i,tool_choice:{type:"web_search_preview"},toolWarnings:o}:{tools:i,tool_choice:{type:"function",name:s.toolName},toolWarnings:o};default:{let l=a;throw new fd.UnsupportedFunctionalityError({functionality:`Unsupported tool choice type: ${l}`})}}}var yd=class{constructor(r,e){this.specificationVersion="v1",this.defaultObjectGenerationMode="json",this.supportsStructuredOutputs=true,this.modelId=r,this.config=e;}get provider(){return this.config.provider}getArgs({mode:r,maxTokens:e,temperature:t,stopSequences:n,topP:o,topK:s,presencePenalty:i,frequencyPenalty:a,seed:l,prompt:u,providerMetadata:d,responseFormat:c}){var p,f,v;let h=[],m=Dd(this.modelId),y=r.type;s!=null&&h.push({type:"unsupported-setting",setting:"topK"}),l!=null&&h.push({type:"unsupported-setting",setting:"seed"}),i!=null&&h.push({type:"unsupported-setting",setting:"presencePenalty"}),a!=null&&h.push({type:"unsupported-setting",setting:"frequencyPenalty"}),n!=null&&h.push({type:"unsupported-setting",setting:"stopSequences"});let{messages:w,warnings:C}=md({prompt:u,systemMessageMode:m.systemMessageMode});h.push(...C);let _=(0, Se.parseProviderOptions)({provider:"openai",providerOptions:d,schema:$d}),k=(p=_?.strictSchemas)!=null?p:true,E={model:this.modelId,input:w,temperature:t,top_p:o,max_output_tokens:e,...c?.type==="json"&&{text:{format:c.schema!=null?{type:"json_schema",strict:k,name:(f=c.name)!=null?f:"response",description:c.description,schema:c.schema}:{type:"json_object"}}},metadata:_?.metadata,parallel_tool_calls:_?.parallelToolCalls,previous_response_id:_?.previousResponseId,store:_?.store,user:_?.user,instructions:_?.instructions,...m.isReasoningModel&&(_?.reasoningEffort!=null||_?.reasoningSummary!=null)&&{reasoning:{..._?.reasoningEffort!=null&&{effort:_.reasoningEffort},..._?.reasoningSummary!=null&&{summary:_.reasoningSummary}}},...m.requiredAutoTruncation};switch(m.isReasoningModel&&(E.temperature!=null&&(E.temperature=void 0,h.push({type:"unsupported-setting",setting:"temperature",details:"temperature is not supported for reasoning models"})),E.top_p!=null&&(E.top_p=void 0,h.push({type:"unsupported-setting",setting:"topP",details:"topP is not supported for reasoning models"}))),y){case "regular":{let{tools:O,tool_choice:R,toolWarnings:x}=hd({mode:r,strict:k});return {args:{...E,tools:O,tool_choice:R},warnings:[...h,...x]}}case "object-json":return {args:{...E,text:{format:r.schema!=null?{type:"json_schema",strict:k,name:(v=r.name)!=null?v:"response",description:r.description,schema:r.schema}:{type:"json_object"}}},warnings:h};case "object-tool":return {args:{...E,tool_choice:{type:"function",name:r.tool.name},tools:[{type:"function",name:r.tool.name,description:r.tool.description,parameters:r.tool.parameters,strict:k}]},warnings:h};default:{let O=y;throw new Error(`Unsupported type: ${O}`)}}}async doGenerate(r){var e,t,n,o,s,i,a;let{args:l,warnings:u}=this.getArgs(r),d=this.config.url({path:"/responses",modelId:this.modelId}),{responseHeaders:c,value:p,rawValue:f}=await(0, Se.postJsonToApi)({url:d,headers:(0, Se.combineHeaders)(this.config.headers(),r.headers),body:l,failedResponseHandler:be,successfulResponseHandler:(0, Se.createJsonResponseHandler)(b.z.object({id:b.z.string(),created_at:b.z.number(),error:b.z.object({message:b.z.string(),code:b.z.string()}).nullish(),model:b.z.string(),output:b.z.array(b.z.discriminatedUnion("type",[b.z.object({type:b.z.literal("message"),role:b.z.literal("assistant"),content:b.z.array(b.z.object({type:b.z.literal("output_text"),text:b.z.string(),annotations:b.z.array(b.z.object({type:b.z.literal("url_citation"),start_index:b.z.number(),end_index:b.z.number(),url:b.z.string(),title:b.z.string()}))}))}),b.z.object({type:b.z.literal("function_call"),call_id:b.z.string(),name:b.z.string(),arguments:b.z.string()}),b.z.object({type:b.z.literal("web_search_call")}),b.z.object({type:b.z.literal("computer_call")}),b.z.object({type:b.z.literal("reasoning"),summary:b.z.array(b.z.object({type:b.z.literal("summary_text"),text:b.z.string()}))})])),incomplete_details:b.z.object({reason:b.z.string()}).nullable(),usage:xs})),abortSignal:r.abortSignal,fetch:this.config.fetch});if(p.error)throw new pd.APICallError({message:p.error.message,url:d,requestBodyValues:l,statusCode:400,responseHeaders:c,responseBody:f,isRetryable:false});let v=p.output.filter(y=>y.type==="message").flatMap(y=>y.content).filter(y=>y.type==="output_text"),h=p.output.filter(y=>y.type==="function_call").map(y=>({toolCallType:"function",toolCallId:y.call_id,toolName:y.name,args:y.arguments})),m=(t=(e=p.output.find(y=>y.type==="reasoning"))==null?void 0:e.summary)!=null?t:null;return {text:v.map(y=>y.text).join(`
|
|
45
|
-
`),sources:v.flatMap(y=>y.annotations.map(w=>{var C,_,k;return {sourceType:"url",id:(k=(_=(C=this.config).generateId)==null?void 0:_.call(C))!=null?k:(0, Se.generateId)(),url:w.url,title:w.title}})),finishReason:_s({finishReason:(n=p.incomplete_details)==null?void 0:n.reason,hasToolCalls:h.length>0}),toolCalls:h.length>0?h:void 0,reasoning:m?m.map(y=>({type:"text",text:y.text})):void 0,usage:{promptTokens:p.usage.input_tokens,completionTokens:p.usage.output_tokens},rawCall:{rawPrompt:void 0,rawSettings:{}},rawResponse:{headers:c,body:f},request:{body:JSON.stringify(l)},response:{id:p.id,timestamp:new Date(p.created_at*1e3),modelId:p.model},providerMetadata:{openai:{responseId:p.id,cachedPromptTokens:(s=(o=p.usage.input_tokens_details)==null?void 0:o.cached_tokens)!=null?s:null,reasoningTokens:(a=(i=p.usage.output_tokens_details)==null?void 0:i.reasoning_tokens)!=null?a:null}},warnings:u}}async doStream(r){let{args:e,warnings:t}=this.getArgs(r),{responseHeaders:n,value:o}=await(0, Se.postJsonToApi)({url:this.config.url({path:"/responses",modelId:this.modelId}),headers:(0, Se.combineHeaders)(this.config.headers(),r.headers),body:{...e,stream:true},failedResponseHandler:be,successfulResponseHandler:(0, Se.createEventSourceResponseHandler)(Pd),abortSignal:r.abortSignal,fetch:this.config.fetch}),s=this,i="unknown",a=NaN,l=NaN,u=null,d=null,c=null,p={},f=false;return {stream:o.pipeThrough(new TransformStream({transform(v,h){var m,y,w,C,_,k,E,O;if(!v.success){i="error",h.enqueue({type:"error",error:v.error});return}let R=v.value;if(zd(R))R.item.type==="function_call"&&(p[R.output_index]={toolName:R.item.name,toolCallId:R.item.call_id},h.enqueue({type:"tool-call-delta",toolCallType:"function",toolCallId:R.item.call_id,toolName:R.item.name,argsTextDelta:R.item.arguments}));else if(Od(R)){let x=p[R.output_index];x!=null&&h.enqueue({type:"tool-call-delta",toolCallType:"function",toolCallId:x.toolCallId,toolName:x.toolName,argsTextDelta:R.delta});}else Id(R)?(c=R.response.id,h.enqueue({type:"response-metadata",id:R.response.id,timestamp:new Date(R.response.created_at*1e3),modelId:R.response.model})):Ad(R)?h.enqueue({type:"text-delta",textDelta:R.delta}):jd(R)?h.enqueue({type:"reasoning",textDelta:R.delta}):Ed(R)&&R.item.type==="function_call"?(p[R.output_index]=void 0,f=true,h.enqueue({type:"tool-call",toolCallType:"function",toolCallId:R.item.call_id,toolName:R.item.name,args:R.item.arguments})):Sd(R)?(i=_s({finishReason:(m=R.response.incomplete_details)==null?void 0:m.reason,hasToolCalls:f}),a=R.response.usage.input_tokens,l=R.response.usage.output_tokens,u=(w=(y=R.response.usage.input_tokens_details)==null?void 0:y.cached_tokens)!=null?w:u,d=(_=(C=R.response.usage.output_tokens_details)==null?void 0:C.reasoning_tokens)!=null?_:d):Md(R)?h.enqueue({type:"source",source:{sourceType:"url",id:(O=(E=(k=s.config).generateId)==null?void 0:E.call(k))!=null?O:(0, Se.generateId)(),url:R.annotation.url,title:R.annotation.title}}):Nd(R)&&h.enqueue({type:"error",error:R});},flush(v){v.enqueue({type:"finish",finishReason:i,usage:{promptTokens:a,completionTokens:l},...(u!=null||d!=null)&&{providerMetadata:{openai:{responseId:c,cachedPromptTokens:u,reasoningTokens:d}}}});}})),rawCall:{rawPrompt:void 0,rawSettings:{}},rawResponse:{headers:n},request:{body:JSON.stringify(e)},warnings:t}}},xs=b.z.object({input_tokens:b.z.number(),input_tokens_details:b.z.object({cached_tokens:b.z.number().nullish()}).nullish(),output_tokens:b.z.number(),output_tokens_details:b.z.object({reasoning_tokens:b.z.number().nullish()}).nullish()}),vd=b.z.object({type:b.z.literal("response.output_text.delta"),delta:b.z.string()}),_d=b.z.object({type:b.z.enum(["response.completed","response.incomplete"]),response:b.z.object({incomplete_details:b.z.object({reason:b.z.string()}).nullish(),usage:xs})}),wd=b.z.object({type:b.z.literal("response.created"),response:b.z.object({id:b.z.string(),created_at:b.z.number(),model:b.z.string()})}),bd=b.z.object({type:b.z.literal("response.output_item.done"),output_index:b.z.number(),item:b.z.discriminatedUnion("type",[b.z.object({type:b.z.literal("message")}),b.z.object({type:b.z.literal("function_call"),id:b.z.string(),call_id:b.z.string(),name:b.z.string(),arguments:b.z.string(),status:b.z.literal("completed")})])}),xd=b.z.object({type:b.z.literal("response.function_call_arguments.delta"),item_id:b.z.string(),output_index:b.z.number(),delta:b.z.string()}),kd=b.z.object({type:b.z.literal("response.output_item.added"),output_index:b.z.number(),item:b.z.discriminatedUnion("type",[b.z.object({type:b.z.literal("message")}),b.z.object({type:b.z.literal("function_call"),id:b.z.string(),call_id:b.z.string(),name:b.z.string(),arguments:b.z.string()})])}),Rd=b.z.object({type:b.z.literal("response.output_text.annotation.added"),annotation:b.z.object({type:b.z.literal("url_citation"),url:b.z.string(),title:b.z.string()})}),Cd=b.z.object({type:b.z.literal("response.reasoning_summary_text.delta"),item_id:b.z.string(),output_index:b.z.number(),summary_index:b.z.number(),delta:b.z.string()}),Td=b.z.object({type:b.z.literal("error"),code:b.z.string(),message:b.z.string(),param:b.z.string().nullish(),sequence_number:b.z.number()}),Pd=b.z.union([vd,_d,wd,bd,xd,kd,Rd,Cd,Td,b.z.object({type:b.z.string()}).passthrough()]);function Ad(r){return r.type==="response.output_text.delta"}function Ed(r){return r.type==="response.output_item.done"}function Sd(r){return r.type==="response.completed"||r.type==="response.incomplete"}function Id(r){return r.type==="response.created"}function Od(r){return r.type==="response.function_call_arguments.delta"}function zd(r){return r.type==="response.output_item.added"}function Md(r){return r.type==="response.output_text.annotation.added"}function jd(r){return r.type==="response.reasoning_summary_text.delta"}function Nd(r){return r.type==="error"}function Dd(r){return r.startsWith("o")||r.startsWith("gpt-5")?r.startsWith("o1-mini")||r.startsWith("o1-preview")?{isReasoningModel:true,systemMessageMode:"remove",requiredAutoTruncation:false}:{isReasoningModel:true,systemMessageMode:"developer",requiredAutoTruncation:false}:{isReasoningModel:false,systemMessageMode:"system",requiredAutoTruncation:false}}var $d=b.z.object({metadata:b.z.any().nullish(),parallelToolCalls:b.z.boolean().nullish(),previousResponseId:b.z.string().nullish(),store:b.z.boolean().nullish(),user:b.z.string().nullish(),reasoningEffort:b.z.string().nullish(),strictSchemas:b.z.boolean().nullish(),instructions:b.z.string().nullish(),reasoningSummary:b.z.string().nullish()}),Hd=W("zod"),qd=Hd.z.object({});function Ld({searchContextSize:r,userLocation:e}={}){return {type:"provider-defined",id:"openai.web_search_preview",args:{searchContextSize:r,userLocation:e},parameters:qd}}var Ud={webSearchPreview:Ld},lr=Q(),Zr=W("zod"),Fd=Zr.z.object({instructions:Zr.z.string().nullish(),speed:Zr.z.number().min(.25).max(4).default(1).nullish()}),Bd=class{constructor(r,e){this.modelId=r,this.config=e,this.specificationVersion="v1";}get provider(){return this.config.provider}getArgs({text:r,voice:e="alloy",outputFormat:t="mp3",speed:n,instructions:o,providerOptions:s}){let i=[],a=(0, lr.parseProviderOptions)({provider:"openai",providerOptions:s,schema:Fd}),l={model:this.modelId,input:r,voice:e,response_format:"mp3",speed:n,instructions:o};if(t&&(["mp3","opus","aac","flac","wav","pcm"].includes(t)?l.response_format=t:i.push({type:"unsupported-setting",setting:"outputFormat",details:`Unsupported output format: ${t}. Using mp3 instead.`})),a){let u={};for(let d in u){let c=u[d];c!==void 0&&(l[d]=c);}}return {requestBody:l,warnings:i}}async doGenerate(r){var e,t,n;let o=(n=(t=(e=this.config._internal)==null?void 0:e.currentDate)==null?void 0:t.call(e))!=null?n:new Date,{requestBody:s,warnings:i}=this.getArgs(r),{value:a,responseHeaders:l,rawValue:u}=await(0, lr.postJsonToApi)({url:this.config.url({path:"/audio/speech",modelId:this.modelId}),headers:(0, lr.combineHeaders)(this.config.headers(),r.headers),body:s,failedResponseHandler:be,successfulResponseHandler:(0, lr.createBinaryResponseHandler)(),abortSignal:r.abortSignal,fetch:this.config.fetch});return {audio:a,warnings:i,request:{body:JSON.stringify(s)},response:{timestamp:o,modelId:this.modelId,headers:l,body:u}}}};function ks(r={}){var e,t,n;let o=(e=(0, gs.withoutTrailingSlash)(r.baseURL))!=null?e:"https://api.openai.com/v1",s=(t=r.compatibility)!=null?t:"compatible",i=(n=r.name)!=null?n:"openai",a=()=>({Authorization:`Bearer ${(0, gs.loadApiKey)({apiKey:r.apiKey,environmentVariableName:"OPENAI_API_KEY",description:"OpenAI"})}`,"OpenAI-Organization":r.organization,"OpenAI-Project":r.project,...r.headers}),l=(y,w={})=>new Ju(y,w,{provider:`${i}.chat`,url:({path:C})=>`${o}${C}`,headers:a,compatibility:s,fetch:r.fetch}),u=(y,w={})=>new Zu(y,w,{provider:`${i}.completion`,url:({path:C})=>`${o}${C}`,headers:a,compatibility:s,fetch:r.fetch}),d=(y,w={})=>new nd(y,w,{provider:`${i}.embedding`,url:({path:C})=>`${o}${C}`,headers:a,fetch:r.fetch}),c=(y,w={})=>new ad(y,w,{provider:`${i}.image`,url:({path:C})=>`${o}${C}`,headers:a,fetch:r.fetch}),p=y=>new dd(y,{provider:`${i}.transcription`,url:({path:w})=>`${o}${w}`,headers:a,fetch:r.fetch}),f=y=>new Bd(y,{provider:`${i}.speech`,url:({path:w})=>`${o}${w}`,headers:a,fetch:r.fetch}),v=(y,w)=>{if(new.target)throw new Error("The OpenAI model function cannot be called with the new keyword.");return y==="gpt-3.5-turbo-instruct"?u(y,w):l(y,w)},h=y=>new yd(y,{provider:`${i}.responses`,url:({path:w})=>`${o}${w}`,headers:a,fetch:r.fetch}),m=function(y,w){return v(y,w)};return m.languageModel=v,m.chat=l,m.completion=u,m.responses=h,m.embedding=d,m.textEmbedding=d,m.textEmbeddingModel=d,m.image=c,m.imageModel=c,m.transcription=p,m.transcriptionModel=p,m.speech=f,m.speechModel=f,m.tools=Ud,m}var Wd=ks({compatibility:"strict"});});var zs=De((My,Os)=>{g();var on=Object.defineProperty,Jd=Object.getOwnPropertyDescriptor,Vd=Object.getOwnPropertyNames,Kd=Object.prototype.hasOwnProperty,Gd=(r,e)=>{for(var t in e)on(r,t,{get:e[t],enumerable:true});},Xd=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Vd(e))!Kd.call(r,o)&&o!==t&&on(r,o,{get:()=>e[o],enumerable:!(n=Jd(e,o))||n.enumerable});return r},Yd=r=>Xd(on({},"__esModule",{value:true}),r),Ss={};Gd(Ss,{anthropic:()=>kc,createAnthropic:()=>Is});Os.exports=Yd(Ss);var Qd=B(),Cs=Q(),Ts=B(),Xe=Q(),T=W("zod"),Zd=Q(),kt=W("zod"),ec=kt.z.object({type:kt.z.literal("error"),error:kt.z.object({type:kt.z.string(),message:kt.z.string()})}),Ps=(0, Zd.createJsonErrorResponseHandler)({errorSchema:ec,errorToMessage:r=>r.error.message}),tc=B();function rc(r){var e;let t=(e=r.tools)!=null&&e.length?r.tools:void 0,n=[],o=new Set;if(t==null)return {tools:void 0,tool_choice:void 0,toolWarnings:n,betas:o};let s=[];for(let l of t)switch(l.type){case "function":s.push({name:l.name,description:l.description,input_schema:l.parameters});break;case "provider-defined":switch(l.id){case "anthropic.computer_20250124":o.add("computer-use-2025-01-24"),s.push({name:l.name,type:"computer_20250124",display_width_px:l.args.displayWidthPx,display_height_px:l.args.displayHeightPx,display_number:l.args.displayNumber});break;case "anthropic.computer_20241022":o.add("computer-use-2024-10-22"),s.push({name:l.name,type:"computer_20241022",display_width_px:l.args.displayWidthPx,display_height_px:l.args.displayHeightPx,display_number:l.args.displayNumber});break;case "anthropic.text_editor_20250124":o.add("computer-use-2025-01-24"),s.push({name:l.name,type:"text_editor_20250124"});break;case "anthropic.text_editor_20241022":o.add("computer-use-2024-10-22"),s.push({name:l.name,type:"text_editor_20241022"});break;case "anthropic.bash_20250124":o.add("computer-use-2025-01-24"),s.push({name:l.name,type:"bash_20250124"});break;case "anthropic.bash_20241022":o.add("computer-use-2024-10-22"),s.push({name:l.name,type:"bash_20241022"});break;default:n.push({type:"unsupported-tool",tool:l});break}break;default:n.push({type:"unsupported-tool",tool:l});break}let i=r.toolChoice;if(i==null)return {tools:s,tool_choice:void 0,toolWarnings:n,betas:o};let a=i.type;switch(a){case "auto":return {tools:s,tool_choice:{type:"auto"},toolWarnings:n,betas:o};case "required":return {tools:s,tool_choice:{type:"any"},toolWarnings:n,betas:o};case "none":return {tools:void 0,tool_choice:void 0,toolWarnings:n,betas:o};case "tool":return {tools:s,tool_choice:{type:"tool",name:i.toolName},toolWarnings:n,betas:o};default:{let l=a;throw new tc.UnsupportedFunctionalityError({functionality:`Unsupported tool choice type: ${l}`})}}}var As=B(),nc=Q();function oc({prompt:r,sendReasoning:e,warnings:t}){var n,o,s,i;let a=new Set,l=sc(r),u,d=[];function c(p){var f;let v=p?.anthropic;return (f=v?.cacheControl)!=null?f:v?.cache_control}for(let p=0;p<l.length;p++){let f=l[p],v=p===l.length-1,h=f.type;switch(h){case "system":{if(u!=null)throw new As.UnsupportedFunctionalityError({functionality:"Multiple system messages that are separated by user/assistant messages"});u=f.messages.map(({content:m,providerMetadata:y})=>({type:"text",text:m,cache_control:c(y)}));break}case "user":{let m=[];for(let y of f.messages){let{role:w,content:C}=y;switch(w){case "user":{for(let _=0;_<C.length;_++){let k=C[_],E=_===C.length-1,O=(n=c(k.providerMetadata))!=null?n:E?c(y.providerMetadata):void 0;switch(k.type){case "text":{m.push({type:"text",text:k.text,cache_control:O});break}case "image":{m.push({type:"image",source:k.image instanceof URL?{type:"url",url:k.image.toString()}:{type:"base64",media_type:(o=k.mimeType)!=null?o:"image/jpeg",data:(0, nc.convertUint8ArrayToBase64)(k.image)},cache_control:O});break}case "file":{if(k.mimeType!=="application/pdf")throw new As.UnsupportedFunctionalityError({functionality:"Non-PDF files in user messages"});a.add("pdfs-2024-09-25"),m.push({type:"document",source:k.data instanceof URL?{type:"url",url:k.data.toString()}:{type:"base64",media_type:"application/pdf",data:k.data},cache_control:O});break}}}break}case "tool":{for(let _=0;_<C.length;_++){let k=C[_],E=_===C.length-1,O=(s=c(k.providerMetadata))!=null?s:E?c(y.providerMetadata):void 0,R=k.content!=null?k.content.map(x=>{var z;switch(x.type){case "text":return {type:"text",text:x.text,cache_control:void 0};case "image":return {type:"image",source:{type:"base64",media_type:(z=x.mimeType)!=null?z:"image/jpeg",data:x.data},cache_control:void 0}}}):JSON.stringify(k.result);m.push({type:"tool_result",tool_use_id:k.toolCallId,content:R,is_error:k.isError,cache_control:O});}break}default:{let _=w;throw new Error(`Unsupported role: ${_}`)}}}d.push({role:"user",content:m});break}case "assistant":{let m=[];for(let y=0;y<f.messages.length;y++){let w=f.messages[y],C=y===f.messages.length-1,{content:_}=w;for(let k=0;k<_.length;k++){let E=_[k],O=k===_.length-1,R=(i=c(E.providerMetadata))!=null?i:O?c(w.providerMetadata):void 0;switch(E.type){case "text":{m.push({type:"text",text:v&&C&&O?E.text.trim():E.text,cache_control:R});break}case "reasoning":{e?m.push({type:"thinking",thinking:E.text,signature:E.signature,cache_control:R}):t.push({type:"other",message:"sending reasoning content is disabled for this model"});break}case "redacted-reasoning":{m.push({type:"redacted_thinking",data:E.data,cache_control:R});break}case "tool-call":{m.push({type:"tool_use",id:E.toolCallId,name:E.toolName,input:E.args,cache_control:R});break}}}}d.push({role:"assistant",content:m});break}default:{let m=h;throw new Error(`Unsupported type: ${m}`)}}}return {prompt:{system:u,messages:d},betas:a}}function sc(r){let e=[],t;for(let n of r){let{role:o}=n;switch(o){case "system":{t?.type!=="system"&&(t={type:"system",messages:[]},e.push(t)),t.messages.push(n);break}case "assistant":{t?.type!=="assistant"&&(t={type:"assistant",messages:[]},e.push(t)),t.messages.push(n);break}case "user":{t?.type!=="user"&&(t={type:"user",messages:[]},e.push(t)),t.messages.push(n);break}case "tool":{t?.type!=="user"&&(t={type:"user",messages:[]},e.push(t)),t.messages.push(n);break}default:{let s=o;throw new Error(`Unsupported role: ${s}`)}}}return e}function Es(r){switch(r){case "end_turn":case "stop_sequence":return "stop";case "tool_use":return "tool-calls";case "max_tokens":return "length";default:return "unknown"}}var ic=class{constructor(r,e,t){this.specificationVersion="v1",this.defaultObjectGenerationMode="tool",this.modelId=r,this.settings=e,this.config=t;}supportsUrl(r){return r.protocol==="https:"}get provider(){return this.config.provider}get supportsImageUrls(){return this.config.supportsImageUrls}async getArgs({mode:r,prompt:e,maxTokens:t=4096,temperature:n,topP:o,topK:s,frequencyPenalty:i,presencePenalty:a,stopSequences:l,responseFormat:u,seed:d,providerMetadata:c}){var p,f,v;let h=r.type,m=[];i!=null&&m.push({type:"unsupported-setting",setting:"frequencyPenalty"}),a!=null&&m.push({type:"unsupported-setting",setting:"presencePenalty"}),d!=null&&m.push({type:"unsupported-setting",setting:"seed"}),u!=null&&u.type!=="text"&&m.push({type:"unsupported-setting",setting:"responseFormat",details:"JSON response format is not supported."});let{prompt:y,betas:w}=oc({prompt:e,sendReasoning:(p=this.settings.sendReasoning)!=null?p:true,warnings:m}),C=(0, Xe.parseProviderOptions)({provider:"anthropic",providerOptions:c,schema:uc}),_=((f=C?.thinking)==null?void 0:f.type)==="enabled",k=(v=C?.thinking)==null?void 0:v.budgetTokens,E={model:this.modelId,max_tokens:t,temperature:n,top_k:s,top_p:o,stop_sequences:l,..._&&{thinking:{type:"enabled",budget_tokens:k}},system:y.system,messages:y.messages};if(_){if(k==null)throw new Ts.UnsupportedFunctionalityError({functionality:"thinking requires a budget"});E.temperature!=null&&(E.temperature=void 0,m.push({type:"unsupported-setting",setting:"temperature",details:"temperature is not supported when thinking is enabled"})),s!=null&&(E.top_k=void 0,m.push({type:"unsupported-setting",setting:"topK",details:"topK is not supported when thinking is enabled"})),o!=null&&(E.top_p=void 0,m.push({type:"unsupported-setting",setting:"topP",details:"topP is not supported when thinking is enabled"})),E.max_tokens=t+k;}switch(h){case "regular":{let{tools:O,tool_choice:R,toolWarnings:x,betas:z}=rc(r);return {args:{...E,tools:O,tool_choice:R},warnings:[...m,...x],betas:new Set([...w,...z])}}case "object-json":throw new Ts.UnsupportedFunctionalityError({functionality:"json-mode object generation"});case "object-tool":{let{name:O,description:R,parameters:x}=r.tool;return {args:{...E,tools:[{name:O,description:R,input_schema:x}],tool_choice:{type:"tool",name:O}},warnings:m,betas:w}}default:{let O=h;throw new Error(`Unsupported type: ${O}`)}}}async getHeaders({betas:r,headers:e}){return (0, Xe.combineHeaders)(await(0, Xe.resolve)(this.config.headers),r.size>0?{"anthropic-beta":Array.from(r).join(",")}:{},e)}buildRequestUrl(r){var e,t,n;return (n=(t=(e=this.config).buildRequestUrl)==null?void 0:t.call(e,this.config.baseURL,r))!=null?n:`${this.config.baseURL}/messages`}transformRequestBody(r){var e,t,n;return (n=(t=(e=this.config).transformRequestBody)==null?void 0:t.call(e,r))!=null?n:r}async doGenerate(r){var e,t,n,o;let{args:s,warnings:i,betas:a}=await this.getArgs(r),{responseHeaders:l,value:u,rawValue:d}=await(0, Xe.postJsonToApi)({url:this.buildRequestUrl(false),headers:await this.getHeaders({betas:a,headers:r.headers}),body:this.transformRequestBody(s),failedResponseHandler:Ps,successfulResponseHandler:(0, Xe.createJsonResponseHandler)(ac),abortSignal:r.abortSignal,fetch:this.config.fetch}),{messages:c,...p}=s,f="";for(let m of u.content)m.type==="text"&&(f+=m.text);let v;if(u.content.some(m=>m.type==="tool_use")){v=[];for(let m of u.content)m.type==="tool_use"&&v.push({toolCallType:"function",toolCallId:m.id,toolName:m.name,args:JSON.stringify(m.input)});}let h=u.content.filter(m=>m.type==="redacted_thinking"||m.type==="thinking").map(m=>m.type==="thinking"?{type:"text",text:m.thinking,signature:m.signature}:{type:"redacted",data:m.data});return {text:f,reasoning:h.length>0?h:void 0,toolCalls:v,finishReason:Es(u.stop_reason),usage:{promptTokens:u.usage.input_tokens,completionTokens:u.usage.output_tokens},rawCall:{rawPrompt:c,rawSettings:p},rawResponse:{headers:l,body:d},response:{id:(e=u.id)!=null?e:void 0,modelId:(t=u.model)!=null?t:void 0},warnings:i,providerMetadata:{anthropic:{cacheCreationInputTokens:(n=u.usage.cache_creation_input_tokens)!=null?n:null,cacheReadInputTokens:(o=u.usage.cache_read_input_tokens)!=null?o:null}},request:{body:JSON.stringify(s)}}}async doStream(r){let{args:e,warnings:t,betas:n}=await this.getArgs(r),o={...e,stream:true},{responseHeaders:s,value:i}=await(0, Xe.postJsonToApi)({url:this.buildRequestUrl(true),headers:await this.getHeaders({betas:n,headers:r.headers}),body:this.transformRequestBody(o),failedResponseHandler:Ps,successfulResponseHandler:(0, Xe.createEventSourceResponseHandler)(lc),abortSignal:r.abortSignal,fetch:this.config.fetch}),{messages:a,...l}=e,u="unknown",d={promptTokens:Number.NaN,completionTokens:Number.NaN},c={},p,f;return {stream:i.pipeThrough(new TransformStream({transform(v,h){var m,y,w,C;if(!v.success){h.enqueue({type:"error",error:v.error});return}let _=v.value;switch(_.type){case "ping":return;case "content_block_start":{let k=_.content_block.type;switch(f=k,k){case "text":case "thinking":return;case "redacted_thinking":{h.enqueue({type:"redacted-reasoning",data:_.content_block.data});return}case "tool_use":{c[_.index]={toolCallId:_.content_block.id,toolName:_.content_block.name,jsonText:""};return}default:{let E=k;throw new Error(`Unsupported content block type: ${E}`)}}}case "content_block_stop":{if(c[_.index]!=null){let k=c[_.index];h.enqueue({type:"tool-call",toolCallType:"function",toolCallId:k.toolCallId,toolName:k.toolName,args:k.jsonText}),delete c[_.index];}f=void 0;return}case "content_block_delta":{let k=_.delta.type;switch(k){case "text_delta":{h.enqueue({type:"text-delta",textDelta:_.delta.text});return}case "thinking_delta":{h.enqueue({type:"reasoning",textDelta:_.delta.thinking});return}case "signature_delta":{f==="thinking"&&h.enqueue({type:"reasoning-signature",signature:_.delta.signature});return}case "input_json_delta":{let E=c[_.index];h.enqueue({type:"tool-call-delta",toolCallType:"function",toolCallId:E.toolCallId,toolName:E.toolName,argsTextDelta:_.delta.partial_json}),E.jsonText+=_.delta.partial_json;return}default:{let E=k;throw new Error(`Unsupported delta type: ${E}`)}}}case "message_start":{d.promptTokens=_.message.usage.input_tokens,d.completionTokens=_.message.usage.output_tokens,p={anthropic:{cacheCreationInputTokens:(m=_.message.usage.cache_creation_input_tokens)!=null?m:null,cacheReadInputTokens:(y=_.message.usage.cache_read_input_tokens)!=null?y:null}},h.enqueue({type:"response-metadata",id:(w=_.message.id)!=null?w:void 0,modelId:(C=_.message.model)!=null?C:void 0});return}case "message_delta":{d.completionTokens=_.usage.output_tokens,u=Es(_.delta.stop_reason);return}case "message_stop":{h.enqueue({type:"finish",finishReason:u,usage:d,providerMetadata:p});return}case "error":{h.enqueue({type:"error",error:_.error});return}default:{let k=_;throw new Error(`Unsupported chunk type: ${k}`)}}}})),rawCall:{rawPrompt:a,rawSettings:l},rawResponse:{headers:s},warnings:t,request:{body:JSON.stringify(o)}}}},ac=T.z.object({type:T.z.literal("message"),id:T.z.string().nullish(),model:T.z.string().nullish(),content:T.z.array(T.z.discriminatedUnion("type",[T.z.object({type:T.z.literal("text"),text:T.z.string()}),T.z.object({type:T.z.literal("thinking"),thinking:T.z.string(),signature:T.z.string()}),T.z.object({type:T.z.literal("redacted_thinking"),data:T.z.string()}),T.z.object({type:T.z.literal("tool_use"),id:T.z.string(),name:T.z.string(),input:T.z.unknown()})])),stop_reason:T.z.string().nullish(),usage:T.z.object({input_tokens:T.z.number(),output_tokens:T.z.number(),cache_creation_input_tokens:T.z.number().nullish(),cache_read_input_tokens:T.z.number().nullish()})}),lc=T.z.discriminatedUnion("type",[T.z.object({type:T.z.literal("message_start"),message:T.z.object({id:T.z.string().nullish(),model:T.z.string().nullish(),usage:T.z.object({input_tokens:T.z.number(),output_tokens:T.z.number(),cache_creation_input_tokens:T.z.number().nullish(),cache_read_input_tokens:T.z.number().nullish()})})}),T.z.object({type:T.z.literal("content_block_start"),index:T.z.number(),content_block:T.z.discriminatedUnion("type",[T.z.object({type:T.z.literal("text"),text:T.z.string()}),T.z.object({type:T.z.literal("thinking"),thinking:T.z.string()}),T.z.object({type:T.z.literal("tool_use"),id:T.z.string(),name:T.z.string()}),T.z.object({type:T.z.literal("redacted_thinking"),data:T.z.string()})])}),T.z.object({type:T.z.literal("content_block_delta"),index:T.z.number(),delta:T.z.discriminatedUnion("type",[T.z.object({type:T.z.literal("input_json_delta"),partial_json:T.z.string()}),T.z.object({type:T.z.literal("text_delta"),text:T.z.string()}),T.z.object({type:T.z.literal("thinking_delta"),thinking:T.z.string()}),T.z.object({type:T.z.literal("signature_delta"),signature:T.z.string()})])}),T.z.object({type:T.z.literal("content_block_stop"),index:T.z.number()}),T.z.object({type:T.z.literal("error"),error:T.z.object({type:T.z.string(),message:T.z.string()})}),T.z.object({type:T.z.literal("message_delta"),delta:T.z.object({stop_reason:T.z.string().nullish()}),usage:T.z.object({output_tokens:T.z.number()})}),T.z.object({type:T.z.literal("message_stop")}),T.z.object({type:T.z.literal("ping")})]),uc=T.z.object({thinking:T.z.object({type:T.z.union([T.z.literal("enabled"),T.z.literal("disabled")]),budgetTokens:T.z.number().optional()}).optional()}),D=W("zod"),dc=D.z.object({command:D.z.string(),restart:D.z.boolean().optional()});function cc(r={}){return {type:"provider-defined",id:"anthropic.bash_20241022",args:{},parameters:dc,execute:r.execute,experimental_toToolResultContent:r.experimental_toToolResultContent}}var pc=D.z.object({command:D.z.string(),restart:D.z.boolean().optional()});function gc(r={}){return {type:"provider-defined",id:"anthropic.bash_20250124",args:{},parameters:pc,execute:r.execute,experimental_toToolResultContent:r.experimental_toToolResultContent}}var mc=D.z.object({command:D.z.enum(["view","create","str_replace","insert","undo_edit"]),path:D.z.string(),file_text:D.z.string().optional(),insert_line:D.z.number().int().optional(),new_str:D.z.string().optional(),old_str:D.z.string().optional(),view_range:D.z.array(D.z.number().int()).optional()});function fc(r={}){return {type:"provider-defined",id:"anthropic.text_editor_20241022",args:{},parameters:mc,execute:r.execute,experimental_toToolResultContent:r.experimental_toToolResultContent}}var hc=D.z.object({command:D.z.enum(["view","create","str_replace","insert","undo_edit"]),path:D.z.string(),file_text:D.z.string().optional(),insert_line:D.z.number().int().optional(),new_str:D.z.string().optional(),old_str:D.z.string().optional(),view_range:D.z.array(D.z.number().int()).optional()});function yc(r={}){return {type:"provider-defined",id:"anthropic.text_editor_20250124",args:{},parameters:hc,execute:r.execute,experimental_toToolResultContent:r.experimental_toToolResultContent}}var vc=D.z.object({action:D.z.enum(["key","type","mouse_move","left_click","left_click_drag","right_click","middle_click","double_click","screenshot","cursor_position"]),coordinate:D.z.array(D.z.number().int()).optional(),text:D.z.string().optional()});function _c(r){return {type:"provider-defined",id:"anthropic.computer_20241022",args:{displayWidthPx:r.displayWidthPx,displayHeightPx:r.displayHeightPx,displayNumber:r.displayNumber},parameters:vc,execute:r.execute,experimental_toToolResultContent:r.experimental_toToolResultContent}}var wc=D.z.object({action:D.z.enum(["key","hold_key","type","cursor_position","mouse_move","left_mouse_down","left_mouse_up","left_click","left_click_drag","right_click","middle_click","double_click","triple_click","scroll","wait","screenshot"]),coordinate:D.z.tuple([D.z.number().int(),D.z.number().int()]).optional(),duration:D.z.number().optional(),scroll_amount:D.z.number().optional(),scroll_direction:D.z.enum(["up","down","left","right"]).optional(),start_coordinate:D.z.tuple([D.z.number().int(),D.z.number().int()]).optional(),text:D.z.string().optional()});function bc(r){return {type:"provider-defined",id:"anthropic.computer_20250124",args:{displayWidthPx:r.displayWidthPx,displayHeightPx:r.displayHeightPx,displayNumber:r.displayNumber},parameters:wc,execute:r.execute,experimental_toToolResultContent:r.experimental_toToolResultContent}}var xc={bash_20241022:cc,bash_20250124:gc,textEditor_20241022:fc,textEditor_20250124:yc,computer_20241022:_c,computer_20250124:bc};function Is(r={}){var e;let t=(e=(0, Cs.withoutTrailingSlash)(r.baseURL))!=null?e:"https://api.anthropic.com/v1",n=()=>({"anthropic-version":"2023-06-01","x-api-key":(0, Cs.loadApiKey)({apiKey:r.apiKey,environmentVariableName:"ANTHROPIC_API_KEY",description:"Anthropic"}),...r.headers}),o=(i,a={})=>new ic(i,a,{provider:"anthropic.messages",baseURL:t,headers:n,fetch:r.fetch,supportsImageUrls:true}),s=function(i,a){if(new.target)throw new Error("The Anthropic model function cannot be called with the new keyword.");return o(i,a)};return s.languageModel=o,s.chat=o,s.messages=o,s.textEmbeddingModel=i=>{throw new Qd.NoSuchModelError({modelId:i,modelType:"textEmbeddingModel"})},s.tools=xc,s}var kc=Is();});var Vs=De((Dy,Js)=>{g();var un=Object.defineProperty,Rc=Object.getOwnPropertyDescriptor,Cc=Object.getOwnPropertyNames,Tc=Object.prototype.hasOwnProperty,Pc=(r,e)=>{for(var t in e)un(r,t,{get:e[t],enumerable:true});},Ac=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Cc(e))!Tc.call(r,o)&&o!==t&&un(r,o,{get:()=>e[o],enumerable:!(n=Rc(e,o))||n.enumerable});return r},Ec=r=>Ac(un({},"__esModule",{value:true}),r),Ls={};Pc(Ls,{createGoogleGenerativeAI:()=>Ws,google:()=>Jc});Js.exports=Ec(Ls);var sn=Q(),Ie=Q(),A=W("zod");function de(r){if(Sc(r))return;if(typeof r=="boolean")return {type:"boolean",properties:{}};let{type:e,description:t,required:n,properties:o,items:s,allOf:i,anyOf:a,oneOf:l,format:u,const:d,minLength:c,enum:p}=r,f={};if(t&&(f.description=t),n&&(f.required=n),u&&(f.format=u),d!==void 0&&(f.enum=[d]),e&&(Array.isArray(e)?e.includes("null")?(f.type=e.filter(v=>v!=="null")[0],f.nullable=true):f.type=e:e==="null"?f.type="null":f.type=e),p!==void 0&&(f.enum=p),o!=null&&(f.properties=Object.entries(o).reduce((v,[h,m])=>(v[h]=de(m),v),{})),s&&(f.items=Array.isArray(s)?s.map(de):de(s)),i&&(f.allOf=i.map(de)),a)if(a.some(v=>typeof v=="object"&&v?.type==="null")){let v=a.filter(h=>!(typeof h=="object"&&h?.type==="null"));if(v.length===1){let h=de(v[0]);typeof h=="object"&&(f.nullable=true,Object.assign(f,h));}else f.anyOf=v.map(de),f.nullable=true;}else f.anyOf=a.map(de);return l&&(f.oneOf=l.map(de)),c!==void 0&&(f.minLength=c),f}function Sc(r){return r!=null&&typeof r=="object"&&r.type==="object"&&(r.properties==null||Object.keys(r.properties).length===0)&&!r.additionalProperties}var an=B(),Ic=Q();function Oc(r){var e,t;let n=[],o=[],s=true;for(let{role:i,content:a}of r)switch(i){case "system":{if(!s)throw new an.UnsupportedFunctionalityError({functionality:"system messages are only supported at the beginning of the conversation"});n.push({text:a});break}case "user":{s=false;let l=[];for(let u of a)switch(u.type){case "text":{l.push({text:u.text});break}case "image":{l.push(u.image instanceof URL?{fileData:{mimeType:(e=u.mimeType)!=null?e:"image/jpeg",fileUri:u.image.toString()}}:{inlineData:{mimeType:(t=u.mimeType)!=null?t:"image/jpeg",data:(0, Ic.convertUint8ArrayToBase64)(u.image)}});break}case "file":{l.push(u.data instanceof URL?{fileData:{mimeType:u.mimeType,fileUri:u.data.toString()}}:{inlineData:{mimeType:u.mimeType,data:u.data}});break}}o.push({role:"user",parts:l});break}case "assistant":{s=false,o.push({role:"model",parts:a.map(l=>{switch(l.type){case "text":return l.text.length===0?void 0:{text:l.text};case "file":{if(l.mimeType!=="image/png")throw new an.UnsupportedFunctionalityError({functionality:"Only PNG images are supported in assistant messages"});if(l.data instanceof URL)throw new an.UnsupportedFunctionalityError({functionality:"File data URLs in assistant messages are not supported"});return {inlineData:{mimeType:l.mimeType,data:l.data}}}case "tool-call":return {functionCall:{name:l.toolName,args:l.args}}}}).filter(l=>l!==void 0)});break}case "tool":{s=false,o.push({role:"user",parts:a.map(l=>({functionResponse:{name:l.toolName,response:{name:l.toolName,content:l.result}}}))});break}}return {systemInstruction:n.length>0?{parts:n}:void 0,contents:o}}function Ms(r){return r.includes("/")?r:`models/${r}`}var zc=Q(),Rt=W("zod"),Mc=Rt.z.object({error:Rt.z.object({code:Rt.z.number().nullable(),message:Rt.z.string(),status:Rt.z.string()})}),ln=(0, zc.createJsonErrorResponseHandler)({errorSchema:Mc,errorToMessage:r=>r.error.message}),jc=B();function Nc(r,e,t,n){var o,s;let i=(o=r.tools)!=null&&o.length?r.tools:void 0,a=[],l=n.includes("gemini-2"),u=n.includes("gemini-1.5-flash")&&!n.includes("-8b");if(e)return {tools:l?{googleSearch:{}}:{googleSearchRetrieval:!u||!t?{}:{dynamicRetrievalConfig:t}},toolConfig:void 0,toolWarnings:a};if(i==null)return {tools:void 0,toolConfig:void 0,toolWarnings:a};let d=[];for(let f of i)f.type==="provider-defined"?a.push({type:"unsupported-tool",tool:f}):d.push({name:f.name,description:(s=f.description)!=null?s:"",parameters:de(f.parameters)});let c=r.toolChoice;if(c==null)return {tools:{functionDeclarations:d},toolConfig:void 0,toolWarnings:a};let p=c.type;switch(p){case "auto":return {tools:{functionDeclarations:d},toolConfig:{functionCallingConfig:{mode:"AUTO"}},toolWarnings:a};case "none":return {tools:{functionDeclarations:d},toolConfig:{functionCallingConfig:{mode:"NONE"}},toolWarnings:a};case "required":return {tools:{functionDeclarations:d},toolConfig:{functionCallingConfig:{mode:"ANY"}},toolWarnings:a};case "tool":return {tools:{functionDeclarations:d},toolConfig:{functionCallingConfig:{mode:"ANY",allowedFunctionNames:[c.toolName]}},toolWarnings:a};default:{let f=p;throw new jc.UnsupportedFunctionalityError({functionality:`Unsupported tool choice type: ${f}`})}}}function js({finishReason:r,hasToolCalls:e}){switch(r){case "STOP":return e?"tool-calls":"stop";case "MAX_TOKENS":return "length";case "IMAGE_SAFETY":case "RECITATION":case "SAFETY":case "BLOCKLIST":case "PROHIBITED_CONTENT":case "SPII":return "content-filter";case "FINISH_REASON_UNSPECIFIED":case "OTHER":return "other";case "MALFORMED_FUNCTION_CALL":return "error";default:return "unknown"}}var Dc=class{constructor(r,e,t){this.specificationVersion="v1",this.defaultObjectGenerationMode="json",this.supportsImageUrls=false,this.modelId=r,this.settings=e,this.config=t;}get supportsStructuredOutputs(){var r;return (r=this.settings.structuredOutputs)!=null?r:true}get provider(){return this.config.provider}async getArgs({mode:r,prompt:e,maxTokens:t,temperature:n,topP:o,topK:s,frequencyPenalty:i,presencePenalty:a,stopSequences:l,responseFormat:u,seed:d,providerMetadata:c}){var p,f,v;let h=r.type,m=[],y=(0, Ie.parseProviderOptions)({provider:"google",providerOptions:c,schema:Lc});((p=y?.thinkingConfig)==null?void 0:p.includeThoughts)===true&&!this.config.provider.startsWith("google.vertex.")&&m.push({type:"other",message:`The 'includeThoughts' option is only supported with the Google Vertex provider and might not be supported or could behave unexpectedly with the current Google provider (${this.config.provider}).`});let w={maxOutputTokens:t,temperature:n,topK:s,topP:o,frequencyPenalty:i,presencePenalty:a,stopSequences:l,seed:d,responseMimeType:u?.type==="json"?"application/json":void 0,responseSchema:u?.type==="json"&&u.schema!=null&&this.supportsStructuredOutputs?de(u.schema):void 0,...this.settings.audioTimestamp&&{audioTimestamp:this.settings.audioTimestamp},responseModalities:y?.responseModalities,thinkingConfig:y?.thinkingConfig},{contents:C,systemInstruction:_}=Oc(e);switch(h){case "regular":{let{tools:k,toolConfig:E,toolWarnings:O}=Nc(r,(f=this.settings.useSearchGrounding)!=null?f:false,this.settings.dynamicRetrievalConfig,this.modelId);return {args:{generationConfig:w,contents:C,systemInstruction:_,safetySettings:this.settings.safetySettings,tools:k,toolConfig:E,cachedContent:this.settings.cachedContent},warnings:[...m,...O]}}case "object-json":return {args:{generationConfig:{...w,responseMimeType:"application/json",responseSchema:r.schema!=null&&this.supportsStructuredOutputs?de(r.schema):void 0},contents:C,systemInstruction:_,safetySettings:this.settings.safetySettings,cachedContent:this.settings.cachedContent},warnings:m};case "object-tool":return {args:{generationConfig:w,contents:C,systemInstruction:_,tools:{functionDeclarations:[{name:r.tool.name,description:(v=r.tool.description)!=null?v:"",parameters:de(r.tool.parameters)}]},toolConfig:{functionCallingConfig:{mode:"ANY"}},safetySettings:this.settings.safetySettings,cachedContent:this.settings.cachedContent},warnings:m};default:{let k=h;throw new Error(`Unsupported type: ${k}`)}}}supportsUrl(r){return this.config.isSupportedUrl(r)}async doGenerate(r){var e,t,n,o,s;let{args:i,warnings:a}=await this.getArgs(r),l=JSON.stringify(i),u=(0, Ie.combineHeaders)(await(0, Ie.resolve)(this.config.headers),r.headers),{responseHeaders:d,value:c,rawValue:p}=await(0, Ie.postJsonToApi)({url:`${this.config.baseURL}/${Ms(this.modelId)}:generateContent`,headers:u,body:i,failedResponseHandler:ln,successfulResponseHandler:(0, Ie.createJsonResponseHandler)(Hc),abortSignal:r.abortSignal,fetch:this.config.fetch}),{contents:f,...v}=i,h=c.candidates[0],m=h.content==null||typeof h.content!="object"||!("parts"in h.content)?[]:h.content.parts,y=Ns({parts:m,generateId:this.config.generateId}),w=c.usageMetadata;return {text:Ds(m),reasoning:$s(m),files:(e=Hs(m))==null?void 0:e.map(C=>({data:C.inlineData.data,mimeType:C.inlineData.mimeType})),toolCalls:y,finishReason:js({finishReason:h.finishReason,hasToolCalls:y!=null&&y.length>0}),usage:{promptTokens:(t=w?.promptTokenCount)!=null?t:NaN,completionTokens:(n=w?.candidatesTokenCount)!=null?n:NaN},rawCall:{rawPrompt:f,rawSettings:v},rawResponse:{headers:d,body:p},warnings:a,providerMetadata:{google:{groundingMetadata:(o=h.groundingMetadata)!=null?o:null,safetyRatings:(s=h.safetyRatings)!=null?s:null}},sources:qs({groundingMetadata:h.groundingMetadata,generateId:this.config.generateId}),request:{body:l}}}async doStream(r){let{args:e,warnings:t}=await this.getArgs(r),n=JSON.stringify(e),o=(0, Ie.combineHeaders)(await(0, Ie.resolve)(this.config.headers),r.headers),{responseHeaders:s,value:i}=await(0, Ie.postJsonToApi)({url:`${this.config.baseURL}/${Ms(this.modelId)}:streamGenerateContent?alt=sse`,headers:o,body:e,failedResponseHandler:ln,successfulResponseHandler:(0, Ie.createEventSourceResponseHandler)(qc),abortSignal:r.abortSignal,fetch:this.config.fetch}),{contents:a,...l}=e,u="unknown",d={promptTokens:Number.NaN,completionTokens:Number.NaN},c,p=this.config.generateId,f=false;return {stream:i.pipeThrough(new TransformStream({transform(v,h){var m,y,w,C,_,k;if(!v.success){h.enqueue({type:"error",error:v.error});return}let E=v.value,O=E.usageMetadata;O!=null&&(d={promptTokens:(m=O.promptTokenCount)!=null?m:NaN,completionTokens:(y=O.candidatesTokenCount)!=null?y:NaN});let R=(w=E.candidates)==null?void 0:w[0];if(R==null)return;let x=R.content;if(x!=null){let z=Ds(x.parts);z!=null&&h.enqueue({type:"text-delta",textDelta:z});let I=$s(x.parts);if(I!=null)for(let F of I)h.enqueue({type:"reasoning",textDelta:F.text});let X=Hs(x.parts);if(X!=null)for(let F of X)h.enqueue({type:"file",mimeType:F.inlineData.mimeType,data:F.inlineData.data});let te=Ns({parts:x.parts,generateId:p});if(te!=null)for(let F of te)h.enqueue({type:"tool-call-delta",toolCallType:"function",toolCallId:F.toolCallId,toolName:F.toolName,argsTextDelta:F.args}),h.enqueue({type:"tool-call",toolCallType:"function",toolCallId:F.toolCallId,toolName:F.toolName,args:F.args}),f=true;}if(R.finishReason!=null){u=js({finishReason:R.finishReason,hasToolCalls:f});let z=(C=qs({groundingMetadata:R.groundingMetadata,generateId:p}))!=null?C:[];for(let I of z)h.enqueue({type:"source",source:I});c={google:{groundingMetadata:(_=R.groundingMetadata)!=null?_:null,safetyRatings:(k=R.safetyRatings)!=null?k:null}};}},flush(v){v.enqueue({type:"finish",finishReason:u,usage:d,providerMetadata:c});}})),rawCall:{rawPrompt:a,rawSettings:l},rawResponse:{headers:s},warnings:t,request:{body:n}}}};function Ns({parts:r,generateId:e}){let t=r?.filter(n=>"functionCall"in n);return t==null||t.length===0?void 0:t.map(n=>({toolCallType:"function",toolCallId:e(),toolName:n.functionCall.name,args:JSON.stringify(n.functionCall.args)}))}function Ds(r){let e=r?.filter(t=>"text"in t&&t.thought!==true);return e==null||e.length===0?void 0:e.map(t=>t.text).join("")}function $s(r){let e=r?.filter(t=>"text"in t&&t.thought===true&&t.text!=null);return e==null||e.length===0?void 0:e.map(t=>({type:"text",text:t.text}))}function Hs(r){return r?.filter(e=>"inlineData"in e)}function qs({groundingMetadata:r,generateId:e}){var t;return (t=r?.groundingChunks)==null?void 0:t.filter(n=>n.web!=null).map(n=>({sourceType:"url",id:e(),url:n.web.uri,title:n.web.title}))}var Us=A.z.object({parts:A.z.array(A.z.union([A.z.object({functionCall:A.z.object({name:A.z.string(),args:A.z.unknown()})}),A.z.object({inlineData:A.z.object({mimeType:A.z.string(),data:A.z.string()})}),A.z.object({text:A.z.string().nullish(),thought:A.z.boolean().nullish()})])).nullish()}),$c=A.z.object({web:A.z.object({uri:A.z.string(),title:A.z.string()}).nullish(),retrievedContext:A.z.object({uri:A.z.string(),title:A.z.string()}).nullish()}),Fs=A.z.object({webSearchQueries:A.z.array(A.z.string()).nullish(),retrievalQueries:A.z.array(A.z.string()).nullish(),searchEntryPoint:A.z.object({renderedContent:A.z.string()}).nullish(),groundingChunks:A.z.array($c).nullish(),groundingSupports:A.z.array(A.z.object({segment:A.z.object({startIndex:A.z.number().nullish(),endIndex:A.z.number().nullish(),text:A.z.string().nullish()}),segment_text:A.z.string().nullish(),groundingChunkIndices:A.z.array(A.z.number()).nullish(),supportChunkIndices:A.z.array(A.z.number()).nullish(),confidenceScores:A.z.array(A.z.number()).nullish(),confidenceScore:A.z.array(A.z.number()).nullish()})).nullish(),retrievalMetadata:A.z.union([A.z.object({webDynamicRetrievalScore:A.z.number()}),A.z.object({})]).nullish()}),Bs=A.z.object({category:A.z.string().nullish(),probability:A.z.string().nullish(),probabilityScore:A.z.number().nullish(),severity:A.z.string().nullish(),severityScore:A.z.number().nullish(),blocked:A.z.boolean().nullish()}),Hc=A.z.object({candidates:A.z.array(A.z.object({content:Us.nullish().or(A.z.object({}).strict()),finishReason:A.z.string().nullish(),safetyRatings:A.z.array(Bs).nullish(),groundingMetadata:Fs.nullish()})),usageMetadata:A.z.object({promptTokenCount:A.z.number().nullish(),candidatesTokenCount:A.z.number().nullish(),totalTokenCount:A.z.number().nullish()}).nullish()}),qc=A.z.object({candidates:A.z.array(A.z.object({content:Us.nullish(),finishReason:A.z.string().nullish(),safetyRatings:A.z.array(Bs).nullish(),groundingMetadata:Fs.nullish()})).nullish(),usageMetadata:A.z.object({promptTokenCount:A.z.number().nullish(),candidatesTokenCount:A.z.number().nullish(),totalTokenCount:A.z.number().nullish()}).nullish()}),Lc=A.z.object({responseModalities:A.z.array(A.z.enum(["TEXT","IMAGE"])).nullish(),thinkingConfig:A.z.object({thinkingBudget:A.z.number().nullish(),includeThoughts:A.z.boolean().nullish()}).nullish()}),Uc=B(),cr=Q(),Ct=W("zod"),Fc=class{constructor(r,e,t){this.specificationVersion="v1",this.modelId=r,this.settings=e,this.config=t;}get provider(){return this.config.provider}get maxEmbeddingsPerCall(){return 2048}get supportsParallelCalls(){return true}async doEmbed({values:r,headers:e,abortSignal:t}){if(r.length>this.maxEmbeddingsPerCall)throw new Uc.TooManyEmbeddingValuesForCallError({provider:this.provider,modelId:this.modelId,maxEmbeddingsPerCall:this.maxEmbeddingsPerCall,values:r});let n=(0, cr.combineHeaders)(await(0, cr.resolve)(this.config.headers),e),{responseHeaders:o,value:s}=await(0, cr.postJsonToApi)({url:`${this.config.baseURL}/models/${this.modelId}:batchEmbedContents`,headers:n,body:{requests:r.map(i=>({model:`models/${this.modelId}`,content:{role:"user",parts:[{text:i}]},outputDimensionality:this.settings.outputDimensionality,taskType:this.settings.taskType}))},failedResponseHandler:ln,successfulResponseHandler:(0, cr.createJsonResponseHandler)(Bc),abortSignal:t,fetch:this.config.fetch});return {embeddings:s.embeddings.map(i=>i.values),usage:void 0,rawResponse:{headers:o}}}},Bc=Ct.z.object({embeddings:Ct.z.array(Ct.z.object({values:Ct.z.array(Ct.z.number())}))});function Wc(r){return r.toString().startsWith("https://generativelanguage.googleapis.com/v1beta/files/")}function Ws(r={}){var e;let t=(e=(0, sn.withoutTrailingSlash)(r.baseURL))!=null?e:"https://generativelanguage.googleapis.com/v1beta",n=()=>({"x-goog-api-key":(0, sn.loadApiKey)({apiKey:r.apiKey,environmentVariableName:"GOOGLE_GENERATIVE_AI_API_KEY",description:"Google Generative AI"}),...r.headers}),o=(a,l={})=>{var u;return new Dc(a,l,{provider:"google.generative-ai",baseURL:t,headers:n,generateId:(u=r.generateId)!=null?u:sn.generateId,isSupportedUrl:Wc,fetch:r.fetch})},s=(a,l={})=>new Fc(a,l,{provider:"google.generative-ai",baseURL:t,headers:n,fetch:r.fetch}),i=function(a,l){if(new.target)throw new Error("The Google Generative AI model function cannot be called with the new keyword.");return o(a,l)};return i.languageModel=o,i.chat=o,i.generativeAI=o,i.embedding=s,i.textEmbedding=s,i.textEmbeddingModel=s,i}var Jc=Ws();});var Ks,Gs;exports.VercelProviderRuntime=void 0;var dn=Z(()=>{g();Le();Ks=10,Gs=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,n){let{generateText:o,tool:s}=await import('ai'),i=this.convertTools(n?.tools??[],s),a=this.createModel(n?.model),l=Math.min(n?.maxSteps??this.config.maxSteps??Ks,Gs);try{let u=0,d=await o({model:a,system:n?.systemPrompt??void 0,prompt:e,tools:i,maxSteps:l,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens},onStepFinish:p=>{if(u++,!!n?.onOutput){if(p.toolCalls&&p.toolCalls.length>0)for(let f of p.toolCalls)n.onOutput(JSON.stringify({type:"assistant",message:{content:[{type:"tool_use",id:f.toolCallId,name:f.toolName,input:f.args}]}}),"stdout");if(p.toolResults&&p.toolResults.length>0)for(let f of p.toolResults){let v=typeof f.result=="string"?f.result:JSON.stringify(f.result);n.onOutput(JSON.stringify({type:"user",message:{content:[{type:"tool_result",tool_use_id:f.toolCallId,output:v,is_error:!1}]}}),"stdout");}}}}),c=new Set((n?.tools??[]).filter(p=>!p.execute).map(p=>p.name));if(d.finishReason==="tool-calls"&&Array.isArray(d.toolCalls)&&d.toolCalls.length>0){let p=d.toolCalls.filter(f=>c.has(f.toolName));if(p.length>0){let f=p[0];throw new exports.ClientToolCallRequiredError({toolCallId:f.toolCallId,toolName:f.toolName,args:f.args},{userMessage:e,responseMessages:d.response?.messages??[],toolDefinitions:n?.tools??[],maxSteps:l,systemPrompt:n?.systemPrompt,modelOverride:n?.model})}}if(n?.onUsage&&d.usage){let p={inputTokens:d.usage.promptTokens??0,outputTokens:d.usage.completionTokens??0,cachedInputTokens:0,costUsd:0};n.onUsage(p);}return n?.onModel&&n.onModel(n.model??this.config.model),d.text??""}catch(u){throw u instanceof exports.ClientToolCallRequiredError?u:u.status===401?new exports.ProviderError(`Authentication failed for ${this.config.provider}. Check your API key.`,this.config.provider):u.status===429?new exports.ProviderError(`Rate limit exceeded for ${this.config.provider}.`,this.config.provider):new exports.ProviderError(`Provider error: ${u.message}`,this.config.provider)}}async continueWithToolResults(e,t,n){let{generateText:o,tool:s}=await import('ai'),i=this.convertTools(e.toolDefinitions,s),a=this.createModel(e.modelOverride),l=Math.min(e.maxSteps??this.config.maxSteps??Ks,Gs),u=[{role:"user",content:e.userMessage},...e.responseMessages,{role:"tool",content:t.map(d=>({type:"tool-result",toolCallId:d.toolCallId,toolName:d.toolName,result:typeof d.result=="string"?d.result:JSON.stringify(d.result)}))}];try{let d=await o({model:a,system:e.systemPrompt??void 0,messages:u,tools:i,maxSteps:l,...this.config.temperature!==void 0&&{temperature:this.config.temperature},...this.config.maxTokens!==void 0&&{maxTokens:this.config.maxTokens}}),c=new Set(e.toolDefinitions.filter(p=>!p.execute).map(p=>p.name));if(d.finishReason==="tool-calls"&&Array.isArray(d.toolCalls)&&d.toolCalls.length>0){let p=d.toolCalls.filter(f=>c.has(f.toolName));if(p.length>0){let f=p[0];throw new exports.ClientToolCallRequiredError({toolCallId:f.toolCallId,toolName:f.toolName,args:f.args},{userMessage:e.userMessage,responseMessages:[...e.responseMessages,{role:"tool",content:t.map(v=>({type:"tool-result",toolCallId:v.toolCallId,toolName:v.toolName,result:typeof v.result=="string"?v.result:JSON.stringify(v.result)}))},...d.response?.messages??[]],toolDefinitions:e.toolDefinitions,maxSteps:e.maxSteps,systemPrompt:e.systemPrompt,modelOverride:e.modelOverride})}}return n?.onUsage&&d.usage&&n.onUsage({inputTokens:d.usage.promptTokens??0,outputTokens:d.usage.completionTokens??0,cachedInputTokens:0,costUsd:0}),n?.onModel&&n.onModel(e.modelOverride??this.config.model),d.text??""}catch(d){throw d instanceof exports.ClientToolCallRequiredError?d:new exports.ProviderError(`Provider error: ${d.message}`,this.config.provider)}}convertTools(e,t){let{z:n}=W("zod"),o={};for(let s of e){let i=this.jsonSchemaToZod(s.parameters??{},n);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 n={},o=e.properties,s=e.required??[];for(let[i,a]of Object.entries(o)){let l;switch(a.type){case "string":l=t.string();break;case "number":l=t.number();break;case "integer":l=t.number().int();break;case "boolean":l=t.boolean();break;case "array":l=t.array(t.any());break;default:l=t.any();}a.description&&(l=l.describe(a.description)),s.includes(i)||(l=l.optional()),n[i]=l;}return t.object(n)}createModel(e){let{provider:t,apiKey:n,baseURL:o}=this.config,s=e||this.config.model;switch(t){case "api/openrouter":{let{createOpenAI:i}=nn();return i({apiKey:n||process.env.OPENROUTER_API_KEY,baseURL:o||"https://openrouter.ai/api/v1"})(s)}case "api/openai":{let{createOpenAI:i}=nn();return i({apiKey:n||process.env.OPENAI_API_KEY,...o&&{baseURL:o}})(s)}case "api/anthropic":{let{createAnthropic:i}=zs();return i({apiKey:n||process.env.ANTHROPIC_API_KEY,...o&&{baseURL:o}})(s)}case "api/google":{let{createGoogleGenerativeAI:i}=Vs();return i({apiKey:n||process.env.GOOGLE_API_KEY})(s)}default:throw new exports.ProviderError(`Unsupported API provider: ${t}`,t)}}};});var Ys={};fr(Ys,{registerApiProviders:()=>Xs});function Xs(r){et("api",(e,t)=>{let n=r?.apiKeys?.[e];return new exports.VercelProviderRuntime({provider:t,model:"",apiKey:n,maxSteps:r?.defaults?.maxSteps,temperature:r?.defaults?.temperature})});}var cn=Z(()=>{g();Le();dn();});function Vc(r){if(!r)return r;let e=r.trim().replace(/\/+$/,"");return e.toLowerCase().endsWith("/mcp")?e.slice(0,-4):e}exports.McpHttpTransport=void 0;var pn=Z(()=>{g();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=Vc(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,n=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(n),!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(n),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 gn=Z(()=>{g();pn();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,n){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,n),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 n=this.requireConfig(e),o=n.tools?.query??"crewx_queryAgent",i={agentId:n.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 l=a instanceof Error?a.message:String(a);throw this.logger(`Remote query failed for agent ${e}: ${l}`,"error"),a}}async execute(e,t){let n=this.requireConfig(e),o=n.tools?.execute??"crewx_executeAgent",i={agentId:n.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 l=a instanceof Error?a.message:String(a);throw this.logger(`Remote execute failed for agent ${e}: ${l}`,"error"),a}}mapToolNames(e,t){let n=this.requireConfig(e);n.tools={query:t.query??n.tools?.query??"crewx_queryAgent",execute:t.execute??n.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,n){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:n}};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 n=t.response??t.implementation??t.message??t.output,o=typeof n=="string"?n:JSON.stringify(n??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 Zs={};fr(Zs,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>Qs,resolveFileRemoteAgent:()=>tp});function Zc(r){let e=fs.readFileSync(r,"utf-8"),t=jsYaml.load(e);return {agents:Array.isArray(t?.agents)?t.agents:void 0}}function ep(r){let e=Array.isArray(r.provider)?r.provider[0]:r.provider;return e||(Array.isArray(r.inline?.provider)?r.inline.provider[0]:r.inline?.provider)}function tp(r,e=Zc,t=fs.existsSync){let n=r.location.replace("file://","");if(!t(n))throw new Error(`Remote config file not found: ${n}`);if(!r.external_agent_id)throw new Error(`external_agent_id is required for file:// remote provider "${r.id}"`);let s=e(n).agents?.find(l=>l.id===r.external_agent_id);if(!s)throw new Error(`Agent "${r.external_agent_id}" not found in ${n}`);let i=ep(s);if(!i)throw new Error(`Agent "${r.external_agent_id}" in ${n} has no provider configured`);if(i.startsWith("remote/"))throw new Error(`Chained remotes not allowed: ${r.id} \u2192 ${i}`);let a=re.resolve(re.dirname(n),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function Qs(r,e=Re){return (t,n)=>{let o=r.get(t);if(!o)throw new Error(`Remote provider "${t}" not found. Available: ${Array.from(r.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 rp(r,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??r}}exports.RemoteProviderRuntime=void 0;var mn=Z(()=>{g();Le();gn();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,n=Re){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let o=rp(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(`
|
|
46
|
-
`)}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(`
|
|
47
|
-
`)}};});var ni={};fr(ni,{PluginProviderRuntime:()=>exports.PluginProviderRuntime,createPluginProviderFactory:()=>ri});function ri(r){return (e,t)=>{let n=r.get(e);if(!n)throw new exports.ProviderError(`Plugin provider "${e}" not found. Available: ${Array.from(r.keys()).join(", ")||"(none)"}`,`plugin/${e}`);return new exports.PluginProviderRuntime(e,n)}}function ei(r,e,t,n){let o=r.map(s=>s.replace(/\{model\}/g,e));return n&&o.push(t),o}function op(r){if(!r||typeof r!="string")throw new Error("Plugin provider requires a cli_command")}function ti(r){if(!Array.isArray(r))throw new Error("CLI arguments must be an array");for(let e of r)if(typeof e!="string")throw new Error("Each CLI argument must be a string")}function sp(r){for(let{pattern:e}of r)if(typeof e!="string")throw new Error("Error pattern must be a string")}function ip(r){for(let[e,t]of Object.entries(r))if(typeof e!="string"||typeof t!="string")throw new Error("env entries must be string key/value pairs")}exports.PluginProviderRuntime=void 0;var fn=Z(()=>{g();Le();qt();exports.PluginProviderRuntime=class{constructor(e,t){this.config=t;this.providerStr=`plugin/${e}`,op(t.cli_command),ti(t.query_args),ti(t.execute_args),t.error_patterns&&sp(t.error_patterns),t.env&&ip(t.env);}config;providerStr;async query(e,t){let n=t?.model??this.config.default_model??"default",o=ei(this.config.query_args,n,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 n=t?.model??this.config.default_model??"default",o=ei(this.config.execute_args,n,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,n,o){return new Promise((s,i)=>{let a={...process.env,...this.config.env??{}},l=it({command:this.config.cli_command,allowShellFallback:true}),u=at(l,e),d=child_process.spawn(u.command,u.argv,{env:a,shell:u.shell??false,stdio:["pipe","pipe","pipe"],windowsHide:u.windowsHide});n!==void 0&&d.stdin.write(n),d.stdin.end(),d.pid!==void 0&&t?.onPid?.(d.pid);let c="",p="",f="",v="";d.stdout.on("data",m=>{let y=m.toString();c+=y,f+=y;let w=f.split(`
|
|
48
|
-
`);f=w.pop()??"";for(let C of w)C.trim()&&t?.onOutput?.(C,"stdout");}),d.stderr.on("data",m=>{let y=m.toString();p+=y,v+=y;let w=v.split(`
|
|
49
|
-
`);v=w.pop()??"";for(let C of w)C.trim()&&t?.onOutput?.(C,"stderr");});let h=setTimeout(()=>{d.kill("SIGTERM"),i(new exports.ProviderError(`Plugin provider "${this.providerStr}" timed out after ${o}ms`,this.providerStr));},o);d.on("error",m=>{if(clearTimeout(h),m.code==="ENOENT"){let y=this.config.not_installed_message??`CLI command "${this.config.cli_command}" not found. Is ${this.config.id} installed?`;i(new exports.ProviderError(y,this.providerStr));}else i(new exports.ProviderError(`Spawn error: ${m.message}`,this.providerStr));}),d.on("close",m=>{clearTimeout(h),f.trim()&&t?.onOutput?.(f,"stdout"),v.trim()&&t?.onOutput?.(v,"stderr");let y=m??0;if(t?.onExitCode?.(y),this.config.error_patterns){let w=p||c;for(let C of this.config.error_patterns)if(w.includes(C.pattern)){i(new exports.ProviderError(C.message,this.providerStr));return}}if(m!==0){i(new exports.ProviderError(`Process exited with code ${m}: ${p.slice(0,500)}`,this.providerStr));return}s(c.trim());});})}};});g();g();g();function Ti(r){let e=o=>o.replace(/[.+^${}()|[\]\\]/g,"\\$&"),n=r.split("/").map(o=>o==="**"?".*":o.split("*").map(e).join("[^/]*"));return new RegExp(`^${n.join("\\/")}$`)}function ye(r,e){try{return Ti(e).test(r)}catch{return false}}g();g();var Pi=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()),Pn=zod.z.object({include:zod.z.array(zod.z.string()).optional()}).optional(),Ai=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:Pi.optional(),skills:Pn}).catchall(zod.z.unknown()),An=zod.z.object({agents:zod.z.array(Ai).optional(),hooks:zod.z.array(zod.z.unknown()).optional(),settings:zod.z.record(zod.z.unknown()).optional(),skills:zod.z.unknown().optional(),layouts:zod.z.record(zod.z.unknown()).optional(),documents:zod.z.record(zod.z.unknown()).optional()}).catchall(zod.z.unknown());var $e=class extends Error{constructor(t,n){super(t);this.cause=n;this.name="ConfigLoadError";}cause};function Mt(r){if(!r||typeof r!="string"||!r.trim())throw new $e("YAML content must be a non-empty string");let e;try{e=jsYaml.load(r);}catch(o){throw new $e(`YAML parse error: ${o.message}`,o)}let t=Ii(e),n=An.safeParse(t);if(!n.success)throw new $e(`Config validation error: ${n.error.message}`);return n.data}function jt(r){let e;try{e=fs.readFileSync(r,"utf-8");}catch(t){throw new $e(`Cannot read file: ${r}`,t)}return Mt(e)}function Ii(r){if(!r||typeof r!="object")return {agents:[]};let e=r,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 n=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:n}}g();var He=re.join("templates","agents");function Mi(){try{let e=(typeof W=="function"?W:module$1.createRequire(typeof __filename<"u"?__filename:process.cwd()+"/")).resolve("@crewx/sdk/package.json");return re.dirname(e)}catch{return null}}function Ye(r){if(r&&fs.existsSync(r))return r;let e=process.env.CREWX_SDK_TEMPLATES_PATH;if(e&&fs.existsSync(e))return e;let t=Mi();if(t){let o=re.join(t,He);if(fs.existsSync(o))return o}let n=[re.join(__dirname,"..",He),re.join(__dirname,"..","..",He),re.join(__dirname,"..","..","..",He),re.join(process.cwd(),"packages","sdk",He),re.join(process.cwd(),He)];for(let o of n)if(fs.existsSync(o))return o;throw new Error(`[@crewx/sdk] Templates directory not found.
|
|
50
|
-
`+(t?` package anchor: ${re.join(t,He)}
|
|
31
|
+
`)}]}handleUpdate(e,t,r){let n=e.update;if(n.sessionUpdate==="agent_message_chunk"){let s=null;this.adapter.extractTextFromUpdate?s=this.adapter.extractTextFromUpdate(e):s=lr(e),s!==null&&(r.push(s),t?.onOutput?.(s,"stdout"));}else if(n.sessionUpdate==="tool_call"){let s=new Date().toISOString(),i=n,a={title:i.title??"",kind:i.kind,rawInput:i.rawInput,rawOutput:i.rawOutput,locations:i.locations,_meta:i._meta},d=this.resolveToolCall(a),c={timestamp:s,type:"tool_use",toolUseId:i.toolCallId,toolName:d.toolName,toolInput:d.toolInput};t?.onTaskLog?.([c]);}else if(n.sessionUpdate==="tool_call_update"){let s=new Date().toISOString(),i=n;if(i.status==="completed"||i.status==="failed"){let d=this.extractResultPreview(i.rawOutput),c={timestamp:s,type:"tool_result",toolUseId:i.toolCallId,resultPreview:d,isError:i.status==="failed"};t?.onTaskLog?.([c]);}else if(i.rawInput!=null&&typeof i.rawInput=="object"&&Object.keys(i.rawInput).length>0){let d={title:i.title??"",kind:i.kind,rawInput:i.rawInput,rawOutput:i.rawOutput,locations:i.locations,_meta:i._meta},c=this.resolveToolCall(d),u={timestamp:s,type:"tool_use",toolUseId:i.toolCallId,toolName:c.toolName,toolInput:c.toolInput};t?.onTaskLog?.([u]);}}else n.sessionUpdate;}resolveToolCall(e){let t=e._meta;if(t?.claudeCode?.toolName)return {toolName:t.claudeCode.toolName,toolInput:wn(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=Us[e.kind??""]??e.title??"unknown",n=wn(e.rawInput,e.locations)??(e.title||void 0);return {toolName:r,toolInput:n}}extractResultPreview(e){if(e!=null){if(typeof e=="string")return e;if(Array.isArray(e)){let t=e.filter(r=>r!=null&&typeof r=="object"&&r.type==="text"&&typeof r.text=="string").map(r=>r.text);if(t.length>0)return t.join(`
|
|
32
|
+
`)}if(typeof e=="object"){let t=e;if(typeof t.formatted_output=="string")return t.formatted_output;if(typeof t.content=="string")return t.content;if(Array.isArray(t.content)){let r=this.extractResultPreview(t.content);if(r)return r}if(typeof t.output=="string")return t.output;if(typeof t.text=="string")return t.text;if(typeof t.message=="string")return t.message;if(t.result!=null){let r=this.extractResultPreview(t.result);if(r)return r}if(t.error!=null){let r=this.extractResultPreview(t.error);if(r)return r}}return JSON.stringify(e)}}handleUsage(e,t){if(!t?.onUsage)return;if(this.adapter.extractUsage){let n=this.adapter.extractUsage(e);if(n){t.onUsage(n);return}}let r=e.usage;r&&t.onUsage({inputTokens:r.inputTokens??0,outputTokens:r.outputTokens??0,cachedInputTokens:r.cachedReadTokens??0,costUsd:0});}};});exports.claudeAcpAdapter=void 0;var gr=M(()=>{l();me();exports.claudeAcpAdapter={spawn:{command:"npx",args:["claude-agent-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/claude-agent-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},extractUsage(o){let e=o.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"bypassPermissions",buildEffortAction(o){return o?{type:"set_config_option",configId:"effort",value:o}:null},resolveMode(o){return {yolo:"bypassPermissions"}[o]??o},parseEvent:G};});exports.codexAcpAdapter=void 0;var mr=M(()=>{l();me();exports.codexAcpAdapter={spawn:{command:"npx",args:["codex-acp"],shellOnWindows:true},npmPackage:"@agentclientprotocol/codex-acp",clientInfo:{name:"crewx-sdk",version:"0.8.4"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},extractUsage(o){let e=o.usage;return e?{inputTokens:e.inputTokens??0,outputTokens:e.outputTokens??0,cachedInputTokens:e.cachedReadTokens??0,costUsd:0}:null},yoloModeId:"agent-full-access",buildEffortAction(o,e){return e&&o?{type:"set_model",modelId:`${e}[${o}]`}:e&&!o?{type:"set_model",modelId:`${e}[medium]`}:null},resolveMode(o){return {yolo:"agent-full-access",default:"agent",plan:"read-only"}[o]??o},parseEvent:G};});exports.geminiAcpAdapter=void 0;var fr=M(()=>{l();me();exports.geminiAcpAdapter={spawn:{command:"gemini",args:["--acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},yoloModeId:"yolo",buildEffortAction(o){return null},resolveMode(o){return {acceptEdits:"autoEdit"}[o]??o},parseEvent:G};});var Ne;exports.copilotAcpAdapter=void 0;var yr=M(()=>{l();me();Ne="https://agentclientprotocol.com/protocol/session-modes",exports.copilotAcpAdapter={spawn:{command:"copilot",args:["--acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},buildSessionParams(o){return {cwd:o.cwd?U.resolve(o.cwd):process.cwd(),mcpServers:[]}},yoloModeId:`${Ne}#autopilot`,buildEffortAction(o){return o?{type:"set_config_option",configId:"reasoning_effort",value:o}:null},resolveMode(o){return o.startsWith("https://")?o:{yolo:`${Ne}#autopilot`,default:`${Ne}#agent`,agent:`${Ne}#agent`,plan:`${Ne}#plan`,autopilot:`${Ne}#autopilot`}[o]??null},parseEvent:G};});exports.opencodeAcpAdapter=void 0;var hr=M(()=>{l();me();exports.opencodeAcpAdapter={spawn:{command:"opencode",args:["acp"],shellOnWindows:false},clientInfo:{name:"crewx-sdk",version:"0.8.4"},buildSessionParams(o){return {cwd:o.cwd??process.cwd(),mcpServers:[]}},yoloModeId:void 0,buildEffortAction(o){return o?{type:"set_config_option",configId:"effort",value:o}:null},resolveMode(o){let e={default:"build"};return o==="yolo"?null:e[o]??o},parseEvent:G};});exports.ACP_ADAPTERS=void 0;var wr=M(()=>{l();gr();mr();fr();yr();hr();gr();mr();fr();yr();hr();exports.ACP_ADAPTERS={claude:exports.claudeAcpAdapter,codex:exports.codexAcpAdapter,gemini:exports.geminiAcpAdapter,copilot:exports.copilotAcpAdapter,opencode:exports.opencodeAcpAdapter};});var vn={};st(vn,{registerAcpProviders:()=>xn});function xn(o){if(o){se("acp",o);return}se("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 xr=M(()=>{l();Z();pr();wr();Z();});function qs(o){if(!o)return o;let e=o.trim().replace(/\/+$/,"");return e.toLowerCase().endsWith("/mcp")?e.slice(0,-4):e}exports.McpHttpTransport=void 0;var vr=M(()=>{l();exports.McpHttpTransport=class{endpoint;headers;timeoutMs;constructor(e){let t=qs(e.url);this.endpoint=`${t}/mcp`,this.headers={"Content-Type":"application/json",...e.headers??{}},e.apiKey&&(this.headers.Authorization=`Bearer ${e.apiKey}`),this.timeoutMs=e.timeoutMs??3e4;}async send(e){let t=new AbortController,r=setTimeout(()=>t.abort(),this.timeoutMs);try{let n=await fetch(this.endpoint,{method:"POST",headers:this.headers,body:JSON.stringify(e),signal:t.signal});if(clearTimeout(r),!n.ok){let a=await n.text();throw new Error(`HTTP ${n.status}: ${n.statusText}${a?` - ${a}`:""}`)}let s=n.headers.get("content-type");if(s?.includes("application/json"))return await n.json();let i=await n.text();return {jsonrpc:"2.0",id:e.id,error:{code:-32600,message:`Unexpected response content-type: ${s}`,data:i}}}catch(n){throw clearTimeout(r),n instanceof Error&&n.name==="AbortError"?new Error(`MCP-HTTP request timeout after ${this.timeoutMs}ms to ${this.endpoint}`):n}}async close(){}};});exports.RemoteAgentManager=void 0;var kr=M(()=>{l();vr();exports.RemoteAgentManager=class{logger;configs=new Map;transports=new Map;constructor(e={}){this.logger=e.logger??(()=>{});}loadConfig(e,t){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,new exports.McpHttpTransport({url:t.url,apiKey:t.apiKey,headers:t.headers,timeoutMs:t.timeoutMs})),this.logger(`Loaded remote agent config for: ${e}`,"debug");}loadConfigWithTransport(e,t,r){this.validateConfig(t),this.configs.set(e,t),this.transports.set(e,r),this.logger(`Loaded remote agent config for: ${e} (custom transport)`,"debug");}getConfig(e){return this.configs.get(e)}isRemoteAgent(e){return this.configs.has(e)}getRemoteAgentIds(){return Array.from(this.configs.keys())}async query(e,t){let r=this.requireConfig(e),n=r.tools?.query??"crewx_queryAgent",i={agentId:r.agentId??e,query:t.query};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote query failed for agent ${e}: ${d}`,"error"),a}}async execute(e,t){let r=this.requireConfig(e),n=r.tools?.execute??"crewx_executeAgent",i={agentId:r.agentId??e,task:t.task};t.context&&(i.context=t.context),t.model&&(i.model=t.model),t.platform&&(i.platform=t.platform),t.messages?.length&&(i.messages=t.messages);try{let a=await this.callRemoteTool(e,n,i);return this.normalizeResponse(a)}catch(a){let d=a instanceof Error?a.message:String(a);throw this.logger(`Remote execute failed for agent ${e}: ${d}`,"error"),a}}mapToolNames(e,t){let r=this.requireConfig(e);r.tools={query:t.query??r.tools?.query??"crewx_queryAgent",execute:t.execute??r.tools?.execute??"crewx_executeAgent"},this.logger(`Updated tool name mapping for agent ${e}`,"debug");}async clearConfigs(){for(let e of this.transports.values())await e.close();this.configs.clear(),this.transports.clear(),this.logger("Cleared all remote agent configurations","debug");}requireConfig(e){let t=this.configs.get(e);if(!t)throw new Error(`Agent ${e} is not configured as a remote agent`);return t}async callRemoteTool(e,t,r){let n=this.transports.get(e);if(!n)throw new Error(`No transport available for agent ${e}`);let s={jsonrpc:"2.0",id:`${t}-${Date.now()}`,method:"tools/call",params:{name:t,arguments:r}};this.logger(`Calling remote MCP tool ${t} for agent ${e}`,"debug");let i=await n.send(s);if(i.error)throw new Error(i.error.message||"MCP server returned an error");return i.result}normalizeResponse(e){if(!e)return {success:false,content:[{type:"text",text:"Remote agent returned no response."}]};let t=e;if(Array.isArray(t.content)&&t.content.length>0)return t;let r=t.response??t.implementation??t.message??t.output,n=typeof r=="string"?r:JSON.stringify(r??e,null,2);return {...t,content:[{type:"text",text:n}]}}validateConfig(e){if(!e.url)throw new Error("Remote agent configuration requires a URL");if(!e.url.startsWith("http://")&&!e.url.startsWith("https://"))throw new Error("Remote agent URL must start with http:// or https://");if(e.type!=="mcp-http")throw new Error(`Unsupported remote agent type: ${e.type}`)}};});var _n={};st(_n,{RemoteProviderRuntime:()=>exports.RemoteProviderRuntime,createRemoteProviderFactory:()=>kn,resolveFileRemoteAgent:()=>Qs});function Js(o){let e=fs.readFileSync(o,"utf-8"),t=jsYaml.load(e);return {agents:Array.isArray(t?.agents)?t.agents:void 0}}function Xs(o){let e=Array.isArray(o.provider)?o.provider[0]:o.provider;return e||(Array.isArray(o.inline?.provider)?o.inline.provider[0]:o.inline?.provider)}function Qs(o,e=Js,t=fs.existsSync){let r=o.location.replace("file://","");if(!t(r))throw new Error(`Remote config file not found: ${r}`);if(!o.external_agent_id)throw new Error(`external_agent_id is required for file:// remote provider "${o.id}"`);let s=e(r).agents?.find(d=>d.id===o.external_agent_id);if(!s)throw new Error(`Agent "${o.external_agent_id}" not found in ${r}`);let i=Xs(s);if(!i)throw new Error(`Agent "${o.external_agent_id}" in ${r} has no provider configured`);if(i.startsWith("remote/"))throw new Error(`Chained remotes not allowed: ${o.id} \u2192 ${i}`);let a=U.resolve(U.dirname(r),s.working_directory??".");return {agent:{...s,working_directory:a},provider:i}}function kn(o,e=ie){return (t,r)=>{let n=o.get(t);if(!n)throw new Error(`Remote provider "${t}" not found. Available: ${Array.from(o.keys()).join(", ")||"(none)"}`);if(n.location.startsWith("file://"))throw new Error(`Remote provider "${t}" uses file:// location which is not supported at the SDK level. Use the CLI commands (crewx query / crewx execute) which handle file:// remotes automatically.`);return new exports.RemoteProviderRuntime(t,n,e)}}function Gs(o,e){let t=e.location;if(!t)throw new Error("Remote provider config requires a location");if(!t.startsWith("http://")&&!t.startsWith("https://"))throw new Error(`Unsupported remote location protocol for MCP-HTTP: ${t}`);return {type:"mcp-http",url:t,apiKey:e.apiKey,headers:e.headers,timeoutMs:e.timeout?.query??3e4,agentId:e.external_agent_id??o}}exports.RemoteProviderRuntime=void 0;var _r=M(()=>{l();Z();kr();exports.RemoteProviderRuntime=class{manager;agentId;constructor(e,t,r=ie){this.agentId=t.external_agent_id??e,this.manager=new exports.RemoteAgentManager;let n=Gs(e,t);this.manager.loadConfig(this.agentId,n);}async query(e,t){return (await this.manager.query(this.agentId,{agentId:this.agentId,query:e,model:t?.model,context:t?.context??t?.systemPrompt})).content.map(n=>n.text).join(`
|
|
33
|
+
`)}async execute(e,t){return (await this.manager.execute(this.agentId,{agentId:this.agentId,task:e,model:t?.model,context:t?.context??t?.systemPrompt})).content.map(n=>n.text).join(`
|
|
34
|
+
`)}};});var Cn={};st(Cn,{PluginProviderRuntime:()=>exports.PluginProviderRuntime,createPluginProviderFactory:()=>An});function An(o){return (e,t)=>{let r=o.get(e);if(!r)throw new exports.ProviderError(`Plugin provider "${e}" not found. Available: ${Array.from(o.keys()).join(", ")||"(none)"}`,`plugin/${e}`);return new exports.PluginProviderRuntime(e,r)}}function Rn(o,e,t,r){let n=o.map(s=>s.replace(/\{model\}/g,e));return r&&n.push(t),n}function Zs(o){if(!o||typeof o!="string")throw new Error("Plugin provider requires a cli_command")}function Pn(o){if(!Array.isArray(o))throw new Error("CLI arguments must be an array");for(let e of o)if(typeof e!="string")throw new Error("Each CLI argument must be a string")}function ei(o){for(let{pattern:e}of o)if(typeof e!="string")throw new Error("Error pattern must be a string")}function ti(o){for(let[e,t]of Object.entries(o))if(typeof e!="string"||typeof t!="string")throw new Error("env entries must be string key/value pairs")}exports.PluginProviderRuntime=void 0;var Rr=M(()=>{l();Z();pt();exports.PluginProviderRuntime=class{constructor(e,t){this.config=t;this.providerStr=`plugin/${e}`,Zs(t.cli_command),Pn(t.query_args),Pn(t.execute_args),t.error_patterns&&ei(t.error_patterns),t.env&&ti(t.env);}config;providerStr;async query(e,t){let r=t?.model??this.config.default_model??"default",n=Rn(this.config.query_args,r,e,this.config.prompt_in_args),s=this.config.prompt_in_args?void 0:e;t?.onCommand?.(`${this.config.cli_command} ${n.join(" ")}`);let i=this.config.timeout?.query??6e5;return this.runProcess(n,t,s,i)}async execute(e,t){let r=t?.model??this.config.default_model??"default",n=Rn(this.config.execute_args,r,e,this.config.prompt_in_args),s=this.config.prompt_in_args?void 0:e;t?.onCommand?.(`${this.config.cli_command} ${n.join(" ")}`);let i=this.config.timeout?.execute??6e5;return this.runProcess(n,t,s,i)}runProcess(e,t,r,n){return new Promise((s,i)=>{let a={...process.env,...this.config.env??{}},d=De({command:this.config.cli_command,allowShellFallback:true}),c=Le(d,e),u=child_process.spawn(c.command,c.argv,{env:a,shell:c.shell??false,stdio:["pipe","pipe","pipe"],windowsHide:c.windowsHide});r!==void 0&&u.stdin.write(r),u.stdin.end(),u.pid!==void 0&&t?.onPid?.(u.pid);let p="",g="",m="",y="";u.stdout.on("data",w=>{let _=w.toString();p+=_,m+=_;let x=m.split(`
|
|
35
|
+
`);m=x.pop()??"";for(let A of x)A.trim()&&t?.onOutput?.(A,"stdout");}),u.stderr.on("data",w=>{let _=w.toString();g+=_,y+=_;let x=y.split(`
|
|
36
|
+
`);y=x.pop()??"";for(let A of x)A.trim()&&t?.onOutput?.(A,"stderr");});let k=setTimeout(()=>{u.kill("SIGTERM"),i(new exports.ProviderError(`Plugin provider "${this.providerStr}" timed out after ${n}ms`,this.providerStr));},n);u.on("error",w=>{if(clearTimeout(k),w.code==="ENOENT"){let _=this.config.not_installed_message??`CLI command "${this.config.cli_command}" not found. Is ${this.config.id} installed?`;i(new exports.ProviderError(_,this.providerStr));}else i(new exports.ProviderError(`Spawn error: ${w.message}`,this.providerStr));}),u.on("close",w=>{clearTimeout(k),m.trim()&&t?.onOutput?.(m,"stdout"),y.trim()&&t?.onOutput?.(y,"stderr");let _=w??0;if(t?.onExitCode?.(_),this.config.error_patterns){let x=g||p;for(let A of this.config.error_patterns)if(x.includes(A.pattern)){i(new exports.ProviderError(A.message,this.providerStr));return}}if(w!==0){i(new exports.ProviderError(`Process exited with code ${w}: ${g.slice(0,500)}`,this.providerStr));return}s(p.trim());});})}};});l();l();l();function Qn(o){let e=n=>n.replace(/[.+^${}()|[\]\\]/g,"\\$&"),r=o.split("/").map(n=>n==="**"?".*":n.split("*").map(e).join("[^/]*"));return new RegExp(`^${r.join("\\/")}$`)}function Y(o,e){try{return Qn(e).test(o)}catch{return false}}l();l();var Gn=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()),Nr=zod.z.object({include:zod.z.array(zod.z.string()).optional()}).optional(),Yn=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:Gn.optional(),skills:Nr}).catchall(zod.z.unknown()),Dr=zod.z.object({agents:zod.z.array(Yn).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 we=class extends Error{constructor(t,r){super(t);this.cause=r;this.name="ConfigLoadError";}cause};function it(o){if(!o||typeof o!="string"||!o.trim())throw new we("YAML content must be a non-empty string");let e;try{e=jsYaml.load(o);}catch(n){throw new we(`YAML parse error: ${n.message}`,n)}let t=to(e),r=Dr.safeParse(t);if(!r.success)throw new we(`Config validation error: ${r.error.message}`);return r.data}function at(o){let e;try{e=fs.readFileSync(o,"utf-8");}catch(t){throw new we(`Cannot read file: ${o}`,t)}return it(e)}function to(o){if(!o||typeof o!="object")return {agents:[]};let e=o,t;if(e.agents&&typeof e.agents=="object"&&!Array.isArray(e.agents)){let n=e.agents;t=Object.entries(n).map(([s,i])=>({id:s,...i&&typeof i=="object"?i:{}}));}else if(Array.isArray(e.agents))t=e.agents;else return {...e,agents:[]};let r=t.map(n=>{if(n.provider===void 0&&n.inline&&typeof n.inline=="object"){let s=n.inline;if(s.provider!==void 0)return {...n,provider:s.provider}}return n});return {...e,agents:r}}l();var xe=U.join("templates","agents");function oo(){try{let e=(typeof F=="function"?F:module$1.createRequire(typeof __filename<"u"?__filename:process.cwd()+"/")).resolve("@crewx/sdk/package.json");return U.dirname(e)}catch{return null}}function Te(o){if(o&&fs.existsSync(o))return o;let e=process.env.CREWX_SDK_TEMPLATES_PATH;if(e&&fs.existsSync(e))return e;let t=oo();if(t){let n=U.join(t,xe);if(fs.existsSync(n))return n}let r=[U.join(__dirname,"..",xe),U.join(__dirname,"..","..",xe),U.join(__dirname,"..","..","..",xe),U.join(process.cwd(),"packages","sdk",xe),U.join(process.cwd(),xe)];for(let n of r)if(fs.existsSync(n))return n;throw new Error(`[@crewx/sdk] Templates directory not found.
|
|
37
|
+
`+(t?` package anchor: ${U.join(t,xe)}
|
|
51
38
|
`:` package anchor: (unresolved)
|
|
52
|
-
`)+
|
|
39
|
+
`)+r.map(n=>` candidate: ${n}`).join(`
|
|
53
40
|
`)+`
|
|
54
|
-
Set CREWX_SDK_TEMPLATES_PATH or pass options.templatesPath.`)}function
|
|
55
|
-
${
|
|
56
|
-
</exec-output>`}catch{return
|
|
57
|
-
${
|
|
58
|
-
\`\`\``}
|
|
59
|
-
`)){let s=/^(#{1,6})\s+(.+)$/.exec(
|
|
60
|
-
`)}getPath(e){return this.docs.get(e)?.path}getNames(){return Array.from(this.docs.keys())}async buildContext(){let e={};for(let t of this.docs.keys()){let n=await this.getContent(t)??"",o=await this.getToc(t),s=this.getPath(t);e[t]={content:n,toc:o,...s?{path:s}:{}};}return e}async loadFromFile(e,t,n){try{let o=this.resolve(t,n),s=await this.fs.readFile(o);this.docs.set(e,{content:s,path:o});}catch(o){let s=o instanceof Error?o.message:String(o);console.warn(`[DocumentLoader] Failed to load '${e}' from '${t}': ${s}`);}}resolve(e,t){return this.fs.isAbsolute(e)?e:t?this.fs.resolvePath(t,e):this.fs.resolvePath(e)}};g();g();var oe=class extends Error{constructor(t,n,o){super(t);this.layoutId=n;this.cause=o;this.name="LayoutLoadError";}layoutId;cause},Ce=class extends Error{constructor(t,n=[],o){super(t);this.errors=n;this.cause=o;this.name="PropsValidationError";}errors;cause};var wa={validationMode:"lenient",fallbackLayoutId:"crewx/default"},ct=class{layouts=new Map;options;constructor(e){this.options={...wa,...e,templatesPath:e?.templatesPath??Ye()},this.loadAllLayouts();}load(e,t){let n=this.layouts.get(e);if(!n){let o=this.normalizeLayoutId(e);n=this.layouts.get(o);}if(!n&&(console.warn(`Layout not found: ${e}, falling back to ${this.options.fallbackLayoutId}`),n=this.layouts.get(this.options.fallbackLayoutId),!n))throw new oe(`Fallback layout not found: ${this.options.fallbackLayoutId}`,this.options.fallbackLayoutId);return t&&Object.keys(t).length>0?{...n,defaultProps:{...n.defaultProps,...t}}:n}getLayoutIds(){return Array.from(this.layouts.keys())}hasLayout(e){if(this.layouts.has(e))return true;let t=this.normalizeLayoutId(e);return this.layouts.has(t)}reload(){this.layouts.clear(),this.loadAllLayouts();}registerLayout(e,t){if(!e||typeof e!="string")throw new oe("Layout ID must be a non-empty string",e);let n=typeof t=="string"?{template:t}:t,o=typeof n.template=="string"?n.template:"";if(!o||o.trim().length===0)throw new oe(`Custom layout template is empty for ${e}`,e);let s=n.propsSchema||{},i=this.extractDefaultProps(s),a=n.defaultProps||{},l={id:e,version:n.version||"1.0.0",description:n.description||`Custom layout ${e}`,template:o,propsSchema:this.parsePropsSchema(s),defaultProps:{...i,...a}},u=this.layouts.get(e),d=u?.template===o&&JSON.stringify(u?.defaultProps??{})===JSON.stringify(l.defaultProps??{})&&JSON.stringify(u?.propsSchema??{})===JSON.stringify(l.propsSchema??{});this.layouts.set(e,l),process.env.CREWX_VERBOSE==="1"&&(u?d||console.error(`Updated custom layout: ${e}`):console.error(`Registered custom layout: ${e}`));}registerLayouts(e){for(let[t,n]of Object.entries(e))try{this.registerLayout(t,n);}catch(o){console.warn(`Failed to register custom layout ${t}:`,o instanceof Error?o.message:o);}}loadAllLayouts(){let e=this.options.templatesPath;if(!fs.existsSync(e))throw new oe(`Templates directory not found: ${e}`,void 0,new Error(`Directory does not exist: ${e}`));try{let t=fs.readdirSync(e).filter(n=>n.endsWith(".yaml")||n.endsWith(".yml"));t.length===0&&console.warn(`No layout files found in ${e}`);for(let n of t){let o=n.replace(/\.(yaml|yml)$/,""),s=re__namespace.join(e,n);try{let i=this.loadLayoutFile(s,o),a=`crewx/${o}`;this.layouts.set(a,i),a!=="crewx/minimal"&&process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded layout: ${a} from ${n}`);}catch(i){console.error(`Failed to load layout file ${n}:`,i);}}process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded ${this.layouts.size} layouts from ${e}`);}catch(t){throw new oe(`Failed to read layouts directory: ${e}`,void 0,t instanceof Error?t:new Error(String(t)))}}loadLayoutFile(e,t){try{let n=fs.readFileSync(e,"utf-8");if(!n||n.trim().length===0)throw console.warn(`Empty YAML file: ${e}, will use fallback`),new oe(`Empty YAML file: ${e}`,t,new Error("File content is empty"));let o=jsYaml.load(n);if(!o||typeof o!="object")throw console.warn(`Invalid YAML content in ${e} (parsed as ${typeof o}), will use fallback`),new oe(`Invalid or empty YAML in ${e}`,t,new Error("YAML parsing returned null/undefined or non-object"));if(o.layouts&&typeof o.layouts=="object"){let s=this.resolveLayoutEntry(o.layouts,t);if(!s||s.template.trim().length===0)throw console.warn(`Empty or missing layout template in ${e} for ${t}`),new oe(`Layout template not found or empty in layouts map: ${t}`,t);let i=s.propsSchema||o.propsSchema||{};return {id:`crewx/${t}`,version:o.version||"1.0.0",description:o.description||`CrewX ${t} layout`,template:s.template,propsSchema:this.parsePropsSchema(i),defaultProps:this.extractDefaultProps(i)}}else {if(!o.template||typeof o.template=="string"&&o.template.trim().length===0)throw console.warn(`Empty or missing template field in ${e}`),new oe(`Layout template is missing or empty in ${e}`,t);return {id:o.id||`crewx/${t}`,version:o.version||"1.0.0",description:o.description||"",template:o.template,propsSchema:this.parsePropsSchema(o.propsSchema||{}),defaultProps:this.extractDefaultProps(o.propsSchema||{})}}}catch(n){throw new oe(`Failed to load layout file: ${e}`,t,n instanceof Error?n:new Error(String(n)))}}parsePropsSchema(e){let t={};for(let[n,o]of Object.entries(e))typeof o=="object"&&o!==null&&(t[n]=o);return t}extractDefaultProps(e){let t={};for(let[n,o]of Object.entries(e))o&&typeof o=="object"&&("defaultValue"in o?t[n]=o.defaultValue:"default"in o&&(t[n]=o.default));return t}normalizeLayoutId(e){return e?e.includes("/")?e:`crewx/${e}`:this.options.fallbackLayoutId}resolveLayoutEntry(e,t){let n=new Set;if(t)if(n.add(t),t.includes("/")){let o=t.split("/"),s=o[o.length-1];s&&n.add(s);}else n.add(`crewx/${t}`);n.add("default");for(let o of n){let s=e[o];if(typeof s=="string"&&s.trim().length>0)return {template:s};if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}for(let o of Object.values(e)){if(typeof o=="string"&&o.trim().length>0)return {template:o};let s=o;if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}}};g();g();function ba(r){return Array.from(new Set(r.filter(e=>e?.isAssistant&&e?.metadata?.agent_id).map(e=>String(e.metadata.agent_id))))}function Fn(r,e,t){if(!Array.isArray(r)||r.length===0||!(t&&typeof t.fn=="function"))return "";let o=ba(r),s=o.length>0?o[0]:"",i={messages:r,platform:typeof e=="string"?e:"",messagesCount:r.length,agentIds:o,primaryAgentId:s};return t.fn(i)}g();var pt=class{defaultMode;constructor(e={}){this.defaultMode=e.defaultMode??"lenient";}validate(e,t,n=this.defaultMode){let o=[],s=this.validateObject(e??{},t,n,["props"],o);if(o.length>0&&n==="strict")throw new Ce("Props validation failed in strict mode",o);return {valid:o.length===0,props:s,errors:o}}validateObject(e,t,n,o,s){let i={};if(n==="strict")for(let a of Object.keys(e))t[a]||s.push({path:this.buildPath([...o,a]),message:`Unknown prop '${a}'`,value:e[a]});for(let[a,l]of Object.entries(t)){let u=[...o,a],d=e[a],c=this.resolveProp(d,l,u,n,s);c.shouldAssign&&(i[a]=c.value);}return i}resolveProp(e,t,n,o,s){let i=this.buildPath(n);if(this.isNil(e)){if(t.isRequired&&s.push({path:i,message:`Required prop '${n[n.length-1]}' is missing`}),t.defaultValue!==void 0)return {shouldAssign:true,value:this.cloneValue(t.defaultValue)};if(t.type==="shape"&&t.shape){let l=this.applyDefaults(t.shape);if(Object.keys(l).length>0)return {shouldAssign:true,value:l}}return {shouldAssign:false}}let a=this.validateType(e,t,n,o,s);if(!a.valid){if(t.type==="shape"&&a.value&&this.isPlainObject(a.value))return {shouldAssign:true,value:a.value};if(s.push({path:i,message:a.error??"Invalid value",value:e}),t.defaultValue!==void 0)return {shouldAssign:true,value:this.cloneValue(t.defaultValue)};if(t.type==="shape"&&t.shape){let l=this.applyDefaults(t.shape);if(Object.keys(l).length>0)return {shouldAssign:true,value:l}}return {shouldAssign:false}}return {shouldAssign:true,value:a.value}}validateType(e,t,n,o,s){let{type:i}=t;switch(i){case "string":return this.validateString(e,t);case "number":return this.validateNumber(e,t);case "bool":return this.validateBoolean(e);case "array":return this.validateArray(e,t);case "arrayOf":return this.validateArrayOf(e,t,n,o,s);case "object":return this.validatePlainObject(e);case "shape":return this.validateShape(e,t,n,o,s);case "oneOfType":return this.validateOneOfType(e,t);case "func":return this.validateFunction(e);case "node":return {valid:true,value:e};default:return {valid:true,value:e}}}validateString(e,t){return typeof e!="string"?{valid:false,error:`Expected string, got ${this.describeType(e)}`}:t.oneOf&&!t.oneOf.includes(e)?{valid:false,error:`Expected one of: ${t.oneOf.join(", ")}`}:t.minLength!==void 0&&e.length<t.minLength?{valid:false,error:`String length must be >= ${t.minLength}`}:t.maxLength!==void 0&&e.length>t.maxLength?{valid:false,error:`String length must be <= ${t.maxLength}`}:t.pattern&&!new RegExp(t.pattern).test(e)?{valid:false,error:`String does not match pattern ${t.pattern}`}:{valid:true,value:e}}validateNumber(e,t){return typeof e!="number"||Number.isNaN(e)?{valid:false,error:`Expected number, got ${this.describeType(e)}`}:t.min!==void 0&&e<t.min?{valid:false,error:`Number must be >= ${t.min}`}:t.max!==void 0&&e>t.max?{valid:false,error:`Number must be <= ${t.max}`}:t.oneOf&&!t.oneOf.includes(e)?{valid:false,error:`Expected one of: ${t.oneOf.join(", ")}`}:{valid:true,value:e}}validateBoolean(e){return typeof e!="boolean"?{valid:false,error:`Expected boolean, got ${this.describeType(e)}`}:{valid:true,value:e}}validateArray(e,t){return Array.isArray(e)?t.minLength!==void 0&&e.length<t.minLength?{valid:false,error:`Array length must be >= ${t.minLength}`}:t.maxLength!==void 0&&e.length>t.maxLength?{valid:false,error:`Array length must be <= ${t.maxLength}`}:{valid:true,value:[...e]}:{valid:false,error:`Expected array, got ${this.describeType(e)}`}}validateArrayOf(e,t,n,o,s){let i=this.validateArray(e,t);if(!i.valid)return i;let a=[],l=t.itemType,u=t.itemOneOf,d=s.length;return i.value.forEach((c,p)=>{let f=[...n,String(p)];if(l){let v=this.validateType(c,{type:l},f,o,s);v.valid?a.push(v.value):s.push({path:this.buildPath(f),message:v.error??"Invalid array item",value:c});}else a.push(c);u&&!u.includes(c)&&s.push({path:this.buildPath(f),message:`Array item must be one of: ${u.join(", ")}`,value:c});}),{valid:s.length===d,value:a}}validatePlainObject(e){return this.isPlainObject(e)?{valid:true,value:{...e}}:{valid:false,error:`Expected object, got ${this.describeType(e)}`}}validateFunction(e){return typeof e!="function"?{valid:false,error:`Expected function, got ${this.describeType(e)}`}:{valid:true,value:e}}validateShape(e,t,n,o,s){if(!this.isPlainObject(e))return {valid:false,error:`Expected object, got ${this.describeType(e)}`};let i=s.length,a=this.validateObject(e,t.shape??{},o,n,s);return {valid:s.length===i,value:a}}validateOneOfType(e,t){let n=t.types??[];return n.some(s=>this.matchesType(e,s))?{valid:true,value:e}:{valid:false,error:`Value does not match any allowed type: ${n.join(", ")}`}}matchesType(e,t){switch(t){case "string":return typeof e=="string";case "number":return typeof e=="number"&&!Number.isNaN(e);case "bool":case "boolean":return typeof e=="boolean";case "array":return Array.isArray(e);case "object":return this.isPlainObject(e);case "func":case "function":return typeof e=="function";case "shape":return this.isPlainObject(e);case "node":return e==null||typeof e!="symbol";default:return true}}applyDefaults(e){let t={};for(let[n,o]of Object.entries(e)){if(o.defaultValue!==void 0){t[n]=this.cloneValue(o.defaultValue);continue}if(o.type==="shape"&&o.shape){let s=this.applyDefaults(o.shape);Object.keys(s).length>0&&(t[n]=s);}}return t}cloneValue(e){if(Array.isArray(e))return e.map(t=>this.cloneValue(t));if(this.isPlainObject(e)){let t={};for(let[n,o]of Object.entries(e))t[n]=this.cloneValue(o);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}isNil(e){return e==null}buildPath(e){return e.join(".")}describeType(e){return Array.isArray(e)?"array":e===null?"null":typeof e}};var gt=class{handlebars;propsValidator;constructor(e){this.handlebars=ve__namespace.default.create(),this.propsValidator=e??new pt,this.registerHelpers();}render(e,t,n={}){try{let o=this.prepareRenderContext(e,t,n);return this.handlebars.compile(e.template,{noEscape:!0})(o)}catch(o){throw o instanceof Error?new Error(`Template rendering failed for layout '${e.id}': ${o.message}`):new Error(`Unknown error rendering layout '${e.id}'`)}}validate(e,t,n="lenient"){return this.executeValidation(e,t,n)}resolveProps(e,t,n="lenient"){let o=this.mergeProps(e.defaultProps,t);return !e.propsSchema||Object.keys(e.propsSchema).length===0?{valid:true,props:o,errors:[]}:this.executeValidation(o,e.propsSchema,n)}prepareRenderContext(e,t,n){let{validationMode:o="lenient",skipValidation:s=false}=n,i=s?this.mergeProps(e.defaultProps,t.props):this.resolveProps(e,t.props,o).props;return {...t,vars:this.sanitizeVars(t.vars),props:i}}registerHelpers(){this.handlebars.registerHelper("formatConversation",Fn),ve__namespace.default.helpers.each&&this.handlebars.registerHelper("each",ve__namespace.default.helpers.each),ve__namespace.default.helpers.if&&this.handlebars.registerHelper("if",ve__namespace.default.helpers.if),ve__namespace.default.helpers.unless&&this.handlebars.registerHelper("unless",ve__namespace.default.helpers.unless),ve__namespace.default.helpers.with&&this.handlebars.registerHelper("with",ve__namespace.default.helpers.with),this.handlebars.registerHelper("eq",function(e,t){return e===t}),this.handlebars.registerHelper("ne",function(e,t){return e!==t}),this.handlebars.registerHelper("gt",function(e,t){return e>t}),this.handlebars.registerHelper("lt",function(e,t){return e<t}),this.handlebars.registerHelper("json",function(e){return new ve__namespace.default.SafeString(JSON.stringify(e))}),this.handlebars.registerHelper("raw",function(e){return typeof e?.fn=="function"?e.fn(this):""}),this.handlebars.registerHelper("escapeHandlebars",function(e){return typeof e!="string"?"":e.replace(/\{\{/g,"{{").replace(/\}\}/g,"}}")}),this.handlebars.registerHelper("formatFileSize",function(e){if(e===0)return "0 B";let t=["B","KB","MB","GB"],n=Math.floor(Math.log(e)/Math.log(1024));return Math.round(e/Math.pow(1024,n)*100)/100+" "+t[n]});}executeValidation(e,t,n){try{return this.propsValidator.validate(e,t,n)}catch(o){if(o instanceof Ce&&o.errors&&o.errors.length>0){let s=o.errors[0];if(s)throw new Ce(s.message,o.errors)}throw o}}mergeProps(e,t){let n=this.cloneDeep(e??{});return t?this.deepMerge(n,t):n}deepMerge(e,t){for(let[n,o]of Object.entries(t)){if(this.isPlainObject(o)){let s=e[n];e[n]=this.deepMerge(this.isPlainObject(s)?s:{},o);continue}if(Array.isArray(o)){e[n]=this.cloneDeep(o);continue}e[n]=o;}return e}cloneDeep(e){if(Array.isArray(e))return e.map(t=>this.cloneDeep(t));if(this.isPlainObject(e)){let t={};for(let[n,o]of Object.entries(e))t[n]=this.cloneDeep(o);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}sanitizeVars(e){if(!e)return {};let t={...e};if(typeof e.user_input=="string"){t.user_input_raw=e.user_input;let n=e.user_input.replace(/\{\{\{/g,"{{{").replace(/\}\}\}/g,"}}}").replace(/\{\{/g,"{{").replace(/\}\}/g,"}}");t.user_input=this.handlebars.escapeExpression(n);}return t}};g();var Or="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function xa(r){let e=crypto$1.randomBytes(r*2),t="";for(let n=0;n<e.length&&t.length<r;n++){let o=e[n];o<248&&(t+=Or[o%62]);}for(;t.length<r;)t+=Or[crypto$1.randomBytes(1)[0]%62];return t}function Fe(r){return `${r}_${xa(8)}`}function ka(r,e){let{createHash:t}=W("crypto"),n=t("sha256").update(e).digest(),o=Buffer.alloc(8);for(let i=0;i<32;i++)o[i%8]^=n[i];let s="";for(let i of o)s+=Or[i%62];return `${r}_${s}`}g();function zr(r){let e=t=>String(t).padStart(2,"0");return `${r.getFullYear()}${e(r.getMonth()+1)}${e(r.getDate())}T${e(r.getHours())}${e(r.getMinutes())}${e(r.getSeconds())}`}g();function Wn(r,e){return t=>{try{let n=e(t);n instanceof Promise&&n.catch(o=>{console.error(`[crewx] event listener error (${r}): ${o instanceof Error?o.message:String(o)}`);});}catch(n){console.error(`[crewx] event listener error (${r}): ${n instanceof Error?n.message:String(n)}`);}}}var mt=class{_emitter=new events.EventEmitter;on(e,t){let n=Wn(e,t);return this._emitter.on(e,n),()=>this._emitter.off(e,n)}once(e,t){let n=Wn(e,t);return this._emitter.once(e,n),()=>this._emitter.off(e,n)}emit(e,t){this._emitter.emit(e,t);}};g();function Mr(r){let e=new Map,t=n=>n.startsWith(`${r}::`)?n:`${r}::${n}`;return {async get(n){let o=e.get(t(n));return o?o.value:void 0},async set(n,o){e.set(t(n),{value:o});},async delete(n){return e.delete(t(n))},async list(n){let o=n?t(n):`${r}::`,s=[];for(let i of e.keys())i.startsWith(o)&&s.push(i.slice(r.length+2));return s}}}g();var jr=new async_hooks.AsyncLocalStorage;function Ta(){return jr}function Pa(r,e){return jr.run(r,e)}function Nr(r){let e=r.log??r.logger??{debug:()=>{},info:()=>{},warn:()=>{},error:()=>{}},t=r.agentRunner??{run:async()=>({output:""})},n=r.db??{get:async()=>{},set:async()=>{},delete:async()=>false,list:async()=>[]},o=r.storage??{put:async()=>"",get:async()=>{},delete:async()=>false},s=r.audit??{log:async()=>{}},i=r.onInbound??(async()=>({accepted:true})),a=r.onEmitEvent??(async()=>({accepted:true})),l=r.onUpdateMessage??(async()=>{}),u=r.onResolveUser??(async p=>({userId:p,displayName:p})),d=async p=>{let f=jr.getStore();if(!f){e.warn("respondSync called outside sync window \u2014 graceful degradation (no-op)",{textPreview:typeof p=="object"&&"text"in p?p.text.slice(0,80):void 0});return}let v="text"in p?p.text:"";f.res.status(200).json({text:v});},c=r.httpRouter??{registerRoute:()=>{e.warn("httpRouter not configured \u2014 registerRoute is a no-op");}};return {instanceId:r.instanceId,config:r.config,capabilities:r.capabilities,log:e,agentRunner:t,db:n,storage:o,audit:s,abortSignal:r.abortSignal??new AbortController().signal,httpRouter:c,inbound:i,emitEvent:a,updateMessage:l,resolveUser:u,respondSync:d}}Ze();Ze();g();function Aa(r){return typeof r!="string"?"":r.replace(/</g,"<").replace(/>/g,">")}function Dr(r){return r.messages.map(e=>({text:Aa(e.text),isAssistant:e.isAssistant,metadata:e.metadata,files:void 0}))}g();g();var Ea={agentId:zod.z.string().describe("The agent ID to query"),query:zod.z.string().describe("The query message to send"),context:zod.z.string().optional().describe("Additional context"),thread:zod.z.string().optional().describe("Thread ID for conversation continuity")},Sa={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 Jn(r,e,t){r.tool("crewx_listAgents","List available CrewX agents exposed by this server",async()=>{let n=[];for(let o of t){let s=e.agents.get(o);s&&n.push({id:s.id,name:s.name??s.id,description:s.description??""});}return {content:[{type:"text",text:JSON.stringify(n,null,2)}]}}),r.tool("crewx_queryAgent","Query a CrewX agent with a read-only question",Ea,async({agentId:n,query:o,context:s,thread:i})=>{if(!t.has(n))return {content:[{type:"text",text:`Agent '${n}' is not exposed by this server`}],isError:true};let a=await e.query(n,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}}),r.tool("crewx_executeAgent","Execute a task on a CrewX agent (may modify state)",Sa,async({agentId:n,task:o,context:s,thread:i})=>{if(!t.has(n))return {content:[{type:"text",text:`Agent '${n}' is not exposed by this server`}],isError:true};let a=await e.execute(n,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}});}g();function Vn(r){return r.headers.get("Origin")?null:new Response(JSON.stringify({error:"Forbidden: Origin header required"}),{status:403,headers:{"Content-Type":"application/json"}})}async function Kn(r,e){return e?await e(r)?null:new Response(JSON.stringify({error:"Unauthorized"}),{status:401,headers:{"Content-Type":"application/json"}}):null}function za(r,e){let t=new mcp_js.McpServer({name:"crewx-mcp-server",version:"1.0.0"},{capabilities:{tools:{}}});return Jn(t,r,e),t}function $r(r,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),n=new Map;return async o=>{let s=Vn(o);if(s)return s;let i=await Kn(o,e.auth);if(i)return i;let a=o.headers.get("mcp-session-id");if(a&&n.has(a))return n.get(a).transport.handleRequest(o);let l=za(r,t),u=new webStandardStreamableHttp_js.WebStandardStreamableHTTPServerTransport({sessionIdGenerator:()=>crypto.randomUUID(),onsessioninitialized:d=>{n.set(d,{transport:u,server:l});},onsessionclosed:d=>{n.delete(d);},enableJsonResponse:true});return await l.connect(u),u.handleRequest(o)}}g();g();var ft=class{detach(e){}};g();g();g();var Vt=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:re.join(Na__default.default.homedir(),".crewx","crewx.db")}resolveDbPaths(){return [this.resolveDbPath()]}isMissingTableError(e){return e instanceof Error&&/no such table:/i.test(e.message)}dbExists(e){return fs.existsSync(e??this.resolveDbPath())}};g();function _e(r){let e=W("better-sqlite3"),{drizzle:t}=W("drizzle-orm/better-sqlite3"),n=new e(r);return n.exec("PRAGMA journal_mode = WAL"),n.exec("PRAGMA busy_timeout = 5000"),n.exec("PRAGMA foreign_keys = ON"),{db:t(n),runRaw:(o,s=[])=>n.prepare(o).run(...s),close:()=>n.close()}}g();var Gn=new Set;function $a(r){let{migrate:e}=W("drizzle-orm/better-sqlite3/migrator"),t=[re__namespace.default.join(__dirname,"../migrations"),re__namespace.default.join(__dirname,"migrations")],n=t.find(o=>fs.existsSync(re__namespace.default.join(o,"meta/_journal.json")));if(!n)throw new Error(`migrations folder not found. Searched:
|
|
41
|
+
Set CREWX_SDK_TEMPLATES_PATH or pass options.templatesPath.`)}function Lt(){let o=Te();return {yamlPath:U.join(o,"default.yaml"),dir:o}}l();var oe=class extends Error{constructor(e,t){let r=t.length>0?` Available: ${t.join(", ")}`:"";super(`Agent not found: "${e}".${r}`),this.name="AgentNotFoundError";}},so={claude:{id:"claude",provider:"cli/claude"},gemini:{id:"gemini",provider:"cli/gemini"},copilot:{id:"copilot",provider:"cli/copilot"},codex:{id:"codex",provider:"cli/codex"}};function lt(o,e){let t=o.startsWith("@")?o.slice(1):o,r=e.find(s=>s.id===t);if(r)return r;let n=so[t];if(n)return n;throw new oe(o,e.map(s=>s.id))}Z();l();function Ur(o,e){if(o===void 0||o==="")return e;let t=parseInt(o,10);return Number.isNaN(t)?e:t}function Fr(o=process.env){return {queryMs:Ur(o.CREWX_TIMEOUT_QUERY,36e5),executeMs:Ur(o.CREWX_TIMEOUT_EXECUTE,36e5)}}l();l();var Co=[/^ANTHROPIC_/i,/^OPENAI_/i,/^AWS_SECRET/i,/^SLACK_/i,/^GITHUB_TOKEN$/i,/^CREWX_MCP_KEY$/i,/^DATABASE_/i,/^AWS_ACCESS_KEY/i,/^AWS_SESSION_TOKEN$/i,/^GH_TOKEN$/i,/^GH_APP_/i,/^NPM_TOKEN$/i,/^NPM_AUTH/i,/^GOOGLE_APPLICATION/i,/^GCLOUD_/i,/^AZURE_/i,/^ARM_/i,/^DOCKER_PASSWORD$/i,/^DOCKER_AUTH/i,/^SSH_PRIVATE/i,/^SSH_AUTH_SOCK$/i,/^CI_JOB_TOKEN$/i,/^ACTIONS_RUNTIME_TOKEN$/i,/^VAULT_TOKEN$/i,/^SONAR_TOKEN$/i,/^CODECOV_TOKEN$/i,/TOKEN$/i,/SECRET$/i,/PASSWORD$/i,/API_KEY$/i],bo=/[;|&`$(){}!><\n\r]/,To=2,So=["*","**","*:*","* *","**/*"];function Eo(){let o={};for(let[e,t]of Object.entries(process.env))t!==void 0&&(Co.some(r=>r.test(e))||(o[e]=t));return o}function Io(o){if(bo.test(o))throw new Error(`exec blocked: shell metacharacter detected in "${o}"`)}function Oo(o){return /^npx\s+@crewx\/[\w-]+/.test(o)}function Mo(o){if(So.includes(o.trim()))throw new Error(`exec config error: overly broad pattern "${o}" is not allowed`);if(!/^[\w./@-]/.test(o))throw new Error("exec config error: pattern must start with a command name")}function No(o,e){let t=e.allow??[],r=e.deny??[];for(let n of [...t,...r])Mo(n);return r.some(n=>Y(o,n))?false:Oo(o)?true:t.some(n=>Y(o,n))}var qr=false;function Do(o){qr=o;}function He(o){if(!qr)return;let e=JSON.stringify({span:"template_exec",...o,timestamp:new Date().toISOString()});console.error(e);}function Lo(o){let e=[],t="",r=false,n=false;for(let s=0;s<o.length;s++){let i=o[s];i==="'"&&!n?r=!r:i==='"'&&!r?n=!n:i===" "&&!r&&!n?t.length>0&&(e.push(t),t=""):t+=i;}return t.length>0&&e.push(t),e}function Wr(o,e){let t=Date.now(),r=parseInt(process.env.CREWX_EXEC_DEPTH??"0",10);if(isNaN(r)||r>=To)return He({command:o,status:"denied",reason:"invalid or max recursion depth"}),"(exec blocked: max recursion depth reached)";try{Io(o);}catch{return He({command:o,status:"denied",reason:"shell metacharacter detected"}),`(exec blocked: shell metacharacter detected in "${o}")`}if(!No(o,e))return He({command:o,status:"denied",reason:"not in allow list"}),`(exec blocked: ${o})`;try{let n=Lo(o),[s,...i]=n;if(!s)return `(exec failed: ${o})`;let a=Eo(),d=child_process.execFileSync(s,i,{timeout:e.timeout??5e3,maxBuffer:64*1024,encoding:"utf-8",env:{...a,CREWX_EXEC_DEPTH:String(r+1)},stdio:["pipe","pipe","pipe"]}),c=Date.now()-t;return He({command:o,status:"allowed",allowed_by:"policy",duration_ms:c}),`<exec-output cmd="${o}">
|
|
42
|
+
${d.trim()}
|
|
43
|
+
</exec-output>`}catch{return He({command:o,status:"error",reason:"execution failed"}),`(exec failed: ${o})`}}l();function Br(o){return o==null?"":String(o)}l();function zr(o,e){return `\`\`\`${e?.hash?.lang??""}
|
|
44
|
+
${o??""}
|
|
45
|
+
\`\`\``}l();function zt(o,e){if(!o)return "";if(o.length<=e)return o;let t=o.length-e;return `${o.substring(0,e)} (...+${t} chars)`}function Vt(o){return Array.isArray(o)||typeof o=="string"?o.length:0}function Kt(o){return typeof o!="string"?"":o.replace(/\{\{/g,"{{").replace(/\}\}/g,"}}")}var Vr=["B","KB","MB","GB"];function Jt(o){if(o===0)return "0 B";let e=Math.min(Math.floor(Math.log(o)/Math.log(1024)),Vr.length-1);return `${Math.round(o/Math.pow(1024,e)*100)/100} ${Vr[e]}`}function Xt(o){if(!o)return "";try{let e=o instanceof Date?o:new Date(o);return isNaN(e.getTime())?"":e.toLocaleString("ko-KR",{year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1})}catch{return ""}}var Ue=class{hbs;execPolicy;execEnabled;constructor(e={}){this.hbs=ee__namespace.create(),this.execPolicy=e.execPolicy??{allow:[],deny:[]},this.execEnabled=e.execEnabled??true,this.registerHelpers();}registerHelpers(){let e=this.hbs,t=this.execPolicy,r=this.execEnabled;e.registerHelper("exec",function(n){return typeof n!="string"?"":r?new e.SafeString(Wr(n,t)):"(exec disabled)"}),e.registerHelper("include",function(n){return new e.SafeString(Br(n))}),e.registerHelper("fenced_code",function(n,s){return new e.SafeString(zr(n,s))}),e.registerHelper("eq",function(n,s){return n===s}),e.registerHelper("ne",function(n,s){return n!==s}),e.registerHelper("and",function(n,s){return n&&s}),e.registerHelper("or",function(n,s){return n||s}),e.registerHelper("not",function(n){return !n}),e.registerHelper("contains",function(n,s){return Array.isArray(n)&&n.includes(s)}),e.registerHelper("json",function(n){return JSON.stringify(n,null,2)}),e.registerHelper("truncate",function(n,s){return zt(n,s)}),e.registerHelper("length",function(n){return Vt(n)}),e.registerHelper("escapeHandlebars",function(n){return new e.SafeString(Kt(n))}),e.registerHelper("formatFileSize",function(n){return Jt(n)}),e.registerHelper("formatTimestamp",function(n){return Xt(n)});}async render(e,t={}){return this.hbs.compile(e,{noEscape:true})(t)}};l();l();var wt=class{async readFile(e){return promises.readFile(e,"utf-8")}async exists(e){try{return await promises.access(e),!0}catch{return false}}resolvePath(...e){return e.length===1?U.resolve(e[0]):U.resolve(U.join(...e))}isAbsolute(e){return U.isAbsolute(e)}},Qt=new wt;var ke=class{docs=new Map;fs;constructor(e){this.fs=e??Qt;}async load(e,t){if(e)for(let[r,n]of Object.entries(e)){let s=n;if(typeof s=="string")this.docs.set(r,{content:s});else if(s&&typeof s=="object"){let i=s;"content"in i&&typeof i.content=="string"?this.docs.set(r,{content:i.content}):"path"in i&&typeof i.path=="string"?await this.loadFromFile(r,i.path,t):console.warn(`[DocumentLoader] Skipping '${r}': unsupported format`);}else console.warn(`[DocumentLoader] Skipping '${r}': unsupported format`);}}async getContent(e){return this.docs.get(e)?.content}async getToc(e){let t=this.docs.get(e);if(!t)return;let r=[];for(let n of t.content.split(`
|
|
46
|
+
`)){let s=/^(#{1,6})\s+(.+)$/.exec(n.trim());s&&r.push({depth:s[1].length,text:s[2].trim()});}if(r.length!==0)return r.map(({depth:n,text:s})=>`${" ".repeat(n-1)}- ${s}`).join(`
|
|
47
|
+
`)}getPath(e){return this.docs.get(e)?.path}getNames(){return Array.from(this.docs.keys())}async buildContext(){let e={};for(let t of this.docs.keys()){let r=await this.getContent(t)??"",n=await this.getToc(t),s=this.getPath(t);e[t]={content:r,toc:n,...s?{path:s}:{}};}return e}async loadFromFile(e,t,r){try{let n=this.resolve(t,r),s=await this.fs.readFile(n);this.docs.set(e,{content:s,path:n});}catch(n){let s=n instanceof Error?n.message:String(n);console.warn(`[DocumentLoader] Failed to load '${e}' from '${t}': ${s}`);}}resolve(e,t){return this.fs.isAbsolute(e)?e:t?this.fs.resolvePath(t,e):this.fs.resolvePath(e)}};l();l();var q=class extends Error{constructor(t,r,n){super(t);this.layoutId=r;this.cause=n;this.name="LayoutLoadError";}layoutId;cause},ae=class extends Error{constructor(t,r=[],n){super(t);this.errors=r;this.cause=n;this.name="PropsValidationError";}errors;cause};var zo={validationMode:"lenient",fallbackLayoutId:"crewx/default"},Fe=class{layouts=new Map;options;constructor(e){this.options={...zo,...e,templatesPath:e?.templatesPath??Te()},this.loadAllLayouts();}load(e,t){let r=this.layouts.get(e);if(!r){let n=this.normalizeLayoutId(e);r=this.layouts.get(n);}if(!r&&(console.warn(`Layout not found: ${e}, falling back to ${this.options.fallbackLayoutId}`),r=this.layouts.get(this.options.fallbackLayoutId),!r))throw new q(`Fallback layout not found: ${this.options.fallbackLayoutId}`,this.options.fallbackLayoutId);return t&&Object.keys(t).length>0?{...r,defaultProps:{...r.defaultProps,...t}}:r}getLayoutIds(){return Array.from(this.layouts.keys())}hasLayout(e){if(this.layouts.has(e))return true;let t=this.normalizeLayoutId(e);return this.layouts.has(t)}reload(){this.layouts.clear(),this.loadAllLayouts();}registerLayout(e,t){if(!e||typeof e!="string")throw new q("Layout ID must be a non-empty string",e);let r=typeof t=="string"?{template:t}:t,n=typeof r.template=="string"?r.template:"";if(!n||n.trim().length===0)throw new q(`Custom layout template is empty for ${e}`,e);let s=r.propsSchema||{},i=this.extractDefaultProps(s),a=r.defaultProps||{},d={id:e,version:r.version||"1.0.0",description:r.description||`Custom layout ${e}`,template:n,propsSchema:this.parsePropsSchema(s),defaultProps:{...i,...a}},c=this.layouts.get(e),u=c?.template===n&&JSON.stringify(c?.defaultProps??{})===JSON.stringify(d.defaultProps??{})&&JSON.stringify(c?.propsSchema??{})===JSON.stringify(d.propsSchema??{});this.layouts.set(e,d),process.env.CREWX_VERBOSE==="1"&&(c?u||console.error(`Updated custom layout: ${e}`):console.error(`Registered custom layout: ${e}`));}registerLayouts(e){for(let[t,r]of Object.entries(e))try{this.registerLayout(t,r);}catch(n){console.warn(`Failed to register custom layout ${t}:`,n instanceof Error?n.message:n);}}loadAllLayouts(){let e=this.options.templatesPath;if(!fs.existsSync(e))throw new q(`Templates directory not found: ${e}`,void 0,new Error(`Directory does not exist: ${e}`));try{let t=fs.readdirSync(e).filter(r=>r.endsWith(".yaml")||r.endsWith(".yml"));t.length===0&&console.warn(`No layout files found in ${e}`);for(let r of t){let n=r.replace(/\.(yaml|yml)$/,""),s=U__namespace.join(e,r);try{let i=this.loadLayoutFile(s,n),a=`crewx/${n}`;this.layouts.set(a,i),a!=="crewx/minimal"&&process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded layout: ${a} from ${r}`);}catch(i){console.error(`Failed to load layout file ${r}:`,i);}}process.env.CREWX_VERBOSE==="1"&&console.error(`Loaded ${this.layouts.size} layouts from ${e}`);}catch(t){throw new q(`Failed to read layouts directory: ${e}`,void 0,t instanceof Error?t:new Error(String(t)))}}loadLayoutFile(e,t){try{let r=fs.readFileSync(e,"utf-8");if(!r||r.trim().length===0)throw console.warn(`Empty YAML file: ${e}, will use fallback`),new q(`Empty YAML file: ${e}`,t,new Error("File content is empty"));let n=jsYaml.load(r);if(!n||typeof n!="object")throw console.warn(`Invalid YAML content in ${e} (parsed as ${typeof n}), will use fallback`),new q(`Invalid or empty YAML in ${e}`,t,new Error("YAML parsing returned null/undefined or non-object"));if(n.layouts&&typeof n.layouts=="object"){let s=this.resolveLayoutEntry(n.layouts,t);if(!s||s.template.trim().length===0)throw console.warn(`Empty or missing layout template in ${e} for ${t}`),new q(`Layout template not found or empty in layouts map: ${t}`,t);let i=s.propsSchema||n.propsSchema||{};return {id:`crewx/${t}`,version:n.version||"1.0.0",description:n.description||`CrewX ${t} layout`,template:s.template,propsSchema:this.parsePropsSchema(i),defaultProps:this.extractDefaultProps(i)}}else {if(!n.template||typeof n.template=="string"&&n.template.trim().length===0)throw console.warn(`Empty or missing template field in ${e}`),new q(`Layout template is missing or empty in ${e}`,t);return {id:n.id||`crewx/${t}`,version:n.version||"1.0.0",description:n.description||"",template:n.template,propsSchema:this.parsePropsSchema(n.propsSchema||{}),defaultProps:this.extractDefaultProps(n.propsSchema||{})}}}catch(r){throw new q(`Failed to load layout file: ${e}`,t,r instanceof Error?r:new Error(String(r)))}}parsePropsSchema(e){let t={};for(let[r,n]of Object.entries(e))typeof n=="object"&&n!==null&&(t[r]=n);return t}extractDefaultProps(e){let t={};for(let[r,n]of Object.entries(e))n&&typeof n=="object"&&("defaultValue"in n?t[r]=n.defaultValue:"default"in n&&(t[r]=n.default));return t}normalizeLayoutId(e){return e?e.includes("/")?e:`crewx/${e}`:this.options.fallbackLayoutId}resolveLayoutEntry(e,t){let r=new Set;if(t)if(r.add(t),t.includes("/")){let n=t.split("/"),s=n[n.length-1];s&&r.add(s);}else r.add(`crewx/${t}`);r.add("default");for(let n of r){let s=e[n];if(typeof s=="string"&&s.trim().length>0)return {template:s};if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}for(let n of Object.values(e)){if(typeof n=="string"&&n.trim().length>0)return {template:n};let s=n;if(s&&typeof s=="object"&&typeof s.template=="string"&&s.template.trim().length>0)return {template:s.template,propsSchema:s.propsSchema}}}};l();l();function Vo(o){return Array.from(new Set(o.filter(e=>e?.isAssistant&&e?.metadata?.agent_id).map(e=>String(e.metadata.agent_id))))}function Qr(o,e,t){if(!Array.isArray(o)||o.length===0||!(t&&typeof t.fn=="function"))return "";let n=Vo(o),s=n.length>0?n[0]:"",i={messages:o,platform:typeof e=="string"?e:"",messagesCount:o.length,agentIds:n,primaryAgentId:s};return t.fn(i)}l();var qe=class{defaultMode;constructor(e={}){this.defaultMode=e.defaultMode??"lenient";}validate(e,t,r=this.defaultMode){let n=[],s=this.validateObject(e??{},t,r,["props"],n);if(n.length>0&&r==="strict")throw new ae("Props validation failed in strict mode",n);return {valid:n.length===0,props:s,errors:n}}validateObject(e,t,r,n,s){let i={};if(r==="strict")for(let a of Object.keys(e))t[a]||s.push({path:this.buildPath([...n,a]),message:`Unknown prop '${a}'`,value:e[a]});for(let[a,d]of Object.entries(t)){let c=[...n,a],u=e[a],p=this.resolveProp(u,d,c,r,s);p.shouldAssign&&(i[a]=p.value);}return i}resolveProp(e,t,r,n,s){let i=this.buildPath(r);if(this.isNil(e)){if(t.isRequired&&s.push({path:i,message:`Required prop '${r[r.length-1]}' is missing`}),t.defaultValue!==void 0)return {shouldAssign:true,value:this.cloneValue(t.defaultValue)};if(t.type==="shape"&&t.shape){let d=this.applyDefaults(t.shape);if(Object.keys(d).length>0)return {shouldAssign:true,value:d}}return {shouldAssign:false}}let a=this.validateType(e,t,r,n,s);if(!a.valid){if(t.type==="shape"&&a.value&&this.isPlainObject(a.value))return {shouldAssign:true,value:a.value};if(s.push({path:i,message:a.error??"Invalid value",value:e}),t.defaultValue!==void 0)return {shouldAssign:true,value:this.cloneValue(t.defaultValue)};if(t.type==="shape"&&t.shape){let d=this.applyDefaults(t.shape);if(Object.keys(d).length>0)return {shouldAssign:true,value:d}}return {shouldAssign:false}}return {shouldAssign:true,value:a.value}}validateType(e,t,r,n,s){let{type:i}=t;switch(i){case "string":return this.validateString(e,t);case "number":return this.validateNumber(e,t);case "bool":return this.validateBoolean(e);case "array":return this.validateArray(e,t);case "arrayOf":return this.validateArrayOf(e,t,r,n,s);case "object":return this.validatePlainObject(e);case "shape":return this.validateShape(e,t,r,n,s);case "oneOfType":return this.validateOneOfType(e,t);case "func":return this.validateFunction(e);case "node":return {valid:true,value:e};default:return {valid:true,value:e}}}validateString(e,t){return typeof e!="string"?{valid:false,error:`Expected string, got ${this.describeType(e)}`}:t.oneOf&&!t.oneOf.includes(e)?{valid:false,error:`Expected one of: ${t.oneOf.join(", ")}`}:t.minLength!==void 0&&e.length<t.minLength?{valid:false,error:`String length must be >= ${t.minLength}`}:t.maxLength!==void 0&&e.length>t.maxLength?{valid:false,error:`String length must be <= ${t.maxLength}`}:t.pattern&&!new RegExp(t.pattern).test(e)?{valid:false,error:`String does not match pattern ${t.pattern}`}:{valid:true,value:e}}validateNumber(e,t){return typeof e!="number"||Number.isNaN(e)?{valid:false,error:`Expected number, got ${this.describeType(e)}`}:t.min!==void 0&&e<t.min?{valid:false,error:`Number must be >= ${t.min}`}:t.max!==void 0&&e>t.max?{valid:false,error:`Number must be <= ${t.max}`}:t.oneOf&&!t.oneOf.includes(e)?{valid:false,error:`Expected one of: ${t.oneOf.join(", ")}`}:{valid:true,value:e}}validateBoolean(e){return typeof e!="boolean"?{valid:false,error:`Expected boolean, got ${this.describeType(e)}`}:{valid:true,value:e}}validateArray(e,t){return Array.isArray(e)?t.minLength!==void 0&&e.length<t.minLength?{valid:false,error:`Array length must be >= ${t.minLength}`}:t.maxLength!==void 0&&e.length>t.maxLength?{valid:false,error:`Array length must be <= ${t.maxLength}`}:{valid:true,value:[...e]}:{valid:false,error:`Expected array, got ${this.describeType(e)}`}}validateArrayOf(e,t,r,n,s){let i=this.validateArray(e,t);if(!i.valid)return i;let a=[],d=t.itemType,c=t.itemOneOf,u=s.length;return i.value.forEach((p,g)=>{let m=[...r,String(g)];if(d){let y=this.validateType(p,{type:d},m,n,s);y.valid?a.push(y.value):s.push({path:this.buildPath(m),message:y.error??"Invalid array item",value:p});}else a.push(p);c&&!c.includes(p)&&s.push({path:this.buildPath(m),message:`Array item must be one of: ${c.join(", ")}`,value:p});}),{valid:s.length===u,value:a}}validatePlainObject(e){return this.isPlainObject(e)?{valid:true,value:{...e}}:{valid:false,error:`Expected object, got ${this.describeType(e)}`}}validateFunction(e){return typeof e!="function"?{valid:false,error:`Expected function, got ${this.describeType(e)}`}:{valid:true,value:e}}validateShape(e,t,r,n,s){if(!this.isPlainObject(e))return {valid:false,error:`Expected object, got ${this.describeType(e)}`};let i=s.length,a=this.validateObject(e,t.shape??{},n,r,s);return {valid:s.length===i,value:a}}validateOneOfType(e,t){let r=t.types??[];return r.some(s=>this.matchesType(e,s))?{valid:true,value:e}:{valid:false,error:`Value does not match any allowed type: ${r.join(", ")}`}}matchesType(e,t){switch(t){case "string":return typeof e=="string";case "number":return typeof e=="number"&&!Number.isNaN(e);case "bool":case "boolean":return typeof e=="boolean";case "array":return Array.isArray(e);case "object":return this.isPlainObject(e);case "func":case "function":return typeof e=="function";case "shape":return this.isPlainObject(e);case "node":return e==null||typeof e!="symbol";default:return true}}applyDefaults(e){let t={};for(let[r,n]of Object.entries(e)){if(n.defaultValue!==void 0){t[r]=this.cloneValue(n.defaultValue);continue}if(n.type==="shape"&&n.shape){let s=this.applyDefaults(n.shape);Object.keys(s).length>0&&(t[r]=s);}}return t}cloneValue(e){if(Array.isArray(e))return e.map(t=>this.cloneValue(t));if(this.isPlainObject(e)){let t={};for(let[r,n]of Object.entries(e))t[r]=this.cloneValue(n);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}isNil(e){return e==null}buildPath(e){return e.join(".")}describeType(e){return Array.isArray(e)?"array":e===null?"null":typeof e}};var We=class{handlebars;propsValidator;constructor(e){this.handlebars=ee__namespace.default.create(),this.propsValidator=e??new qe,this.registerHelpers();}render(e,t,r={}){try{let n=this.prepareRenderContext(e,t,r);return this.handlebars.compile(e.template,{noEscape:!0})(n)}catch(n){throw n instanceof Error?new Error(`Template rendering failed for layout '${e.id}': ${n.message}`):new Error(`Unknown error rendering layout '${e.id}'`)}}validate(e,t,r="lenient"){return this.executeValidation(e,t,r)}resolveProps(e,t,r="lenient"){let n=this.mergeProps(e.defaultProps,t);return !e.propsSchema||Object.keys(e.propsSchema).length===0?{valid:true,props:n,errors:[]}:this.executeValidation(n,e.propsSchema,r)}prepareRenderContext(e,t,r){let{validationMode:n="lenient",skipValidation:s=false}=r,i=s?this.mergeProps(e.defaultProps,t.props):this.resolveProps(e,t.props,n).props;return {...t,vars:this.sanitizeVars(t.vars),props:i}}registerHelpers(){this.handlebars.registerHelper("formatConversation",Qr),ee__namespace.default.helpers.each&&this.handlebars.registerHelper("each",ee__namespace.default.helpers.each),ee__namespace.default.helpers.if&&this.handlebars.registerHelper("if",ee__namespace.default.helpers.if),ee__namespace.default.helpers.unless&&this.handlebars.registerHelper("unless",ee__namespace.default.helpers.unless),ee__namespace.default.helpers.with&&this.handlebars.registerHelper("with",ee__namespace.default.helpers.with),this.handlebars.registerHelper("eq",function(e,t){return e===t}),this.handlebars.registerHelper("ne",function(e,t){return e!==t}),this.handlebars.registerHelper("gt",function(e,t){return e>t}),this.handlebars.registerHelper("lt",function(e,t){return e<t}),this.handlebars.registerHelper("json",function(e){return new ee__namespace.default.SafeString(JSON.stringify(e))}),this.handlebars.registerHelper("raw",function(e){return typeof e?.fn=="function"?e.fn(this):""}),this.handlebars.registerHelper("escapeHandlebars",function(e){return typeof e!="string"?"":e.replace(/\{\{/g,"{{").replace(/\}\}/g,"}}")}),this.handlebars.registerHelper("formatFileSize",function(e){if(e===0)return "0 B";let t=["B","KB","MB","GB"],r=Math.floor(Math.log(e)/Math.log(1024));return Math.round(e/Math.pow(1024,r)*100)/100+" "+t[r]});}executeValidation(e,t,r){try{return this.propsValidator.validate(e,t,r)}catch(n){if(n instanceof ae&&n.errors&&n.errors.length>0){let s=n.errors[0];if(s)throw new ae(s.message,n.errors)}throw n}}mergeProps(e,t){let r=this.cloneDeep(e??{});return t?this.deepMerge(r,t):r}deepMerge(e,t){for(let[r,n]of Object.entries(t)){if(this.isPlainObject(n)){let s=e[r];e[r]=this.deepMerge(this.isPlainObject(s)?s:{},n);continue}if(Array.isArray(n)){e[r]=this.cloneDeep(n);continue}e[r]=n;}return e}cloneDeep(e){if(Array.isArray(e))return e.map(t=>this.cloneDeep(t));if(this.isPlainObject(e)){let t={};for(let[r,n]of Object.entries(e))t[r]=this.cloneDeep(n);return t}return e}isPlainObject(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}sanitizeVars(e){if(!e)return {};let t={...e};if(typeof e.user_input=="string"){t.user_input_raw=e.user_input;let r=e.user_input.replace(/\{\{\{/g,"{{{").replace(/\}\}\}/g,"}}}").replace(/\{\{/g,"{{").replace(/\}\}/g,"}}");t.user_input=this.handlebars.escapeExpression(r);}return t}};l();var Gt="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function Ko(o){let e=crypto$1.randomBytes(o*2),t="";for(let r=0;r<e.length&&t.length<o;r++){let n=e[r];n<248&&(t+=Gt[n%62]);}for(;t.length<o;)t+=Gt[crypto$1.randomBytes(1)[0]%62];return t}function _e(o){return `${o}_${Ko(8)}`}function Jo(o,e){let{createHash:t}=F("crypto"),r=t("sha256").update(e).digest(),n=Buffer.alloc(8);for(let i=0;i<32;i++)n[i%8]^=r[i];let s="";for(let i of n)s+=Gt[i%62];return `${o}_${s}`}l();function Yt(o){let e=t=>String(t).padStart(2,"0");return `${o.getFullYear()}${e(o.getMonth()+1)}${e(o.getDate())}T${e(o.getHours())}${e(o.getMinutes())}${e(o.getSeconds())}`}l();function Yr(o,e){return t=>{try{let r=e(t);r instanceof Promise&&r.catch(n=>{console.error(`[crewx] event listener error (${o}): ${n instanceof Error?n.message:String(n)}`);});}catch(r){console.error(`[crewx] event listener error (${o}): ${r instanceof Error?r.message:String(r)}`);}}}var Be=class{_emitter=new events.EventEmitter;on(e,t){let r=Yr(e,t);return this._emitter.on(e,r),()=>this._emitter.off(e,r)}once(e,t){let r=Yr(e,t);return this._emitter.once(e,r),()=>this._emitter.off(e,r)}emit(e,t){this._emitter.emit(e,t);}};l();function Zt(o){let e=new Map,t=r=>r.startsWith(`${o}::`)?r:`${o}::${r}`;return {async get(r){let n=e.get(t(r));return n?n.value:void 0},async set(r,n){e.set(t(r),{value:n});},async delete(r){return e.delete(t(r))},async list(r){let n=r?t(r):`${o}::`,s=[];for(let i of e.keys())i.startsWith(n)&&s.push(i.slice(o.length+2));return s}}}l();var er=new async_hooks.AsyncLocalStorage;function Go(){return er}function Yo(o,e){return er.run(o,e)}function tr(o){let e=o.log??o.logger??{debug:()=>{},info:()=>{},warn:()=>{},error:()=>{}},t=o.agentRunner??{run:async()=>({output:""})},r=o.db??{get:async()=>{},set:async()=>{},delete:async()=>false,list:async()=>[]},n=o.storage??{put:async()=>"",get:async()=>{},delete:async()=>false},s=o.audit??{log:async()=>{}},i=o.onInbound??(async()=>({accepted:true})),a=o.onEmitEvent??(async()=>({accepted:true})),d=o.onUpdateMessage??(async()=>{}),c=o.onResolveUser??(async g=>({userId:g,displayName:g})),u=async g=>{let m=er.getStore();if(!m){e.warn("respondSync called outside sync window \u2014 graceful degradation (no-op)",{textPreview:typeof g=="object"&&"text"in g?g.text.slice(0,80):void 0});return}let y="text"in g?g.text:"";m.res.status(200).json({text:y});},p=o.httpRouter??{registerRoute:()=>{e.warn("httpRouter not configured \u2014 registerRoute is a no-op");}};return {instanceId:o.instanceId,config:o.config,capabilities:o.capabilities,log:e,agentRunner:t,db:r,storage:n,audit:s,abortSignal:o.abortSignal??new AbortController().signal,httpRouter:p,inbound:i,emitEvent:a,updateMessage:d,resolveUser:c,respondSync:u}}Ie();Ie();l();function Zo(o){return typeof o!="string"?"":o.replace(/</g,"<").replace(/>/g,">")}function rr(o){return o.messages.map(e=>({text:Zo(e.text),isAssistant:e.isAssistant,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")},ts={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 Zr(o,e,t){o.tool("crewx_listAgents","List available CrewX agents exposed by this server",async()=>{let r=[];for(let n of t){let s=e.agents.get(n);s&&r.push({id:s.id,name:s.name??s.id,description:s.description??""});}return {content:[{type:"text",text:JSON.stringify(r,null,2)}]}}),o.tool("crewx_queryAgent","Query a CrewX agent with a read-only question",es,async({agentId:r,query:n,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.query(r,n,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Query failed"}],isError:true}}),o.tool("crewx_executeAgent","Execute a task on a CrewX agent (may modify state)",ts,async({agentId:r,task:n,context:s,thread:i})=>{if(!t.has(r))return {content:[{type:"text",text:`Agent '${r}' is not exposed by this server`}],isError:true};let a=await e.execute(r,n,{context:s,threadId:i});return a.ok?{content:[{type:"text",text:a.data}]}:{content:[{type:"text",text:a.error?.message??"Execute failed"}],isError:true}});}l();function en(o){return o.headers.get("Origin")?null:new Response(JSON.stringify({error:"Forbidden: Origin header required"}),{status:403,headers:{"Content-Type":"application/json"}})}async function tn(o,e){return e?await e(o)?null:new Response(JSON.stringify({error:"Unauthorized"}),{status:401,headers:{"Content-Type":"application/json"}}):null}function os(o,e){let t=new mcp_js.McpServer({name:"crewx-mcp-server",version:"1.0.0"},{capabilities:{tools:{}}});return Zr(t,o,e),t}function nr(o,e){if(!e.agents||e.agents.length===0)throw new Error("crewx.handler() requires at least one agent in the agents option");let t=new Set(e.agents),r=new Map;return async n=>{let s=en(n);if(s)return s;let i=await tn(n,e.auth);if(i)return i;let a=n.headers.get("mcp-session-id");if(a&&r.has(a))return r.get(a).transport.handleRequest(n);let d=os(o,t),c=new webStandardStreamableHttp_js.WebStandardStreamableHTTPServerTransport({sessionIdGenerator:()=>crypto.randomUUID(),onsessioninitialized:u=>{r.set(u,{transport:c,server:d});},onsessionclosed:u=>{r.delete(u);},enableJsonResponse:true});return await d.connect(c),c.handleRequest(n)}}l();l();var ze=class{detach(e){}};l();l();l();var xt=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:U.join(as__default.default.homedir(),".crewx","crewx.db")}resolveDbPaths(){return [this.resolveDbPath()]}isMissingTableError(e){return e instanceof Error&&/no such table:/i.test(e.message)}dbExists(e){return fs.existsSync(e??this.resolveDbPath())}};l();function te(o){let e=F("better-sqlite3"),{drizzle:t}=F("drizzle-orm/better-sqlite3"),r=new e(o);return r.exec("PRAGMA journal_mode = WAL"),r.exec("PRAGMA busy_timeout = 5000"),r.exec("PRAGMA foreign_keys = ON"),{db:t(r),runRaw:(n,s=[])=>r.prepare(n).run(...s),close:()=>r.close()}}l();var rn=new Set;function ls(o){let{migrate:e}=F("drizzle-orm/better-sqlite3/migrator"),t=[U__namespace.default.join(__dirname,"../migrations"),U__namespace.default.join(__dirname,"migrations")],r=t.find(n=>fs.existsSync(U__namespace.default.join(n,"meta/_journal.json")));if(!r)throw new Error(`migrations folder not found. Searched:
|
|
61
48
|
${t.join(`
|
|
62
|
-
`)}`);e(r,{migrationsFolder:n});}function Xn(r,e){Gn.has(e)||($a(r),Gn.add(e));}g();var K=class extends Error{code;cause;constructor(e,t,n){super(t),this.name="RepositoryError",this.code=e,this.cause=n,Object.setPrototypeOf(this,new.target.prototype);}};g();g();var tt=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()});g();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"),workspace_name:sqliteCore.text("workspace_name"),trace_id:sqliteCore.text("trace_id"),parent_task_id:sqliteCore.text("parent_task_id"),caller_agent_id:sqliteCore.text("caller_agent_id"),model:sqliteCore.text("model"),platform:sqliteCore.text("platform").default("cli"),crewx_version:sqliteCore.text("crewx_version"),input_tokens:sqliteCore.integer("input_tokens").default(0),output_tokens:sqliteCore.integer("output_tokens").default(0),cost_usd:sqliteCore.real("cost_usd").default(0),pid:sqliteCore.integer("pid"),rendered_prompt:sqliteCore.text("rendered_prompt"),command:sqliteCore.text("command"),coding_agent_command:sqliteCore.text("coding_agent_command"),exit_code:sqliteCore.integer("exit_code"),logs:sqliteCore.text("logs"),thread_id:sqliteCore.text("thread_id"),workspace_ref:sqliteCore.text("workspace_ref"),project_id:sqliteCore.text("project_id"),project_name:sqliteCore.text("project_name"),project_ref:sqliteCore.text("project_ref"),cached_input_tokens:sqliteCore.integer("cached_input_tokens").default(0)},r=>({idx_tasks_agent_id:sqliteCore.index("idx_tasks_agent_id").on(r.agent_id),idx_tasks_status:sqliteCore.index("idx_tasks_status").on(r.status),idx_tasks_started_at:sqliteCore.index("idx_tasks_started_at").on(r.started_at),idx_tasks_trace_id:sqliteCore.index("idx_tasks_trace_id").on(r.trace_id),idx_tasks_parent_task_id:sqliteCore.index("idx_tasks_parent_task_id").on(r.parent_task_id),idx_tasks_crewx_version:sqliteCore.index("idx_tasks_crewx_version").on(r.crewx_version),idx_tasks_pid:sqliteCore.index("idx_tasks_pid").on(r.pid),idx_tasks_thread_id:sqliteCore.index("idx_tasks_thread_id").on(r.thread_id),idx_tasks_workspace_id:sqliteCore.index("idx_tasks_workspace_id").on(r.workspace_id),idx_tasks_workspace_ref:sqliteCore.index("idx_tasks_workspace_ref").on(r.workspace_ref),idx_tasks_project_id:sqliteCore.index("idx_tasks_project_id").on(r.project_id),idx_tasks_ws_started:sqliteCore.index("idx_tasks_ws_started").on(r.workspace_id,r.started_at)}));g();var j=sqliteCore.sqliteTable("threads",{id:sqliteCore.text("id").primaryKey(),workspace_id:sqliteCore.text("workspace_id").references(()=>tt.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)},r=>({idx_threads_updated_at:sqliteCore.index("idx_threads_updated_at").on(r.updated_at),idx_threads_workspace_id:sqliteCore.index("idx_threads_workspace_id").on(r.workspace_id)}));g();var Ja=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(()=>Ja.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")},r=>({idx_spans_task_id:sqliteCore.index("idx_spans_task_id").on(r.task_id),idx_spans_parent_span_id:sqliteCore.index("idx_spans_parent_span_id").on(r.parent_span_id)}));g();sqliteCore.sqliteTable("tool_calls",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").notNull().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()},r=>({idx_tool_calls_task_id:sqliteCore.index("idx_tool_calls_task_id").on(r.task_id),idx_tool_calls_tool_name:sqliteCore.index("idx_tool_calls_tool_name").on(r.tool_name),idx_tool_calls_timestamp:sqliteCore.index("idx_tool_calls_timestamp").on(r.timestamp)}));g();sqliteCore.sqliteTable("thread_boxes",{id:sqliteCore.text("id").primaryKey(),thread_id:sqliteCore.text("thread_id").notNull().references(()=>j.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()},r=>({idx_thread_boxes_thread_id:sqliteCore.index("idx_thread_boxes_thread_id").on(r.thread_id),idx_thread_boxes_seq:sqliteCore.index("idx_thread_boxes_seq").on(r.thread_id,r.seq),uniq_thread_boxes_thread_seq:sqliteCore.unique().on(r.thread_id,r.seq)}));g();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")},r=>({idx_request_logs_timestamp:sqliteCore.index("idx_request_logs_timestamp").on(r.timestamp),idx_request_logs_path:sqliteCore.index("idx_request_logs_path").on(r.path),idx_request_logs_status_code:sqliteCore.index("idx_request_logs_status_code").on(r.status_code),idx_request_logs_partition_key:sqliteCore.index("idx_request_logs_partition_key").on(r.partition_key)}));var Yt=class extends Vt{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=re.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let o=re.dirname(t);fs.existsSync(o)||fs.mkdirSync(o,{recursive:true});}else if(!fs.existsSync(t))throw new K("NOT_FOUND","Database not found");let n=_e(t);if(e)try{Xn(n.db,t);}catch(o){throw n.close(),o}return n}validateWorkspaceId(e,t){return e.db.select({id:tt.id}).from(tt).where(drizzleOrm.eq(tt.id,t)).limit(1).get()?t:null}findAllThreads(e){let t=this.resolveDbPaths(),n=new Set,o=[];for(let s of t){if(!fs.existsSync(s))continue;let i=_e(s);try{let a=e?drizzleOrm.or(drizzleOrm.eq(j.workspace_id,e),drizzleOrm.isNull(j.workspace_id)):void 0,l=i.db.select().from(j).where(a).orderBy(drizzleOrm.desc(j.updated_at)).all();for(let u of l)n.has(u.id)||(n.add(u.id),o.push(u));}catch(a){throw new K("DB_ERROR","Failed to find all threads",a)}finally{i.close();}}return o}findThreadById(e,t){let n=this.resolveDbPaths();for(let o of n){if(!fs.existsSync(o))continue;let s=_e(o);try{let i=drizzleOrm.eq(j.id,e),a=t?drizzleOrm.and(i,drizzleOrm.or(drizzleOrm.eq(j.workspace_id,t),drizzleOrm.isNull(j.workspace_id))):i,l=s.db.select().from(j).where(a).limit(1).get()??void 0;if(l)return l}catch(i){throw new K("DB_ERROR","Failed to find thread by id",i)}finally{s.close();}}}threadExists(e,t){let n=this.resolveDbPaths();for(let o of n){if(!fs.existsSync(o))continue;let s=_e(o);try{let i=drizzleOrm.eq(j.id,e),a=t?drizzleOrm.and(i,drizzleOrm.or(drizzleOrm.eq(j.workspace_id,t),drizzleOrm.isNull(j.workspace_id))):i;if(s.db.select({id:j.id}).from(j).where(a).limit(1).get())return !0}catch(i){throw new K("DB_ERROR","Failed to check thread existence",i)}finally{s.close();}}return false}aggregateTaskStats(e,t){let n=this.resolveDbPaths(),o=0,s=0,i=0,a=0,l=0,u=new Set;for(let d of n){if(!fs.existsSync(d))continue;let c=_e(d);try{let p=drizzleOrm.and(drizzleOrm.eq(H.thread_id,e),drizzleOrm.or(drizzleOrm.isNull(H.parent_task_id),drizzleOrm.eq(H.parent_task_id,""))),f=t?drizzleOrm.and(p,drizzleOrm.eq(H.workspace_id,t)):p,v=c.db.select({cnt:drizzleOrm.sql`count(*)`,total_input:drizzleOrm.sql`COALESCE(SUM(input_tokens), 0)`,total_output:drizzleOrm.sql`COALESCE(SUM(output_tokens), 0)`,total_cached:drizzleOrm.sql`COALESCE(SUM(cached_input_tokens), 0)`,total_cost:drizzleOrm.sql`COALESCE(SUM(cost_usd), 0)`}).from(H).where(f).get();v&&(o+=v.cnt,s+=v.total_input,i+=v.total_output,a+=v.total_cached,l+=v.total_cost);let h=c.db.all(drizzleOrm.sql`
|
|
49
|
+
`)}`);e(o,{migrationsFolder:r});}function nn(o,e){rn.has(e)||(ls(o),rn.add(e));}l();var L=class extends Error{code;cause;constructor(e,t,r){super(t),this.name="RepositoryError",this.code=e,this.cause=r,Object.setPrototypeOf(this,new.target.prototype);}};l();l();var Oe=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 I=sqliteCore.sqliteTable("tasks",{id:sqliteCore.text("id").primaryKey(),agent_id:sqliteCore.text("agent_id").notNull(),user_id:sqliteCore.text("user_id"),prompt:sqliteCore.text("prompt").notNull(),mode:sqliteCore.text("mode").notNull().default("execute"),status:sqliteCore.text("status").notNull().default("running"),result:sqliteCore.text("result"),error:sqliteCore.text("error"),started_at:sqliteCore.text("started_at").notNull(),completed_at:sqliteCore.text("completed_at"),duration_ms:sqliteCore.integer("duration_ms"),metadata:sqliteCore.text("metadata"),workspace_id:sqliteCore.text("workspace_id"),workspace_name:sqliteCore.text("workspace_name"),trace_id:sqliteCore.text("trace_id"),parent_task_id:sqliteCore.text("parent_task_id"),caller_agent_id:sqliteCore.text("caller_agent_id"),model:sqliteCore.text("model"),platform:sqliteCore.text("platform").default("cli"),crewx_version:sqliteCore.text("crewx_version"),input_tokens:sqliteCore.integer("input_tokens").default(0),output_tokens:sqliteCore.integer("output_tokens").default(0),cost_usd:sqliteCore.real("cost_usd").default(0),pid:sqliteCore.integer("pid"),rendered_prompt:sqliteCore.text("rendered_prompt"),command:sqliteCore.text("command"),coding_agent_command:sqliteCore.text("coding_agent_command"),exit_code:sqliteCore.integer("exit_code"),logs:sqliteCore.text("logs"),thread_id:sqliteCore.text("thread_id"),workspace_ref:sqliteCore.text("workspace_ref"),project_id:sqliteCore.text("project_id"),project_name:sqliteCore.text("project_name"),project_ref:sqliteCore.text("project_ref"),cached_input_tokens:sqliteCore.integer("cached_input_tokens").default(0)},o=>({idx_tasks_agent_id:sqliteCore.index("idx_tasks_agent_id").on(o.agent_id),idx_tasks_status:sqliteCore.index("idx_tasks_status").on(o.status),idx_tasks_started_at:sqliteCore.index("idx_tasks_started_at").on(o.started_at),idx_tasks_trace_id:sqliteCore.index("idx_tasks_trace_id").on(o.trace_id),idx_tasks_parent_task_id:sqliteCore.index("idx_tasks_parent_task_id").on(o.parent_task_id),idx_tasks_crewx_version:sqliteCore.index("idx_tasks_crewx_version").on(o.crewx_version),idx_tasks_pid:sqliteCore.index("idx_tasks_pid").on(o.pid),idx_tasks_thread_id:sqliteCore.index("idx_tasks_thread_id").on(o.thread_id),idx_tasks_workspace_id:sqliteCore.index("idx_tasks_workspace_id").on(o.workspace_id),idx_tasks_workspace_ref:sqliteCore.index("idx_tasks_workspace_ref").on(o.workspace_ref),idx_tasks_project_id:sqliteCore.index("idx_tasks_project_id").on(o.project_id),idx_tasks_ws_started:sqliteCore.index("idx_tasks_ws_started").on(o.workspace_id,o.started_at)}));l();var P=sqliteCore.sqliteTable("threads",{id:sqliteCore.text("id").primaryKey(),workspace_id:sqliteCore.text("workspace_id").references(()=>Oe.id,{onDelete:"set null"}),platform:sqliteCore.text("platform").notNull().default("cli"),title:sqliteCore.text("title"),first_message:sqliteCore.text("first_message"),last_message:sqliteCore.text("last_message"),message_count:sqliteCore.integer("message_count").notNull().default(0),created_at:sqliteCore.text("created_at").notNull(),updated_at:sqliteCore.text("updated_at").notNull(),metadata:sqliteCore.text("metadata"),title_locked:sqliteCore.integer("title_locked").notNull().default(0)},o=>({idx_threads_updated_at:sqliteCore.index("idx_threads_updated_at").on(o.updated_at),idx_threads_workspace_id:sqliteCore.index("idx_threads_workspace_id").on(o.workspace_id)}));l();var hs=sqliteCore.sqliteTable("spans",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").references(()=>I.id,{onDelete:"set null"}),parent_span_id:sqliteCore.text("parent_span_id").references(()=>hs.id,{onDelete:"set null"}),name:sqliteCore.text("name").notNull(),kind:sqliteCore.text("kind").notNull().default("internal"),status:sqliteCore.text("status").notNull().default("ok"),started_at:sqliteCore.text("started_at").notNull(),completed_at:sqliteCore.text("completed_at"),duration_ms:sqliteCore.integer("duration_ms"),input:sqliteCore.text("input"),output:sqliteCore.text("output"),error:sqliteCore.text("error"),attributes:sqliteCore.text("attributes")},o=>({idx_spans_task_id:sqliteCore.index("idx_spans_task_id").on(o.task_id),idx_spans_parent_span_id:sqliteCore.index("idx_spans_parent_span_id").on(o.parent_span_id)}));l();sqliteCore.sqliteTable("tool_calls",{id:sqliteCore.text("id").primaryKey(),task_id:sqliteCore.text("task_id").notNull().references(()=>I.id,{onDelete:"cascade"}),session_id:sqliteCore.text("session_id"),tool_name:sqliteCore.text("tool_name").notNull(),files:sqliteCore.text("files"),input:sqliteCore.text("input"),output:sqliteCore.text("output"),duration_ms:sqliteCore.integer("duration_ms"),timestamp:sqliteCore.text("timestamp").notNull()},o=>({idx_tool_calls_task_id:sqliteCore.index("idx_tool_calls_task_id").on(o.task_id),idx_tool_calls_tool_name:sqliteCore.index("idx_tool_calls_tool_name").on(o.tool_name),idx_tool_calls_timestamp:sqliteCore.index("idx_tool_calls_timestamp").on(o.timestamp)}));l();sqliteCore.sqliteTable("thread_boxes",{id:sqliteCore.text("id").primaryKey(),thread_id:sqliteCore.text("thread_id").notNull().references(()=>P.id,{onDelete:"cascade"}),seq:sqliteCore.integer("seq").notNull(),first_task_id:sqliteCore.text("first_task_id").notNull(),mid_task_id:sqliteCore.text("mid_task_id").notNull(),last_task_id:sqliteCore.text("last_task_id").notNull(),task_count:sqliteCore.integer("task_count").notNull(),summary:sqliteCore.text("summary"),source_tokens:sqliteCore.integer("source_tokens").notNull(),summary_tokens:sqliteCore.integer("summary_tokens"),created_at:sqliteCore.text("created_at").notNull()},o=>({idx_thread_boxes_thread_id:sqliteCore.index("idx_thread_boxes_thread_id").on(o.thread_id),idx_thread_boxes_seq:sqliteCore.index("idx_thread_boxes_seq").on(o.thread_id,o.seq),uniq_thread_boxes_thread_seq:sqliteCore.unique().on(o.thread_id,o.seq)}));l();sqliteCore.sqliteTable("request_logs",{id:sqliteCore.text("id").primaryKey(),path:sqliteCore.text("path").notNull(),method:sqliteCore.text("method").notNull(),status_code:sqliteCore.integer("status_code").notNull(),duration_ms:sqliteCore.integer("duration_ms").notNull(),ip:sqliteCore.text("ip"),request_headers:sqliteCore.text("request_headers"),response_headers:sqliteCore.text("response_headers"),request_body:sqliteCore.text("request_body"),response_body:sqliteCore.text("response_body"),query:sqliteCore.text("query"),user_id:sqliteCore.text("user_id"),project_id:sqliteCore.text("project_id"),partition_key:sqliteCore.text("partition_key").notNull(),timestamp:sqliteCore.text("timestamp").notNull().default(drizzleOrm.sql`(datetime('now'))`),metadata:sqliteCore.text("metadata")},o=>({idx_request_logs_timestamp:sqliteCore.index("idx_request_logs_timestamp").on(o.timestamp),idx_request_logs_path:sqliteCore.index("idx_request_logs_path").on(o.path),idx_request_logs_status_code:sqliteCore.index("idx_request_logs_status_code").on(o.status_code),idx_request_logs_partition_key:sqliteCore.index("idx_request_logs_partition_key").on(o.partition_key)}));var Rt=class extends xt{dbPath;constructor(e={}){super(),e.dbPath?this.dbPath=e.dbPath:e.dbRoot&&(this.dbPath=U.join(e.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(e){let t=this.resolveDbPath();if(e){let n=U.dirname(t);fs.existsSync(n)||fs.mkdirSync(n,{recursive:true});}else if(!fs.existsSync(t))throw new L("NOT_FOUND","Database not found");let r=te(t);if(e)try{nn(r.db,t);}catch(n){throw r.close(),n}return r}validateWorkspaceId(e,t){return e.db.select({id:Oe.id}).from(Oe).where(drizzleOrm.eq(Oe.id,t)).limit(1).get()?t:null}findAllThreads(e){let t=this.resolveDbPaths(),r=new Set,n=[];for(let s of t){if(!fs.existsSync(s))continue;let i=te(s);try{let a=e?drizzleOrm.or(drizzleOrm.eq(P.workspace_id,e),drizzleOrm.isNull(P.workspace_id)):void 0,d=i.db.select().from(P).where(a).orderBy(drizzleOrm.desc(P.updated_at)).all();for(let c of d)r.has(c.id)||(r.add(c.id),n.push(c));}catch(a){throw new L("DB_ERROR","Failed to find all threads",a)}finally{i.close();}}return n}findThreadById(e,t){let r=this.resolveDbPaths();for(let n of r){if(!fs.existsSync(n))continue;let s=te(n);try{let i=drizzleOrm.eq(P.id,e),a=t?drizzleOrm.and(i,drizzleOrm.or(drizzleOrm.eq(P.workspace_id,t),drizzleOrm.isNull(P.workspace_id))):i,d=s.db.select().from(P).where(a).limit(1).get()??void 0;if(d)return d}catch(i){throw new L("DB_ERROR","Failed to find thread by id",i)}finally{s.close();}}}threadExists(e,t){let r=this.resolveDbPaths();for(let n of r){if(!fs.existsSync(n))continue;let s=te(n);try{let i=drizzleOrm.eq(P.id,e),a=t?drizzleOrm.and(i,drizzleOrm.or(drizzleOrm.eq(P.workspace_id,t),drizzleOrm.isNull(P.workspace_id))):i;if(s.db.select({id:P.id}).from(P).where(a).limit(1).get())return !0}catch(i){throw new L("DB_ERROR","Failed to check thread existence",i)}finally{s.close();}}return false}aggregateTaskStats(e,t){let r=this.resolveDbPaths(),n=0,s=0,i=0,a=0,d=0,c=new Set;for(let u of r){if(!fs.existsSync(u))continue;let p=te(u);try{let g=drizzleOrm.and(drizzleOrm.eq(I.thread_id,e),drizzleOrm.or(drizzleOrm.isNull(I.parent_task_id),drizzleOrm.eq(I.parent_task_id,""))),m=t?drizzleOrm.and(g,drizzleOrm.eq(I.workspace_id,t)):g,y=p.db.select({cnt:drizzleOrm.sql`count(*)`,total_input:drizzleOrm.sql`COALESCE(SUM(input_tokens), 0)`,total_output:drizzleOrm.sql`COALESCE(SUM(output_tokens), 0)`,total_cached:drizzleOrm.sql`COALESCE(SUM(cached_input_tokens), 0)`,total_cost:drizzleOrm.sql`COALESCE(SUM(cost_usd), 0)`}).from(I).where(m).get();y&&(n+=y.cnt,s+=y.total_input,i+=y.total_output,a+=y.total_cached,d+=y.total_cost);let k=p.db.all(drizzleOrm.sql`
|
|
63
50
|
SELECT DISTINCT agent_id FROM tasks
|
|
64
51
|
WHERE thread_id = ${e}
|
|
65
52
|
AND agent_id IS NOT NULL AND agent_id != ''
|
|
66
53
|
AND (parent_task_id IS NULL OR parent_task_id = '')
|
|
67
54
|
${t?drizzleOrm.sql`AND workspace_id = ${t}`:drizzleOrm.sql``}
|
|
68
|
-
`);for(let
|
|
55
|
+
`);for(let w of k)c.add(w.agent_id);}catch(g){throw new L("DB_ERROR","Failed to aggregate task stats",g)}finally{p.close();}}return {taskCount:n,inputTokens:s,outputTokens:i,cachedInputTokens:a,costUsd:d,agentIds:Array.from(c)}}findTopLevelTasks(e,t){let r=this.resolveDbPaths(),n=new Set,s=[];for(let i of r){if(!fs.existsSync(i))continue;let a=te(i);try{let d=drizzleOrm.and(drizzleOrm.eq(I.thread_id,e),drizzleOrm.or(drizzleOrm.isNull(I.parent_task_id),drizzleOrm.eq(I.parent_task_id,""))),c=t?drizzleOrm.and(d,drizzleOrm.eq(I.workspace_id,t)):d,u=a.db.select().from(I).where(c).orderBy(drizzleOrm.asc(I.started_at)).all();for(let p of u)n.has(p.id)||(n.add(p.id),s.push(p));}catch(d){throw new L("DB_ERROR","Failed to find top-level tasks",d)}finally{a.close();}}return s}findAllTasks(e,t){let r=this.resolveDbPaths(),n=new Set,s=[];for(let i of r){if(!fs.existsSync(i))continue;let a=te(i);try{let d=drizzleOrm.eq(I.thread_id,e),c=t?drizzleOrm.and(d,drizzleOrm.eq(I.workspace_id,t)):d,u=a.db.select().from(I).where(c).orderBy(drizzleOrm.asc(I.started_at)).all();for(let p of u)n.has(p.id)||(n.add(p.id),s.push(p));}catch(d){throw new L("DB_ERROR","Failed to find all tasks for thread",d)}finally{a.close();}}return s}findTaskById(e,t,r){let n=this.resolveDbPaths();for(let s of n){if(!fs.existsSync(s))continue;let i=te(s);try{let a=drizzleOrm.and(drizzleOrm.eq(I.id,t),drizzleOrm.eq(I.thread_id,e)),d=r?drizzleOrm.and(a,drizzleOrm.eq(I.workspace_id,r)):a,c=i.db.select().from(I).where(d).limit(1).get();if(!c)continue;let u=i.db.select().from(I).where(drizzleOrm.eq(I.parent_task_id,c.id)).orderBy(drizzleOrm.asc(I.started_at)).all();return {task:c,children:u}}catch(a){throw new L("DB_ERROR","Failed to find task by id",a)}finally{i.close();}}}batchFetchTasks(e,t){let r=new Map;if(e.length===0)return r;let n=this.resolveDbPaths();for(let s of n){if(!fs.existsSync(s))continue;let i=te(s);try{let a=drizzleOrm.and(drizzleOrm.inArray(I.thread_id,e),drizzleOrm.or(drizzleOrm.isNull(I.parent_task_id),drizzleOrm.eq(I.parent_task_id,""))),d=t?drizzleOrm.and(a,drizzleOrm.eq(I.workspace_id,t)):a,c=i.db.select().from(I).where(d).orderBy(drizzleOrm.asc(I.started_at)).all();for(let u of c){let p=u.thread_id;r.has(p)||r.set(p,[]),r.get(p).push(u);}}catch(a){throw new L("DB_ERROR","Failed to batch fetch tasks",a)}finally{i.close();}}return r}updateThreadTitle(e,t,r){if(!this.dbExists())return;let n=this.openHandle(true);try{let s=drizzleOrm.eq(P.id,e),i=r?drizzleOrm.and(s,drizzleOrm.or(drizzleOrm.eq(P.workspace_id,r),drizzleOrm.isNull(P.workspace_id))):s;if(!n.db.select({id:P.id}).from(P).where(i).limit(1).get())return;n.db.update(P).set({title:t,title_locked:1,updated_at:new Date().toISOString()}).where(drizzleOrm.eq(P.id,e)).run();}catch(s){throw s instanceof L?s:new L("DB_ERROR","Failed to update thread title",s)}finally{n.close();}}upsertThread(e,t){let r=this.openHandle(true);try{let n=t.workspaceId?this.validateWorkspaceId(r,t.workspaceId):null,s=new Date().toISOString();if(r.db.select({id:P.id,message_count:P.message_count}).from(P).where(drizzleOrm.eq(P.id,e)).limit(1).get()){let a={updated_at:s};t.title!==void 0&&(a.title=t.title),t.titleLocked!==void 0&&(a.title_locked=t.titleLocked?1:0),r.db.update(P).set(a).where(drizzleOrm.eq(P.id,e)).run();}else r.db.insert(P).values({id:e,platform:t.platform,workspace_id:n,title:t.title??null,title_locked:t.titleLocked?1:0,message_count:0,created_at:s,updated_at:s}).run();}catch(n){throw n instanceof L?n:new L("DB_ERROR","Failed to upsert thread",n)}finally{r.close();}}ensureThread(e,t,r){let n=this.openHandle(true);try{let s=r?this.validateWorkspaceId(n,r):null,i=n.db.select({id:P.id,platform:P.platform,workspace_id:P.workspace_id}).from(P).where(drizzleOrm.eq(P.id,e)).limit(1).get();if(i){s&&!i.workspace_id&&n.db.update(P).set({workspace_id:s}).where(drizzleOrm.eq(P.id,e)).run();return}let a=new Date().toISOString();n.db.insert(P).values({id:e,platform:t,workspace_id:s,message_count:0,created_at:a,updated_at:a}).run();}catch(s){throw s instanceof L?s:new L("DB_ERROR","Failed to ensure thread",s)}finally{n.close();}}saveUserMessage(e,t,r){if(!this.dbExists())return;let n=this.openHandle(true);try{let s=new Date().toISOString();n.db.run(drizzleOrm.sql`
|
|
69
56
|
UPDATE threads
|
|
70
57
|
SET first_message = COALESCE(first_message, ${t}),
|
|
71
58
|
title = CASE WHEN title_locked = 0 AND title IS NULL THEN substr(${t}, 1, 60) ELSE title END,
|
|
@@ -73,14 +60,14 @@ ${t.join(`
|
|
|
73
60
|
message_count = message_count + 1,
|
|
74
61
|
updated_at = ${s}
|
|
75
62
|
WHERE id = ${e}
|
|
76
|
-
`);}catch(s){throw s instanceof
|
|
77
|
-
`).filter(
|
|
78
|
-
`).trim()}function
|
|
79
|
-
`):t&&typeof t=="object"&&t.result!==void 0&&(e=t.result||"");}catch{e=
|
|
80
|
-
${i.message}`)}let s=Mt(o);if(s.documents&&typeof s.documents=="object"){let i={};for(let[a,l]of Object.entries(s.documents))if(l&&typeof l=="object"){let u=l;typeof u.path=="string"&&!re.isAbsolute(u.path)?i[a]={...u,path:re.resolve(n,u.path)}:i[a]=u;}else i[a]=l;return {...s,documents:i}}return s}static mergeCrewxConfig(e,t){let n=new Map;for(let w of e.agents??[])n.set(w.id,w);for(let w of t.agents??[])n.has(w.id)&&console.warn(`[agent-loader] User agent "${w.id}" overrides built-in`),n.set(w.id,w);let o=Array.from(n.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,l=t,u=ii(a.vars,l.vars),d=ii(a.settings,l.settings),c;e.skills&&t.skills&&typeof e.skills=="object"&&typeof t.skills=="object"&&!Array.isArray(e.skills)&&!Array.isArray(t.skills)?c={...e.skills,...t.skills}:c=t.skills??e.skills;let p=[...e.hooks??[],...t.hooks??[]],f=gp(a.providers,l.providers),v={...e},h={...t};for(let w of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete v[w],delete h[w];let y={...{...v,...h},agents:o,layouts:s,documents:i,skills:c};return p.length>0&&(y.hooks=p),u!==void 0&&(y.vars=u),d!==void 0&&(y.settings=d),f!==void 0&&(y.providers=f),y}static async loadYaml(e,t,n){let o=t?.includeBuiltIns!==false,s,i;if(o){let d=await r.loadBuiltInConfig(n);if(e!==void 0){let c=jt(e);s=r.mergeCrewxConfig(d,c),i=re.dirname(e);}else s=d,i=process.cwd();}else {if(e===void 0)throw new Error("[@crewx/sdk] loadYaml: path is required when includeBuiltIns is false");s=jt(e),i=re.dirname(e);}let a=new Ue(n);await a.load(s.documents,i);let l=s.agents??[];await ai(l,s,t);let u=new r(l,t??{},s,a,i);return await u.use(new ht),u}static async fromConfig(e,t,n,o){let s=t?.includeBuiltIns===true,i=e;if(s){let d=await r.loadBuiltInConfig(o);i=r.mergeCrewxConfig(d,e);}let a=new Ue(o);await a.load(i.documents,n??(typeof process<"u"?process.cwd():"/"));let l=i.agents??[];await ai(l,i,t);let u=new r(l,t??{},i,a,n);return await u.use(new ht),u}get agents(){return this._agents}get config(){return this._config}get plugins(){return this._plugins}get tools(){return this._tools}get workspaceId(){return this._workspaceId}get workspaceName(){return this._workspaceName}getAgent(e){let t=e.startsWith("@")?e.slice(1):e;return this._agents.get(t)}getRemoteProviderConfig(e){let t=this._config?.providers;return Array.isArray(t)?t.find(o=>o.type==="remote"&&o.id===e):void 0}computeTaskLogPath(e,t){let n=zr(t);return re.join(this._projectRoot,".crewx","logs",`${n}_${e}.log`)}registerTool(e,t){this._tools.set(e,{name:e,...t});}async use(e){this._plugins.includes(e)||(await e.attach(this),this._plugins.push(e));}handler(e){return $r(this,e)}async registerChannelAdapter(e){let{adapter:t,instanceId:n,config:o}=e;if(this._activeAdapters.has(n))throw new Error(`Adapter instance already registered: ${n}`);let s=new Set(t.manifest.capabilities),i=e.store??Mr(n),a=e.defaultMode??"query",l=t.manifest.platform,u=e.agentRunner??{run:async(f,v,h)=>{let y=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${f}`,v,{threadId:h?.threadId,platform:l});return {output:y.ok?y.data:y.error?.message??""}}},d=e.onInbound??(async f=>{let v=f.routingHints?.agentId??e.defaultAgent;if(!v)return {accepted:false,reason:"no_agent"};let{output:h}=await u.run(v,f.text,{threadId:f.threadId});return {accepted:true,output:h}}),c=Nr({instanceId:n,config:o,capabilities:s,db:i,agentRunner:u,onInbound:d}),p={adapter:t,ctx:c,state:"starting"};this._activeAdapters.set(n,p),this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:n,state:"starting",timestamp:new Date});try{await t.start(c),p.state="started",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:n,state:"started",timestamp:new Date});}catch(f){throw p.state="failed",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:n,state:"failed",error:f instanceof Error?f:new Error(String(f)),timestamp:new Date}),this._activeAdapters.delete(n),f}}async unregisterChannelAdapter(e){let t=this._activeAdapters.get(e);if(t){t.state="stopping",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopping",timestamp:new Date});try{await t.adapter.stop(t.ctx),t.state="stopped",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopped",timestamp:new Date});}catch(n){t.state="failed",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"failed",error:n instanceof Error?n:new Error(String(n)),timestamp:new Date});}finally{this._activeAdapters.delete(e);}}}async stopAllAdapters(e={}){let t=e.timeoutMs??1e4,n=Array.from(this._activeAdapters.keys()),o=await Promise.allSettled(n.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 (${n[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 n=>{try{await(await n).close();}catch(o){console.error(`[crewx] remote target close error: ${o instanceof Error?o.message:String(o)}`);}}));let t=[...this._plugins].reverse();for(let n of t)try{await n.detach(this);}catch(o){console.error(`[crewx] plugin ${n.name} detach error: ${o instanceof Error?o.message:String(o)}`);}this._plugins.length=0;}filterAgents(e){let t=a=>a?a.split(",").map(l=>l.trim().toLowerCase()).filter(Boolean):void 0,n=t(e.role),o=t(e.team),s=t(e.provider),i=Array.from(this._agents.values());return n&&(i=i.filter(a=>a.role&&n.some(l=>ye(a.role.toLowerCase(),l)))),o&&(i=i.filter(a=>a.team&&o.some(l=>ye(a.team.toLowerCase(),l)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(u=>s.some(d=>ye(u.toLowerCase(),d))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,n=this._agents.get(t);if(!n)throw new ke(t,Array.from(this._agents.keys()));return n.inline?.prompt??n.inline?.system_prompt??n.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 n=e.startsWith("@")?e.slice(1):e,o=this._agents.get(n);if(!o)throw new ke(n,Array.from(this._agents.keys()));let s=this._resolveLayoutSpec(o,t?.layout),i=this._extractLayoutId(s),a=this._extractLayoutProps(o,s,t?.layout),l=this._layoutLoader.load(i,a),u=o.inline?.prompt??o.inline?.system_prompt??o.description??`You are an expert ${n}.`,d=await this._documentLoader.buildContext(),c=t?.env??(typeof process<"u"?process.env:{}),p=t?.vars?.security_key??pp(),f={...t?.vars??{},documents:d,env:c,agent:{id:o.id,name:o.name??o.id,role:o.role??"",team:o.team??"",description:o.description??""}},v=await this._templateEngine.render(u,f),h={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},m=o.provider,y=Array.isArray(m)?m:typeof m=="string"&&m.length>0?[m]:[],w=y.join(", ")||(typeof m=="string"?m:""),C=o.options,_=!Array.isArray(C)&&typeof C=="object"&&C!==null?C:void 0,k=Array.isArray(C)?C:void 0,E={};for(let[x,z]of Object.entries(d))E[x]={content:z.content??"",toc:z.toc,summary:z.summary,path:z.path};let R={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:w,providerList:y,model:o.inline?.model,workingDirectory:o.working_directory??o.workingDirectory??".",inline:{...o.inline??{},prompt:v},specialties:o.specialties??[],capabilities:o.capabilities??[],remote:o.remote??null,optionsByMode:_,optionsArray:k},agentMetadata:{specialties:o.specialties??[],capabilities:o.capabilities??[],description:o.description??""},documents:E,skills:t?.skills??[],session:h,env:c,vars:{security_key:p,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:h.platform,mode:h.mode,messages:t?.messages??[],tools:this._tools.size>0?{list:Array.from(this._tools.values()).map(x=>({name:x.name,description:x.description,parameters:x.parameters})),json:JSON.stringify(Array.from(this._tools.values()).map(x=>({name:x.name,description:x.description,parameters:x.parameters})),null,2),count:this._tools.size}:null,metadata:{}};return this._layoutRenderer.render(l,R)}_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 n=e.inline?.layout;if(n!==void 0)return n;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,n){let o=e.inline?.layout,s=o&&typeof o=="object"&&"props"in o?o.props:void 0,i=n&&typeof n=="object"&&"id"in n?n.props:void 0;if(s||i)return {...s??{},...i??{}}}_getConversationProvider(){return this._plugins.find(t=>t.name==="conversation")?.conversationProvider}async _fetchHistoryMessages(e,t,n){if(n&&n.length>0)return n;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:Dr(s)}catch{return}}_resolveTimeout(e){let t=Mn();return e==="query"?t.queryMs:t.executeMs}emitToolEvents(e,t,n,o,s,i,a){try{let u=exports.BUILTIN_ADAPTERS[n]?.parseEvent?.(o)??kr(new Date().toISOString(),o);for(let d of u)d.type==="tool_use"&&d.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:n,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:s,threadId:i,sessionId:a,provider:n,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,n){let o=await this.resolveFileRemoteTarget(e);if(o)return o.target.query(o.agentRef,t,n);let s=Date.now(),i=Fe("tsk"),a=new Date,l;try{l=Dt(e,Array.from(this._agents.values()));}catch(x){if(x instanceof ke){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...n?.metadata??{}},threadId:n?.threadId,platform:n?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let z=Date.now()-s,I={code:"AGENT_NOT_FOUND",message:x.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:z,error:I,metadata:n?.metadata?{...n.metadata}:void 0}),{ok:false,data:"",error:I,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:z}}}throw x}let u=Array.isArray(l.provider)?l.provider[0]??"cli/claude":l.provider,d=n?.provider??u,c=n?.model??l.inline?.model,p;try{p=Re(d);}catch(x){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...n?.metadata??{}},threadId:n?.threadId,platform:n?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let z=Date.now()-s,I={code:"PROVIDER_ERROR",message:x.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:z,error:I,metadata:n?.metadata?{...n.metadata}:void 0}),{ok:false,data:"",error:I,meta:{agentId:l.id,provider:d,model:c,durationMs:z}}}let f=await this._fetchHistoryMessages(n?.threadId,i,n?.messages),v;try{v=await this.renderAgentPromptFull(e,{session:{mode:"query",platform:n?.platform},vars:{user_input:t},messages:f});}catch{}let h,m,y,w=c,C=false,_=x=>{C||(C=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",pid:x,model:w,provider:d,codingAgentCommand:h,renderedPrompt:v,metadata:{...n?.metadata??{},provider:d},threadId:n?.threadId,platform:n?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},k=l.options,E=Array.isArray(k?.query?.tools)?k.query.tools:void 0,O=this._tools.size>0?this._filterToolsByMode(E):[],R=l.inline?.max_steps;d.startsWith("api/")&&_();try{let x=await p.query(t,{model:c,context:n?.context,systemPrompt:v??l.inline?.system_prompt??l.inline?.prompt,additionalArgs:Array.isArray(k?.query)?k.query:void 0,tools:O.length>0?O:void 0,maxSteps:R,timeoutMs:this._resolveTimeout("query"),env:{CREWX_AGENT_ID:l.id,CREWX_AGENT_ROLE:l.role??"",CREWX_AGENT_TEAM:l.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:n?.threadId??"",CREWX_PROVIDER:d,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,a)},onPid:I=>_(I),onOutput:(I,X)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:I,level:X}),X==="stdout"&&this.emitToolEvents(i,e,d,I,l.id,n?.threadId??"","");},onCommand:I=>{h=I;},onUsage:I=>{m=I;},onExitCode:I=>{y=I;},onModel:I=>{w||(w=I);}});_();let z=Date.now()-s;return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:x,durationMs:z,exitCode:y,inputTokens:m?.inputTokens,outputTokens:m?.outputTokens,cachedInputTokens:m?.cachedInputTokens,costUsd:m?.costUsd,model:w,metadata:{...n?.metadata??{},...n?.threadId?{threadId:n.threadId}:{}}}),{ok:!0,data:x,meta:{agentId:l.id,provider:d,model:c,durationMs:z}}}catch(x){if(x instanceof exports.ClientToolCallRequiredError){let X=Fe("thd");return this._pendingThreads.set(X,{agentRef:l.id,providerStr:d,continuationState:x.continuationState,toolCall:x.toolCall,traceId:i,startMs:s,model:c}),{ok:true,status:"requires_action",data:"",toolCall:x.toolCall,threadId:X,meta:{agentId:l.id,provider:d,model:c,durationMs:Date.now()-s}}}_();let z=Date.now()-s,I={code:"QUERY_FAILED",message:x.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:z,error:I,exitCode:y,inputTokens:m?.inputTokens,outputTokens:m?.outputTokens,cachedInputTokens:m?.cachedInputTokens,costUsd:m?.costUsd,model:w,metadata:n?.metadata?{...n.metadata}:void 0}),{ok:false,data:"",error:I,meta:{agentId:l.id,provider:d,model:c,durationMs:z}}}}async continueQuery(e,t){let n=this._pendingThreads.get(e);if(!n)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=Re(n.providerStr);if(!o.continueWithToolResults)return {ok:false,data:"",error:{code:"UNSUPPORTED",message:"Provider does not support client tool continuation"},meta:{agentId:n.agentRef,provider:n.providerStr,durationMs:0}};let s=t.map(i=>({...i,toolName:n.toolCall.toolCallId===i.toolCallId?n.toolCall.toolName:i.toolCallId}));try{let i=await o.continueWithToolResults(n.continuationState,s),a=Date.now()-n.startMs;return this.emit("task:end",{traceId:n.traceId,timestamp:new Date,agentRef:n.agentRef,mode:"query",result:i,durationMs:a}),{ok:!0,status:"complete",data:i,meta:{agentId:n.agentRef,provider:n.providerStr,model:n.model,durationMs:a}}}catch(i){if(i instanceof exports.ClientToolCallRequiredError)return this._pendingThreads.set(e,{...n,continuationState:i.continuationState,toolCall:i.toolCall}),{ok:true,status:"requires_action",data:"",toolCall:i.toolCall,threadId:e,meta:{agentId:n.agentRef,provider:n.providerStr,model:n.model,durationMs:Date.now()-n.startMs}};let a=Date.now()-n.startMs;return {ok:false,data:"",error:{code:"CONTINUE_FAILED",message:i.message},meta:{agentId:n.agentRef,provider:n.providerStr,model:n.model,durationMs:a}}}}async execute(e,t,n){let o=await this.resolveFileRemoteTarget(e);if(o)return o.target.execute(o.agentRef,t,n);let s=Date.now(),i=Fe("tsk"),a=new Date,l;try{l=Dt(e,Array.from(this._agents.values()));}catch(x){if(x instanceof ke){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...n?.metadata??{}},threadId:n?.threadId,platform:n?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let z=Date.now()-s,I={code:"AGENT_NOT_FOUND",message:x.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:z,error:I,metadata:n?.metadata?{...n.metadata}:void 0}),{ok:false,data:"",error:I,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:z}}}throw x}let u=Array.isArray(l.provider)?l.provider[0]??"cli/claude":l.provider,d=n?.provider??u,c=n?.model??l.inline?.model,p;try{p=Re(d);}catch(x){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...n?.metadata??{}},threadId:n?.threadId,platform:n?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let z=Date.now()-s,I={code:"PROVIDER_ERROR",message:x.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:z,error:I,metadata:n?.metadata?{...n.metadata}:void 0}),{ok:false,data:"",error:I,meta:{agentId:l.id,provider:d,model:c,durationMs:z}}}let f=await this._fetchHistoryMessages(n?.threadId,i,n?.messages),v;try{v=await this.renderAgentPromptFull(e,{session:{mode:"execute",platform:n?.platform},vars:{user_input:t},messages:f});}catch{}let h,m,y,w=c,C=false,_=x=>{C||(C=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",pid:x,model:w,provider:d,codingAgentCommand:h,renderedPrompt:v,metadata:{...n?.metadata??{},provider:d},threadId:n?.threadId,platform:n?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},k=l.options,E=Array.isArray(k?.execute?.tools)?k.execute.tools:void 0,O=this._tools.size>0?this._filterToolsByMode(E):[],R=l.inline?.max_steps;d.startsWith("api/")&&_();try{let x=await p.execute(t,{model:c,context:n?.context,systemPrompt:v??l.inline?.system_prompt??l.inline?.prompt,additionalArgs:Array.isArray(k?.execute)?k.execute:void 0,tools:O.length>0?O:void 0,maxSteps:R,timeoutMs:this._resolveTimeout("execute"),env:{CREWX_AGENT_ID:l.id,CREWX_AGENT_ROLE:l.role??"",CREWX_AGENT_TEAM:l.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:n?.threadId??"",CREWX_PROVIDER:d,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,a)},onPid:I=>_(I),onOutput:(I,X)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:I,level:X}),X==="stdout"&&this.emitToolEvents(i,e,d,I,l.id,n?.threadId??"","");},onCommand:I=>{h=I;},onUsage:I=>{m=I;},onExitCode:I=>{y=I;},onModel:I=>{w||(w=I);}});_();let z=Date.now()-s;return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:x,durationMs:z,exitCode:y,inputTokens:m?.inputTokens,outputTokens:m?.outputTokens,cachedInputTokens:m?.cachedInputTokens,costUsd:m?.costUsd,model:w,metadata:{...n?.metadata??{},...n?.threadId?{threadId:n.threadId}:{}}}),{ok:!0,data:x,meta:{agentId:l.id,provider:d,model:c,durationMs:z}}}catch(x){_();let z=Date.now()-s,I={code:"EXECUTE_FAILED",message:x.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:z,error:I,exitCode:y,inputTokens:m?.inputTokens,outputTokens:m?.outputTokens,cachedInputTokens:m?.cachedInputTokens,costUsd:m?.costUsd,model:w,metadata:n?.metadata?{...n.metadata}:void 0}),{ok:false,data:"",error:I,meta:{agentId:l.id,provider:d,model:c,durationMs:z}}}}};function ii(r,e){let t=yn(r)?r:void 0,n=yn(e)?e:void 0;if(!(!t&&!n))return {...t??{},...n??{}}}function yn(r){return typeof r=="object"&&r!==null&&!Array.isArray(r)}function gp(r,e){let t=Array.isArray(r)?r:void 0,n=Array.isArray(e)?e:void 0;if(!t&&!n)return;let o=a=>{if(!yn(a))return;let l=a.id;if(typeof l=="string")return `id:${l}`;let u=a.name;if(typeof u=="string")return `name:${u}`},s=new Set;for(let a of n??[]){let l=o(a);l&&s.add(l);}let i=[];for(let a of t??[]){let l=o(a);l&&s.has(l)||i.push(a);}for(let a of n??[])i.push(a);return i}async function ai(r,e,t){if(r.some(o=>(Array.isArray(o.provider)?o.provider:[o.provider]).some(i=>i.startsWith("api/")))){let{registerApiProviders:o}=await Promise.resolve().then(()=>(cn(),Ys));o(t?.api);}mp(r,e),fp(r,e);}function mp(r,e){if(!r.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(l=>l.startsWith("remote/"))))return;let n=e.providers;if(!Array.isArray(n))return;let{createRemoteProviderFactory:o}=(mn(),Tn(Zs)),s=new Map;for(let i of n)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&et("remote",o(s,Re));}function fp(r,e){if(!r.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(l=>l.startsWith("plugin/"))))return;let n=e.providers;if(!Array.isArray(n))return;let{createPluginProviderFactory:o}=(fn(),Tn(ni)),s=new Map;for(let i of n)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&et("plugin",o(s));}g();var hp="crewx:fs:",vn=class{prefix;store;constructor(e){this.prefix=e?.prefix??hp,this.store=e?.storage??new Map;}async readFile(e){let t=this.toKey(e),n=this.store.get(t);if(n===void 0)throw new Error(`BrowserFsAdapter: file not found: ${e}`);return n}async exists(e){return this.store.has(this.toKey(e))}resolvePath(...e){let t=e.map(i=>i.replace(/\\/g,"/")).join("/").replace(/\/+/g,"/"),n=t.split("/"),o=[];for(let i of n)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))}toKey(e){return `${this.prefix}${e.replace(/\\/g,"/")}`}};g();function yp(r,e){let t=r.skills?.include;if(t===void 0)return [...e];if(t.length===0)return [];let n=new Set(t);return e.filter(o=>n.has(o))}Le();dn();cn();yr();Ze();g();var _n=0;function vp(r){let e=Array.from(r.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(_n>=3)return "Error: Maximum delegation depth (3) reached. Cannot delegate further.";let n=t.agent,o=t.message,s=t.mode??"query";if(!e.includes(n))return `Error: Unknown agent "${n}". Available: ${e.join(", ")}`;_n++;try{if(s==="execute"){let a=await r.execute(n,o);return a.ok?a.data:`Error: ${a.error?.message??"Unknown error"}`}let i=await r.query(n,o);return i.ok?i.data:`Error: ${i.error?.message??"Unknown error"}`}finally{_n--;}}}}g();var li=typeof process<"u"?process.env:{};function _p(){return li.CREWX_CLI||"npx crewx"}function wp(){return li.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}g();var bp=/^[a-zA-Z0-9._-]+$/,wn=class{constructor(e){this.storage=e;}storage;listBoxes(e){this.validateId(e);let n=this.storage.listBoxes(e).map(o=>this.toBoxResponse(o));return {boxes:n,total:n.length}}getBox(e,t){this.validateId(e),this.validateId(t);let n=this.storage.findBox(e,t);return n?this.toBoxResponse(n):null}createBox(e,t){this.validateId(e);let n=this.generateBoxId(),o=new Date().toISOString(),s=this.storage.insertBox(e,{id:n,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(!bp.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return Fe("box")}};g();function xp(r,e,t,n,o){let{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}=n,l=s*i,u=s*a,d=l+u,c=e.getThreadMessages(r),p=[],f=0,v=false,h=[];for(let w=0;w<c.length;w+=2){let C=c[w],_=c[w+1],k=C?.content||"",E=_?.content||"",O=o.countTokens(k+E),R=[];C&&R.push(C),_&&R.push(_),h.push({messages:R,tokens:O});}for(let w=h.length-1;w>=0;w--){let C=h[w];if(f+C.tokens>l){v=true;break}f+=C.tokens,p.unshift(...C.messages);}let m=[],y=0;if(v&&u>0)try{let{boxes:w}=t.listBoxes(r);for(let C=w.length-1;C>=0;C--){let _=w[C],k=_.summaryTokens??_.sourceTokens;if(y+k>u)break;y+=k,m.unshift({boxId:_.id,seq:_.seq,taskCount:_.taskCount,sourceTokens:_.sourceTokens,summary:_.summary,previewFirst:_.previewFirst,previewMid:_.previewMid,previewLast:_.previewLast,createdAt:_.createdAt});}}catch(w){if(w instanceof Error&&!/not found/i.test(w.message))throw w}return {hot:p,warm:m,hotTokens:f,warmTokens:y,hotOverflow:v,totalBudget:d,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}Ze();qe();g();var pr=class extends Error{constructor(t,n){super(`Task ${t} timed out after ${n}ms`);this.taskId=t;this.timeoutMs=n;this.name="ParallelRunnerTimeoutError";}taskId;timeoutMs},Ot=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 n=this.mergeOptions(t),o=Math.max(1,n.maxConcurrency??5),s=n.timeoutMs,i=n.failFast??false,a=n.callbacks,l=n.evaluateTaskSuccess??(()=>true),u=[],d=0,c=0,p=0,f=false,v=0,h=perf_hooks.performance.now(),m=async R=>{a?.onTaskStart&&await a.onTaskStart(R),p+=1;let x=new AbortController,z={signal:x.signal},I,X;typeof s=="number"&&Number.isFinite(s)&&s>0&&(X=new Promise((ce,he)=>{I=setTimeout(()=>{let J=new pr(R.id,s);x.abort(J),he(J);},s);}));let te=perf_hooks.performance.now(),F=R.run(z),Ne=X?Promise.race([F,X]):F;try{let ce=await Ne,he=perf_hooks.performance.now(),J=he-te,ne=l(ce,R),Y={taskId:R.id,success:ne,value:ce,durationMs:J,startedAt:te,finishedAt:he,metadata:R.metadata,aborted:!1};u.push(Y),ne?d+=1:c+=1,a?.onTaskComplete&&await a.onTaskComplete(Y),i&&!ne&&(f=!0);}catch(ce){let he=perf_hooks.performance.now(),J=he-te,ne=ce instanceof Error?ce:new Error(String(ce)),Y={taskId:R.id,success:false,error:ne,durationMs:J,startedAt:te,finishedAt:he,metadata:R.metadata,aborted:x.signal.aborted};u.push(Y),c+=1,a?.onError&&await a.onError(R,ne,J),i&&(f=true);}finally{I&&clearTimeout(I),X&&F.catch(()=>{});}},y=async()=>{for(;!f;){let R=v;if(R>=e.length)break;v+=1;let x=e[R];if(!x||(await m(x),f))break}},w=Math.min(o,e.length),C=[];for(let R=0;R<w;R++)C.push(y());await Promise.all(C);let k=perf_hooks.performance.now()-h,E=u.length?u.reduce((R,x)=>R+x.durationMs,0)/u.length:0,O=k>0?u.length/(k/1e3):u.length;return this.metrics={totalTasks:e.length,startedTasks:p,completedTasks:u.length,successCount:d,failureCount:c,totalDurationMs:k,averageDurationMs:E,throughput:O},u}getMetrics(){return this.metrics}mergeOptions(e){return {maxConcurrency:e.maxConcurrency??this.defaults.maxConcurrency,timeoutMs:e.timeoutMs??this.defaults.timeoutMs,failFast:e.failFast??this.defaults.failFast,evaluateTaskSuccess:e.evaluateTaskSuccess??this.defaults.evaluateTaskSuccess,callbacks:this.mergeCallbacks(this.defaults.callbacks,e.callbacks)}}mergeCallbacks(e,t){if(!(!e&&!t))return {onTaskStart:async n=>{e?.onTaskStart&&await e.onTaskStart(n),t?.onTaskStart&&await t.onTaskStart(n);},onTaskComplete:async n=>{e?.onTaskComplete&&await e.onTaskComplete(n),t?.onTaskComplete&&await t.onTaskComplete(n);},onError:async(n,o,s)=>{e?.onError&&await e.onError(n,o,s),t?.onError&&await t.onError(n,o,s);}}}};g();g();var zt=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 ui=3,di=3e4,ci=500,kp=r=>{if(typeof r!="number"||Number.isNaN(r)||!Number.isFinite(r))return ui;let e=Math.floor(r);return e>0?e:ui},Rp=r=>r===void 0||typeof r!="number"||Number.isNaN(r)||r<=0?di:r,Cp=r=>{if(!r)return {maxRetries:0,retryDelay:ci};let e=Number.isInteger(r.maxRetries)&&r.maxRetries>=0?r.maxRetries:0,t=typeof r.retryDelay=="number"&&r.retryDelay>=0?r.retryDelay:ci;return {maxRetries:e,retryDelay:t}},bn=r=>{let e=r.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},Tp=(r,e)=>r<=0?Promise.resolve():new Promise((t,n)=>{let o=setTimeout(()=>{e.removeEventListener("abort",s),t();},r),s=()=>{clearTimeout(o),n(bn(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),Pp=async(r,e,t)=>{let n,o;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw bn(t);try{let i=await r();if(n=i,i.success||s===e.maxRetries)return i}catch(i){if(o=i,t.aborted)throw bn(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await Tp(e.retryDelay,t);}if(n)return n;throw o?o instanceof Error?o:new Error(String(o)):new Error("Parallel helper encountered an unexpected state")},pi=(r,e,t)=>{e.completed+=1,t?e.success+=1:e.failure+=1;try{r.onProgress?.(e.completed,e.total);}catch(n){process.env.NODE_ENV!=="production"&&console.warn("Parallel helper onProgress callback threw an error:",n);}},Ap=r=>r.map(t=>({metadata:t.metadata,taskResult:t})).slice().sort((t,n)=>t.metadata.index-n.metadata.index).map(({metadata:t,taskResult:n})=>{if(n.value){let s=n.value;return {...s,agentId:s.agentId??t.request.agentId,metadata:{...s.metadata,requestIndex:t.index,mode:t.mode}}}let o=n.error??new Error("Unknown error");return {agentId:t.request.agentId,content:o.message,success:false,metadata:{error:o.message,aborted:n.aborted??false,requestIndex:t.index,mode:t.mode}}}),Ep=r=>r.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 n=String(e.value.metadata?.error??e.value.content??"Agent returned unsuccessful result");return {index:t.index,error:new Error(n)}}return {index:t.index,error:new Error("Unknown failure")}}),Sp=(r,e)=>({onTaskComplete:async t=>{pi(e,r,t.success);},onError:async()=>{pi(e,r,false);}}),gi=async(r,e,t={})=>{if(!Array.isArray(r))throw new TypeError("Parallel helpers expect an array of requests");if(r.length===0){let m={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?.(m),[]}let n=kp(t.concurrency),o=Rp(t.timeout),s=Cp(t.retryPolicy),i=new Ot,a=new zt,l=r.map((h,m)=>({id:`${e}:${h.agentId??"anonymous"}:${m}`,metadata:{index:m,mode:e,request:h},run:y=>Pp(()=>e==="query"?a.query(h):a.execute(h),s,y.signal)})),u={completed:0,success:0,failure:0,total:r.length},d=await i.run(l,{maxConcurrency:n,timeoutMs:o,evaluateTaskSuccess:h=>h.success,callbacks:Sp(u,t)}),c=Ap(d),p=Ep(d),f=i.getMetrics(),v={total:r.length,completed:r.length,successCount:c.filter(h=>h.success).length,failureCount:c.filter(h=>!h.success).length,results:c,errors:p,metrics:f};return t.onComplete?.(v),c},Ip=(r,e)=>gi(r,"query",e),Op=(r,e)=>gi(r,"execute",e);fn();mn();gn();pn();g();g();var gr=class{capabilities={required:[]}};g();g();g();var mi=2e3;function fi(r){let e=r.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f\u2028\u2029]/g,"");return e.length<=mi?e:e.slice(0,mi-11)+" [redacted]"}var qp=10*1024*1024,Lp={b:1,kb:1024,mb:1024*1024,gb:1024*1024*1024};function xn(r,e){return r===void 0?true:Array.isArray(r)?r.includes(e):r===e}function Up(r,e){return r===void 0?true:Array.isArray(r)?r.some(t=>e.includes(t)):e.includes(r)}function yi(r){if(typeof r=="number")return r;let e=r.match(/^(\d+(?:\.\d+)?)\s*(b|kb|mb|gb)?$/i);if(!e)return 0;let t=parseFloat(e[1]),n=(e[2]??"b").toLowerCase();return Math.floor(t*(Lp[n]??1))}function vi(r){return typeof r=="string"}function _i(r){try{let e=fs.statSync(r);return e.size>qp?(process.stderr.write(`[YamlHookPlugin] File too large for line count: ${r} (${e.size} bytes)
|
|
81
|
-
`),null):fs.readFileSync(
|
|
82
|
-
`).length}catch{return null}}function
|
|
63
|
+
`);}catch(s){throw s instanceof L?s:new L("DB_ERROR","Failed to save user message",s)}finally{n.close();}}saveAssistantMessage(e,t,r){if(!this.dbExists())return;let n=this.openHandle(true);try{let s=new Date().toISOString();n.db.update(P).set({last_message:t,updated_at:s}).where(drizzleOrm.eq(P.id,e)).run();}catch(s){throw s instanceof L?s:new L("DB_ERROR","Failed to save assistant message",s)}finally{n.close();}}updateThread(e,t){if(!this.dbExists())return;let r=this.openHandle(true);try{let n={updated_at:new Date().toISOString()};t.title!==void 0&&(n.title=t.title,n.title_locked=1),t.titleLocked!==void 0&&(n.title_locked=t.titleLocked?1:0),r.db.update(P).set(n).where(drizzleOrm.eq(P.id,e)).run();}catch(n){throw n instanceof L?n:new L("DB_ERROR","Failed to update thread",n)}finally{r.close();}}};function Is(o){return o.replace(/<conversation_history[^>]*>[\s\S]*?<\/conversation_history>/g,"").split(`
|
|
64
|
+
`).filter(n=>!(n.startsWith("Loaded ")&&n.includes("layouts from")||n.includes("[dotenv@")||n.includes("[Nest]")&&n.includes("DEBUG")||n.startsWith("Registered custom layout:")||n.startsWith("Updated custom layout:"))).join(`
|
|
65
|
+
`).trim()}function Os(o){if(!o)return "";let e=o;try{let t=JSON.parse(e);Array.isArray(t)?e=t.filter(r=>r?.type==="text"&&r?.text).map(r=>r.text).join(`
|
|
66
|
+
`):t&&typeof t=="object"&&t.result!==void 0&&(e=t.result||"");}catch{e=Is(e);}return e}var Pt=class{dbPath;constructor(e){this.dbPath=e??U.join(as.homedir(),".crewx","crewx.db");}getThreadRepo(){return new Rt({dbPath:this.dbPath})}updateThread(e,t){this.getThreadRepo().updateThread(e,{title:t.title});}async ensureThread(e,t,r){let n=this.getThreadRepo(),s=n.findThreadById(e);if(s){if(s.platform!==t)throw new Error(`Thread '${e}' already exists with platform '${s.platform}' \u2014 cannot change to '${t}' (platform is immutable)`);return}n.ensureThread(e,t,r);}async fetchHistory(e,t){let r=t?.limit??100,n=this.getThreadRepo(),s=n.findThreadById(e),i=n.findTopLevelTasks(e),a=new Set(["done","completed","success"]);i=i.filter(u=>(!u.status||a.has(u.status))&&(!t?.currentTraceId||u.trace_id!==t.currentTraceId)),i=i.slice(0,r);let d=s?.platform??"cli",c=this.rowsToMessages(i);return {threadId:e,platform:d,messages:c,metadata:{title:s?.title??void 0,firstMessage:s?.first_message??void 0,lastMessage:s?.last_message??void 0,messageCount:s?.message_count??0,updatedAt:s?.updated_at?new Date(s.updated_at).getTime():void 0}}}async saveUserMessage(e,t,r,n){this.getThreadRepo().saveUserMessage(e,t);}async saveAssistantMessage(e,t,r,n){this.getThreadRepo().saveAssistantMessage(e,t);}close(){}rowsToMessages(e){let t=[];for(let r of e){r.prompt&&t.push({id:`${r.id}-user`,text:r.prompt,isAssistant:false,timestamp:new Date(r.started_at).getTime()});let n=Os(r.result);n&&t.push({id:`${r.id}-assistant`,text:n,isAssistant:true,timestamp:new Date(r.started_at).getTime()});}return t}};var Ve=class extends ze{name="conversation";_provider;unsubStart=null;unsubEnd=null;constructor(e){super(),this._provider=new Pt(e?.dbPath);}get conversationProvider(){return this._provider}attach(e){this.unsubStart=e.on("task:start",async t=>{if(!t.threadId)return;let r=t.platform??"cli";try{await this._provider.ensureThread(t.threadId,r,t.workspaceId),await this._provider.saveUserMessage(t.threadId,t.message??"");}catch{}}),this.unsubEnd=e.on("task:end",async t=>{if(!t.result)return;let r=t.metadata?.threadId;if(!r)return;let n=t.agentRef?.replace(/^@/,"")??"";try{await this._provider.saveAssistantMessage(r,t.result,n);}catch{}});}detach(e){this.unsubStart?.(),this.unsubStart=null,this.unsubEnd?.(),this.unsubEnd=null,this._provider.close?.();}};l();function un(o){let e=U__namespace.resolve(o);return process.platform==="win32"&&(e=e.replace(/\\/g,"/"),e=e.replace(/^([A-Z]):/,(t,r)=>`${r.toLowerCase()}:`)),e.length>1&&!/^[a-zA-Z]:\/$/.test(e)&&(e=e.replace(/\/+$/,"")),e}function ir(o){let e=un(o);return crypto$1.createHash("sha256").update(e).digest("hex")}function ii(o){return o?o.settings?.template?.exec:void 0}function ai(){try{let o=new Uint8Array(8);return globalThis.crypto.getRandomValues(o),Array.from(o,e=>e.toString(16).padStart(2,"0")).join("")}catch{let{randomBytes:o}=F("crypto");return o(8).toString("hex")}}var Pr=class o extends Be{_agents;_templateEngine;_documentLoader;_layoutLoader;_layoutRenderer;_config;_projectRoot;_workspaceId;_workspaceName;_plugins=[];_tools=new Map;_activeAdapters=new Map;_pendingThreads=new Map;_remoteFactory;_remoteTargets=new Map;constructor(e,t={},r,n,s){super(),this._agents=new Map(e.map(d=>[d.id,d])),this._config=r,this._projectRoot=s??(typeof process<"u"?process.cwd():"/");let i=s??(typeof process<"u"?process.env.CREWX_WORKSPACE??process.cwd():"/");this._workspaceId=ir(i),this._workspaceName=U.basename(i);let a=ii(r);this._templateEngine=new Ue({execPolicy:t.execPolicy??a}),this._documentLoader=n??new ke,this._layoutLoader=new Fe({templatesPath:Te()}),this._layoutRenderer=new We,this._remoteFactory=t.remoteFactory;}async resolveFileRemoteTarget(e){let t=this.getAgent(e),r=Array.isArray(t?.provider)?t?.provider[0]:t?.provider;if(!r?.startsWith("remote/"))return null;let n=r.slice(7),s=this.getRemoteProviderConfig(n);if(!s?.location?.startsWith("file://"))return null;let i=U.resolve(s.location.replace("file://","")),a=s.external_agent_id??e.replace(/^@/,""),d=this._remoteTargets.get(i);d||(d=(this._remoteFactory??(m=>o.loadYaml(m)))(i),this._remoteTargets.set(i,d),d.catch(()=>this._remoteTargets.delete(i)));let c=await d,u=c.getAgent("@"+a),p=Array.isArray(u?.provider)?u?.provider[0]:u?.provider;if(p?.startsWith("remote/"))throw new Error(`Chained remotes not allowed: "${n}" \u2192 "${p}"`);return {target:c,agentRef:"@"+a}}static async loadBuiltInConfig(e){let{yamlPath:t,dir:r}=Lt(),n;try{n=fs.readFileSync(t,"utf-8");}catch(i){throw new Error(`[@crewx/sdk] Cannot read built-in config: ${t}
|
|
67
|
+
${i.message}`)}let s=it(n);if(s.documents&&typeof s.documents=="object"){let i={};for(let[a,d]of Object.entries(s.documents))if(d&&typeof d=="object"){let c=d;typeof c.path=="string"&&!U.isAbsolute(c.path)?i[a]={...c,path:U.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 x of e.agents??[])r.set(x.id,x);for(let x of t.agents??[])r.has(x.id)&&console.warn(`[agent-loader] User agent "${x.id}" overrides built-in`),r.set(x.id,x);let n=Array.from(r.values()),s={...e.layouts??{},...t.layouts??{}},i={...e.documents??{},...t.documents??{}},a=e,d=t,c=Sn(a.vars,d.vars),u=Sn(a.settings,d.settings),p;e.skills&&t.skills&&typeof e.skills=="object"&&typeof t.skills=="object"&&!Array.isArray(e.skills)&&!Array.isArray(t.skills)?p={...e.skills,...t.skills}:p=t.skills??e.skills;let g=[...e.hooks??[],...t.hooks??[]],m=di(a.providers,d.providers),y={...e},k={...t};for(let x of ["agents","layouts","documents","skills","hooks","vars","settings","providers"])delete y[x],delete k[x];let _={...{...y,...k},agents:n,layouts:s,documents:i,skills:p};return g.length>0&&(_.hooks=g),c!==void 0&&(_.vars=c),u!==void 0&&(_.settings=u),m!==void 0&&(_.providers=m),_}static async loadYaml(e,t,r){let n=t?.includeBuiltIns!==false,s,i;if(n){let u=await o.loadBuiltInConfig(r);if(e!==void 0){let p=at(e);s=o.mergeCrewxConfig(u,p),i=U.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=at(e),i=U.dirname(e);}let a=new ke(r);await a.load(s.documents,i);let d=s.agents??[];await En(d,s,t);let c=new o(d,t??{},s,a,i);return await c.use(new Ve),c}static async fromConfig(e,t,r,n){let s=t?.includeBuiltIns===true,i=e;if(s){let u=await o.loadBuiltInConfig(n);i=o.mergeCrewxConfig(u,e);}let a=new ke(n);await a.load(i.documents,r??(typeof process<"u"?process.cwd():"/"));let d=i.agents??[];await En(d,i,t);let c=new o(d,t??{},i,a,r);return await c.use(new Ve),c}get agents(){return this._agents}get config(){return this._config}get plugins(){return this._plugins}get tools(){return this._tools}get workspaceId(){return this._workspaceId}get workspaceName(){return this._workspaceName}getAgent(e){let t=e.startsWith("@")?e.slice(1):e;return this._agents.get(t)}getRemoteProviderConfig(e){let t=this._config?.providers;return Array.isArray(t)?t.find(n=>n.type==="remote"&&n.id===e):void 0}computeTaskLogPath(e,t){let r=Yt(t);return U.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 nr(this,e)}async registerChannelAdapter(e){let{adapter:t,instanceId:r,config:n}=e;if(this._activeAdapters.has(r))throw new Error(`Adapter instance already registered: ${r}`);let s=new Set(t.manifest.capabilities),i=e.store??Zt(r),a=e.defaultMode??"query",d=t.manifest.platform,c=e.agentRunner??{run:async(m,y,k)=>{let _=await(a==="execute"?this.execute.bind(this):this.query.bind(this))(`@${m}`,y,{threadId:k?.threadId,platform:d});return {output:_.ok?_.data:_.error?.message??""}}},u=e.onInbound??(async m=>{let y=m.routingHints?.agentId??e.defaultAgent;if(!y)return {accepted:false,reason:"no_agent"};let{output:k}=await c.run(y,m.text,{threadId:m.threadId});return {accepted:true,output:k}}),p=tr({instanceId:r,config:n,capabilities:s,db:i,agentRunner:c,onInbound:u}),g={adapter:t,ctx:p,state:"starting"};this._activeAdapters.set(r,g),this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"starting",timestamp:new Date});try{await t.start(p),g.state="started",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"started",timestamp:new Date});}catch(m){throw g.state="failed",this.emit("adapter:lifecycle",{adapterId:t.manifest.id,instanceId:r,state:"failed",error:m instanceof Error?m:new Error(String(m)),timestamp:new Date}),this._activeAdapters.delete(r),m}}async unregisterChannelAdapter(e){let t=this._activeAdapters.get(e);if(t){t.state="stopping",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopping",timestamp:new Date});try{await t.adapter.stop(t.ctx),t.state="stopped",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"stopped",timestamp:new Date});}catch(r){t.state="failed",this.emit("adapter:lifecycle",{adapterId:t.adapter.manifest.id,instanceId:e,state:"failed",error:r instanceof Error?r:new Error(String(r)),timestamp:new Date});}finally{this._activeAdapters.delete(e);}}}async stopAllAdapters(e={}){let t=e.timeoutMs??1e4,r=Array.from(this._activeAdapters.keys()),n=await Promise.allSettled(r.map(s=>Promise.race([this.unregisterChannelAdapter(s),new Promise((i,a)=>setTimeout(()=>a(new Error(`Adapter stop timeout: ${s}`)),t))])));for(let s=0;s<n.length;s++)n[s].status==="rejected"&&console.error(`[crewx] adapter stop error (${r[s]}): ${n[s].reason}`);}async close(){await this.stopAllAdapters({timeoutMs:1e4});let e=[...this._remoteTargets.values()];this._remoteTargets.clear(),await Promise.allSettled(e.map(async r=>{try{await(await r).close();}catch(n){console.error(`[crewx] remote target close error: ${n instanceof Error?n.message:String(n)}`);}}));let t=[...this._plugins].reverse();for(let r of t)try{await r.detach(this);}catch(n){console.error(`[crewx] plugin ${r.name} detach error: ${n instanceof Error?n.message:String(n)}`);}this._plugins.length=0;}filterAgents(e){let t=a=>a?a.split(",").map(d=>d.trim().toLowerCase()).filter(Boolean):void 0,r=t(e.role),n=t(e.team),s=t(e.provider),i=Array.from(this._agents.values());return r&&(i=i.filter(a=>a.role&&r.some(d=>Y(a.role.toLowerCase(),d)))),n&&(i=i.filter(a=>a.team&&n.some(d=>Y(a.team.toLowerCase(),d)))),s&&(i=i.filter(a=>(Array.isArray(a.provider)?a.provider:[a.provider]).some(c=>s.some(u=>Y(c.toLowerCase(),u))))),i}renderAgentPrompt(e){let t=e.startsWith("@")?e.slice(1):e,r=this._agents.get(t);if(!r)throw new oe(t,Array.from(this._agents.keys()));return r.inline?.prompt??r.inline?.system_prompt??r.description??`You are an expert ${t}.`}async renderPrompt(e,t){let n={...await this._documentLoader.buildContext(),...t?.documents??{}},s={...t,documents:n};return this._templateEngine.render(e,s)}registerLayout(e,t){this._layoutLoader.registerLayout(e,t);}async renderAgentPromptFull(e,t){let r=e.startsWith("@")?e.slice(1):e,n=this._agents.get(r);if(!n)throw new oe(r,Array.from(this._agents.keys()));let s=this._resolveLayoutSpec(n,t?.layout),i=this._extractLayoutId(s),a=this._extractLayoutProps(n,s,t?.layout),d=this._layoutLoader.load(i,a),c=n.inline?.prompt??n.inline?.system_prompt??n.description??`You are an expert ${r}.`,u=await this._documentLoader.buildContext(),p=t?.env??(typeof process<"u"?process.env:{}),g=t?.vars?.security_key??ai(),m={...t?.vars??{},documents:u,env:p,agent:{id:n.id,name:n.name??n.id,role:n.role??"",team:n.team??"",description:n.description??""}},y=await this._templateEngine.render(c,m),k={mode:t?.session?.mode??"query",platform:t?.session?.platform??"cli",options:t?.session?.options??[]},w=n.provider,_=Array.isArray(w)?w:typeof w=="string"&&w.length>0?[w]:[],x=_.join(", ")||(typeof w=="string"?w:""),A=n.options,S=!Array.isArray(A)&&typeof A=="object"&&A!==null?A:void 0,O=Array.isArray(A)?A:void 0,j={};for(let[h,E]of Object.entries(u))j[h]={content:E.content??"",toc:E.toc,summary:E.summary,path:E.path};let b={user_input:t?.vars?.user_input??void 0,agent:{id:n.id,name:n.name??n.id,role:n.role??"",team:n.team??"",description:n.description??"",provider:x,providerList:_,model:n.inline?.model,workingDirectory:n.working_directory??n.workingDirectory??".",inline:{...n.inline??{},prompt:y},specialties:n.specialties??[],capabilities:n.capabilities??[],remote:n.remote??null,optionsByMode:S,optionsArray:O},agentMetadata:{specialties:n.specialties??[],capabilities:n.capabilities??[],description:n.description??""},documents:j,skills:t?.skills??[],session:k,env:p,vars:{security_key:g,...t?.vars??{}},props:{...a??{},...t?.messages&&t.messages.length>0?{showConversationHistory:true}:{}},platform:k.platform,mode:k.mode,messages:t?.messages??[],tools:this._tools.size>0?{list:Array.from(this._tools.values()).map(h=>({name:h.name,description:h.description,parameters:h.parameters})),json:JSON.stringify(Array.from(this._tools.values()).map(h=>({name:h.name,description:h.description,parameters:h.parameters})),null,2),count:this._tools.size}:null,metadata:{}};return this._layoutRenderer.render(d,b)}_filterToolsByMode(e){return e?e.map(t=>this._tools.get(t)).filter(t=>t!==void 0):Array.from(this._tools.values())}_resolveLayoutSpec(e,t){if(t!==void 0)return t;let r=e.inline?.layout;if(r!==void 0)return r;let n=this._config?.layouts?.default;return typeof n=="string"&&n?n:"crewx/default"}_extractLayoutId(e){if(typeof e=="string")return e;if("id"in e)return e.id;let t=`crewx/__inline_${Date.now()}`;return this._layoutLoader.registerLayout(t,e.template),t}_extractLayoutProps(e,t,r){let n=e.inline?.layout,s=n&&typeof n=="object"&&"props"in n?n.props:void 0,i=r&&typeof r=="object"&&"id"in r?r.props:void 0;if(s||i)return {...s??{},...i??{}}}_getConversationProvider(){return this._plugins.find(t=>t.name==="conversation")?.conversationProvider}async _fetchHistoryMessages(e,t,r){if(r&&r.length>0)return r;if(!e)return;let n=this._getConversationProvider();if(n)try{let s=await n.fetchHistory(e,{currentTraceId:t});return s.messages.length===0?void 0:rr(s)}catch{return}}_resolveTimeout(e){let t=Fr();return e==="query"?t.queryMs:t.executeMs}emitToolEvents(e,t,r,n,s,i,a){try{let c=exports.BUILTIN_ADAPTERS[r]?.parseEvent?.(n)??Wt(new Date().toISOString(),n);for(let u of c)u.type==="tool_use"&&u.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName,rawName:u.toolName,input:u.toolInput?this.tryParseJson(u.toolInput):void 0,toolUseId:u.toolUseId}}),u.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:s,threadId:i,sessionId:a,provider:r,tool:{name:u.toolName??"unknown",rawName:u.toolName??"unknown",toolUseId:u.toolUseId,result:u.resultPreview,isError:u.isError}});}catch{}}emitTaskLogEntries(e,t,r,n,s,i,a){try{for(let d of a)d.type==="tool_use"&&d.toolName&&this.emit("tool:observed:before",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:n,sessionId:s,provider:i,tool:{name:d.toolName,rawName:d.toolName,input:d.toolInput?this.tryParseJson(d.toolInput):void 0,toolUseId:d.toolUseId}}),d.type==="tool_result"&&this.emit("tool:observed:after",{traceId:e,timestamp:new Date,agentRef:t,agentId:r,threadId:n,sessionId:s,provider:i,tool:{name:d.toolName??"unknown",rawName:d.toolName??"unknown",toolUseId:d.toolUseId,result:d.resultPreview,isError:d.isError}});}catch{}}tryParseJson(e){try{return JSON.parse(e)}catch{return e}}async query(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.query(n.agentRef,t,r);let s=Date.now(),i=_e("tsk"),a=new Date,d;try{d=lt(e,Array.from(this._agents.values()));}catch(h){if(h instanceof oe){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let E=Date.now()-s,v={code:"AGENT_NOT_FOUND",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:E,error:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:E}}}throw h}let c=Array.isArray(d.provider)?d.provider[0]??"cli/claude":d.provider,u=r?.provider??c,p=r?.model??d.inline?.model;p&&p.includes("{{")&&(p=await this._templateEngine.render(p,{...r?.vars??{}}));let g;try{g=ie(u);}catch(h){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let E=Date.now()-s,v={code:"PROVIDER_ERROR",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:E,error:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:d.id,provider:u,model:p,durationMs:E}}}let m=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),y;try{y=await this.renderAgentPromptFull(e,{session:{mode:"query",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:m});}catch(h){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${h instanceof Error?h.message:String(h)}`);}let k,w,_,x=p,A=false,S=h=>{A||(A=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"query",pid:h,model:x,provider:u,codingAgentCommand:k,renderedPrompt:y,metadata:{...r?.metadata??{},provider:u},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},O=d.options,j=Array.isArray(O?.query?.tools)?O.query.tools:void 0,$=this._tools.size>0?this._filterToolsByMode(j):[],b=d.inline?.max_steps;u.startsWith("api/")&&S();try{let h=await g.query(t,{model:p,effort:O?.query?.effort,mode:O?.query?.mode,context:r?.context,systemPrompt:y??d.inline?.system_prompt??d.inline?.prompt??d.description??`You are ${d.id}.`,additionalArgs:Array.isArray(O?.query)?O.query:void 0,tools:$.length>0?$:void 0,maxSteps:b,timeoutMs:this._resolveTimeout("query"),env:{CREWX_AGENT_ID:d.id,CREWX_AGENT_ROLE:d.role??"",CREWX_AGENT_TEAM:d.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:u,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,a)},onPid:v=>S(v),onOutput:(v,H)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:v,level:H}),H==="stdout"&&this.emitToolEvents(i,e,u,v,d.id,r?.threadId??"","");},onTaskLog:v=>{this.emitTaskLogEntries(i,e,d.id,r?.threadId??"","",u,v);for(let H of v)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(H),level:"info"});},onCommand:v=>{k=v;},onUsage:v=>{w=v;},onExitCode:v=>{_=v;},onModel:v=>{x||(x=v);}});S();let E=Date.now()-s;return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",result:h,durationMs:E,exitCode:_,inputTokens:w?.inputTokens,outputTokens:w?.outputTokens,cachedInputTokens:w?.cachedInputTokens,costUsd:w?.costUsd,model:x,metadata:{...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}}}),{ok:!0,data:h,meta:{agentId:d.id,provider:u,model:p,durationMs:E}}}catch(h){if(h instanceof exports.ClientToolCallRequiredError){let H=_e("thd");return this._pendingThreads.set(H,{agentRef:d.id,providerStr:u,continuationState:h.continuationState,toolCall:h.toolCall,traceId:i,startMs:s,model:p}),{ok:true,status:"requires_action",data:"",toolCall:h.toolCall,threadId:H,meta:{agentId:d.id,provider:u,model:p,durationMs:Date.now()-s}}}S();let E=Date.now()-s,v={code:"QUERY_FAILED",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"query",durationMs:E,error:v,exitCode:_,inputTokens:w?.inputTokens,outputTokens:w?.outputTokens,cachedInputTokens:w?.cachedInputTokens,costUsd:w?.costUsd,model:x,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:d.id,provider:u,model:p,durationMs:E}}}}async continueQuery(e,t){let r=this._pendingThreads.get(e);if(!r)return {ok:false,data:"",error:{code:"THREAD_NOT_FOUND",message:`No pending thread: ${e}`},meta:{agentId:"",provider:"",durationMs:0}};this._pendingThreads.delete(e);let n=ie(r.providerStr);if(!n.continueWithToolResults)return {ok:false,data:"",error:{code:"UNSUPPORTED",message:"Provider does not support client tool continuation"},meta:{agentId:r.agentRef,provider:r.providerStr,durationMs:0}};let s=t.map(i=>({...i,toolName:r.toolCall.toolCallId===i.toolCallId?r.toolCall.toolName:i.toolCallId}));try{let i=await n.continueWithToolResults(r.continuationState,s),a=Date.now()-r.startMs;return this.emit("task:end",{traceId:r.traceId,timestamp:new Date,agentRef:r.agentRef,mode:"query",result:i,durationMs:a}),{ok:!0,status:"complete",data:i,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}catch(i){if(i instanceof exports.ClientToolCallRequiredError)return this._pendingThreads.set(e,{...r,continuationState:i.continuationState,toolCall:i.toolCall}),{ok:true,status:"requires_action",data:"",toolCall:i.toolCall,threadId:e,meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:Date.now()-r.startMs}};let a=Date.now()-r.startMs;return {ok:false,data:"",error:{code:"CONTINUE_FAILED",message:i.message},meta:{agentId:r.agentRef,provider:r.providerStr,model:r.model,durationMs:a}}}}async execute(e,t,r){let n=await this.resolveFileRemoteTarget(e);if(n)return n.target.execute(n.agentRef,t,r);let s=Date.now(),i=_e("tsk"),a=new Date,d;try{d=lt(e,Array.from(this._agents.values()));}catch(h){if(h instanceof oe){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let E=Date.now()-s,v={code:"AGENT_NOT_FOUND",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:E,error:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:E}}}throw h}let c=Array.isArray(d.provider)?d.provider[0]??"cli/claude":d.provider,u=r?.provider??c,p=r?.model??d.inline?.model;p&&p.includes("{{")&&(p=await this._templateEngine.render(p,{...r?.vars??{}}));let g;try{g=ie(u);}catch(h){this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",metadata:{...r?.metadata??{}},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName});let E=Date.now()-s,v={code:"PROVIDER_ERROR",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:E,error:v,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:d.id,provider:u,model:p,durationMs:E}}}let m=await this._fetchHistoryMessages(r?.threadId,i,r?.messages),y;try{y=await this.renderAgentPromptFull(e,{session:{mode:"execute",platform:r?.platform},vars:{user_input:t,...r?.vars??{}},messages:m});}catch(h){console.error(`[crewx] renderAgentPromptFull failed for ${e}: ${h instanceof Error?h.message:String(h)}`);}let k,w,_,x=p,A=false,S=h=>{A||(A=true,this.emit("task:start",{traceId:i,timestamp:a,agentRef:e,message:t,mode:"execute",pid:h,model:x,provider:u,codingAgentCommand:k,renderedPrompt:y,metadata:{...r?.metadata??{},provider:u},threadId:r?.threadId,platform:r?.platform??"cli",workspaceId:this._workspaceId,workspaceName:this._workspaceName}));},O=d.options,j=Array.isArray(O?.execute?.tools)?O.execute.tools:void 0,$=this._tools.size>0?this._filterToolsByMode(j):[],b=d.inline?.max_steps;u.startsWith("api/")&&S();try{let h=await g.execute(t,{model:p,effort:O?.execute?.effort,mode:O?.execute?.mode,context:r?.context,systemPrompt:y??d.inline?.system_prompt??d.inline?.prompt??d.description??`You are ${d.id}.`,additionalArgs:Array.isArray(O?.execute)?O.execute:void 0,tools:$.length>0?$:void 0,maxSteps:b,timeoutMs:this._resolveTimeout("execute"),env:{CREWX_AGENT_ID:d.id,CREWX_AGENT_ROLE:d.role??"",CREWX_AGENT_TEAM:d.team??"",CREWX_USER_ID:process.env.USER||process.env.USERNAME||"unknown",CREWX_TRACE_ID:i,CREWX_PARENT_TASK_ID:i,CREWX_TASK_ID:i,CREWX_CALLER_AGENT_ID:process.env.CREWX_AGENT_ID??"",CREWX_THREAD_ID:r?.threadId??"",CREWX_PROVIDER:u,CREWX_SESSION_ID:"",CREWX_TASK_LOG_PATH:this.computeTaskLogPath(i,a)},onPid:v=>S(v),onOutput:(v,H)=>{this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:v,level:H}),H==="stdout"&&this.emitToolEvents(i,e,u,v,d.id,r?.threadId??"","");},onTaskLog:v=>{this.emitTaskLogEntries(i,e,d.id,r?.threadId??"","",u,v);for(let H of v)this.emit("task:output",{traceId:i,timestamp:new Date,agentRef:e,output:JSON.stringify(H),level:"info"});},onCommand:v=>{k=v;},onUsage:v=>{w=v;},onExitCode:v=>{_=v;},onModel:v=>{x||(x=v);}});S();let E=Date.now()-s;return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",result:h,durationMs:E,exitCode:_,inputTokens:w?.inputTokens,outputTokens:w?.outputTokens,cachedInputTokens:w?.cachedInputTokens,costUsd:w?.costUsd,model:x,metadata:{...r?.metadata??{},...r?.threadId?{threadId:r.threadId}:{}}}),{ok:!0,data:h,meta:{agentId:d.id,provider:u,model:p,durationMs:E}}}catch(h){S();let E=Date.now()-s,v={code:"EXECUTE_FAILED",message:h.message};return this.emit("task:end",{traceId:i,timestamp:new Date,agentRef:e,mode:"execute",durationMs:E,error:v,exitCode:_,inputTokens:w?.inputTokens,outputTokens:w?.outputTokens,cachedInputTokens:w?.cachedInputTokens,costUsd:w?.costUsd,model:x,metadata:r?.metadata?{...r.metadata}:void 0}),{ok:false,data:"",error:v,meta:{agentId:d.id,provider:u,model:p,durationMs:E}}}}};function Sn(o,e){let t=Ar(o)?o:void 0,r=Ar(e)?e:void 0;if(!(!t&&!r))return {...t??{},...r??{}}}function Ar(o){return typeof o=="object"&&o!==null&&!Array.isArray(o)}function di(o,e){let t=Array.isArray(o)?o:void 0,r=Array.isArray(e)?e:void 0;if(!t&&!r)return;let n=a=>{if(!Ar(a))return;let d=a.id;if(typeof d=="string")return `id:${d}`;let c=a.name;if(typeof c=="string")return `name:${c}`},s=new Set;for(let a of r??[]){let d=n(a);d&&s.add(d);}let i=[];for(let a of t??[]){let d=n(a);d&&s.has(d)||i.push(a);}for(let a of r??[])i.push(a);return i}async function En(o,e,t){if(o.some(n=>(Array.isArray(n.provider)?n.provider:[n.provider]).some(i=>i.startsWith("api/")))){let{registerApiProviders:n}=await Promise.resolve().then(()=>(dr(),fn));n(t?.api);}ci(o,e),ui(o,e),li(o);}function li(o){if(!o.some(r=>(Array.isArray(r.provider)?r.provider:[r.provider]).some(s=>s.startsWith("acp/"))))return;let{registerAcpProviders:t}=(xr(),Dt(vn));t();}function ci(o,e){if(!o.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("remote/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createRemoteProviderFactory:n}=(_r(),Dt(_n)),s=new Map;for(let i of r)i.type==="remote"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&se("remote",n(s,ie));}function ui(o,e){if(!o.some(i=>(Array.isArray(i.provider)?i.provider:[i.provider]).some(d=>d.startsWith("plugin/"))))return;let r=e.providers;if(!Array.isArray(r))return;let{createPluginProviderFactory:n}=(Rr(),Dt(Cn)),s=new Map;for(let i of r)i.type==="plugin"&&typeof i.id=="string"&&s.set(i.id,i);s.size>0&&se("plugin",n(s));}l();var pi="crewx:fs:",Cr=class{prefix;store;constructor(e){this.prefix=e?.prefix??pi,this.store=e?.storage??new Map;}async readFile(e){let t=this.toKey(e),r=this.store.get(t);if(r===void 0)throw new Error(`BrowserFsAdapter: file not found: ${e}`);return r}async exists(e){return this.store.has(this.toKey(e))}resolvePath(...e){let t=e.map(i=>i.replace(/\\/g,"/")).join("/").replace(/\/+/g,"/"),r=t.split("/"),n=[];for(let i of r)i==="."||i===""||(i===".."?n.pop():n.push(i));let s=n.join("/");return t.startsWith("/")?`/${s}`:s}isAbsolute(e){return e.startsWith("/")}setItem(e,t){this.store.set(this.toKey(e),t);}removeItem(e){this.store.delete(this.toKey(e));}keys(){return Array.from(this.store.keys()).filter(e=>e.startsWith(this.prefix)).map(e=>e.slice(this.prefix.length))}toKey(e){return `${this.prefix}${e.replace(/\\/g,"/")}`}};l();function gi(o,e){let t=o.skills?.include;if(t===void 0)return [...e];if(t.length===0)return [];let r=new Set(t);return e.filter(n=>r.has(n))}Z();ar();dr();l();cr();me();ur();pr();wr();xr();$t();Ie();l();var br=0;function mi(o){let e=Array.from(o.agents.keys());return {name:"delegate_to_agent",description:`Delegate a task to another agent. Available agents: ${e.join(", ")}`,parameters:{type:"object",properties:{agent:{type:"string",description:`Agent ID to delegate to. One of: ${e.join(", ")}`},message:{type:"string",description:"Task description for the target agent"},mode:{type:"string",description:'Execution mode: "query" for questions, "execute" for actions. Default: query'}},required:["agent","message"]},execute:async t=>{if(br>=3)return "Error: Maximum delegation depth (3) reached. Cannot delegate further.";let r=t.agent,n=t.message,s=t.mode??"query";if(!e.includes(r))return `Error: Unknown agent "${r}". Available: ${e.join(", ")}`;br++;try{if(s==="execute"){let a=await o.execute(r,n);return a.ok?a.data:`Error: ${a.error?.message??"Unknown error"}`}let i=await o.query(r,n);return i.ok?i.data:`Error: ${i.error?.message??"Unknown error"}`}finally{br--;}}}}l();var In=typeof process<"u"?process.env:{};function fi(){return In.CREWX_CLI||"npx crewx"}function yi(){return In.CREWX_WORKSPACE||(typeof process<"u"?process.cwd():"/")}l();var hi=/^[a-zA-Z0-9._-]+$/,Tr=class{constructor(e){this.storage=e;}storage;listBoxes(e){this.validateId(e);let r=this.storage.listBoxes(e).map(n=>this.toBoxResponse(n));return {boxes:r,total:r.length}}getBox(e,t){this.validateId(e),this.validateId(t);let r=this.storage.findBox(e,t);return r?this.toBoxResponse(r):null}createBox(e,t){this.validateId(e);let r=this.generateBoxId(),n=new Date().toISOString(),s=this.storage.insertBox(e,{id:r,seq:t.seq,firstTaskId:t.firstTaskId,midTaskId:t.midTaskId,lastTaskId:t.lastTaskId,taskCount:t.taskCount,summary:t.summary??null,sourceTokens:t.sourceTokens,summaryTokens:t.summaryTokens??null,createdAt:n});return this.toBoxResponse(s)}toBoxResponse(e){return {id:e.id,threadId:e.thread_id,seq:e.seq,firstTaskId:e.first_task_id,lastTaskId:e.last_task_id,taskCount:e.task_count,sourceTokens:e.source_tokens,summaryTokens:e.summary_tokens,summary:e.summary,previewFirst:this.storage.getTaskPreview(e.first_task_id,200),previewMid:this.storage.getTaskPreview(e.mid_task_id,200),previewLast:this.storage.getTaskPreview(e.last_task_id,200),createdAt:e.created_at}}validateId(e){if(!hi.test(e))throw new Error(`Invalid ID format: ${e}`)}generateBoxId(){return _e("box")}};l();function wi(o,e,t,r,n){let{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}=r,d=s*i,c=s*a,u=d+c,p=e.getThreadMessages(o),g=[],m=0,y=false,k=[];for(let x=0;x<p.length;x+=2){let A=p[x],S=p[x+1],O=A?.content||"",j=S?.content||"",$=n.countTokens(O+j),b=[];A&&b.push(A),S&&b.push(S),k.push({messages:b,tokens:$});}for(let x=k.length-1;x>=0;x--){let A=k[x];if(m+A.tokens>d){y=true;break}m+=A.tokens,g.unshift(...A.messages);}let w=[],_=0;if(y&&c>0)try{let{boxes:x}=t.listBoxes(o);for(let A=x.length-1;A>=0;A--){let S=x[A],O=S.summaryTokens??S.sourceTokens;if(_+O>c)break;_+=O,w.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(x){if(x instanceof Error&&!/not found/i.test(x.message))throw x}return {hot:g,warm:w,hotTokens:m,warmTokens:_,hotOverflow:y,totalBudget:u,config:{maxTokens:s,hotzoneRatio:i,warmzoneRatio:a}}}Ie();ve();l();var It=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},tt=class{constructor(e={}){this.defaults=e;}defaults;metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0};async run(e,t={}){if(!Array.isArray(e))throw new TypeError("ParallelRunner.run expects an array of tasks");if(e.length===0)return this.metrics={totalTasks:0,startedTasks:0,completedTasks:0,successCount:0,failureCount:0,totalDurationMs:0,averageDurationMs:0,throughput:0},[];let r=this.mergeOptions(t),n=Math.max(1,r.maxConcurrency??5),s=r.timeoutMs,i=r.failFast??false,a=r.callbacks,d=r.evaluateTaskSuccess??(()=>true),c=[],u=0,p=0,g=0,m=false,y=0,k=perf_hooks.performance.now(),w=async b=>{a?.onTaskStart&&await a.onTaskStart(b),g+=1;let h=new AbortController,E={signal:h.signal},v,H;typeof s=="number"&&Number.isFinite(s)&&s>0&&(H=new Promise((fe,ye)=>{v=setTimeout(()=>{let he=new It(b.id,s);h.abort(he),ye(he);},s);}));let nt=perf_hooks.performance.now(),Mt=b.run(E),zn=H?Promise.race([Mt,H]):Mt;try{let fe=await zn,ye=perf_hooks.performance.now(),he=ye-nt,be=d(fe,b),ot={taskId:b.id,success:be,value:fe,durationMs:he,startedAt:nt,finishedAt:ye,metadata:b.metadata,aborted:!1};c.push(ot),be?u+=1:p+=1,a?.onTaskComplete&&await a.onTaskComplete(ot),i&&!be&&(m=!0);}catch(fe){let ye=perf_hooks.performance.now(),he=ye-nt,be=fe instanceof Error?fe:new Error(String(fe)),ot={taskId:b.id,success:false,error:be,durationMs:he,startedAt:nt,finishedAt:ye,metadata:b.metadata,aborted:h.signal.aborted};c.push(ot),p+=1,a?.onError&&await a.onError(b,be,he),i&&(m=true);}finally{v&&clearTimeout(v),H&&Mt.catch(()=>{});}},_=async()=>{for(;!m;){let b=y;if(b>=e.length)break;y+=1;let h=e[b];if(!h||(await w(h),m))break}},x=Math.min(n,e.length),A=[];for(let b=0;b<x;b++)A.push(_());await Promise.all(A);let O=perf_hooks.performance.now()-k,j=c.length?c.reduce((b,h)=>b+h.durationMs,0)/c.length:0,$=O>0?c.length/(O/1e3):c.length;return this.metrics={totalTasks:e.length,startedTasks:g,completedTasks:c.length,successCount:u,failureCount:p,totalDurationMs:O,averageDurationMs:j,throughput:$},c}getMetrics(){return this.metrics}mergeOptions(e){return {maxConcurrency:e.maxConcurrency??this.defaults.maxConcurrency,timeoutMs:e.timeoutMs??this.defaults.timeoutMs,failFast:e.failFast??this.defaults.failFast,evaluateTaskSuccess:e.evaluateTaskSuccess??this.defaults.evaluateTaskSuccess,callbacks:this.mergeCallbacks(this.defaults.callbacks,e.callbacks)}}mergeCallbacks(e,t){if(!(!e&&!t))return {onTaskStart:async r=>{e?.onTaskStart&&await e.onTaskStart(r),t?.onTaskStart&&await t.onTaskStart(r);},onTaskComplete:async r=>{e?.onTaskComplete&&await e.onTaskComplete(r),t?.onTaskComplete&&await t.onTaskComplete(r);},onError:async(r,n,s)=>{e?.onError&&await e.onError(r,n,s),t?.onError&&await t.onError(r,n,s);}}}};l();l();var rt=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 On=3,Mn=3e4,Nn=500,xi=o=>{if(typeof o!="number"||Number.isNaN(o)||!Number.isFinite(o))return On;let e=Math.floor(o);return e>0?e:On},vi=o=>o===void 0||typeof o!="number"||Number.isNaN(o)||o<=0?Mn:o,ki=o=>{if(!o)return {maxRetries:0,retryDelay:Nn};let e=Number.isInteger(o.maxRetries)&&o.maxRetries>=0?o.maxRetries:0,t=typeof o.retryDelay=="number"&&o.retryDelay>=0?o.retryDelay:Nn;return {maxRetries:e,retryDelay:t}},Sr=o=>{let e=o.reason;return e instanceof Error?e:typeof e=="string"?new Error(e):new Error("Parallel operation aborted")},_i=(o,e)=>o<=0?Promise.resolve():new Promise((t,r)=>{let n=setTimeout(()=>{e.removeEventListener("abort",s),t();},o),s=()=>{clearTimeout(n),r(Sr(e));};if(e.aborted){s();return}e.addEventListener("abort",s,{once:true});}),Ri=async(o,e,t)=>{let r,n;for(let s=0;s<=e.maxRetries;s++){if(t.aborted)throw Sr(t);try{let i=await o();if(r=i,i.success||s===e.maxRetries)return i}catch(i){if(n=i,t.aborted)throw Sr(t);if(s===e.maxRetries)throw i instanceof Error?i:new Error(String(i))}s<e.maxRetries&&await _i(e.retryDelay,t);}if(r)return r;throw n?n instanceof Error?n:new Error(String(n)):new Error("Parallel helper encountered an unexpected state")},Dn=(o,e,t)=>{e.completed+=1,t?e.success+=1:e.failure+=1;try{o.onProgress?.(e.completed,e.total);}catch(r){process.env.NODE_ENV!=="production"&&console.warn("Parallel helper onProgress callback threw an error:",r);}},Pi=o=>o.map(t=>({metadata:t.metadata,taskResult:t})).slice().sort((t,r)=>t.metadata.index-r.metadata.index).map(({metadata:t,taskResult:r})=>{if(r.value){let s=r.value;return {...s,agentId:s.agentId??t.request.agentId,metadata:{...s.metadata,requestIndex:t.index,mode:t.mode}}}let n=r.error??new Error("Unknown error");return {agentId:t.request.agentId,content:n.message,success:false,metadata:{error:n.message,aborted:r.aborted??false,requestIndex:t.index,mode:t.mode}}}),Ai=o=>o.filter(e=>!e.success).map(e=>{let t=e.metadata;if(e.error instanceof Error)return {index:t.index,error:e.error};if(e.value&&!e.value.success){let r=String(e.value.metadata?.error??e.value.content??"Agent returned unsuccessful result");return {index:t.index,error:new Error(r)}}return {index:t.index,error:new Error("Unknown failure")}}),Ci=(o,e)=>({onTaskComplete:async t=>{Dn(e,o,t.success);},onError:async()=>{Dn(e,o,false);}}),Ln=async(o,e,t={})=>{if(!Array.isArray(o))throw new TypeError("Parallel helpers expect an array of requests");if(o.length===0){let w={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?.(w),[]}let r=xi(t.concurrency),n=vi(t.timeout),s=ki(t.retryPolicy),i=new tt,a=new rt,d=o.map((k,w)=>({id:`${e}:${k.agentId??"anonymous"}:${w}`,metadata:{index:w,mode:e,request:k},run:_=>Ri(()=>e==="query"?a.query(k):a.execute(k),s,_.signal)})),c={completed:0,success:0,failure:0,total:o.length},u=await i.run(d,{maxConcurrency:r,timeoutMs:n,evaluateTaskSuccess:k=>k.success,callbacks:Ci(c,t)}),p=Pi(u),g=Ai(u),m=i.getMetrics(),y={total:o.length,completed:o.length,successCount:p.filter(k=>k.success).length,failureCount:p.filter(k=>!k.success).length,results:p,errors:g,metrics:m};return t.onComplete?.(y),p},bi=(o,e)=>Ln(o,"query",e),Ti=(o,e)=>Ln(o,"execute",e);Rr();_r();kr();vr();l();l();var Ot=class{capabilities={required:[]}};l();l();l();var $n=2e3;function jn(o){let e=o.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f\u2028\u2029]/g,"");return e.length<=$n?e:e.slice(0,$n-11)+" [redacted]"}var Li=10*1024*1024,$i={b:1,kb:1024,mb:1024*1024,gb:1024*1024*1024};function Er(o,e){return o===void 0?true:Array.isArray(o)?o.includes(e):o===e}function ji(o,e){return o===void 0?true:Array.isArray(o)?o.some(t=>e.includes(t)):e.includes(o)}function Un(o){if(typeof o=="number")return o;let e=o.match(/^(\d+(?:\.\d+)?)\s*(b|kb|mb|gb)?$/i);if(!e)return 0;let t=parseFloat(e[1]),r=(e[2]??"b").toLowerCase();return Math.floor(t*($i[r]??1))}function Fn(o){return typeof o=="string"}function qn(o){try{let e=fs.statSync(o);return e.size>Li?(process.stderr.write(`[YamlHookPlugin] File too large for line count: ${o} (${e.size} bytes)
|
|
68
|
+
`),null):fs.readFileSync(o,"utf8").split(`
|
|
69
|
+
`).length}catch{return null}}function Wn(o){try{return fs.statSync(o).size}catch{return null}}function Hi(o,e,t){if(!o)return true;let r=e,n=r?.path??r?.file_path??r?.filePath??r?.filename;if(typeof n!="string")return false;if(Y(n,o))return true;if(t&&n.startsWith("/")){let{relative:s,isAbsolute:i}=F("path");if(i(n)){let a=s(t,n);if(a&&!a.startsWith("..")&&Y(a,o))return true}}return false}function Ui(o,e){return o?JSON.stringify(e).includes(o):true}function Fi(o,e){if(!o)return true;try{let t=new RegExp(o),r=JSON.stringify(e);return t.test(r)}catch{return false}}function qi(o,e){if(!o)return true;try{let t=new RegExp(o),r=JSON.stringify(e);return t.test(r)}catch{return false}}function Wi(o,e){if(o.pathSizeMin===void 0&&o.pathSizeMax===void 0)return true;let t=e,r=t?.path??t?.file_path??t?.filePath??t?.filename;if(typeof r!="string")return false;if(o.pathSizeMin!==void 0)if(Fn(o.pathSizeMin)){let n=Wn(r);if(n===null||n<Un(o.pathSizeMin))return false}else {let n=qn(r);if(n===null||n<o.pathSizeMin)return false}if(o.pathSizeMax!==void 0)if(Fn(o.pathSizeMax)){let n=Wn(r);if(n===null||n>Un(o.pathSizeMax))return false}else {let n=qn(r);if(n===null||n>o.pathSizeMax)return false}return true}function Bi(o){let e=[],t=[];for(let r=0;r<o.length;r++){let n=o[r];if(!n||typeof n!="object"){t.push(`Hook at index ${r}: not an object, skipping`);continue}let s=n;if(typeof s.name!="string"||!s.name){t.push(`Hook at index ${r}: missing or invalid "name", skipping`);continue}let i=s.guide&&typeof s.guide=="object",a=s.deny&&typeof s.deny=="object",d=typeof s.plugin=="string";if(!i&&!a&&!d){t.push(`Hook "${s.name}": missing guide/deny/plugin, skipping`);continue}if(i&&typeof s.guide.say!="string"){t.push(`Hook "${s.name}": guide.say is required and must be string, skipping`);continue}if(a&&typeof s.deny.reason!="string"){t.push(`Hook "${s.name}": deny.reason is required and must be string, skipping`);continue}e.push(s);}return {valid:e,warnings:t}}var Or=class extends Ot{name="@crewx/yaml-hook-plugin";version="0.1.0";capabilities={required:["inject"]};hooks;agentMap;constructor(e){super(),this.hooks=e.hooks,this.agentMap=new Map((e.agents??[]).map(t=>[t.id,t]));}async run(e){let t=[],r=process.env.CREWX_TASK_LOG_PATH,n=process.env.CREWX_HOOK_LOG_VERBOSE==="1";for(let s of this.hooks)if(this.matchEntryLevel(s,e)&&s.guide){if(!this.matchRuleLevel(s.guide,e)){n&&r&&this.appendHookLog(r,{rule:s.name,action:"pass",once:s.guide.once??false,ctx:e,matched:false});continue}s.guide.once&&this.hasFired(e.sessionId,s.name)||(s.guide.once&&this.markFired(e.sessionId,s.name),t.push(s.guide.say),r&&this.appendHookLog(r,{rule:s.name,action:"inject",once:s.guide.once??false,ctx:e,matched:true,message:s.guide.say}));}return t.length?e.inject(t.join(`
|
|
83
70
|
|
|
84
|
-
`)):e.pass()}appendHookLog(e,t){try{let
|
|
85
|
-
`;fs.appendFileSync(e,
|
|
86
|
-
`);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return
|
|
71
|
+
`)):e.pass()}appendHookLog(e,t){try{let r={rule:t.rule,action:t.action,once:t.once,sessionId:t.ctx.sessionId,provider:t.ctx.provider,agent:t.ctx.agent.id,toolName:t.ctx.tool.name,rawToolName:t.ctx.tool.rawName};t.message&&(r.chars=t.message.length,process.env.CREWX_HOOK_LOG_VERBOSE==="1"&&(r.message=jn(t.message).slice(0,500)));let n=`[${new Date().toISOString()}] HOOK: ${JSON.stringify(r)}
|
|
72
|
+
`;fs.appendFileSync(e,n,{encoding:"utf8",mode:384});}catch{}}matchEntryLevel(e,t){if(e.provider!==void 0){let r=t.provider.replace(/^cli\//,"");if(!Er(e.provider,r))return false}if(e.team!==void 0){let n=this.agentMap.get(t.agent.id)?.team??t.agent.team;if(!Er(e.team,n))return false}if(e.role!==void 0){let n=this.agentMap.get(t.agent.id)?.role??t.agent.role;if(!Er(e.role,n))return false}if(e.tag!==void 0){let n=this.agentMap.get(t.agent.id)?.tags??[];if(!ji(e.tag,n))return false}return !(e.agents!==void 0&&!e.agents.includes(t.agent.id))}matchRuleLevel(e,t){return !(e.when!==void 0&&e.when.length>0&&!e.when.includes(t.tool.name)&&!e.when.includes(t.tool.rawName)||!Ui(e.pattern,t.tool.input)||!Fi(e.regex,t.tool.input)||!Hi(e.pathPattern,t.tool.input,t.cwd)||!Wi(e,t.tool.input)||!qi(e.whenInputRegex,t.tool.input))}hasFired(e,t){try{let r=this.firedFilePath(e);if(!fs.existsSync(r))return !1;let n=JSON.parse(fs.readFileSync(r,"utf8"));return Array.isArray(n.fired)&&n.fired.includes(t)}catch{return false}}markFired(e,t){try{let r=this.firedFilePath(e);fs.mkdirSync(U.dirname(r),{recursive:!0,mode:448});let n=fs.existsSync(r)?JSON.parse(fs.readFileSync(r,"utf8")):{fired:[]};Array.isArray(n.fired)||(n.fired=[]),n.fired.includes(t)||(n.fired.push(t),fs.writeFileSync(r,JSON.stringify(n),{mode:384}));}catch(r){process.stderr.write(`[YamlHookPlugin] once state write failed: ${r}
|
|
73
|
+
`);}}firedFilePath(e){let t=crypto$1.createHash("sha1").update(e).digest("hex");return U.join(as.homedir(),".crewx","sessions",t,"fired-rules.json")}};l();l();l();function zi(o){let e=o.messages.map(t=>({id:t.id,role:t.isAssistant?"assistant":"user",content:t.text,timestamp:new Date(t.timestamp).toISOString(),metadata:t.metadata??null}));return {getThreadMessages(t){return e}}}l();var Mr=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 Vi(o){return o}function Ki(o){return {name:o.name,async attach(e){let t=await o.configFactory(e),n=e.registerChannelAdapter,s=o.instanceId??o.name;n&&await n({adapter:o.adapter,instanceId:s,config:t}),o.onAttach&&await o.onAttach(e);},async detach(e){let r=e.unregisterChannelAdapter;r&&await r(o.instanceId??o.name),o.onDetach&&await o.onDetach(e);}}}pt();exports.AdapterError=Mr;exports.AgentNotFoundError=oe;exports.AgentRuntime=rt;exports.AgentSkillsSchema=Nr;exports.BrowserFsAdapter=Cr;exports.ConfigLoadError=we;exports.Crewx=Pr;exports.CrewxPlugin=ze;exports.DocumentLoader=ke;exports.LayoutLoadError=q;exports.LayoutLoader=Fe;exports.LayoutRenderer=We;exports.NodeFsAdapter=wt;exports.ParallelRunner=tt;exports.ParallelRunnerTimeoutError=It;exports.PropsValidationError=ae;exports.PropsValidator=qe;exports.SdkBoxService=Tr;exports.TemplateEngine=Ue;exports.TypedEventEmitter=Be;exports.YamlHookPlugin=Or;exports.buildContext=wi;exports.createAdapterContext=tr;exports.createDelegateTool=mi;exports.createHandler=nr;exports.createPluginProviderFactory=An;exports.createProvider=ie;exports.createRemoteProviderFactory=kn;exports.createScopedAdapterStore=Zt;exports.defaultExtractText=lr;exports.defaultFsAdapter=Qt;exports.defaultParseEvent=G;exports.defineChannelAdapter=Vi;exports.defineChannelAdapterPlugin=Ki;exports.escapeHandlebarsHelper=Kt;exports.formatFileSizeHelper=Jt;exports.formatTimestamp=Yt;exports.formatTimestampHelper=Xt;exports.generateFingerprint=Jo;exports.generateId=_e;exports.getSyncWindowStore=Go;exports.hashWorkspaceId=ir;exports.lengthHelper=Vt;exports.loadYamlFile=at;exports.materializeWindowsSpawnProgram=Le;exports.normalizeWorkspacePath=un;exports.parseStdoutEvent=Wt;exports.parseUsage=K;exports.parseYamlContent=it;exports.registerAcpProviders=xn;exports.registerApiProviders=mn;exports.registerProviderFactory=se;exports.resolveAgent=lt;exports.resolveAgentSkills=gi;exports.resolveCrewxCli=fi;exports.resolveCrewxWorkspace=yi;exports.resolveDefaultAgentsYaml=Lt;exports.resolveTemplatesPath=Te;exports.resolveWindowsExecutablePath=$r;exports.resolveWindowsSpawnProgram=De;exports.runExecutesParallel=Ti;exports.runInSyncWindow=Yo;exports.runQueriesParallel=bi;exports.setAuditVerbose=Do;exports.toTaskReader=zi;exports.toTemplateMessages=rr;exports.truncateHelper=zt;exports.validateHooksSchema=Bi;
|