@toolpack-sdk/agents 2.1.1 → 2.2.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/README.md +72 -4
- package/dist/channels/index.cjs +2 -2
- package/dist/channels/index.d.cts +1 -1
- package/dist/channels/index.d.ts +1 -1
- package/dist/channels/index.js +2 -2
- package/dist/eval-report-BCGixIYd.d.cts +343 -0
- package/dist/eval-report-CpdAMa2b.d.ts +343 -0
- package/dist/{index-Du6S0eG7.d.cts → index-DVhRtkNq.d.cts} +75 -1
- package/dist/{index-o8Lbzv5N.d.ts → index-dhKoHWTy.d.ts} +75 -1
- package/dist/index.cjs +40 -26
- package/dist/index.d.cts +4 -3
- package/dist/index.d.ts +4 -3
- package/dist/index.js +40 -26
- package/dist/interceptors/index.cjs +1 -1
- package/dist/interceptors/index.d.cts +88 -1
- package/dist/interceptors/index.d.ts +88 -1
- package/dist/interceptors/index.js +1 -1
- package/dist/testing/index.cjs +16 -2
- package/dist/testing/index.d.cts +1 -0
- package/dist/testing/index.d.ts +1 -0
- package/dist/testing/index.js +16 -2
- package/package.json +18 -9
package/dist/index.js
CHANGED
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
var nt=Object.defineProperty;var T=(s,e)=>()=>(s&&(e=s(s=0)),e);var rt=(s,e)=>{for(var t in e)nt(s,t,{get:e[t],enumerable:!0})};import rn from"path";import{fileURLToPath as sn}from"url";var d=T(()=>{"use strict"});import{randomUUID as te}from"crypto";var ne,re,ie,oe,se,g,q,Ue=T(()=>{"use strict";d();ne=.6,re=.2,ie=.2,oe={low:.3,medium:.6,high:1},se=30,g={type:"_type",status:"_status",priority:"_priority",tags:"_tags",progress:"_progress",dueBy:"_dueBy",outcome:"_outcome",confidence:"_confidence",expiresAt:"_expiresAt",pinned:"_pinned",relatedTo:"_relatedTo",error:"_error",createdAt:"_createdAt",updatedAt:"_updatedAt"},q=class{constructor(e,t){this.provider=e;this.embedder=t;this.zeroVector=new Array(t.dimensions).fill(0)}provider;embedder;zeroVector;async initialize(){await this.provider.validateDimensions(this.embedder.dimensions)}async embed(e){return this.embedder.embed(e)}async embedBatch(e){return this.embedder.embedBatch(e)}async getActiveGoals(){return(await this._getAllByMeta(t=>t[g.type]==="goal"&&t[g.status]==="active")).map(t=>this.chunkToGoal(t)).sort((t,n)=>{let r={high:0,normal:1,low:2},i=r[t.priority]-r[n.priority];return i!==0?i:t.createdAt-n.createdAt})}async getActiveGoalCount(){return(await this._getAllByMeta(t=>t[g.type]==="goal"&&t[g.status]==="active")).length}async getPinnedReflections(){return(await this._getAllByMeta(t=>t[g.type]==="reflection"&&t[g.pinned]===!0)).map(t=>this.chunkToReflection(t))}async getPinnedReflectionCount(){return(await this._getAllByMeta(t=>t[g.type]==="reflection"&&t[g.pinned]===!0)).length}async getHighConfidenceBeliefs(e){let t=Date.now();return(await this._getAllByMeta(r=>r[g.type]==="belief"&&r[g.confidence]==="high"&&!r[g.error]&&!(r[g.expiresAt]&&r[g.expiresAt]<t))).map(r=>{let i=this.chunkToBelief(r),o=(t-i.createdAt)/864e5,l=Math.exp(-o/se)*re+oe.high*ie+ne;return{...i,score:l}}).sort((r,i)=>i.score-r.score).slice(0,e)}async getRecentReflections(e,t){let n=Date.now()-e*864e5;return(await this._getAllByMeta(i=>i[g.type]==="reflection"&&!i[g.pinned]&&!i[g.error]&&i[g.createdAt]>=n)).map(i=>this.chunkToReflection(i)).sort((i,o)=>o.createdAt-i.createdAt).slice(0,t)}async keywordSearchGoals(e,t={}){let{limit:n=10,status:r="active",tags:i}=t,o;if(e.trim()&&typeof this.provider.keywordQuery=="function")o=(await this.provider.keywordQuery(e,{limit:n*2,threshold:0,filter:{[g.type]:"goal",[g.status]:r}})).map(l=>this.chunkToGoal(l.chunk));else{let c=r;if(o=(await this._getAllByMeta(a=>a[g.type]==="goal"&&a[g.status]===c)).map(a=>this.chunkToGoal(a)),e.trim()){let a=e.toLowerCase();o=o.filter(p=>p.description.toLowerCase().includes(a))}}return i?.length&&(o=o.filter(c=>i.every(l=>c.tags.includes(l)))),o.slice(0,n)}async queryBeliefs(e,t){let{limit:n=10,threshold:r=0,tags:i,includeExpired:o=!1}=t,c=Date.now(),l=await this.provider.query(e,{limit:n*4,threshold:0,filter:{[g.type]:"belief"}}),a=[];for(let p of l){let m=this.chunkToBelief(p.chunk);if(!o&&m.expiresAt&&m.expiresAt<c||i?.length&&!i.every(I=>m.tags.includes(I)))continue;let h=(c-m.createdAt)/864e5,u=Math.exp(-h/se),v=m.error?.3:oe[m.confidence],f=p.score*ne+u*re+v*ie;f<r||a.push({...m,score:f})}return a.sort((p,m)=>m.score-p.score).slice(0,n)}async queryReflections(e,t){let{limit:n=10,threshold:r=0,tags:i,pinned:o}=t,c=Date.now(),l={[g.type]:"reflection"};o===!0&&(l[g.pinned]=!0);let a=await this.provider.query(e,{limit:n*4,threshold:0,filter:l}),p=[];for(let m of a){let h=this.chunkToReflection(m.chunk);if(o===!1&&h.pinned||i?.length&&!i.every(I=>h.tags.includes(I)))continue;let u=(c-h.createdAt)/864e5,v=Math.exp(-u/se),f=m.score*ne+v*re+oe.medium*ie;f<r||p.push({...h,score:f})}return p.sort((m,h)=>h.score-m.score).slice(0,n)}async findSimilarBelief(e,t){let n=Date.now(),r=await this.provider.query(e,{limit:5,threshold:t,filter:{[g.type]:"belief"}});for(let i of r){let o=this.chunkToBelief(i.chunk);if(!(o.expiresAt&&o.expiresAt<n))return{id:i.chunk.id,score:i.score,belief:o}}return null}async addGoal(e){let t=te();return await this.provider.add([this.goalToChunk({...e,id:t})]),t}async updateGoal(e,t){let n=await this._getById(e);if(!n)throw new Error(`[AgentMind] Goal not found: ${e}`);let r=this.chunkToGoal(n),i={...r,description:t.description??r.description,priority:t.priority??r.priority,status:t.status??r.status,outcome:t.outcome??r.outcome,progress:t.appendProgress?[...r.progress,t.appendProgress]:r.progress,updatedAt:Date.now()};await this.provider.add([this.goalToChunk(i)])}async completeGoal(e,t){let n=await this._getById(e);if(!n)throw new Error(`[AgentMind] Goal not found: ${e}`);let r=this.chunkToGoal(n);await this.provider.add([this.goalToChunk({...r,status:"completed",outcome:t??r.outcome,updatedAt:Date.now()})])}async addBelief(e,t){let n=te();return await this.provider.add([this.beliefToChunk({...e,id:n},t)]),n}async updateBelief(e,t,n){let r=await this._getById(e);if(!r)throw new Error(`[AgentMind] Belief not found: ${e}`);let i=this.chunkToBelief(r),o={...i,content:t.content??i.content,confidence:t.confidence??i.confidence,tags:t.tags??i.tags,expiresAt:t.expiresAt!==void 0?t.expiresAt:i.expiresAt,error:t.error??i.error,updatedAt:Date.now()},c=n??r.vector??this.zeroVector;await this.provider.add([this.beliefToChunk(o,c)])}async addReflection(e,t){let n=te();return await this.provider.add([this.reflectionToChunk({...e,id:n},t)]),n}async updateReflection(e,t){let n=await this._getById(e);if(!n)throw new Error(`[AgentMind] Reflection not found: ${e}`);let r=this.chunkToReflection(n),i={...r,pinned:t.pinned??r.pinned,error:t.error??r.error,updatedAt:Date.now()};await this.provider.add([this.reflectionToChunk(i,n.vector??this.zeroVector)])}goalToChunk(e){return{id:e.id,content:e.description,metadata:{[g.type]:"goal",[g.status]:e.status,[g.priority]:e.priority,[g.tags]:JSON.stringify(e.tags),[g.progress]:JSON.stringify(e.progress),[g.dueBy]:e.dueBy??"",[g.outcome]:e.outcome??"",[g.createdAt]:e.createdAt,[g.updatedAt]:e.updatedAt},vector:this.zeroVector}}chunkToGoal(e){let t=e.metadata;return{id:e.id,type:"goal",description:e.content,status:t[g.status],priority:t[g.priority],tags:this._parseTags(t[g.tags]),progress:this._parseTags(t[g.progress]),dueBy:t[g.dueBy]||void 0,outcome:t[g.outcome]||void 0,createdAt:t[g.createdAt],updatedAt:t[g.updatedAt]}}beliefToChunk(e,t){return{id:e.id,content:e.content,metadata:{[g.type]:"belief",[g.confidence]:e.confidence,[g.tags]:JSON.stringify(e.tags),[g.expiresAt]:e.expiresAt??0,[g.error]:e.error===!0,[g.createdAt]:e.createdAt,[g.updatedAt]:e.updatedAt},vector:t}}chunkToBelief(e){let t=e.metadata;return{id:e.id,type:"belief",content:e.content,confidence:t[g.confidence],tags:this._parseTags(t[g.tags]),expiresAt:t[g.expiresAt]||void 0,error:t[g.error]||void 0,createdAt:t[g.createdAt],updatedAt:t[g.updatedAt]}}reflectionToChunk(e,t){return{id:e.id,content:e.content,metadata:{[g.type]:"reflection",[g.pinned]:e.pinned,[g.tags]:JSON.stringify(e.tags),[g.relatedTo]:e.relatedTo??"",[g.error]:e.error===!0,[g.createdAt]:e.createdAt,[g.updatedAt]:e.updatedAt},vector:t}}chunkToReflection(e){let t=e.metadata;return{id:e.id,type:"reflection",content:e.content,pinned:t[g.pinned],tags:this._parseTags(t[g.tags]),relatedTo:t[g.relatedTo]||void 0,error:t[g.error]||void 0,createdAt:t[g.createdAt],updatedAt:t[g.updatedAt]}}async _getById(e){let t=await this.provider.getAllChunks?.();return t?t.find(n=>n.id===e)??null:null}async _getAllByMeta(e){return(await this.provider.getAllChunks?.()??[]).filter(n=>e(n.metadata))}_parseTags(e){try{let t=JSON.parse(e);return Array.isArray(t)?t:[]}catch{return[]}}}});function ae(s){let e=s.match(/^(\d+)(d|h|m|s)$/);if(!e)throw new Error(`Invalid duration format: "${s}". Expected a number followed by d/h/m/s (e.g., "30d", "24h").`);let t=parseInt(e[1],10),n=e[2];return t*{d:864e5,h:36e5,m:6e4,s:1e3}[n]}function Fe(s){if(/^\d{4}-\d{2}-\d{2}/.test(s))return s;let e=ae(s);return new Date(Date.now()+e).toISOString().slice(0,10)}function Ge(s,e){let t=0,n=0,r=0;for(let o=0;o<s.length;o++)t+=s[o]*e[o],n+=s[o]*s[o],r+=e[o]*e[o];let i=Math.sqrt(n)*Math.sqrt(r);return i===0?0:t/i}function ce(s){return Math.ceil(s.length/4)}var de=T(()=>{"use strict";d()});import{randomUUID as dt}from"crypto";var W,ze=T(()=>{"use strict";d();de();W=class{constructor(e,t,n,r,i,o){this.store=e;this.deduplicationThreshold=t;this.maxGoals=n;this.maxPinnedReflections=r;this.committedGoalCount=i;this.committedPinnedReflectionCount=o}store;deduplicationThreshold;maxGoals;maxPinnedReflections;committedGoalCount;committedPinnedReflectionCount;ops=[];get draftGoalCount(){return this.ops.filter(e=>e.op==="set_goal").length}get draftPinnedReflectionCount(){return this.ops.filter(e=>e.op==="reflect"&&e.pinned).length}get totalGoalCount(){return this.committedGoalCount+this.draftGoalCount}get totalPinnedReflectionCount(){return this.committedPinnedReflectionCount+this.draftPinnedReflectionCount}async addBelieve(e){let t=Date.now(),n=await this.store.embed(e.content),r,i=e.expiresIn??e.ttlDefault;i&&(r=t+ae(i));let o=this._findSimilarInDraft(n);if(o!==null){let a=this.ops[o],p=e.confidence,m=a.confidence,h={low:0,medium:1,high:2},u=h[p]>h[m]||e.allowDowngrade&&h[p]<h[m];return this.ops[o]={...a,content:e.content,confidence:u?p:m,tags:e.tags.length>0?e.tags:a.tags,expiresAt:r,allowDowngrade:e.allowDowngrade,vector:n},{action:"updated_draft",id:a.existingId??`draft-${o}`}}let c=await this.store.findSimilarBelief(n,this.deduplicationThreshold);if(c){let a=c.belief,p=e.confidence,m=a.confidence,h={low:0,medium:1,high:2},u=h[p]>h[m]||e.allowDowngrade&&h[p]<h[m],v={op:"believe",content:e.content,confidence:u?p:m,tags:e.tags.length>0?e.tags:a.tags,expiresAt:r,allowDowngrade:e.allowDowngrade,createdAt:t,vector:n,existingId:c.id};return this.ops.push(v),{action:"updated_store",id:c.id}}let l={op:"believe",content:e.content,confidence:e.confidence,tags:e.tags,expiresAt:r,allowDowngrade:e.allowDowngrade,createdAt:t,vector:n};return this.ops.push(l),{action:"created",id:`draft-${this.ops.length-1}`}}async addReflect(e){let t;if(e.pinned){let o=this.totalPinnedReflectionCount;if(o>=this.maxPinnedReflections)throw new Error(`[AgentMind] Pinned reflection cap reached (${this.maxPinnedReflections}). Call mind_recall with type:'reflection' and pinned:true to list current pinned reflections, then call mind_unpin_reflection to remove one before adding another.`);o>=this.maxPinnedReflections-2&&(t=`Pinned reflection count is ${o+1} of ${this.maxPinnedReflections}. Review and unpin standing rules that are no longer universally applicable.`)}let n=await this.store.embed(e.content),r={op:"reflect",content:e.content,pinned:e.pinned,tags:e.tags,relatedTo:e.relatedTo,createdAt:Date.now(),vector:n},i=`draft-reflect-${this.ops.length}`;return this.ops.push(r),{id:i,warning:t}}addSetGoal(e){if(this.totalGoalCount>=this.maxGoals)throw new Error(`[AgentMind] Active goal cap reached (${this.maxGoals}). Complete or archive an existing goal before setting a new one.`);let t=e.dueBy?Fe(e.dueBy):void 0,n={op:"set_goal",tempId:dt(),description:e.description,priority:e.priority,tags:e.tags,dueBy:t,createdAt:Date.now()};return this.ops.push(n),{id:n.tempId}}addUpdateGoal(e){let t={op:"update_goal",id:e.id,description:e.description,priority:e.priority,progress:e.progress,updatedAt:Date.now()};this.ops.push(t)}addUnpinReflection(e){let t={op:"unpin_reflection",id:e};this.ops.push(t)}async flushClean(){await this._flush(!1)}async flushOnError(){await this._flush(!0)}async _flush(e){let t=Date.now();for(let n of this.ops)if(n.op==="believe"){let r=n;e?r.existingId?await this.store.updateBelief(r.existingId,{content:r.content,confidence:r.confidence,tags:r.tags,expiresAt:r.expiresAt,error:!0},r.vector):await this.store.addBelief({type:"belief",content:r.content,confidence:r.confidence,tags:r.tags,expiresAt:r.expiresAt,error:!0,createdAt:r.createdAt,updatedAt:t},r.vector):r.existingId?await this.store.updateBelief(r.existingId,{content:r.content,confidence:r.confidence,tags:r.tags,expiresAt:r.expiresAt},r.vector):await this.store.addBelief({type:"belief",content:r.content,confidence:r.confidence,tags:r.tags,expiresAt:r.expiresAt,createdAt:r.createdAt,updatedAt:t},r.vector)}else if(n.op==="reflect"){let r=n;await this.store.addReflection({type:"reflection",content:r.content,pinned:r.pinned,tags:r.tags,relatedTo:r.relatedTo,error:e||void 0,createdAt:r.createdAt,updatedAt:t},r.vector)}else if(n.op==="set_goal"){if(!e){let r=n;await this.store.addGoal({type:"goal",description:r.description,priority:r.priority,status:"active",tags:r.tags,dueBy:r.dueBy,progress:[],createdAt:r.createdAt,updatedAt:r.createdAt})}}else if(n.op==="update_goal"){if(!e){let r=n;await this.store.updateGoal(r.id,{description:r.description,priority:r.priority,appendProgress:r.progress})}}else if(n.op==="unpin_reflection"&&!e){let r=n;await this.store.updateReflection(r.id,{pinned:!1})}this.ops=[]}_findSimilarInDraft(e){let t=this.ops.map((n,r)=>({op:n,idx:r})).filter(({op:n})=>n.op==="believe");for(let{op:n,idx:r}of t){let i=n;if(i.vector.length===0)continue;if(Ge(e,i.vector)>=this.deduplicationThreshold)return r}return null}}});function Je(s,e,t){return[lt(s,t),pt(s,e,t),ut(e,t),gt(e),ht(e,t),mt(s,e),ft(s)]}function lt(s,e){return{name:"mind_recall",displayName:"Mind Recall",description:"Search the agent's persistent memory for past beliefs, reflections, and goals. Use mid-task when the current task may have relevant past context not in the header. Reads from committed store only \u2014 writes from the current run are not visible here.",category:"mind",cacheable:!1,parameters:{type:"object",properties:{query:{type:"string",description:"Free-text search query. Used for semantic search on beliefs/reflections and text matching on goals."},type:{type:"string",enum:["belief","reflection","goal","all"],description:"Entry type to search. Default: 'all'"},status:{type:"string",enum:["active","completed"],description:"For goal queries only. Default: 'active'"},tags:{type:"array",items:{type:"string"},description:"Filter to entries that have all of these tags."},pinned:{type:"boolean",description:"When true, return only pinned reflections. For type:'all', applies only to the reflection subset."},includeExpired:{type:"boolean",description:"Whether to include archived (expired) beliefs. Default: false"},threshold:{type:"number",description:"Composite score threshold override for this call (0\u20131). Results below this score are excluded. Silently ignored for goal queries."},limit:{type:"number",description:"Max entries to return. Default: 5"}},required:["query"]},execute:async t=>{let n=String(t.query??""),r=t.type??"all",i=t.status??"active",o=Array.isArray(t.tags)?t.tags.map(String):void 0,c=typeof t.pinned=="boolean"?t.pinned:void 0,l=t.includeExpired===!0,a=typeof t.threshold=="number"?t.threshold:e.retrievalThreshold,p=typeof t.limit=="number"?Math.max(1,Math.floor(t.limit)):5,m=[],u=(r==="belief"||r==="reflection"||r==="all")&&n.trim()?await s.embed(n):null;if(r==="goal"||r==="all"){let v=await s.keywordSearchGoals(n,{limit:p,status:i,tags:o});for(let f of v)m.push(yt(f))}if(u&&(r==="belief"||r==="all")){let v=await s.queryBeliefs(u,{limit:p,threshold:a,tags:o,includeExpired:l});for(let f of v)m.push(wt(f))}if(u&&(r==="reflection"||r==="all")){let v=await s.queryReflections(u,{limit:p,threshold:a,tags:o,pinned:c});for(let f of v)m.push(vt(f))}return m}}}function pt(s,e,t){return{name:"mind_believe",displayName:"Mind Believe",description:"Record a new belief about the operating environment, or update an existing one. Call at the end of a task when you have learned something that should persist across runs. Deduplicates automatically \u2014 if a similar belief already exists above the similarity threshold it is updated in place. Writes are buffered and committed when the task completes cleanly.",category:"mind",parameters:{type:"object",properties:{content:{type:"string",description:"The belief statement."},confidence:{type:"string",enum:["low","medium","high"],description:"Certainty at write time. Default: 'medium'"},tags:{type:"array",items:{type:"string"},description:"Tags for structured filtering via mind_recall."},expiresIn:{type:"string",description:"TTL override, e.g. '30d', '90d'. Overrides the agent default TTL."},allowDowngrade:{type:"boolean",description:"If true, allows confidence downgrade on an existing belief. Default: false."}},required:["content"]},execute:async n=>({status:"ok",...await e.addBelieve({content:String(n.content),confidence:n.confidence??"medium",tags:Array.isArray(n.tags)?n.tags.map(String):[],expiresIn:n.expiresIn?String(n.expiresIn):void 0,allowDowngrade:n.allowDowngrade===!0,ttlDefault:t.ttlDefaults.belief})})}}function ut(s,e){return{name:"mind_reflect",displayName:"Mind Reflect",description:"Log a post-task observation about your own performance. Reflections are append-only and not auto-injected (use pin:true to make a standing rule always shown in the header). Call at the end of a task with something you would do differently next time.",category:"mind",parameters:{type:"object",properties:{content:{type:"string",description:"The post-task observation."},pin:{type:"boolean",description:`If true, marks as a standing rule always shown in the header. Capped at ${e.maxPinnedReflections}. Default: false`},tags:{type:"array",items:{type:"string"},description:"Tags for structured filtering via mind_recall."},relatedTo:{type:"string",description:"Informational context (e.g., a PR number or task ID). Not filterable \u2014 use tags for that."}},required:["content"]},execute:async t=>({status:"ok",...await s.addReflect({content:String(t.content),pinned:t.pin===!0,tags:Array.isArray(t.tags)?t.tags.map(String):[],relatedTo:t.relatedTo?String(t.relatedTo):void 0})})}}function gt(s){return{name:"mind_unpin_reflection",displayName:"Mind Unpin Reflection",description:"Remove the pin flag from a standing rule reflection. The reflection stays in the store as a regular non-pinned reflection. Use when a pinned rule is no longer universally applicable. Requires the reflection id \u2014 call mind_recall with type:reflection and pinned:true first.",category:"mind",parameters:{type:"object",properties:{id:{type:"string",description:"ID of the pinned reflection to unpin. Obtain via mind_recall."}},required:["id"]},execute:async e=>(s.addUnpinReflection(String(e.id)),{status:"ok"})}}function ht(s,e){return{name:"mind_set_goal",displayName:"Mind Set Goal",description:`Create a new active goal to track across sessions. No deduplication \u2014 call mind_recall with type:goal first to avoid re-creating existing goals. Goal cap is ${e.maxGoals} active goals; the call is rejected if the cap is reached.`,category:"mind",parameters:{type:"object",properties:{description:{type:"string",description:"The goal statement."},priority:{type:"string",enum:["low","normal","high"],description:"Goal priority. Default: 'normal'"},tags:{type:"array",items:{type:"string"},description:"Tags for filtering via mind_recall."},dueBy:{type:"string",description:"Optional deadline. ISO 8601 date (e.g., '2026-06-01') or duration string (e.g., '30d'). Metadata only \u2014 goals are not auto-archived."}},required:["description"]},execute:async t=>({status:"ok",...s.addSetGoal({description:String(t.description),priority:t.priority??"normal",tags:Array.isArray(t.tags)?t.tags.map(String):[],dueBy:t.dueBy?String(t.dueBy):void 0})})}}function mt(s,e){return{name:"mind_update_goal",displayName:"Mind Update Goal",description:"Partially update an active goal \u2014 change priority, description, or append a progress note. Does not complete the goal; use mind_complete_goal for that. Requires the goal id \u2014 call mind_recall with type:goal first.",category:"mind",parameters:{type:"object",properties:{id:{type:"string",description:"ID of the goal to update. Obtain via mind_recall."},description:{type:"string",description:"Revised goal description."},priority:{type:"string",enum:["low","normal","high"],description:"Updated priority."},progress:{type:"string",description:"A progress note to append to the goal history. Not a replacement."}},required:["id"]},execute:async t=>(e.addUpdateGoal({id:String(t.id),description:t.description?String(t.description):void 0,priority:t.priority,progress:t.progress?String(t.progress):void 0}),{status:"ok"})}}function ft(s){return{name:"mind_complete_goal",displayName:"Mind Complete Goal",description:"Mark an active goal as completed and archive it. Commits immediately (does not go through the draft buffer). Completed goals are excluded from the header but remain queryable via mind_recall with status:completed. Requires the goal id \u2014 call mind_recall with type:goal first.",category:"mind",parameters:{type:"object",properties:{id:{type:"string",description:"ID of the goal to complete. Obtain via mind_recall with type:goal."},outcome:{type:"string",description:"Optional summary of what was accomplished."}},required:["id"]},execute:async e=>(await s.completeGoal(String(e.id),e.outcome?String(e.outcome):void 0),{status:"ok"})}}function yt(s){return{id:s.id,type:"goal",content:s.description,tags:s.tags,createdAt:s.createdAt,updatedAt:s.updatedAt,priority:s.priority,status:s.status,progress:s.progress,outcome:s.outcome,dueBy:s.dueBy}}function wt(s){return{id:s.id,type:"belief",content:s.content,score:s.score,tags:s.tags,createdAt:s.createdAt,updatedAt:s.updatedAt,confidence:s.confidence,expiresAt:s.expiresAt,error:s.error}}function vt(s){return{id:s.id,type:"reflection",content:s.content,score:s.score,tags:s.tags,createdAt:s.createdAt,updatedAt:s.updatedAt,pinned:s.pinned,relatedTo:s.relatedTo,error:s.error}}var He=T(()=>{"use strict";d()});async function qe(s,e){let[t,n,r,i]=await Promise.all([s.getActiveGoals(),s.getPinnedReflections(),s.getHighConfidenceBeliefs(20),s.getRecentReflections(e.recencyWindowDays,3)]),o=t.map(m=>It(m)),c=n.map(m=>`- ${m.content}`),{beliefLines:l,reflectionLines:a}=At(r,i,e.tokenBudget);if(o.length===0&&c.length===0&&l.length===0&&a.length===0)return"";let p=["--- AGENT MIND ---",""];return o.length>0&&(p.push("## Goals"),p.push(...o),p.push("")),c.length>0&&(p.push("## Standing Rules (Pinned)"),p.push(...c),p.push("")),l.length>0&&(p.push("## Beliefs"),p.push(...l),p.push("")),a.length>0&&(p.push("## Recent Reflections"),p.push(...a),p.push("")),p.push("---"),p.join(`
|
|
2
|
-
`)}function It(s){let e=s.progress[s.progress.length-1],t=`[${s.priority}] ${s.description}`;return e&&(t+=` \u2014 last progress: ${e}`),s.dueBy&&(t+=` (due: ${s.dueBy})`),t}function At(s,e,t){let n=t,r=[],i=[];for(let o of s){let c=`- ${o.content} (${o.confidence} confidence)`,l=ce(c);if(l>n)break;r.push(c),n-=l}for(let o of e){let l=`- [${new Date(o.createdAt).toISOString().slice(0,10)}] ${o.content}`,a=ce(l);if(a>n)break;i.push(l),n-=a}return{beliefLines:r,reflectionLines:i}}var We=T(()=>{"use strict";d();de()});var Ke={};rt(Ke,{AgentMind:()=>K});function Dt(s,e){let t=Math.min(e.maxGoals??kt,Tt),n=Math.min(e.maxPinnedReflections??xt,Pt);return{tokenBudget:e.tokenBudget??bt,recencyWindowDays:e.recencyWindowDays??Ct,maxGoals:t,maxPinnedReflections:n,deduplicationThreshold:e.deduplicationThreshold??Rt,retrievalThreshold:e.retrievalThreshold??St,ttlDefaults:{belief:e.ttlDefaults?.belief??_t,reflection:e.ttlDefaults?.reflection},namespace:e.namespace??`mind/${s}`}}var bt,Ct,kt,xt,Rt,St,_t,Tt,Pt,K,le=T(()=>{"use strict";d();Ue();ze();He();We();bt=300,Ct=7,kt=10,xt=10,Rt=.85,St=.35,_t="30d",Tt=10,Pt=10,K=class s{constructor(e,t){this.store=e;this.config=t}store;config;static async create(e,t){let n;if(t.provider)n=t.provider;else{let{PersistentKnowledgeProvider:o}=await import("@toolpack-sdk/knowledge"),c=t.namespace??`mind/${e}`;n=new o({namespace:c})}let r=Dt(e,t),i=new q(n,t.embedder);return await i.initialize(),new s(i,r)}async createRunContext(){let[e,t,n]=await Promise.all([this.store.getActiveGoalCount(),this.store.getPinnedReflectionCount(),qe(this.store,this.config)]),r=new W(this.store,this.config.deduplicationThreshold,this.config.maxGoals,this.config.maxPinnedReflections,e,t),i=Je(this.store,r,this.config);return{mindHeader:n,tools:i,flush:async c=>{c?await r.flushOnError():await r.flushClean()}}}async close(){this.store&&await Promise.resolve()}}});d();d();d();import{EventEmitter as Et}from"events";import{Toolpack as Mt,InMemoryConversationStore as Nt}from"toolpack-sdk";d();d();var D=Symbol("interceptor-skip-sentinel");function E(s){return s===D}function G(){return D}var $=class extends Error{constructor(e,t){super(`Invocation depth ${e} exceeds maximum ${t}`),this.name="InvocationDepthExceededError"}};function z(s,e,t,n,r={}){let i=r.maxInvocationDepth??5;return{async execute(o){let l=(p=>({agent:e,channel:t,registry:n,invocationDepth:p,delegateAndWait:async(m,h)=>{let u=p+1;if(u>i)throw new $(u,i);if(!n)throw new Error(`Cannot delegate to "${m}": agent is running in standalone mode without a registry`);let v=n.getAgent(m);if(!v)throw new Error(`Agent "${m}" not found for delegation`);let f={message:h.message??"",intent:h.intent,data:h.data,context:h.context,conversationId:h.conversationId??o.conversationId??`delegation-${Date.now()}`};return await v.invokeAgent(f)},skip:G}))(0),a=async p=>{let m=p??o;return await e.invokeAgent(m)};for(let p=s.length-1;p>=0;p--){let m=s[p],h=a;a=async u=>await m(u??o,l,h)}return await a()}}}async function J(s,e){let t=await s.execute(e);return t===D?null:t}d();import{randomUUID as Be}from"crypto";function it(s){let e=s.context??{},t=e.channelType;return t==="im"||t==="private"||t==="dm"?"dm":e.threadId!==void 0?"thread":"channel"}var j=Symbol.for("toolpack:capture-history");function B(s){let e=s.captureAgentReplies??!0,t=s.getScope??it,n=s.getMessageId??(o=>o.context?.messageId??o.context?.eventId??Be()),r=s.getMentions??(o=>o.context?.mentions??[]),i=async(o,c,l)=>{let a=o.conversationId;if(!a)return c.logger?.warn("[capture-history] Message has no conversationId \u2014 skipping capture"),await l();let p=o.participant;if(p){let h={id:n(o),conversationId:a,participant:p,content:o.message??"",timestamp:new Date().toISOString(),scope:t(o),metadata:{channelType:o.context?.channelType,threadId:o.context?.threadId,messageId:o.context?.messageId,mentions:r(o),channelName:o.context?.channelName,channelId:o.context?.channelId}};try{await s.store.append(h),s.onCaptured?.(h),c.logger?.debug("[capture-history] Captured inbound message",{messageId:h.id,participantId:p.id,conversationId:a})}catch(u){c.logger?.warn("[capture-history] Failed to store inbound message",{error:u instanceof Error?u.message:String(u)})}}let m=await l();if(e&&!E(m)&&m.output!=null){let h={kind:"agent",id:c.agent.name,displayName:c.agent.name},u={id:Be(),conversationId:a,participant:h,content:m.output,timestamp:new Date().toISOString(),scope:t(o),metadata:{channelType:o.context?.channelType,threadId:o.context?.threadId,channelName:o.context?.channelName,channelId:o.context?.channelId}};try{await s.store.append(u),s.onCaptured?.(u),c.logger?.debug("[capture-history] Captured agent reply",{messageId:u.id,agentId:c.agent.name,conversationId:a})}catch(v){c.logger?.warn("[capture-history] Failed to store agent reply",{error:v instanceof Error?v.message:String(v)})}}return m};return i[j]=!0,i}d();import{randomUUID as ot}from"crypto";function Le(s){return Math.ceil(s.length/4)}function st(s){return{id:s.id,participant:s.participant,content:s.content,timestamp:s.timestamp}}function at(s,e){let{participant:t,content:n}=s;return t.kind==="system"?{role:"system",content:n}:t.kind==="agent"?t.id===e?{role:"assistant",content:n}:{role:"user",content:`${t.displayName??t.id} (agent): ${n}`}:{role:"user",content:`${t.displayName??t.id}: ${n}`}}function ct(s,e,t){return!!(s.participant.id===e||s.metadata?.mentions?.some(n=>t.has(n)))}async function H(s,e,t,n,r={},i){let{scope:o,addressedOnlyMode:c=!0,tokenBudget:l=3e3,rollingSummaryThreshold:a=40,timeWindowMinutes:p,maxTurnsToLoad:m=100,agentAliases:h}=r,u=new Set([t,...h??[]]),v=p!==void 0?new Date(Date.now()-p*60*1e3).toISOString():void 0,f=await s.get(e,{scope:o,sinceTimestamp:v,limit:m}),I=f.length;if(c){let k=new Set;for(let x=0;x<f.length;x++){let O=f[x];if(ct(O,t,u)&&k.add(O.id),x<f.length-1){let P=f[x+1];P.participant.kind==="agent"&&P.participant.id===t&&k.add(O.id)}}let _=f[f.length-1];_&&k.add(_.id),f=f.filter(x=>k.has(x.id))}let R=!1;if(f.length>a&&i){let k=Math.floor(f.length/2),_=f.slice(0,k),x=f.slice(k),O=_.filter(P=>!P.metadata?.isSummary);try{let P=await i.invokeAgent({message:"summarize",data:{turns:O.map(st),agentName:n,agentId:t,maxTokens:Math.floor(l*.25),extractDecisions:!0}}),$e=JSON.parse(P.output),je={id:`summary-${ot()}`,conversationId:e,participant:{kind:"system",id:"summarizer"},content:`[Summary of ${$e.turnsSummarized} earlier turns]: ${$e.summary}`,timestamp:_[0].timestamp,scope:o??"channel",metadata:{isSummary:!0}};f=[je,...x],R=!0;try{await s.append(je),await s.deleteMessages(e,_.map(tt=>tt.id))}catch{}}catch{f=f.slice(-a)}}else f.length>a&&(f=f.slice(-a));let S=f.map(k=>at(k,t));if(S.length===0)return{messages:[],estimatedTokens:0,turnsLoaded:I,hasSummary:R};let F=S[S.length-1],Oe=[F],ee=Le(F.content);for(let k=S.length-2;k>=0;k--){let _=S[k],x=Le(_.content);if(ee+x>l)break;Oe.unshift(_),ee+=x}return{messages:Oe,estimatedTokens:ee,turnsLoaded:I,hasSummary:R}}d();var A=class extends Error{constructor(e){super(e),this.name="AgentError"}};var C=class extends Et{provider;model;workflow;mind;delegation;conversationHistory;assemblerOptions;channels=[];interceptors=[];_registry;_triggeringChannel;_conversationId;_isTriggerChannel;toolpack;_initConfig;_ownedToolpack=!1;_conversationLocks=new Map;_mind;_mindInitPromise;constructor(e){super(),this.conversationHistory=new Nt,"toolpack"in e?this.toolpack=e.toolpack:this._initConfig=e}async _ensureToolpack(){if(!this.toolpack){if(!this._initConfig)throw new Error(`[${this.name??"agent"}] Cannot start: no apiKey or toolpack provided`);this.toolpack=await Mt.init({provider:this._initConfig.provider??"anthropic",apiKey:this._initConfig.apiKey,model:this._initConfig.model}),this._ownedToolpack=!0}}async _ensureMind(){this._mind!==void 0||!this.mind||(this._mindInitPromise||(this._mindInitPromise=(async()=>{let{AgentMind:e}=await Promise.resolve().then(()=>(le(),Ke));this._mind=await e.create(this.name,this.mind)})().catch(e=>{throw this._mindInitPromise=void 0,e})),await this._mindInitPromise)}async start(){await this._ensureToolpack(),this.mode&&(typeof this.mode=="string"?this.toolpack.setMode(this.mode):(this.toolpack.registerMode(this.mode),this.toolpack.setMode(this.mode.name)));for(let e of this.channels)this._bindChannel(e),e.listen()}async stop(){for(let e of this.channels)"stop"in e&&typeof e.stop=="function"&&await e.stop();this._ownedToolpack&&await this.toolpack.disconnect?.()}async run(e,t,n){let r=n?.conversationId??this._conversationId;await this.onBeforeRun({message:e,conversationId:r}),this.emit("agent:start",{message:e}),await this._ensureMind();let i,o="",c=[];if(this._mind){let l=await this._mind.createRunContext();o=l.mindHeader,c=l.tools,i=l.flush}try{typeof this.mode=="string"?this.toolpack.setMode(this.mode):(this.toolpack.registerMode(this.mode),this.toolpack.setMode(this.mode.name));let l=[];if(o&&l.push({role:"system",content:o}),r)try{let h=await H(this.conversationHistory,r,this.name,this.name,this._resolveAssemblerOptions()),u=h.messages[h.messages.length-1],v=e.trim(),I=v!==""&&u?.role==="user"&&typeof u.content=="string"&&(u.content===v||u.content.endsWith(`: ${v}`))?h.messages.slice(0,-1):h.messages;l.push(...I)}catch{}e.trim()&&l.push({role:"user",content:e});let a=[...c];if(r){let h=this.conversationHistory;a.push({name:"conversation_search",displayName:"Conversation Search",description:"Search past conversation history for specific information, questions, or topics mentioned earlier in this conversation.",category:"search",parameters:{type:"object",properties:{query:{type:"string",description:"Keywords or phrases to search for in conversation history."},limit:{type:"number",description:"Maximum number of results to return (default: 5)."}},required:["query"]},execute:async u=>{let v=await h.search(r,String(u.query??""),{limit:typeof u.limit=="number"?u.limit:5});return{results:v.map(f=>({role:f.participant.kind==="agent"?"assistant":"user",content:f.content,timestamp:f.timestamp})),count:v.length}}})}if(this.delegation?.enabled&&this._registry){let h=this.delegation.allowedAgents,u=this._registry.getAllAgents().filter(v=>v.name!==this.name&&(h===void 0||h.includes(v.name)));if(u.length>0){let v=u.map(I=>I.name),f=u.map(I=>`- ${I.name}: ${I.description}`).join(`
|
|
3
|
-
`);this.delegation.mode==="forget"?
|
|
1
|
+
var ft=Object.defineProperty;var M=(o,e)=>()=>(o&&(e=o(o=0)),e);var yt=(o,e)=>{for(var t in e)ft(o,t,{get:e[t],enumerable:!0})};import bn from"path";import{fileURLToPath as kn}from"url";var d=M(()=>{"use strict"});import{randomUUID as ue}from"crypto";var pe,ge,me,he,fe,h,W,Qe=M(()=>{"use strict";d();pe=.6,ge=.2,me=.2,he={low:.3,medium:.6,high:1},fe=30,h={type:"_type",status:"_status",priority:"_priority",tags:"_tags",progress:"_progress",dueBy:"_dueBy",outcome:"_outcome",confidence:"_confidence",expiresAt:"_expiresAt",pinned:"_pinned",relatedTo:"_relatedTo",error:"_error",createdAt:"_createdAt",updatedAt:"_updatedAt"},W=class{constructor(e,t){this.provider=e;this.embedder=t;this.zeroVector=new Array(t.dimensions).fill(0)}provider;embedder;zeroVector;async initialize(){await this.provider.validateDimensions(this.embedder.dimensions)}async embed(e){return this.embedder.embed(e)}async embedBatch(e){return this.embedder.embedBatch(e)}async getActiveGoals(){return(await this._getAllByMeta(t=>t[h.type]==="goal"&&t[h.status]==="active")).map(t=>this.chunkToGoal(t)).sort((t,n)=>{let r={high:0,normal:1,low:2},s=r[t.priority]-r[n.priority];return s!==0?s:t.createdAt-n.createdAt})}async getActiveGoalCount(){return(await this._getAllByMeta(t=>t[h.type]==="goal"&&t[h.status]==="active")).length}async getPinnedReflections(){return(await this._getAllByMeta(t=>t[h.type]==="reflection"&&t[h.pinned]===!0)).map(t=>this.chunkToReflection(t))}async getPinnedReflectionCount(){return(await this._getAllByMeta(t=>t[h.type]==="reflection"&&t[h.pinned]===!0)).length}async getHighConfidenceBeliefs(e){let t=Date.now();return(await this._getAllByMeta(r=>r[h.type]==="belief"&&r[h.confidence]==="high"&&!r[h.error]&&!(r[h.expiresAt]&&r[h.expiresAt]<t))).map(r=>{let s=this.chunkToBelief(r),i=(t-s.createdAt)/864e5,u=Math.exp(-i/fe)*ge+he.high*me+pe;return{...s,score:u}}).sort((r,s)=>s.score-r.score).slice(0,e)}async getRecentReflections(e,t){let n=Date.now()-e*864e5;return(await this._getAllByMeta(s=>s[h.type]==="reflection"&&!s[h.pinned]&&!s[h.error]&&s[h.createdAt]>=n)).map(s=>this.chunkToReflection(s)).sort((s,i)=>i.createdAt-s.createdAt).slice(0,t)}async keywordSearchGoals(e,t={}){let{limit:n=10,status:r="active",tags:s}=t,i;if(e.trim()&&typeof this.provider.keywordQuery=="function")i=(await this.provider.keywordQuery(e,{limit:n*2,threshold:0,filter:{[h.type]:"goal",[h.status]:r}})).map(u=>this.chunkToGoal(u.chunk));else{let a=r;if(i=(await this._getAllByMeta(c=>c[h.type]==="goal"&&c[h.status]===a)).map(c=>this.chunkToGoal(c)),e.trim()){let c=e.toLowerCase();i=i.filter(l=>l.description.toLowerCase().includes(c))}}return s?.length&&(i=i.filter(a=>s.every(u=>a.tags.includes(u)))),i.slice(0,n)}async queryBeliefs(e,t){let{limit:n=10,threshold:r=0,tags:s,includeExpired:i=!1}=t,a=Date.now(),u=await this.provider.query(e,{limit:n*4,threshold:0,filter:{[h.type]:"belief"}}),c=[];for(let l of u){let g=this.chunkToBelief(l.chunk);if(!i&&g.expiresAt&&g.expiresAt<a||s?.length&&!s.every(A=>g.tags.includes(A)))continue;let p=(a-g.createdAt)/864e5,m=Math.exp(-p/fe),w=g.error?.3:he[g.confidence],v=l.score*pe+m*ge+w*me;v<r||c.push({...g,score:v})}return c.sort((l,g)=>g.score-l.score).slice(0,n)}async queryReflections(e,t){let{limit:n=10,threshold:r=0,tags:s,pinned:i}=t,a=Date.now(),u={[h.type]:"reflection"};i===!0&&(u[h.pinned]=!0);let c=await this.provider.query(e,{limit:n*4,threshold:0,filter:u}),l=[];for(let g of c){let p=this.chunkToReflection(g.chunk);if(i===!1&&p.pinned||s?.length&&!s.every(A=>p.tags.includes(A)))continue;let m=(a-p.createdAt)/864e5,w=Math.exp(-m/fe),v=g.score*pe+w*ge+he.medium*me;v<r||l.push({...p,score:v})}return l.sort((g,p)=>p.score-g.score).slice(0,n)}async findSimilarBelief(e,t){let n=Date.now(),r=await this.provider.query(e,{limit:5,threshold:t,filter:{[h.type]:"belief"}});for(let s of r){let i=this.chunkToBelief(s.chunk);if(!(i.expiresAt&&i.expiresAt<n))return{id:s.chunk.id,score:s.score,belief:i}}return null}async addGoal(e){let t=ue();return await this.provider.add([this.goalToChunk({...e,id:t})]),t}async updateGoal(e,t){let n=await this._getById(e);if(!n)throw new Error(`[AgentMind] Goal not found: ${e}`);let r=this.chunkToGoal(n),s={...r,description:t.description??r.description,priority:t.priority??r.priority,status:t.status??r.status,outcome:t.outcome??r.outcome,progress:t.appendProgress?[...r.progress,t.appendProgress]:r.progress,updatedAt:Date.now()};await this.provider.add([this.goalToChunk(s)])}async completeGoal(e,t){let n=await this._getById(e);if(!n)throw new Error(`[AgentMind] Goal not found: ${e}`);let r=this.chunkToGoal(n);await this.provider.add([this.goalToChunk({...r,status:"completed",outcome:t??r.outcome,updatedAt:Date.now()})])}async addBelief(e,t){let n=ue();return await this.provider.add([this.beliefToChunk({...e,id:n},t)]),n}async updateBelief(e,t,n){let r=await this._getById(e);if(!r)throw new Error(`[AgentMind] Belief not found: ${e}`);let s=this.chunkToBelief(r),i={...s,content:t.content??s.content,confidence:t.confidence??s.confidence,tags:t.tags??s.tags,expiresAt:t.expiresAt!==void 0?t.expiresAt:s.expiresAt,error:t.error??s.error,updatedAt:Date.now()},a=n??r.vector??this.zeroVector;await this.provider.add([this.beliefToChunk(i,a)])}async addReflection(e,t){let n=ue();return await this.provider.add([this.reflectionToChunk({...e,id:n},t)]),n}async updateReflection(e,t){let n=await this._getById(e);if(!n)throw new Error(`[AgentMind] Reflection not found: ${e}`);let r=this.chunkToReflection(n),s={...r,pinned:t.pinned??r.pinned,error:t.error??r.error,updatedAt:Date.now()};await this.provider.add([this.reflectionToChunk(s,n.vector??this.zeroVector)])}goalToChunk(e){return{id:e.id,content:e.description,metadata:{[h.type]:"goal",[h.status]:e.status,[h.priority]:e.priority,[h.tags]:JSON.stringify(e.tags),[h.progress]:JSON.stringify(e.progress),[h.dueBy]:e.dueBy??"",[h.outcome]:e.outcome??"",[h.createdAt]:e.createdAt,[h.updatedAt]:e.updatedAt},vector:this.zeroVector}}chunkToGoal(e){let t=e.metadata;return{id:e.id,type:"goal",description:e.content,status:t[h.status],priority:t[h.priority],tags:this._parseTags(t[h.tags]),progress:this._parseTags(t[h.progress]),dueBy:t[h.dueBy]||void 0,outcome:t[h.outcome]||void 0,createdAt:t[h.createdAt],updatedAt:t[h.updatedAt]}}beliefToChunk(e,t){return{id:e.id,content:e.content,metadata:{[h.type]:"belief",[h.confidence]:e.confidence,[h.tags]:JSON.stringify(e.tags),[h.expiresAt]:e.expiresAt??0,[h.error]:e.error===!0,[h.createdAt]:e.createdAt,[h.updatedAt]:e.updatedAt},vector:t}}chunkToBelief(e){let t=e.metadata;return{id:e.id,type:"belief",content:e.content,confidence:t[h.confidence],tags:this._parseTags(t[h.tags]),expiresAt:t[h.expiresAt]||void 0,error:t[h.error]||void 0,createdAt:t[h.createdAt],updatedAt:t[h.updatedAt]}}reflectionToChunk(e,t){return{id:e.id,content:e.content,metadata:{[h.type]:"reflection",[h.pinned]:e.pinned,[h.tags]:JSON.stringify(e.tags),[h.relatedTo]:e.relatedTo??"",[h.error]:e.error===!0,[h.createdAt]:e.createdAt,[h.updatedAt]:e.updatedAt},vector:t}}chunkToReflection(e){let t=e.metadata;return{id:e.id,type:"reflection",content:e.content,pinned:t[h.pinned],tags:this._parseTags(t[h.tags]),relatedTo:t[h.relatedTo]||void 0,error:t[h.error]||void 0,createdAt:t[h.createdAt],updatedAt:t[h.updatedAt]}}async _getById(e){let t=await this.provider.getAllChunks?.();return t?t.find(n=>n.id===e)??null:null}async _getAllByMeta(e){return(await this.provider.getAllChunks?.()??[]).filter(n=>e(n.metadata))}_parseTags(e){try{let t=JSON.parse(e);return Array.isArray(t)?t:[]}catch{return[]}}}});function ye(o){let e=o.match(/^(\d+)(d|h|m|s)$/);if(!e)throw new Error(`Invalid duration format: "${o}". Expected a number followed by d/h/m/s (e.g., "30d", "24h").`);let t=parseInt(e[1],10),n=e[2];return t*{d:864e5,h:36e5,m:6e4,s:1e3}[n]}function Ze(o){if(/^\d{4}-\d{2}-\d{2}/.test(o))return o;let e=ye(o);return new Date(Date.now()+e).toISOString().slice(0,10)}function et(o,e){let t=0,n=0,r=0;for(let i=0;i<o.length;i++)t+=o[i]*e[i],n+=o[i]*o[i],r+=e[i]*e[i];let s=Math.sqrt(n)*Math.sqrt(r);return s===0?0:t/s}function ve(o){return Math.ceil(o.length/4)}var we=M(()=>{"use strict";d()});import{randomUUID as Ct}from"crypto";var K,tt=M(()=>{"use strict";d();we();K=class{constructor(e,t,n,r,s,i){this.store=e;this.deduplicationThreshold=t;this.maxGoals=n;this.maxPinnedReflections=r;this.committedGoalCount=s;this.committedPinnedReflectionCount=i}store;deduplicationThreshold;maxGoals;maxPinnedReflections;committedGoalCount;committedPinnedReflectionCount;ops=[];get draftGoalCount(){return this.ops.filter(e=>e.op==="set_goal").length}get draftPinnedReflectionCount(){return this.ops.filter(e=>e.op==="reflect"&&e.pinned).length}get totalGoalCount(){return this.committedGoalCount+this.draftGoalCount}get totalPinnedReflectionCount(){return this.committedPinnedReflectionCount+this.draftPinnedReflectionCount}async addBelieve(e){let t=Date.now(),n=await this.store.embed(e.content),r,s=e.expiresIn??e.ttlDefault;s&&(r=t+ye(s));let i=this._findSimilarInDraft(n);if(i!==null){let c=this.ops[i],l=e.confidence,g=c.confidence,p={low:0,medium:1,high:2},m=p[l]>p[g]||e.allowDowngrade&&p[l]<p[g];return this.ops[i]={...c,content:e.content,confidence:m?l:g,tags:e.tags.length>0?e.tags:c.tags,expiresAt:r,allowDowngrade:e.allowDowngrade,vector:n},{action:"updated_draft",id:c.existingId??`draft-${i}`}}let a=await this.store.findSimilarBelief(n,this.deduplicationThreshold);if(a){let c=a.belief,l=e.confidence,g=c.confidence,p={low:0,medium:1,high:2},m=p[l]>p[g]||e.allowDowngrade&&p[l]<p[g],w={op:"believe",content:e.content,confidence:m?l:g,tags:e.tags.length>0?e.tags:c.tags,expiresAt:r,allowDowngrade:e.allowDowngrade,createdAt:t,vector:n,existingId:a.id};return this.ops.push(w),{action:"updated_store",id:a.id}}let u={op:"believe",content:e.content,confidence:e.confidence,tags:e.tags,expiresAt:r,allowDowngrade:e.allowDowngrade,createdAt:t,vector:n};return this.ops.push(u),{action:"created",id:`draft-${this.ops.length-1}`}}async addReflect(e){let t;if(e.pinned){let i=this.totalPinnedReflectionCount;if(i>=this.maxPinnedReflections)throw new Error(`[AgentMind] Pinned reflection cap reached (${this.maxPinnedReflections}). Call mind_recall with type:'reflection' and pinned:true to list current pinned reflections, then call mind_unpin_reflection to remove one before adding another.`);i>=this.maxPinnedReflections-2&&(t=`Pinned reflection count is ${i+1} of ${this.maxPinnedReflections}. Review and unpin standing rules that are no longer universally applicable.`)}let n=await this.store.embed(e.content),r={op:"reflect",content:e.content,pinned:e.pinned,tags:e.tags,relatedTo:e.relatedTo,createdAt:Date.now(),vector:n},s=`draft-reflect-${this.ops.length}`;return this.ops.push(r),{id:s,warning:t}}addSetGoal(e){if(this.totalGoalCount>=this.maxGoals)throw new Error(`[AgentMind] Active goal cap reached (${this.maxGoals}). Complete or archive an existing goal before setting a new one.`);let t=e.dueBy?Ze(e.dueBy):void 0,n={op:"set_goal",tempId:Ct(),description:e.description,priority:e.priority,tags:e.tags,dueBy:t,createdAt:Date.now()};return this.ops.push(n),{id:n.tempId}}addUpdateGoal(e){let t={op:"update_goal",id:e.id,description:e.description,priority:e.priority,progress:e.progress,updatedAt:Date.now()};this.ops.push(t)}addUnpinReflection(e){let t={op:"unpin_reflection",id:e};this.ops.push(t)}async flushClean(){await this._flush(!1)}async flushOnError(){await this._flush(!0)}async _flush(e){let t=Date.now();for(let n of this.ops)if(n.op==="believe"){let r=n;e?r.existingId?await this.store.updateBelief(r.existingId,{content:r.content,confidence:r.confidence,tags:r.tags,expiresAt:r.expiresAt,error:!0},r.vector):await this.store.addBelief({type:"belief",content:r.content,confidence:r.confidence,tags:r.tags,expiresAt:r.expiresAt,error:!0,createdAt:r.createdAt,updatedAt:t},r.vector):r.existingId?await this.store.updateBelief(r.existingId,{content:r.content,confidence:r.confidence,tags:r.tags,expiresAt:r.expiresAt},r.vector):await this.store.addBelief({type:"belief",content:r.content,confidence:r.confidence,tags:r.tags,expiresAt:r.expiresAt,createdAt:r.createdAt,updatedAt:t},r.vector)}else if(n.op==="reflect"){let r=n;await this.store.addReflection({type:"reflection",content:r.content,pinned:r.pinned,tags:r.tags,relatedTo:r.relatedTo,error:e||void 0,createdAt:r.createdAt,updatedAt:t},r.vector)}else if(n.op==="set_goal"){if(!e){let r=n;await this.store.addGoal({type:"goal",description:r.description,priority:r.priority,status:"active",tags:r.tags,dueBy:r.dueBy,progress:[],createdAt:r.createdAt,updatedAt:r.createdAt})}}else if(n.op==="update_goal"){if(!e){let r=n;await this.store.updateGoal(r.id,{description:r.description,priority:r.priority,appendProgress:r.progress})}}else if(n.op==="unpin_reflection"&&!e){let r=n;await this.store.updateReflection(r.id,{pinned:!1})}this.ops=[]}_findSimilarInDraft(e){let t=this.ops.map((n,r)=>({op:n,idx:r})).filter(({op:n})=>n.op==="believe");for(let{op:n,idx:r}of t){let s=n;if(s.vector.length===0)continue;if(et(e,s.vector)>=this.deduplicationThreshold)return r}return null}}});function nt(o,e,t){return[kt(o,t),Rt(o,e,t),xt(e,t),St(e),Et(e,t),Tt(o,e),_t(o)]}function kt(o,e){return{name:"mind_recall",displayName:"Mind Recall",description:"Search the agent's persistent memory for past beliefs, reflections, and goals. Use mid-task when the current task may have relevant past context not in the header. Reads from committed store only \u2014 writes from the current run are not visible here.",category:"mind",cacheable:!1,parameters:{type:"object",properties:{query:{type:"string",description:"Free-text search query. Used for semantic search on beliefs/reflections and text matching on goals."},type:{type:"string",enum:["belief","reflection","goal","all"],description:"Entry type to search. Default: 'all'"},status:{type:"string",enum:["active","completed"],description:"For goal queries only. Default: 'active'"},tags:{type:"array",items:{type:"string"},description:"Filter to entries that have all of these tags."},pinned:{type:"boolean",description:"When true, return only pinned reflections. For type:'all', applies only to the reflection subset."},includeExpired:{type:"boolean",description:"Whether to include archived (expired) beliefs. Default: false"},threshold:{type:"number",description:"Composite score threshold override for this call (0\u20131). Results below this score are excluded. Silently ignored for goal queries."},limit:{type:"number",description:"Max entries to return. Default: 5"}},required:["query"]},execute:async t=>{let n=String(t.query??""),r=t.type??"all",s=t.status??"active",i=Array.isArray(t.tags)?t.tags.map(String):void 0,a=typeof t.pinned=="boolean"?t.pinned:void 0,u=t.includeExpired===!0,c=typeof t.threshold=="number"?t.threshold:e.retrievalThreshold,l=typeof t.limit=="number"?Math.max(1,Math.floor(t.limit)):5,g=[],m=(r==="belief"||r==="reflection"||r==="all")&&n.trim()?await o.embed(n):null;if(r==="goal"||r==="all"){let w=await o.keywordSearchGoals(n,{limit:l,status:s,tags:i});for(let v of w)g.push(Mt(v))}if(m&&(r==="belief"||r==="all")){let w=await o.queryBeliefs(m,{limit:l,threshold:c,tags:i,includeExpired:u});for(let v of w)g.push(Pt(v))}if(m&&(r==="reflection"||r==="all")){let w=await o.queryReflections(m,{limit:l,threshold:c,tags:i,pinned:a});for(let v of w)g.push(Dt(v))}return g}}}function Rt(o,e,t){return{name:"mind_believe",displayName:"Mind Believe",description:"Record a new belief about the operating environment, or update an existing one. Call at the end of a task when you have learned something that should persist across runs. Deduplicates automatically \u2014 if a similar belief already exists above the similarity threshold it is updated in place. Writes are buffered and committed when the task completes cleanly.",category:"mind",parameters:{type:"object",properties:{content:{type:"string",description:"The belief statement."},confidence:{type:"string",enum:["low","medium","high"],description:"Certainty at write time. Default: 'medium'"},tags:{type:"array",items:{type:"string"},description:"Tags for structured filtering via mind_recall."},expiresIn:{type:"string",description:"TTL override, e.g. '30d', '90d'. Overrides the agent default TTL."},allowDowngrade:{type:"boolean",description:"If true, allows confidence downgrade on an existing belief. Default: false."}},required:["content"]},execute:async n=>({status:"ok",...await e.addBelieve({content:String(n.content),confidence:n.confidence??"medium",tags:Array.isArray(n.tags)?n.tags.map(String):[],expiresIn:n.expiresIn?String(n.expiresIn):void 0,allowDowngrade:n.allowDowngrade===!0,ttlDefault:t.ttlDefaults.belief})})}}function xt(o,e){return{name:"mind_reflect",displayName:"Mind Reflect",description:"Log a post-task observation about your own performance. Reflections are append-only and not auto-injected (use pin:true to make a standing rule always shown in the header). Call at the end of a task with something you would do differently next time.",category:"mind",parameters:{type:"object",properties:{content:{type:"string",description:"The post-task observation."},pin:{type:"boolean",description:`If true, marks as a standing rule always shown in the header. Capped at ${e.maxPinnedReflections}. Default: false`},tags:{type:"array",items:{type:"string"},description:"Tags for structured filtering via mind_recall."},relatedTo:{type:"string",description:"Informational context (e.g., a PR number or task ID). Not filterable \u2014 use tags for that."}},required:["content"]},execute:async t=>({status:"ok",...await o.addReflect({content:String(t.content),pinned:t.pin===!0,tags:Array.isArray(t.tags)?t.tags.map(String):[],relatedTo:t.relatedTo?String(t.relatedTo):void 0})})}}function St(o){return{name:"mind_unpin_reflection",displayName:"Mind Unpin Reflection",description:"Remove the pin flag from a standing rule reflection. The reflection stays in the store as a regular non-pinned reflection. Use when a pinned rule is no longer universally applicable. Requires the reflection id \u2014 call mind_recall with type:reflection and pinned:true first.",category:"mind",parameters:{type:"object",properties:{id:{type:"string",description:"ID of the pinned reflection to unpin. Obtain via mind_recall."}},required:["id"]},execute:async e=>(o.addUnpinReflection(String(e.id)),{status:"ok"})}}function Et(o,e){return{name:"mind_set_goal",displayName:"Mind Set Goal",description:`Create a new active goal to track across sessions. No deduplication \u2014 call mind_recall with type:goal first to avoid re-creating existing goals. Goal cap is ${e.maxGoals} active goals; the call is rejected if the cap is reached.`,category:"mind",parameters:{type:"object",properties:{description:{type:"string",description:"The goal statement."},priority:{type:"string",enum:["low","normal","high"],description:"Goal priority. Default: 'normal'"},tags:{type:"array",items:{type:"string"},description:"Tags for filtering via mind_recall."},dueBy:{type:"string",description:"Optional deadline. ISO 8601 date (e.g., '2026-06-01') or duration string (e.g., '30d'). Metadata only \u2014 goals are not auto-archived."}},required:["description"]},execute:async t=>({status:"ok",...o.addSetGoal({description:String(t.description),priority:t.priority??"normal",tags:Array.isArray(t.tags)?t.tags.map(String):[],dueBy:t.dueBy?String(t.dueBy):void 0})})}}function Tt(o,e){return{name:"mind_update_goal",displayName:"Mind Update Goal",description:"Partially update an active goal \u2014 change priority, description, or append a progress note. Does not complete the goal; use mind_complete_goal for that. Requires the goal id \u2014 call mind_recall with type:goal first.",category:"mind",parameters:{type:"object",properties:{id:{type:"string",description:"ID of the goal to update. Obtain via mind_recall."},description:{type:"string",description:"Revised goal description."},priority:{type:"string",enum:["low","normal","high"],description:"Updated priority."},progress:{type:"string",description:"A progress note to append to the goal history. Not a replacement."}},required:["id"]},execute:async t=>(e.addUpdateGoal({id:String(t.id),description:t.description?String(t.description):void 0,priority:t.priority,progress:t.progress?String(t.progress):void 0}),{status:"ok"})}}function _t(o){return{name:"mind_complete_goal",displayName:"Mind Complete Goal",description:"Mark an active goal as completed and archive it. Commits immediately (does not go through the draft buffer). Completed goals are excluded from the header but remain queryable via mind_recall with status:completed. Requires the goal id \u2014 call mind_recall with type:goal first.",category:"mind",parameters:{type:"object",properties:{id:{type:"string",description:"ID of the goal to complete. Obtain via mind_recall with type:goal."},outcome:{type:"string",description:"Optional summary of what was accomplished."}},required:["id"]},execute:async e=>(await o.completeGoal(String(e.id),e.outcome?String(e.outcome):void 0),{status:"ok"})}}function Mt(o){return{id:o.id,type:"goal",content:o.description,tags:o.tags,createdAt:o.createdAt,updatedAt:o.updatedAt,priority:o.priority,status:o.status,progress:o.progress,outcome:o.outcome,dueBy:o.dueBy}}function Pt(o){return{id:o.id,type:"belief",content:o.content,score:o.score,tags:o.tags,createdAt:o.createdAt,updatedAt:o.updatedAt,confidence:o.confidence,expiresAt:o.expiresAt,error:o.error}}function Dt(o){return{id:o.id,type:"reflection",content:o.content,score:o.score,tags:o.tags,createdAt:o.createdAt,updatedAt:o.updatedAt,pinned:o.pinned,relatedTo:o.relatedTo,error:o.error}}var rt=M(()=>{"use strict";d()});async function st(o,e){let[t,n,r,s]=await Promise.all([o.getActiveGoals(),o.getPinnedReflections(),o.getHighConfidenceBeliefs(20),o.getRecentReflections(e.recencyWindowDays,3)]),i=t.map(g=>Ot(g)),a=n.map(g=>`- ${g.content}`),{beliefLines:u,reflectionLines:c}=Nt(r,s,e.tokenBudget);if(i.length===0&&a.length===0&&u.length===0&&c.length===0)return"";let l=["--- AGENT MIND ---",""];return i.length>0&&(l.push("## Goals"),l.push(...i),l.push("")),a.length>0&&(l.push("## Standing Rules (Pinned)"),l.push(...a),l.push("")),u.length>0&&(l.push("## Beliefs"),l.push(...u),l.push("")),c.length>0&&(l.push("## Recent Reflections"),l.push(...c),l.push("")),l.push("---"),l.join(`
|
|
2
|
+
`)}function Ot(o){let e=o.progress[o.progress.length-1],t=`[${o.priority}] ${o.description}`;return e&&(t+=` \u2014 last progress: ${e}`),o.dueBy&&(t+=` (due: ${o.dueBy})`),t}function Nt(o,e,t){let n=t,r=[],s=[];for(let i of o){let a=`- ${i.content} (${i.confidence} confidence)`,u=ve(a);if(u>n)break;r.push(a),n-=u}for(let i of e){let u=`- [${new Date(i.createdAt).toISOString().slice(0,10)}] ${i.content}`,c=ve(u);if(c>n)break;s.push(u),n-=c}return{beliefLines:r,reflectionLines:s}}var ot=M(()=>{"use strict";d();we()});var it={};yt(it,{AgentMind:()=>V});function qt(o,e){let t=Math.min(e.maxGoals??Bt,Jt),n=Math.min(e.maxPinnedReflections??Lt,zt);return{tokenBudget:e.tokenBudget??$t,recencyWindowDays:e.recencyWindowDays??jt,maxGoals:t,maxPinnedReflections:n,deduplicationThreshold:e.deduplicationThreshold??Ut,retrievalThreshold:e.retrievalThreshold??Ft,ttlDefaults:{belief:e.ttlDefaults?.belief??Gt,reflection:e.ttlDefaults?.reflection},namespace:e.namespace??`mind/${o}`}}var $t,jt,Bt,Lt,Ut,Ft,Gt,Jt,zt,V,Ae=M(()=>{"use strict";d();Qe();tt();rt();ot();$t=300,jt=7,Bt=10,Lt=10,Ut=.85,Ft=.35,Gt="30d",Jt=10,zt=10,V=class o{constructor(e,t){this.store=e;this.config=t}store;config;static async create(e,t){let n;if(t.provider)n=t.provider;else{let{PersistentKnowledgeProvider:i}=await import("@toolpack-sdk/knowledge"),a=t.namespace??`mind/${e}`;n=new i({namespace:a})}let r=qt(e,t),s=new W(n,t.embedder);return await s.initialize(),new o(s,r)}async createRunContext(){let[e,t,n]=await Promise.all([this.store.getActiveGoalCount(),this.store.getPinnedReflectionCount(),st(this.store,this.config)]),r=new K(this.store,this.config.deduplicationThreshold,this.config.maxGoals,this.config.maxPinnedReflections,e,t),s=nt(this.store,r,this.config);return{mindHeader:n,tools:s,flush:async a=>{a?await r.flushOnError():await r.flushClean()}}}async close(){this.store&&await Promise.resolve()}}});d();d();d();import{EventEmitter as Ht}from"events";import{Toolpack as Wt,InMemoryConversationStore as Kt}from"toolpack-sdk";d();d();var D=Symbol("interceptor-skip-sentinel");function _(o){return o===D}function J(){return D}var j=class extends Error{constructor(e,t){super(`Invocation depth ${e} exceeds maximum ${t}`),this.name="InvocationDepthExceededError"}};function z(o,e,t,n,r={}){let s=r.maxInvocationDepth??5;return{async execute(i){let u=(l=>({agent:e,channel:t,registry:n,invocationDepth:l,delegateAndWait:async(g,p)=>{let m=l+1;if(m>s)throw new j(m,s);if(!n)throw new Error(`Cannot delegate to "${g}": agent is running in standalone mode without a registry`);let w=n.getAgent(g);if(!w)throw new Error(`Agent "${g}" not found for delegation`);let v={message:p.message??"",intent:p.intent,data:p.data,context:p.context,conversationId:p.conversationId??i.conversationId??`delegation-${Date.now()}`};return await w.invokeAgent(v)},skip:J}))(0),c=async l=>{let g=l??i;return await e.invokeAgent(g)};for(let l=o.length-1;l>=0;l--){let g=o[l],p=c;c=async m=>await g(m??i,u,p)}return await c()}}}async function q(o,e){let t=await o.execute(e);return t===D?null:t}d();import{randomUUID as Ye}from"crypto";function vt(o){let e=o.context??{},t=e.channelType;return t==="im"||t==="private"||t==="dm"?"dm":e.threadId!==void 0?"thread":"channel"}var B=Symbol.for("toolpack:capture-history");function L(o){let e=o.captureAgentReplies??!0,t=o.getScope??vt,n=o.getMessageId??(i=>i.context?.messageId??i.context?.eventId??Ye()),r=o.getMentions??(i=>i.context?.mentions??[]),s=async(i,a,u)=>{let c=i.conversationId;if(!c)return a.logger?.warn("[capture-history] Message has no conversationId \u2014 skipping capture"),await u();let l=i.participant;if(l){let p={id:n(i),conversationId:c,participant:l,content:i.message??"",timestamp:new Date().toISOString(),scope:t(i),metadata:{channelType:i.context?.channelType,threadId:i.context?.threadId,messageId:i.context?.messageId,mentions:r(i),channelName:i.context?.channelName,channelId:i.context?.channelId}};try{await o.store.append(p),o.onCaptured?.(p),a.logger?.debug("[capture-history] Captured inbound message",{messageId:p.id,participantId:l.id,conversationId:c})}catch(m){a.logger?.warn("[capture-history] Failed to store inbound message",{error:m instanceof Error?m.message:String(m)})}}let g=await u();if(e&&!_(g)&&g.output!=null){let p={kind:"agent",id:a.agent.name,displayName:a.agent.name},m={id:Ye(),conversationId:c,participant:p,content:g.output,timestamp:new Date().toISOString(),scope:t(i),metadata:{channelType:i.context?.channelType,threadId:i.context?.threadId,channelName:i.context?.channelName,channelId:i.context?.channelId}};try{await o.store.append(m),o.onCaptured?.(m),a.logger?.debug("[capture-history] Captured agent reply",{messageId:m.id,agentId:a.agent.name,conversationId:c})}catch(w){a.logger?.warn("[capture-history] Failed to store agent reply",{error:w instanceof Error?w.message:String(w)})}}return g};return s[B]=!0,s}d();import{randomUUID as wt}from"crypto";function Xe(o){return Math.ceil(o.length/4)}function At(o){return{id:o.id,participant:o.participant,content:o.content,timestamp:o.timestamp}}function It(o,e){let{participant:t,content:n}=o;return t.kind==="system"?{role:"system",content:n}:t.kind==="agent"?t.id===e?{role:"assistant",content:n}:{role:"user",content:`${t.displayName??t.id} (agent): ${n}`}:{role:"user",content:`${t.displayName??t.id}: ${n}`}}function bt(o,e,t){return!!(o.participant.id===e||o.metadata?.mentions?.some(n=>t.has(n)))}async function H(o,e,t,n,r={},s){let{scope:i,addressedOnlyMode:a=!0,tokenBudget:u=3e3,rollingSummaryThreshold:c=40,timeWindowMinutes:l,maxTurnsToLoad:g=100,agentAliases:p}=r,m=new Set([t,...p??[]]),w=l!==void 0?new Date(Date.now()-l*60*1e3).toISOString():void 0,v=await o.get(e,{scope:i,sinceTimestamp:w,limit:g}),A=v.length;if(a){let R=new Set;for(let x=0;x<v.length;x++){let $=v[x];if(bt($,t,m)&&R.add($.id),x<v.length-1){let P=v[x+1];P.participant.kind==="agent"&&P.participant.id===t&&R.add($.id)}}let T=v[v.length-1];T&&R.add(T.id),v=v.filter(x=>R.has(x.id))}let k=!1;if(v.length>c&&s){let R=Math.floor(v.length/2),T=v.slice(0,R),x=v.slice(R),$=T.filter(P=>!P.metadata?.isSummary);try{let P=await s.invokeAgent({message:"summarize",data:{turns:$.map(At),agentName:n,agentId:t,maxTokens:Math.floor(u*.25),extractDecisions:!0}}),Ke=JSON.parse(P.output),Ve={id:`summary-${wt()}`,conversationId:e,participant:{kind:"system",id:"summarizer"},content:`[Summary of ${Ke.turnsSummarized} earlier turns]: ${Ke.summary}`,timestamp:T[0].timestamp,scope:i??"channel",metadata:{isSummary:!0}};v=[Ve,...x],k=!0;try{await o.append(Ve),await o.deleteMessages(e,T.map(ht=>ht.id))}catch{}}catch{v=v.slice(-c)}}else v.length>c&&(v=v.slice(-c));let E=v.map(R=>It(R,t));if(E.length===0)return{messages:[],estimatedTokens:0,turnsLoaded:A,hasSummary:k};let G=E[E.length-1],We=[G],le=Xe(G.content);for(let R=E.length-2;R>=0;R--){let T=E[R],x=Xe(T.content);if(le+x>u)break;We.unshift(T),le+=x}return{messages:We,estimatedTokens:le,turnsLoaded:A,hasSummary:k}}d();var I=class extends Error{constructor(e){super(e),this.name="AgentError"}};var C=class extends Ht{provider;model;workflow;mind;delegation;conversationHistory;assemblerOptions;channels=[];interceptors=[];_registry;_triggeringChannel;_conversationId;_isTriggerChannel;toolpack;_initConfig;_ownedToolpack=!1;_conversationLocks=new Map;_mind;_mindInitPromise;constructor(e){super(),this.conversationHistory=new Kt,"toolpack"in e?this.toolpack=e.toolpack:this._initConfig=e}async _ensureToolpack(){if(!this.toolpack){if(!this._initConfig)throw new Error(`[${this.name??"agent"}] Cannot start: no apiKey or toolpack provided`);this.toolpack=await Wt.init({provider:this._initConfig.provider??"anthropic",apiKey:this._initConfig.apiKey,model:this._initConfig.model}),this._ownedToolpack=!0}}async _ensureMind(){this._mind!==void 0||!this.mind||(this._mindInitPromise||(this._mindInitPromise=(async()=>{let{AgentMind:e}=await Promise.resolve().then(()=>(Ae(),it));this._mind=await e.create(this.name,this.mind)})().catch(e=>{throw this._mindInitPromise=void 0,e})),await this._mindInitPromise)}async start(){await this._ensureToolpack(),this.mode&&(typeof this.mode=="string"?this.toolpack.setMode(this.mode):(this.toolpack.registerMode(this.mode),this.toolpack.setMode(this.mode.name)));for(let e of this.channels)this._bindChannel(e),e.listen()}async stop(){for(let e of this.channels)"stop"in e&&typeof e.stop=="function"&&await e.stop();this._ownedToolpack&&await this.toolpack.disconnect?.()}async run(e,t,n){let r=n?.conversationId??this._conversationId;await this.onBeforeRun({message:e,conversationId:r}),this.emit("agent:start",{message:e}),await this._ensureMind();let s,i="",a=[];if(this._mind){let u=await this._mind.createRunContext();i=u.mindHeader,a=u.tools,s=u.flush}try{typeof this.mode=="string"?this.toolpack.setMode(this.mode):(this.toolpack.registerMode(this.mode),this.toolpack.setMode(this.mode.name));let u=[];if(i&&u.push({role:"system",content:i}),r)try{let p=await H(this.conversationHistory,r,this.name,this.name,this._resolveAssemblerOptions()),m=p.messages[p.messages.length-1],w=e.trim(),A=w!==""&&m?.role==="user"&&typeof m.content=="string"&&(m.content===w||m.content.endsWith(`: ${w}`))?p.messages.slice(0,-1):p.messages;u.push(...A)}catch{}e.trim()&&u.push({role:"user",content:e});let c=[...a];if(r){let p=this.conversationHistory;c.push({name:"conversation_search",displayName:"Conversation Search",description:"Search past conversation history for specific information, questions, or topics mentioned earlier in this conversation.",category:"search",parameters:{type:"object",properties:{query:{type:"string",description:"Keywords or phrases to search for in conversation history."},limit:{type:"number",description:"Maximum number of results to return (default: 5)."}},required:["query"]},execute:async m=>{let w=await p.search(r,String(m.query??""),{limit:typeof m.limit=="number"?m.limit:5});return{results:w.map(v=>({role:v.participant.kind==="agent"?"assistant":"user",content:v.content,timestamp:v.timestamp})),count:w.length}}})}if(this.delegation?.enabled&&this._registry){let p=this.delegation.allowedAgents,m=this._registry.getAllAgents().filter(w=>w.name!==this.name&&(p===void 0||p.includes(w.name)));if(m.length>0){let w=m.map(A=>A.name),v=m.map(A=>`- ${A.name}: ${A.description}`).join(`
|
|
3
|
+
`);this.delegation.mode==="forget"?c.push({name:"delegate_and_forget",displayName:"Delegate and Forget",description:`Hand off the current task to a peer agent. The agent will handle its own delivery (e.g. posting to Slack or GitHub) \u2014 you do not need to relay its response. Call this ONCE, then output an empty string.
|
|
4
4
|
|
|
5
5
|
Available agents:
|
|
6
|
-
${
|
|
6
|
+
${v}`,category:"agent",parameters:{type:"object",properties:{agent:{type:"string",enum:w,description:"Name of the agent to delegate to."},message:{type:"string",description:"The task or message to pass to the agent."}},required:["agent","message"]},execute:async A=>{let k=String(A.agent),E=String(A.message??"");return this._registry.invoke(k,{message:E,conversationId:r,context:{delegatedBy:this.name}}).catch(G=>{console.error(`[${this.name}] delegate_and_forget to ${k} failed:`,G)}),{status:"delegated",agent:k}}}):c.push({name:"delegate_to_agent",displayName:"Delegate to Agent",description:`Hand off the current task to a peer agent and return its result. Use when the task falls outside your own specialisation.
|
|
7
7
|
|
|
8
8
|
Available agents:
|
|
9
|
-
${
|
|
9
|
+
${v}`,category:"agent",parameters:{type:"object",properties:{agent:{type:"string",enum:w,description:"Name of the agent to delegate to."},message:{type:"string",description:"The task or message to pass to the agent."}},required:["agent","message"]},execute:async A=>{let k=String(A.agent),E=String(A.message??"");return this._registry.invoke(k,{message:E,conversationId:r,context:{delegatedBy:this.name}})}})}}let l=await this.toolpack.generate({messages:u,model:this.model||"",requestTools:c.length>0?c:void 0,maxToolRounds:t?.maxToolRounds},this.provider),g={output:l.content||"",steps:this.extractSteps(l),metadata:l.usage?{usage:l.usage}:void 0};return await this.onComplete(g),s&&await s(!1),this.emit("agent:complete",g),g}catch(u){throw s&&s(!0).catch(c=>{console.error(`[${this.name??"agent"}][AgentMind] Draft buffer flush on error failed:`,c)}),await this.onError(u),this.emit("agent:error",u),u}}getAgentAliases(){let e=[];for(let t of this.channels){let n=t.botUserId;n&&e.push(n)}return e}async sendTo(e,t){if(!this._registry)throw new Error("Agent not registered - _registry not set");await this._registry.sendTo(e,{output:t})}async ask(e,t){if(!this._registry)throw new I("Agent not registered - cannot use ask()");if(!this._conversationId)throw new I("No conversationId available - ask() requires a conversation channel");if(this._isTriggerChannel)throw new I("this.ask() called from a trigger channel (ScheduledChannel). Trigger channels have no human recipient \u2014 use a conversation channel (Slack, Telegram, Webhook) instead.");if(!this._triggeringChannel||this._triggeringChannel.trim()==="")throw new I("Cannot use ask() - no triggering channel available. The channel must have a name registered with AgentRegistry.");let n=this._registry.addPendingAsk({conversationId:this._conversationId,agentName:this.name,question:e,context:t?.context??{},maxRetries:t?.maxRetries??2,expiresAt:t?.expiresIn?new Date(Date.now()+t.expiresIn):void 0,channelName:this._triggeringChannel});return await this.sendTo(this._triggeringChannel,e),{output:e,metadata:{waitingForHuman:!0,askId:n.id}}}getPendingAsk(e){if(!this._registry)return null;let t=e??this._conversationId;return t?this._registry.getPendingAsk(t)??null:null}async resolvePendingAsk(e,t){if(!this._registry)throw new I("Agent not registered - cannot resolve ask");await this._registry.resolvePendingAsk(e,t)}async evaluateAnswer(e,t,n){return n?.simpleValidation?n.simpleValidation(t):(await this.run(`Evaluate if this answer sufficiently addresses the question.
|
|
10
10
|
|
|
11
11
|
Question: "${e}"
|
|
12
12
|
Answer: "${t}"
|
|
13
13
|
|
|
14
|
-
Is this answer sufficient? Reply with ONLY "yes" or "no".`,{workflow:{mode:"single-shot"}})).output.toLowerCase().trim().startsWith("yes")}async handlePendingAsk(e,t,n,r){return await this.evaluateAnswer(e.question,t,{simpleValidation:o=>o.trim().length>3})?(await this.resolvePendingAsk(e.id,t),n(t)):e.retries>=e.maxRetries?(await this.resolvePendingAsk(e.id,"__insufficient__"),this._triggeringChannel&&await this.sendTo(this._triggeringChannel,"I was unable to get enough information to proceed. Skipping this step."),r?r():{output:"Step skipped due to insufficient input.",metadata:{skipped:!0,askId:e.id}}):(this._registry?.incrementRetries(e.id),this.ask(`I need a bit more clarity on: "${e.question}". Could you provide more details?`,{context:e.context,maxRetries:e.maxRetries}))}async delegateAndWait(e,t){if(!this._registry)throw new A("Agent not registered - cannot use delegateAndWait()");let n={message:t.message,intent:t.intent,data:t.data,context:{...t.context||{},delegatedBy:this.name},conversationId:t.conversationId||this._conversationId||`delegation-${Date.now()}`};return await this._registry.invoke(e,n)}async onBeforeRun(e){}async onComplete(e){}async onError(e){}_resolveAssemblerOptions(){let e=this.channels.map(r=>r.botUserId).filter(r=>typeof r=="string"&&r.length>0),t=this.assemblerOptions?.agentAliases??[];if(e.length===0&&t.length===0)return this.assemblerOptions;let n=Array.from(new Set([...t,...e]));return{...this.assemblerOptions,agentAliases:n}}_getEffectiveInterceptors(){return this.interceptors.some(t=>t[j]===!0)?this.interceptors:[B({store:this.conversationHistory}),...this.interceptors]}_bindChannel(e){e.onMessage(async t=>{if(!t.conversationId){console.warn(`[${this.name}] Message received without conversationId \u2014 skipping`);return}let n=await this._acquireConversationLock(t.conversationId);try{this._triggeringChannel=e.name,this._isTriggerChannel=e.isTriggerChannel,this._conversationId=t.conversationId;let r=z(this._getEffectiveInterceptors(),this,e,this._registry??null),i=await J(r,t);if(i===null)return;let o={output:i.output,metadata:i.metadata};await e.send({output:o.output,metadata:{...o.metadata,conversationId:t.conversationId,...t.context}})}catch(r){let i=r instanceof Error?r.message:"Unknown error occurred";console.error(`[${this.name}] Error in agent invocation: ${i}`);try{await e.send({output:`Error: ${i}`,metadata:{conversationId:t.conversationId,error:!0,...t.context}})}catch(o){console.error(`[${this.name}] Failed to send error to channel: ${o}`)}}finally{n()}})}async _acquireConversationLock(e){for(;this._conversationLocks.has(e);)try{await this._conversationLocks.get(e)}catch{}let t,n=new Promise(r=>{t=r});return this._conversationLocks.set(e,n),()=>{this._conversationLocks.delete(e),t()}}extractSteps(e){let t=e;if(t.plan&&typeof t.plan=="object"){let n=t.plan;if(Array.isArray(n.steps))return n.steps.map(r=>({number:r.number||0,description:r.description||"",status:r.status||"completed",result:r.result}))}if(Array.isArray(t.steps))return t.steps}};d();import{randomUUID as Ot}from"crypto";d();import{randomUUID as Ye}from"crypto";var M=class{constructor(e){this.registry=e}registry;async invoke(e,t){let n=this.registry.getAgent(e);if(!n)throw new A(`Agent "${e}" not found in registry. Available agents: ${this.registry.getAllAgents().map(l=>l.name).join(", ")}`);let r=n.conversationHistory,i=t.conversationId,o=t.context?.delegatedBy;if(r&&i&&o){let l={id:t.context?.messageId??Ye(),conversationId:i,participant:{kind:"agent",id:o,displayName:o},content:t.message??"",timestamp:new Date().toISOString(),scope:"channel",metadata:{}};try{await r.append(l)}catch{}}let c=await n.invokeAgent(t);if(r&&i){let l={id:Ye(),conversationId:i,participant:{kind:"agent",id:e,displayName:e},content:c.output,timestamp:new Date().toISOString(),scope:"channel",metadata:{}};try{await r.append(l)}catch{}}return c}};var pe=class{agentList;instances=new Map;channels=new Map;_transport;pendingAsks=new Map;constructor(e,t){this.agentList=e,this._transport=t?.transport||new M(this)}async start(){for(let e of this.agentList){await e._ensureToolpack(),e._registry=this,this.instances.set(e.name,e);for(let t of e.channels??[])t.name&&this.channels.set(t.name,t)}for(let e of this.agentList)await e.start()}async sendTo(e,t){let n=this.channels.get(e);if(!n)throw new Error(`No channel registered with name "${e}"`);await n.send(t)}getAgent(e){return this.instances.get(e)}getAllAgents(){return Array.from(this.instances.values())}getChannel(e){return this.channels.get(e)}async invoke(e,t){return this._transport.invoke(e,t)}async stop(){for(let e of this.agentList)await e.stop();this.instances.clear(),this.channels.clear(),this.pendingAsks.clear()}getPendingAsk(e){let t=this.pendingAsks.get(e);if(!t||t.length===0)return;let n=new Date;for(;t.length>0;){let r=t[0];if(r.expiresAt&&r.expiresAt<n)t.shift();else break}if(t.length===0){this.pendingAsks.delete(e);return}return t[0]}hasPendingAsks(e){let t=this.pendingAsks.get(e);if(!t||t.length===0)return!1;let n=new Date,r=t.filter(i=>!i.expiresAt||i.expiresAt>=n);return r.length===0?(this.pendingAsks.delete(e),!1):(r.length!==t.length&&this.pendingAsks.set(e,r),r.some(i=>i.status==="pending"))}cleanupExpiredAsks(){let e=0,t=new Date;for(let[n,r]of this.pendingAsks.entries()){let i=r.filter(o=>!o.expiresAt||o.expiresAt>=t);e+=r.length-i.length,i.length===0?this.pendingAsks.delete(n):i.length!==r.length&&this.pendingAsks.set(n,i)}return e}addPendingAsk(e){let t={...e,id:Ot(),askedAt:new Date,retries:0,status:"pending"},n=this.pendingAsks.get(e.conversationId);return n?n.push(t):this.pendingAsks.set(e.conversationId,[t]),t}incrementRetries(e){for(let t of this.pendingAsks.values()){let n=t.find(r=>r.id===e);if(n)return n.retries+=1,n.retries}}async resolvePendingAsk(e,t){for(let[n,r]of this.pendingAsks.entries()){let i=r.findIndex(o=>o.id===e);if(i!==-1){r[i].status="answered",r[i].answer=t;let o=r[i].channelName;if(r.splice(i,1),r.length>0){let c=r[0];if(o&&o.trim()!=="")try{await this.sendTo(o,{output:c.question})}catch(l){console.error(`[AgentRegistry] Failed to auto-send next ask: ${l instanceof Error?l.message:"Unknown error"}`)}else console.warn(`[AgentRegistry] Cannot auto-send next ask: channelName is empty for conversation ${n}`)}r.length===0&&this.pendingAsks.delete(n);return}}throw new Error(`Pending ask with id "${e}" not found`)}};d();import{AGENT_MODE as $t}from"toolpack-sdk";var jt={...$t,name:"research-agent-mode",systemPrompt:["You are a research agent specialized in web research and information gathering.","Use web.search to find relevant information, web.fetch to retrieve content, and web.scrape when needed.","Always cite your sources with URLs.","Provide comprehensive, well-structured summaries.","Flag any conflicting information or uncertainty in your findings."].join(" ")},ue=class extends C{name="research-agent";description="Web research agent for summarization, fact-finding, competitive analysis, and trend monitoring";mode=jt;constructor(e){super(e)}async invokeAgent(e){let t=await this.run(e.message||"",void 0,{conversationId:e.conversationId});return await this.onComplete(t),t}};d();import{CODING_MODE as Bt}from"toolpack-sdk";var Lt={...Bt,name:"coding-agent-mode",systemPrompt:["You are a coding agent specialized in software development tasks.","Use coding.* tools for code analysis, fs.* for file operations, and git.* for version control.","Write clean, idiomatic code following best practices.","Always verify your changes and check for potential issues.","Provide clear explanations of your code changes."].join(" ")},ge=class extends C{name="coding-agent";description="Coding agent for code generation, refactoring, debugging, test writing, and code review";mode=Lt;constructor(e){super(e)}async invokeAgent(e){let t=await this.run(e.message||"",void 0,{conversationId:e.conversationId});return await this.onComplete(t),t}};d();import{AGENT_MODE as Ut}from"toolpack-sdk";var Ft={...Ut,name:"data-agent-mode",systemPrompt:["You are a data agent specialized in database operations and data analysis.","Use db.* tools for database queries, fs.* for file operations, and http.* for API requests.","Generate clear, well-formatted reports and summaries.","Always validate data integrity and handle errors gracefully.","Provide insights and patterns when analyzing data."].join(" ")},he=class extends C{name="data-agent";description="Data agent for database queries, CSV generation, data analysis, reporting, and aggregation";mode=Ft;constructor(e){super(e)}async invokeAgent(e){let t=await this.run(e.message||"",void 0,{conversationId:e.conversationId});return await this.onComplete(t),t}};d();import{CHAT_MODE as Gt}from"toolpack-sdk";var zt={...Gt,name:"browser-agent-mode",systemPrompt:["You are a browser agent specialized in web interaction and content extraction.","Use web.fetch to retrieve pages, web.screenshot for visual content, and web.extract_links for navigation.","Follow links intelligently to gather comprehensive information.","Extract structured data from web pages when possible.","Be mindful of rate limits and respectful of website resources."].join(" ")},me=class extends C{name="browser-agent";description="Browser agent for web browsing, form interaction, page extraction, and link following";mode=zt;constructor(e){super(e)}async invokeAgent(e){let t=await this.run(e.message||"",void 0,{conversationId:e.conversationId});return await this.onComplete(t),t}};d();var b=class{name;_handler;onMessage(e){this._handler=e}async handleMessage(e){this._handler&&await this._handler(e)}};d();import{createHmac as Jt,timingSafeEqual as Ht}from"crypto";var fe=class extends b{isTriggerChannel=!1;config;server;participantCache=new Map;botUserId;allowedChannels;constructor(e){super(),this.config={port:3e3,...e},this.name=e.name;let t=e.channel;this.allowedChannels=t==null?null:Array.isArray(t)?t:[t]}listen(){typeof process<"u"&&import("http").then(e=>{this.server=e.createServer((t,n)=>{this.handleRequest(t,n)}),this.server.listen(this.config.port,()=>{console.log(`[SlackChannel] Listening on port ${this.config.port}`),this.runStartupCheck().catch(()=>{})})}).catch(e=>{console.error("[SlackChannel] Failed to start HTTP server:",e)})}async runStartupCheck(){try{let t=await(await fetch("https://slack.com/api/auth.test",{method:"POST",headers:{Authorization:`Bearer ${this.config.token}`,"Content-Type":"application/json"}})).json();t.ok?(this.botUserId=t.user_id,console.log(`[SlackChannel] Connected as @${t.user} (${t.user_id}) in workspace "${t.team}" \u2014 ${t.url}`)):console.warn(`[SlackChannel] auth.test failed: ${t.error}. Check your bot token.`)}catch(e){console.warn("[SlackChannel] Startup self-check failed (network error):",e)}}verifySignature(e,t){let n=e["x-slack-request-timestamp"],r=e["x-slack-signature"];if(!n||!r||Array.isArray(n)||Array.isArray(r))return!1;let i=parseInt(n,10),o=Math.floor(Date.now()/1e3);if(isNaN(i)||Math.abs(o-i)>300)return!1;let c=`v0:${n}:${t}`,a=`v0=${Jt("sha256",this.config.signingSecret).update(c).digest("hex")}`;if(a.length!==r.length)return!1;try{return Ht(Buffer.from(a),Buffer.from(r))}catch{return!1}}async send(e){let t=e.metadata?.threadTs??e.metadata?.thread_ts??e.metadata?.threadId,r=e.metadata?.channelId??(this.allowedChannels&&this.allowedChannels.length>0?this.allowedChannels[0]:void 0);if(!r)throw new Error("[SlackChannel] Cannot send: no channel configured and metadata.channelId is missing. Provide a target via SlackChannelConfig.channel or output.metadata.channelId.");let i={channel:r,text:e.output};t&&(i.thread_ts=t);let o=await fetch("https://slack.com/api/chat.postMessage",{method:"POST",headers:{Authorization:`Bearer ${this.config.token}`,"Content-Type":"application/json"},body:JSON.stringify(i)});if(!o.ok)throw new Error(`Failed to send Slack message: ${o.statusText}`);let c=await o.json();if(!c.ok)throw new Error(`Slack API error: ${c.error}`)}normalize(e){let t=e,r=(t.text||"").replace(/<(https?:\/\/[^|>]+)\|([^>]+)>/g,"$2 ($1)").replace(/<(https?:\/\/[^>]+)>/g,"$1").replace(/<!here>/g,"@here").replace(/<!channel>/g,"@channel").replace(/<!everyone>/g,"@everyone"),i=t.ts,o=t.thread_ts,c=o!==void 0&&o!==i,l=t.user,a=l?{kind:"user",id:l}:void 0,p=/<@([A-Z0-9]+)>/g,m=[],h;for(;(h=p.exec(r))!==null;)m.push(h[1]);let u=t.channel;return{message:r,conversationId:c?o:u||i||"",data:t,participant:a,context:{user:l,channel:u,team:t.team,channelType:t.channel_type,threadId:c?o:void 0,mentions:m.length>0?m:void 0,channelId:u,channelName:typeof this.config.channel=="string"?this.config.channel:u}}}async resolveParticipant(e){let t=e.participant?.id??e.context?.user;if(!t)return;let n=this.participantCache.get(t);if(n)return n;try{let r=await fetch(`https://slack.com/api/users.info?user=${encodeURIComponent(t)}`,{method:"GET",headers:{Authorization:`Bearer ${this.config.token}`}});if(!r.ok)return{kind:"user",id:t};let i=await r.json();if(!i.ok||!i.user){let l={kind:"user",id:t};return this.participantCache.set(t,l),l}let o=i.user.profile?.display_name||i.user.profile?.real_name||i.user.real_name||i.user.name||t,c={kind:"user",id:t,displayName:o,metadata:{slackUser:i.user}};return this.participantCache.set(t,c),c}catch{return{kind:"user",id:t}}}invalidateParticipant(e){this.participantCache.delete(e)}shouldProcessEvent(e){let t=e.type;if(t!=="message"&&t!=="app_mention")return!1;if(this.allowedChannels!==null){let o=e.channel_type;if(!(o==="im"||o==="mpim")){let l=e.channel;if(!l||!this.allowedChannels.includes(l))return!1}}let n=e.user;if(this.botUserId&&n===this.botUserId)return!1;let r=e.bot_id;if(!r)return!0;let i=this.config.blockedBotIds??[];if(i.includes(r)||n!==void 0&&i.includes(n))return!1;if(this.config.allowedBotIds!==void 0){let o=this.config.allowedBotIds;return o.includes(r)||n!==void 0&&o.includes(n)}return!0}handleRequest(e,t){if(e.method!=="POST"){t.writeHead(405),t.end("Method not allowed");return}let n="";e.on("data",r=>{n+=r.toString()}),e.on("end",()=>{if(!this.verifySignature(e.headers,n)){t.writeHead(401),t.end("Invalid signature");return}try{let r=JSON.parse(n);if(r.type==="url_verification"){t.writeHead(200,{"Content-Type":"application/json"}),t.end(JSON.stringify({challenge:r.challenge}));return}if(r.type==="event_callback"&&r.event){let i=r.event;if(this.shouldProcessEvent(i)){let o=this.normalize(i);this.handleMessage(o)}else i.type==="user_change"&&i.user&&this.invalidateParticipant(i.user.id);t.writeHead(200),t.end("OK");return}t.writeHead(200),t.end("OK")}catch(r){console.error("[SlackChannel] Error handling request:",r),t.writeHead(400),t.end("Bad request")}})}async stop(){if(this.server)return new Promise(e=>{this.server.close(e)})}};d();var ye=class extends b{isTriggerChannel=!1;config;server;pendingResponses=new Map;constructor(e){super(),this.name=e.name,this.config={port:e.port??3e3,path:e.path??"/webhook"}}listen(){typeof process<"u"&&import("http").then(e=>{this.server=e.createServer((t,n)=>{this.handleRequest(t,n)}),this.server.listen(this.config.port,()=>{console.log(`[WebhookChannel] Listening on port ${this.config.port}${this.config.path}`)})}).catch(e=>{console.error("[WebhookChannel] Failed to start HTTP server:",e)})}async send(e){let t=e.metadata?.conversationId;if(t&&this.pendingResponses.has(t)){let n=this.pendingResponses.get(t);this.pendingResponses.delete(t),n.resolve({output:e.output,metadata:e.metadata})}}normalize(e){let t=e,n=t.headers||{},r=n["x-session-id"]||n["X-Session-Id"]||t.sessionId||t.conversationId||this.generateSessionId();return{message:t.message||t.text||"",intent:t.intent,conversationId:r,data:t,context:{headers:t.headers,method:t.method,sessionId:r}}}handleRequest(e,t){if(e.url!==this.config.path){t.writeHead(404),t.end("Not found");return}if(e.method!=="POST"){t.writeHead(405),t.end("Method not allowed");return}let n="";e.on("data",r=>{n+=r.toString()}),e.on("end",()=>{try{let r=JSON.parse(n),i=this.normalize(r),o=i.conversationId||this.generateSessionId(),c=new Promise((l,a)=>{this.pendingResponses.set(o,{resolve:l,reject:a}),setTimeout(()=>{this.pendingResponses.has(o)&&(this.pendingResponses.delete(o),a(new Error("Agent response timeout")))},3e4)});this.handleMessage({...i,conversationId:o,context:{...i.context,sessionId:o}}),c.then(l=>{t.writeHead(200,{"Content-Type":"application/json"}),t.end(JSON.stringify(l))}).catch(l=>{t.writeHead(500,{"Content-Type":"application/json"}),t.end(JSON.stringify({error:l.message}))})}catch(r){console.error("[WebhookChannel] Error handling request:",r),t.writeHead(400,{"Content-Type":"application/json"}),t.end(JSON.stringify({error:"Bad request"}))}})}generateSessionId(){return`webhook-${Date.now()}-${Math.random().toString(36).substring(2,9)}`}async stop(){if(this.server)return new Promise(e=>{this.server.close(e)})}};d();import{CronExpressionParser as Ve}from"cron-parser";var we=class extends b{isTriggerChannel=!0;config;timer;_stopped=!1;_generation=0;constructor(e){if(super(),!e.cron&&!e.store)throw new Error("ScheduledChannel: provide at least one of `cron` (static schedule) or `store` (dynamic scheduling).");if(e.cron)try{Ve.parse(e.cron)}catch(t){throw new Error(`ScheduledChannel: invalid cron expression '${e.cron}': ${t.message}`)}if(e.store&&!e.name&&console.warn("[ScheduledChannel] A `store` was provided without a `name`. All store queries will be unscoped and will pick up jobs from every channel. Set `name` to scope this channel to its own jobs."),e.idlePollMs!==void 0&&e.idlePollMs<1e3)throw new Error(`ScheduledChannel: idlePollMs must be at least 1000ms (got ${e.idlePollMs}). Values below 1 second create a tight polling loop.`);this.config=e,this.name=e.name}listen(){this._generation++,this.timer&&(clearTimeout(this.timer),this.timer=void 0),this._stopped=!1,this.config.store?this._listenWithStore():this._listenStatic()}async stop(){this._stopped=!0,this.timer&&(clearTimeout(this.timer),this.timer=void 0)}async send(e){}normalize(e){let t=e,n=new Date,r=`${n.getFullYear()}-${n.getMonth()+1}-${n.getDate()}`;return{intent:t?.intent??this.config.intent,message:t?.message??this.config.message??`Scheduled task triggered at ${n.toISOString()}`,conversationId:`scheduled:${this.name??"default"}:${r}`,data:{...t?.payload??{},scheduled:!0,jobId:t?.id,cron:t?.cron??this.config.cron,timestamp:n.toISOString()}}}_listenStatic(){this._scheduleNextStatic(this._generation)}_scheduleNextStatic(e){if(this._stopped||e!==this._generation)return;let t=this._nextRunFromCron(this.config.cron),n=t.getTime()-Date.now();if(n<=0){this.timer=setTimeout(()=>this._scheduleNextStatic(e),0);return}console.log(`[ScheduledChannel:${this.name??"default"}] Next run: ${t.toISOString()}`),this.timer=setTimeout(async()=>{this._stopped||e!==this._generation||(await this._triggerStatic(),this._scheduleNextStatic(e))},n)}async _triggerStatic(){if(!this._handler){console.warn(`[ScheduledChannel:${this.name??"default"}] Cron fired but no message handler is registered. Call onMessage() before listen() to avoid silently losing triggers.`);return}let e=this.normalize(null);try{await this.handleMessage(e)}catch(t){console.error(`[ScheduledChannel:${this.name??"default"}] Error on trigger:`,t)}}_listenWithStore(){let e=this.config.store,t=this._generation;if(t===1){let r=e.resetStuck(this.name);r>0&&console.log(`[ScheduledChannel:${this.name??"default"}] Reset ${r} stuck 'running' job(s) to 'pending'.`)}if(this.config.cron){let{duplicate:r}=e.create({channelName:this.name,cron:this.config.cron,intent:this.config.intent,message:this.config.message});r||console.log(`[ScheduledChannel:${this.name??"default"}] Seeded static cron '${this.config.cron}' into store.`)}let n=e.getDue(Date.now(),this.name);n.length>0&&(console.log(`[ScheduledChannel:${this.name??"default"}] Recovering ${n.length} overdue job(s).`),Promise.allSettled(n.map(r=>this._triggerJob(r)))),this._scheduleNextFromStore(t)}_scheduleNextFromStore(e){if(this._stopped||e!==this._generation)return;let t=this.config.store,n=t.getNextPending(this.name);if(!n){let i=this.config.idlePollMs??3e4;this.timer=setTimeout(()=>this._scheduleNextFromStore(e),i);return}let r=Math.max(0,n.nextRunAt-Date.now());console.log(`[ScheduledChannel:${this.name??"default"}] Next store job at ${new Date(n.nextRunAt).toISOString()} (in ${Math.round(r/1e3)}s)`),this.timer=setTimeout(async()=>{if(this._stopped||e!==this._generation)return;let i=t.getDue(Date.now(),this.name);await Promise.allSettled(i.map(o=>this._triggerJob(o))),this._scheduleNextFromStore(e)},r)}async _triggerJob(e){let t=this.config.store;if(!this._handler){console.warn(`[ScheduledChannel:${this.name??"default"}] Job ${e.id} fired but no message handler is registered. Call onMessage() before listen() to avoid silently losing jobs.`),t.markFailed(e.id,"No message handler registered");return}t.markRunning(e.id);let n=this.normalize(e);try{await this.handleMessage(n),t.markCompleted(e.id)}catch(r){let i=r instanceof Error?r.message:String(r);console.error(`[ScheduledChannel:${this.name??"default"}] Job ${e.id} failed:`,r),t.markFailed(e.id,i)}}_nextRunFromCron(e){return Ve.parse(e,{currentDate:new Date}).next().toDate()}};d();var ve=class extends b{isTriggerChannel=!1;config;offset=0;pollingInterval;server;botUserId;botUsername;constructor(e){super(),this.name=e.name,this.config=e}listen(){this.runStartupCheck().catch(()=>{}),this.config.webhookUrl?this.startWebhook():this.startPolling()}async runStartupCheck(){try{let t=await(await fetch(`https://api.telegram.org/bot${this.config.token}/getMe`)).json();if(t.ok&&t.result){let n=t.result;this.botUserId=n.id!=null?String(n.id):void 0,this.botUsername=n.username,console.log(`[TelegramChannel] Connected as @${n.username} (id: ${n.id}, name: ${n.first_name})`)}else console.warn(`[TelegramChannel] getMe failed: ${t.description??"unknown error"}. Check your bot token.`)}catch(e){console.warn("[TelegramChannel] Startup self-check failed (network error):",e)}}async send(e){let t=e.metadata?.chatId;if(!t)throw new Error("Telegram send requires chatId in metadata");let n=await fetch(`https://api.telegram.org/bot${this.config.token}/sendMessage`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({chat_id:t,text:e.output,parse_mode:"Markdown"})});if(!n.ok)throw new Error(`Failed to send Telegram message: ${n.statusText}`);let r=await n.json();if(!r.ok)throw new Error(`Telegram API error: ${r.description}`)}normalize(e){let t=e,n=t.message||t.edited_message||{},r=n.text||"",i=n.chat||{},o=n.from||{},c=o.id!=null?String(o.id):void 0,l=o.first_name||o.username||c,a=c?{kind:"user",id:c,displayName:l??c}:void 0,p=n.entities??[],m=[];for(let v of p)if(v.type==="text_mention"&&v.user){let f=v.user;f.id!=null&&m.push(String(f.id))}let h=i.type,u=i.id!=null?String(i.id):"";return{message:r,conversationId:u,data:t,participant:a,context:{chatId:i.id,userId:o.id,username:o.username,firstName:o.first_name,lastName:o.last_name,messageId:n.message_id,channelType:h,channelId:u,channelName:i.title,mentions:m.length>0?m:void 0}}}startPolling(){console.log("[TelegramChannel] Starting polling mode"),this.pollingInterval=setInterval(async()=>{try{await this.pollUpdates()}catch(e){console.error("[TelegramChannel] Polling error:",e)}},5e3)}async pollUpdates(){let e=`https://api.telegram.org/bot${this.config.token}/getUpdates?offset=${this.offset}&limit=100`,t=await fetch(e);if(!t.ok)throw new Error(`Telegram getUpdates failed: ${t.statusText}`);let n=await t.json();if(!n.ok)throw new Error("Telegram getUpdates returned not ok");for(let r of n.result){let i=r.update_id;i>=this.offset&&(this.offset=i+1);try{let o=this.normalize(r);await this.handleMessage(o)}catch(o){console.error("[TelegramChannel] Error processing update:",o)}}}startWebhook(){typeof process>"u"||(console.log("[TelegramChannel] Starting webhook mode"),import("http").then(e=>{this.server=e.createServer((r,i)=>{this.handleWebhookRequest(r,i)});let t=new URL(this.config.webhookUrl||"http://localhost:3000"),n=parseInt(t.port,10)||3e3;this.server.listen(n,()=>{console.log(`[TelegramChannel] Webhook server listening on port ${n}`)}),this.setWebhook()}).catch(e=>{console.error("[TelegramChannel] Failed to start webhook server:",e)}))}async setWebhook(){if(!this.config.webhookUrl)return;let e=await fetch(`https://api.telegram.org/bot${this.config.token}/setWebhook`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({url:this.config.webhookUrl})});if(!e.ok){console.error("[TelegramChannel] Failed to set webhook");return}let t=await e.json();t.ok?console.log("[TelegramChannel] Webhook set successfully"):console.error("[TelegramChannel] Failed to set webhook:",t.description)}handleWebhookRequest(e,t){if(e.method!=="POST"){t.writeHead(405),t.end("Method not allowed");return}let n="";e.on("data",r=>{n+=r.toString()}),e.on("end",()=>{try{let r=JSON.parse(n);this.handleMessage(this.normalize(r)).catch(i=>{console.error("[TelegramChannel] Error processing webhook:",i)}),t.writeHead(200),t.end("OK")}catch(r){console.error("[TelegramChannel] Error parsing webhook:",r),t.writeHead(400),t.end("Bad request")}})}async stop(){if(this.pollingInterval&&(clearInterval(this.pollingInterval),this.pollingInterval=void 0),this.server)return new Promise(e=>{this.server.close(e)});if(this.config.webhookUrl)try{await fetch(`https://api.telegram.org/bot${this.config.token}/deleteWebhook`,{method:"POST"})}catch(e){console.error("[TelegramChannel] Failed to delete webhook:",e)}}};d();var qt=new Set([1,3]),Xe=/<@!?(\d+)>/g,Wt="https://discord.com/api/v10",Ie=class extends b{isTriggerChannel=!1;config;allowedChannelIds;botUserId;participantCache=new Map;client;constructor(e){super(),this.config=e,this.name=e.name,e.channelId==null?this.allowedChannelIds=new Set:Array.isArray(e.channelId)?this.allowedChannelIds=new Set(e.channelId):this.allowedChannelIds=new Set([e.channelId])}shouldProcessEvent(e){return!e.author||e.webhookId||this.botUserId&&e.author.id===this.botUserId||this.config.guildId&&e.guildId!==this.config.guildId||this.allowedChannelIds.size>0&&(!e.channelId||!this.allowedChannelIds.has(e.channelId))?!1:e.author.bot||e.author.system?this.config.blockedBotIds?.includes(e.author.id)?!1:this.config.allowedBotIds?this.config.allowedBotIds.includes(e.author.id):!1:!0}normalize(e){let t=e,n=t.channelId,r=(n??"")+(t.thread?.id?`:${t.thread.id}`:""),i=t.channel?.type,o=i!==void 0&&qt.has(i),c=t.author?.id,l=t.author?.globalName??t.author?.username,a=[];if(t.content){Xe.lastIndex=0;let p;for(;(p=Xe.exec(t.content))!==null;)a.push(p[1])}return{message:t.content,conversationId:r,data:t,participant:c?{kind:"user",id:c,displayName:l??void 0}:void 0,context:{userId:c,username:t.author?.username,channelType:o?"dm":"channel",channelId:n,channelName:t.channel?.name,guildId:t.guildId,threadId:t.thread?.id,messageId:t.id,mentions:a.length>0?a:void 0,isMentioned:this.botUserId?a.includes(this.botUserId):void 0}}}async resolveParticipant(e){let t=e.participant?.id??e.context?.userId;if(!t)return;let n=this.participantCache.get(t);if(n)return n;try{let r=await fetch(`${Wt}/users/${t}`,{headers:{Authorization:`Bot ${this.config.token}`}});if(!r.ok)return console.warn(`[DiscordChannel] Failed to resolve user ${t}: HTTP ${r.status}`),{kind:"user",id:t};let i=await r.json(),o=i.global_name??i.username,c={kind:"user",id:i.id,displayName:o};return this.participantCache.set(t,c),c}catch(r){return console.warn(`[DiscordChannel] resolveParticipant error for ${t}:`,r),{kind:"user",id:t}}}invalidateParticipant(e){this.participantCache.delete(e)}async send(e){if(!this.client)throw new Error("[DiscordChannel] Client not initialized. Did you call listen()?");let t=e.metadata?.threadId;if(t){let i=await this.client.channels.fetch(t);if(i&&"send"in i)try{await i.send({content:e.output});return}catch(o){throw console.error("[DiscordChannel] Failed to send to thread:",o),new Error(`[DiscordChannel] Failed to send Discord message: ${o instanceof Error?o.message:String(o)}`)}console.warn(`[DiscordChannel] Thread ${t} not found or not sendable; falling back to channel send.`)}let n=e.metadata?.channelId??(this.allowedChannelIds.size>0?[...this.allowedChannelIds][0]:void 0);if(!n)throw new Error("[DiscordChannel] No channel ID available for sending. Configure channelId or pass output.metadata.channelId.");let r=await this.client.channels.fetch(n);if(!r||!("send"in r))throw new Error(`[DiscordChannel] Channel ${n} not found or is not a text channel`);try{await r.send({content:e.output})}catch(i){throw console.error("[DiscordChannel] Failed to send to channel:",i),new Error(`[DiscordChannel] Failed to send Discord message: ${i instanceof Error?i.message:String(i)}`)}}listen(){typeof process>"u"||import("discord.js").then(e=>{let{Client:t,GatewayIntentBits:n}=e;this.client=new t({intents:[n.Guilds,n.GuildMessages,n.MessageContent,n.DirectMessages]}),this.client.on("ready",()=>{let r=this.client.user;this.botUserId=r?.id;let i=this.allowedChannelIds.size===0?"all channels":[...this.allowedChannelIds].join(", "),o=this.config.guildId??"all guilds";console.log(`[DiscordChannel] Logged in as ${r?.tag??"unknown"} (botUserId=${this.botUserId??"unknown"}) | guild=${o} | channels=${i}`)}),this.client.on("messageCreate",r=>{let i=r;if(!this.shouldProcessEvent(i))return;let o=this.normalize(i);this.handleMessage(o)}),this.client.on("userUpdate",(r,i)=>{let o=i;o?.id&&this.invalidateParticipant(o.id)}),this.client.login(this.config.token).catch(r=>{console.error("[DiscordChannel] Failed to login to Discord:",r)})}).catch(e=>{console.error("[DiscordChannel] Failed to initialize Discord client:",e),console.error("[DiscordChannel] Make sure discord.js is installed: npm install discord.js")})}async stop(){this.client&&(await this.client.destroy(),this.client=void 0)}};d();var Ae=class extends b{isTriggerChannel=!0;config;transporter;constructor(e){super(),this.config=e,this.name=e.name}listen(){typeof process<"u"&&import("nodemailer").then(e=>{this.transporter=e.default.createTransport({host:this.config.smtp.host,port:this.config.smtp.port,secure:this.config.smtp.secure??this.config.smtp.port===465,auth:{user:this.config.smtp.auth.user,pass:this.config.smtp.auth.pass}}),console.log(`[EmailChannel] Email transporter initialized for ${this.config.from}`)}).catch(e=>{console.error("[EmailChannel] Failed to initialize nodemailer:",e),console.error("[EmailChannel] Make sure to install nodemailer: npm install nodemailer")})}async send(e){if(!this.transporter)throw new Error("Email transporter not initialized. Did you call listen()?");let t=Array.isArray(this.config.to)?this.config.to:[this.config.to],n=this.config.subject||"Message from Agent",r={from:this.config.from,to:t.join(", "),subject:n,text:e.output,html:this.formatAsHtml(e.output)};try{await this.transporter.sendMail(r)}catch(i){throw console.error("[EmailChannel] Failed to send email:",i),new Error(`Failed to send email: ${i instanceof Error?i.message:String(i)}`)}}normalize(e){throw new Error("EmailChannel is outbound-only. Use WebhookChannel with email webhook events for inbound email.")}formatAsHtml(e){return e.split(`
|
|
14
|
+
Is this answer sufficient? Reply with ONLY "yes" or "no".`,{workflow:{mode:"single-shot"}})).output.toLowerCase().trim().startsWith("yes")}async handlePendingAsk(e,t,n,r){return await this.evaluateAnswer(e.question,t,{simpleValidation:i=>i.trim().length>3})?(await this.resolvePendingAsk(e.id,t),n(t)):e.retries>=e.maxRetries?(await this.resolvePendingAsk(e.id,"__insufficient__"),this._triggeringChannel&&await this.sendTo(this._triggeringChannel,"I was unable to get enough information to proceed. Skipping this step."),r?r():{output:"Step skipped due to insufficient input.",metadata:{skipped:!0,askId:e.id}}):(this._registry?.incrementRetries(e.id),this.ask(`I need a bit more clarity on: "${e.question}". Could you provide more details?`,{context:e.context,maxRetries:e.maxRetries}))}async delegateAndWait(e,t){if(!this._registry)throw new I("Agent not registered - cannot use delegateAndWait()");let n={message:t.message,intent:t.intent,data:t.data,context:{...t.context||{},delegatedBy:this.name},conversationId:t.conversationId||this._conversationId||`delegation-${Date.now()}`};return await this._registry.invoke(e,n)}async onBeforeRun(e){}async onComplete(e){}async onError(e){}_resolveAssemblerOptions(){let e=this.channels.map(r=>r.botUserId).filter(r=>typeof r=="string"&&r.length>0),t=this.assemblerOptions?.agentAliases??[];if(e.length===0&&t.length===0)return this.assemblerOptions;let n=Array.from(new Set([...t,...e]));return{...this.assemblerOptions,agentAliases:n}}_getEffectiveInterceptors(){return this.interceptors.some(t=>t[B]===!0)?this.interceptors:[L({store:this.conversationHistory}),...this.interceptors]}_bindChannel(e){e.onMessage(async t=>{if(!t.conversationId){console.warn(`[${this.name}] Message received without conversationId \u2014 skipping`);return}let n=await this._acquireConversationLock(t.conversationId);try{this._triggeringChannel=e.name,this._isTriggerChannel=e.isTriggerChannel,this._conversationId=t.conversationId;let r=z(this._getEffectiveInterceptors(),this,e,this._registry??null),s=await q(r,t);if(s===null)return;let i={output:s.output,metadata:s.metadata};await e.send({output:i.output,metadata:{...i.metadata,conversationId:t.conversationId,...t.context}})}catch(r){let s=r instanceof Error?r.message:"Unknown error occurred";console.error(`[${this.name}] Error in agent invocation: ${s}`);try{await e.send({output:`Error: ${s}`,metadata:{conversationId:t.conversationId,error:!0,...t.context}})}catch(i){console.error(`[${this.name}] Failed to send error to channel: ${i}`)}}finally{n()}})}async _acquireConversationLock(e){for(;this._conversationLocks.has(e);)try{await this._conversationLocks.get(e)}catch{}let t,n=new Promise(r=>{t=r});return this._conversationLocks.set(e,n),()=>{this._conversationLocks.delete(e),t()}}extractSteps(e){let t=e;if(t.plan&&typeof t.plan=="object"){let n=t.plan;if(Array.isArray(n.steps))return n.steps.map(r=>({number:r.number||0,description:r.description||"",status:r.status||"completed",result:r.result}))}if(Array.isArray(t.steps))return t.steps}};d();import{randomUUID as Vt}from"crypto";d();import{randomUUID as at}from"crypto";var O=class{constructor(e){this.registry=e}registry;async invoke(e,t){let n=this.registry.getAgent(e);if(!n)throw new I(`Agent "${e}" not found in registry. Available agents: ${this.registry.getAllAgents().map(u=>u.name).join(", ")}`);let r=n.conversationHistory,s=t.conversationId,i=t.context?.delegatedBy;if(r&&s&&i){let u={id:t.context?.messageId??at(),conversationId:s,participant:{kind:"agent",id:i,displayName:i},content:t.message??"",timestamp:new Date().toISOString(),scope:"channel",metadata:{}};try{await r.append(u)}catch{}}let a=await n.invokeAgent(t);if(r&&s){let u={id:at(),conversationId:s,participant:{kind:"agent",id:e,displayName:e},content:a.output,timestamp:new Date().toISOString(),scope:"channel",metadata:{}};try{await r.append(u)}catch{}}return a}};var Ie=class{agentList;instances=new Map;channels=new Map;_transport;pendingAsks=new Map;constructor(e,t){this.agentList=e,this._transport=t?.transport||new O(this)}async start(){for(let e of this.agentList){await e._ensureToolpack(),e._registry=this,this.instances.set(e.name,e);for(let t of e.channels??[])t.name&&this.channels.set(t.name,t)}for(let e of this.agentList)await e.start()}async sendTo(e,t){let n=this.channels.get(e);if(!n)throw new Error(`No channel registered with name "${e}"`);await n.send(t)}getAgent(e){return this.instances.get(e)}getAllAgents(){return Array.from(this.instances.values())}getChannel(e){return this.channels.get(e)}async invoke(e,t){return this._transport.invoke(e,t)}async stop(){for(let e of this.agentList)await e.stop();this.instances.clear(),this.channels.clear(),this.pendingAsks.clear()}getPendingAsk(e){let t=this.pendingAsks.get(e);if(!t||t.length===0)return;let n=new Date;for(;t.length>0;){let r=t[0];if(r.expiresAt&&r.expiresAt<n)t.shift();else break}if(t.length===0){this.pendingAsks.delete(e);return}return t[0]}hasPendingAsks(e){let t=this.pendingAsks.get(e);if(!t||t.length===0)return!1;let n=new Date,r=t.filter(s=>!s.expiresAt||s.expiresAt>=n);return r.length===0?(this.pendingAsks.delete(e),!1):(r.length!==t.length&&this.pendingAsks.set(e,r),r.some(s=>s.status==="pending"))}cleanupExpiredAsks(){let e=0,t=new Date;for(let[n,r]of this.pendingAsks.entries()){let s=r.filter(i=>!i.expiresAt||i.expiresAt>=t);e+=r.length-s.length,s.length===0?this.pendingAsks.delete(n):s.length!==r.length&&this.pendingAsks.set(n,s)}return e}addPendingAsk(e){let t={...e,id:Vt(),askedAt:new Date,retries:0,status:"pending"},n=this.pendingAsks.get(e.conversationId);return n?n.push(t):this.pendingAsks.set(e.conversationId,[t]),t}incrementRetries(e){for(let t of this.pendingAsks.values()){let n=t.find(r=>r.id===e);if(n)return n.retries+=1,n.retries}}async resolvePendingAsk(e,t){for(let[n,r]of this.pendingAsks.entries()){let s=r.findIndex(i=>i.id===e);if(s!==-1){r[s].status="answered",r[s].answer=t;let i=r[s].channelName;if(r.splice(s,1),r.length>0){let a=r[0];if(i&&i.trim()!=="")try{await this.sendTo(i,{output:a.question})}catch(u){console.error(`[AgentRegistry] Failed to auto-send next ask: ${u instanceof Error?u.message:"Unknown error"}`)}else console.warn(`[AgentRegistry] Cannot auto-send next ask: channelName is empty for conversation ${n}`)}r.length===0&&this.pendingAsks.delete(n);return}}throw new Error(`Pending ask with id "${e}" not found`)}};d();import{AGENT_MODE as Yt}from"toolpack-sdk";var Xt={...Yt,name:"research-agent-mode",systemPrompt:["You are a research agent specialized in web research and information gathering.","Use web.search to find relevant information, web.fetch to retrieve content, and web.scrape when needed.","Always cite your sources with URLs.","Provide comprehensive, well-structured summaries.","Flag any conflicting information or uncertainty in your findings."].join(" ")},be=class extends C{name="research-agent";description="Web research agent for summarization, fact-finding, competitive analysis, and trend monitoring";mode=Xt;constructor(e){super(e)}async invokeAgent(e){let t=await this.run(e.message||"",void 0,{conversationId:e.conversationId});return await this.onComplete(t),t}};d();import{CODING_MODE as Qt}from"toolpack-sdk";var Zt={...Qt,name:"coding-agent-mode",systemPrompt:["You are a coding agent specialized in software development tasks.","Use coding.* tools for code analysis, fs.* for file operations, and git.* for version control.","Write clean, idiomatic code following best practices.","Always verify your changes and check for potential issues.","Provide clear explanations of your code changes."].join(" ")},Ce=class extends C{name="coding-agent";description="Coding agent for code generation, refactoring, debugging, test writing, and code review";mode=Zt;constructor(e){super(e)}async invokeAgent(e){let t=await this.run(e.message||"",void 0,{conversationId:e.conversationId});return await this.onComplete(t),t}};d();import{AGENT_MODE as en}from"toolpack-sdk";var tn={...en,name:"data-agent-mode",systemPrompt:["You are a data agent specialized in database operations and data analysis.","Use db.* tools for database queries, fs.* for file operations, and http.* for API requests.","Generate clear, well-formatted reports and summaries.","Always validate data integrity and handle errors gracefully.","Provide insights and patterns when analyzing data."].join(" ")},ke=class extends C{name="data-agent";description="Data agent for database queries, CSV generation, data analysis, reporting, and aggregation";mode=tn;constructor(e){super(e)}async invokeAgent(e){let t=await this.run(e.message||"",void 0,{conversationId:e.conversationId});return await this.onComplete(t),t}};d();import{CHAT_MODE as nn}from"toolpack-sdk";var rn={...nn,name:"browser-agent-mode",systemPrompt:["You are a browser agent specialized in web interaction and content extraction.","Use web.fetch to retrieve pages, web.screenshot for visual content, and web.extract_links for navigation.","Follow links intelligently to gather comprehensive information.","Extract structured data from web pages when possible.","Be mindful of rate limits and respectful of website resources."].join(" ")},Re=class extends C{name="browser-agent";description="Browser agent for web browsing, form interaction, page extraction, and link following";mode=rn;constructor(e){super(e)}async invokeAgent(e){let t=await this.run(e.message||"",void 0,{conversationId:e.conversationId});return await this.onComplete(t),t}};d();var b=class{name;_handler;onMessage(e){this._handler=e}async handleMessage(e){this._handler&&await this._handler(e)}};d();import{createHmac as sn,timingSafeEqual as on}from"crypto";var xe=class extends b{isTriggerChannel=!1;config;server;participantCache=new Map;botUserId;allowedChannels;constructor(e){super(),this.config={port:3e3,...e},this.name=e.name;let t=e.channel;this.allowedChannels=t==null?null:Array.isArray(t)?t:[t]}listen(){typeof process<"u"&&import("http").then(e=>{this.server=e.createServer((t,n)=>{this.handleRequest(t,n)}),this.server.listen(this.config.port,()=>{console.log(`[SlackChannel] Listening on port ${this.config.port}`),this.runStartupCheck().catch(()=>{})})}).catch(e=>{console.error("[SlackChannel] Failed to start HTTP server:",e)})}async runStartupCheck(){try{let t=await(await fetch("https://slack.com/api/auth.test",{method:"POST",headers:{Authorization:`Bearer ${this.config.token}`,"Content-Type":"application/json"}})).json();t.ok?(this.botUserId=t.user_id,console.log(`[SlackChannel] Connected as @${t.user} (${t.user_id}) in workspace "${t.team}" \u2014 ${t.url}`)):console.warn(`[SlackChannel] auth.test failed: ${t.error}. Check your bot token.`)}catch(e){console.warn("[SlackChannel] Startup self-check failed (network error):",e)}}verifySignature(e,t){let n=e["x-slack-request-timestamp"],r=e["x-slack-signature"];if(!n||!r||Array.isArray(n)||Array.isArray(r))return!1;let s=parseInt(n,10),i=Math.floor(Date.now()/1e3);if(isNaN(s)||Math.abs(i-s)>300)return!1;let a=`v0:${n}:${t}`,c=`v0=${sn("sha256",this.config.signingSecret).update(a).digest("hex")}`;if(c.length!==r.length)return!1;try{return on(Buffer.from(c),Buffer.from(r))}catch{return!1}}async send(e){let t=e.metadata?.threadTs??e.metadata?.thread_ts??e.metadata?.threadId,r=e.metadata?.channelId??(this.allowedChannels&&this.allowedChannels.length>0?this.allowedChannels[0]:void 0);if(!r)throw new Error("[SlackChannel] Cannot send: no channel configured and metadata.channelId is missing. Provide a target via SlackChannelConfig.channel or output.metadata.channelId.");let s={channel:r,text:e.output};t&&(s.thread_ts=t);let i=await fetch("https://slack.com/api/chat.postMessage",{method:"POST",headers:{Authorization:`Bearer ${this.config.token}`,"Content-Type":"application/json"},body:JSON.stringify(s)});if(!i.ok)throw new Error(`Failed to send Slack message: ${i.statusText}`);let a=await i.json();if(!a.ok)throw new Error(`Slack API error: ${a.error}`)}normalize(e){let t=e,r=(t.text||"").replace(/<(https?:\/\/[^|>]+)\|([^>]+)>/g,"$2 ($1)").replace(/<(https?:\/\/[^>]+)>/g,"$1").replace(/<!here>/g,"@here").replace(/<!channel>/g,"@channel").replace(/<!everyone>/g,"@everyone"),s=t.ts,i=t.thread_ts,a=i!==void 0&&i!==s,u=t.user,c=u?{kind:"user",id:u}:void 0,l=/<@([A-Z0-9]+)>/g,g=[],p;for(;(p=l.exec(r))!==null;)g.push(p[1]);let m=t.channel;return{message:r,conversationId:a?i:m||s||"",data:t,participant:c,context:{user:u,channel:m,team:t.team,channelType:t.channel_type,threadId:a?i:void 0,mentions:g.length>0?g:void 0,channelId:m,channelName:typeof this.config.channel=="string"?this.config.channel:m}}}async resolveParticipant(e){let t=e.participant?.id??e.context?.user;if(!t)return;let n=this.participantCache.get(t);if(n)return n;try{let r=await fetch(`https://slack.com/api/users.info?user=${encodeURIComponent(t)}`,{method:"GET",headers:{Authorization:`Bearer ${this.config.token}`}});if(!r.ok)return{kind:"user",id:t};let s=await r.json();if(!s.ok||!s.user){let u={kind:"user",id:t};return this.participantCache.set(t,u),u}let i=s.user.profile?.display_name||s.user.profile?.real_name||s.user.real_name||s.user.name||t,a={kind:"user",id:t,displayName:i,metadata:{slackUser:s.user}};return this.participantCache.set(t,a),a}catch{return{kind:"user",id:t}}}invalidateParticipant(e){this.participantCache.delete(e)}shouldProcessEvent(e){let t=e.type;if(t!=="message"&&t!=="app_mention")return!1;if(this.allowedChannels!==null){let i=e.channel_type;if(!(i==="im"||i==="mpim")){let u=e.channel;if(!u||!this.allowedChannels.includes(u))return!1}}let n=e.user;if(this.botUserId&&n===this.botUserId)return!1;let r=e.bot_id;if(!r)return!0;let s=this.config.blockedBotIds??[];if(s.includes(r)||n!==void 0&&s.includes(n))return!1;if(this.config.allowedBotIds!==void 0){let i=this.config.allowedBotIds;return i.includes(r)||n!==void 0&&i.includes(n)}return!0}handleRequest(e,t){if(e.method!=="POST"){t.writeHead(405),t.end("Method not allowed");return}let n="";e.on("data",r=>{n+=r.toString()}),e.on("end",()=>{if(!this.verifySignature(e.headers,n)){t.writeHead(401),t.end("Invalid signature");return}try{let r=JSON.parse(n);if(r.type==="url_verification"){t.writeHead(200,{"Content-Type":"application/json"}),t.end(JSON.stringify({challenge:r.challenge}));return}if(r.type==="event_callback"&&r.event){let s=r.event;if(this.shouldProcessEvent(s)){let i=this.normalize(s);this.handleMessage(i)}else s.type==="user_change"&&s.user&&this.invalidateParticipant(s.user.id);t.writeHead(200),t.end("OK");return}t.writeHead(200),t.end("OK")}catch(r){console.error("[SlackChannel] Error handling request:",r),t.writeHead(400),t.end("Bad request")}})}async stop(){if(this.server)return new Promise(e=>{this.server.close(e)})}};d();var Se=class extends b{isTriggerChannel=!1;config;server;pendingResponses=new Map;constructor(e){super(),this.name=e.name,this.config={port:e.port??3e3,path:e.path??"/webhook"}}listen(){typeof process<"u"&&import("http").then(e=>{this.server=e.createServer((t,n)=>{this.handleRequest(t,n)}),this.server.listen(this.config.port,()=>{console.log(`[WebhookChannel] Listening on port ${this.config.port}${this.config.path}`)})}).catch(e=>{console.error("[WebhookChannel] Failed to start HTTP server:",e)})}async send(e){let t=e.metadata?.conversationId;if(t&&this.pendingResponses.has(t)){let n=this.pendingResponses.get(t);this.pendingResponses.delete(t),n.resolve({output:e.output,metadata:e.metadata})}}normalize(e){let t=e,n=t.headers||{},r=n["x-session-id"]||n["X-Session-Id"]||t.sessionId||t.conversationId||this.generateSessionId();return{message:t.message||t.text||"",intent:t.intent,conversationId:r,data:t,context:{headers:t.headers,method:t.method,sessionId:r}}}handleRequest(e,t){if(e.url!==this.config.path){t.writeHead(404),t.end("Not found");return}if(e.method!=="POST"){t.writeHead(405),t.end("Method not allowed");return}let n="";e.on("data",r=>{n+=r.toString()}),e.on("end",()=>{try{let r=JSON.parse(n),s=this.normalize(r),i=s.conversationId||this.generateSessionId(),a=new Promise((u,c)=>{this.pendingResponses.set(i,{resolve:u,reject:c}),setTimeout(()=>{this.pendingResponses.has(i)&&(this.pendingResponses.delete(i),c(new Error("Agent response timeout")))},3e4)});this.handleMessage({...s,conversationId:i,context:{...s.context,sessionId:i}}),a.then(u=>{t.writeHead(200,{"Content-Type":"application/json"}),t.end(JSON.stringify(u))}).catch(u=>{t.writeHead(500,{"Content-Type":"application/json"}),t.end(JSON.stringify({error:u.message}))})}catch(r){console.error("[WebhookChannel] Error handling request:",r),t.writeHead(400,{"Content-Type":"application/json"}),t.end(JSON.stringify({error:"Bad request"}))}})}generateSessionId(){return`webhook-${Date.now()}-${Math.random().toString(36).substring(2,9)}`}async stop(){if(this.server)return new Promise(e=>{this.server.close(e)})}};d();import{CronExpressionParser as ct}from"cron-parser";var Ee=class extends b{isTriggerChannel=!0;config;timer;_stopped=!1;_generation=0;constructor(e){if(super(),!e.cron&&!e.store)throw new Error("ScheduledChannel: provide at least one of `cron` (static schedule) or `store` (dynamic scheduling).");if(e.cron)try{ct.parse(e.cron)}catch(t){throw new Error(`ScheduledChannel: invalid cron expression '${e.cron}': ${t.message}`)}if(e.store&&!e.name&&console.warn("[ScheduledChannel] A `store` was provided without a `name`. All store queries will be unscoped and will pick up jobs from every channel. Set `name` to scope this channel to its own jobs."),e.idlePollMs!==void 0&&e.idlePollMs<1e3)throw new Error(`ScheduledChannel: idlePollMs must be at least 1000ms (got ${e.idlePollMs}). Values below 1 second create a tight polling loop.`);this.config=e,this.name=e.name}listen(){this._generation++,this.timer&&(clearTimeout(this.timer),this.timer=void 0),this._stopped=!1,this.config.store?this._listenWithStore():this._listenStatic()}async stop(){this._stopped=!0,this.timer&&(clearTimeout(this.timer),this.timer=void 0)}async send(e){}normalize(e){let t=e,n=new Date,r=`${n.getFullYear()}-${n.getMonth()+1}-${n.getDate()}`;return{intent:t?.intent??this.config.intent,message:t?.message??this.config.message??`Scheduled task triggered at ${n.toISOString()}`,conversationId:`scheduled:${this.name??"default"}:${r}`,data:{...t?.payload??{},scheduled:!0,jobId:t?.id,cron:t?.cron??this.config.cron,timestamp:n.toISOString()}}}_listenStatic(){this._scheduleNextStatic(this._generation)}_scheduleNextStatic(e){if(this._stopped||e!==this._generation)return;let t=this._nextRunFromCron(this.config.cron),n=t.getTime()-Date.now();if(n<=0){this.timer=setTimeout(()=>this._scheduleNextStatic(e),0);return}console.log(`[ScheduledChannel:${this.name??"default"}] Next run: ${t.toISOString()}`),this.timer=setTimeout(async()=>{this._stopped||e!==this._generation||(await this._triggerStatic(),this._scheduleNextStatic(e))},n)}async _triggerStatic(){if(!this._handler){console.warn(`[ScheduledChannel:${this.name??"default"}] Cron fired but no message handler is registered. Call onMessage() before listen() to avoid silently losing triggers.`);return}let e=this.normalize(null);try{await this.handleMessage(e)}catch(t){console.error(`[ScheduledChannel:${this.name??"default"}] Error on trigger:`,t)}}_listenWithStore(){let e=this.config.store,t=this._generation;if(t===1){let r=e.resetStuck(this.name);r>0&&console.log(`[ScheduledChannel:${this.name??"default"}] Reset ${r} stuck 'running' job(s) to 'pending'.`)}if(this.config.cron){let{duplicate:r}=e.create({channelName:this.name,cron:this.config.cron,intent:this.config.intent,message:this.config.message});r||console.log(`[ScheduledChannel:${this.name??"default"}] Seeded static cron '${this.config.cron}' into store.`)}let n=e.getDue(Date.now(),this.name);n.length>0&&(console.log(`[ScheduledChannel:${this.name??"default"}] Recovering ${n.length} overdue job(s).`),Promise.allSettled(n.map(r=>this._triggerJob(r)))),this._scheduleNextFromStore(t)}_scheduleNextFromStore(e){if(this._stopped||e!==this._generation)return;let t=this.config.store,n=t.getNextPending(this.name);if(!n){let s=this.config.idlePollMs??3e4;this.timer=setTimeout(()=>this._scheduleNextFromStore(e),s);return}let r=Math.max(0,n.nextRunAt-Date.now());console.log(`[ScheduledChannel:${this.name??"default"}] Next store job at ${new Date(n.nextRunAt).toISOString()} (in ${Math.round(r/1e3)}s)`),this.timer=setTimeout(async()=>{if(this._stopped||e!==this._generation)return;let s=t.getDue(Date.now(),this.name);await Promise.allSettled(s.map(i=>this._triggerJob(i))),this._scheduleNextFromStore(e)},r)}async _triggerJob(e){let t=this.config.store;if(!this._handler){console.warn(`[ScheduledChannel:${this.name??"default"}] Job ${e.id} fired but no message handler is registered. Call onMessage() before listen() to avoid silently losing jobs.`),t.markFailed(e.id,"No message handler registered");return}t.markRunning(e.id);let n=this.normalize(e);try{await this.handleMessage(n),t.markCompleted(e.id)}catch(r){let s=r instanceof Error?r.message:String(r);console.error(`[ScheduledChannel:${this.name??"default"}] Job ${e.id} failed:`,r),t.markFailed(e.id,s)}}_nextRunFromCron(e){return ct.parse(e,{currentDate:new Date}).next().toDate()}};d();var Te=class extends b{isTriggerChannel=!1;config;offset=0;pollingInterval;server;botUserId;botUsername;constructor(e){super(),this.name=e.name,this.config=e}listen(){this.runStartupCheck().catch(()=>{}),this.config.webhookUrl?this.startWebhook():this.startPolling()}async runStartupCheck(){try{let t=await(await fetch(`https://api.telegram.org/bot${this.config.token}/getMe`)).json();if(t.ok&&t.result){let n=t.result;this.botUserId=n.id!=null?String(n.id):void 0,this.botUsername=n.username,console.log(`[TelegramChannel] Connected as @${n.username} (id: ${n.id}, name: ${n.first_name})`)}else console.warn(`[TelegramChannel] getMe failed: ${t.description??"unknown error"}. Check your bot token.`)}catch(e){console.warn("[TelegramChannel] Startup self-check failed (network error):",e)}}async send(e){let t=e.metadata?.chatId;if(!t)throw new Error("Telegram send requires chatId in metadata");let n=await fetch(`https://api.telegram.org/bot${this.config.token}/sendMessage`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({chat_id:t,text:e.output,parse_mode:"Markdown"})});if(!n.ok)throw new Error(`Failed to send Telegram message: ${n.statusText}`);let r=await n.json();if(!r.ok)throw new Error(`Telegram API error: ${r.description}`)}normalize(e){let t=e,n=t.message||t.edited_message||{},r=n.text||"",s=n.chat||{},i=n.from||{},a=i.id!=null?String(i.id):void 0,u=i.first_name||i.username||a,c=a?{kind:"user",id:a,displayName:u??a}:void 0,l=n.entities??[],g=[];for(let w of l)if(w.type==="text_mention"&&w.user){let v=w.user;v.id!=null&&g.push(String(v.id))}let p=s.type,m=s.id!=null?String(s.id):"";return{message:r,conversationId:m,data:t,participant:c,context:{chatId:s.id,userId:i.id,username:i.username,firstName:i.first_name,lastName:i.last_name,messageId:n.message_id,channelType:p,channelId:m,channelName:s.title,mentions:g.length>0?g:void 0}}}startPolling(){console.log("[TelegramChannel] Starting polling mode"),this.pollingInterval=setInterval(async()=>{try{await this.pollUpdates()}catch(e){console.error("[TelegramChannel] Polling error:",e)}},5e3)}async pollUpdates(){let e=`https://api.telegram.org/bot${this.config.token}/getUpdates?offset=${this.offset}&limit=100`,t=await fetch(e);if(!t.ok)throw new Error(`Telegram getUpdates failed: ${t.statusText}`);let n=await t.json();if(!n.ok)throw new Error("Telegram getUpdates returned not ok");for(let r of n.result){let s=r.update_id;s>=this.offset&&(this.offset=s+1);try{let i=this.normalize(r);await this.handleMessage(i)}catch(i){console.error("[TelegramChannel] Error processing update:",i)}}}startWebhook(){typeof process>"u"||(console.log("[TelegramChannel] Starting webhook mode"),import("http").then(e=>{this.server=e.createServer((r,s)=>{this.handleWebhookRequest(r,s)});let t=new URL(this.config.webhookUrl||"http://localhost:3000"),n=parseInt(t.port,10)||3e3;this.server.listen(n,()=>{console.log(`[TelegramChannel] Webhook server listening on port ${n}`)}),this.setWebhook()}).catch(e=>{console.error("[TelegramChannel] Failed to start webhook server:",e)}))}async setWebhook(){if(!this.config.webhookUrl)return;let e=await fetch(`https://api.telegram.org/bot${this.config.token}/setWebhook`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({url:this.config.webhookUrl})});if(!e.ok){console.error("[TelegramChannel] Failed to set webhook");return}let t=await e.json();t.ok?console.log("[TelegramChannel] Webhook set successfully"):console.error("[TelegramChannel] Failed to set webhook:",t.description)}handleWebhookRequest(e,t){if(e.method!=="POST"){t.writeHead(405),t.end("Method not allowed");return}let n="";e.on("data",r=>{n+=r.toString()}),e.on("end",()=>{try{let r=JSON.parse(n);this.handleMessage(this.normalize(r)).catch(s=>{console.error("[TelegramChannel] Error processing webhook:",s)}),t.writeHead(200),t.end("OK")}catch(r){console.error("[TelegramChannel] Error parsing webhook:",r),t.writeHead(400),t.end("Bad request")}})}async stop(){if(this.pollingInterval&&(clearInterval(this.pollingInterval),this.pollingInterval=void 0),this.server)return new Promise(e=>{this.server.close(e)});if(this.config.webhookUrl)try{await fetch(`https://api.telegram.org/bot${this.config.token}/deleteWebhook`,{method:"POST"})}catch(e){console.error("[TelegramChannel] Failed to delete webhook:",e)}}};d();var an=new Set([1,3]),dt=/<@!?(\d+)>/g,cn="https://discord.com/api/v10",_e=class extends b{isTriggerChannel=!1;config;allowedChannelIds;botUserId;participantCache=new Map;client;constructor(e){super(),this.config=e,this.name=e.name,e.channelId==null?this.allowedChannelIds=new Set:Array.isArray(e.channelId)?this.allowedChannelIds=new Set(e.channelId):this.allowedChannelIds=new Set([e.channelId])}shouldProcessEvent(e){return!e.author||e.webhookId||this.botUserId&&e.author.id===this.botUserId||this.config.guildId&&e.guildId!==this.config.guildId||this.allowedChannelIds.size>0&&(!e.channelId||!this.allowedChannelIds.has(e.channelId))?!1:e.author.bot||e.author.system?this.config.blockedBotIds?.includes(e.author.id)?!1:this.config.allowedBotIds?this.config.allowedBotIds.includes(e.author.id):!1:!0}normalize(e){let t=e,n=t.channelId,r=(n??"")+(t.thread?.id?`:${t.thread.id}`:""),s=t.channel?.type,i=s!==void 0&&an.has(s),a=t.author?.id,u=t.author?.globalName??t.author?.username,c=[];if(t.content){dt.lastIndex=0;let l;for(;(l=dt.exec(t.content))!==null;)c.push(l[1])}return{message:t.content,conversationId:r,data:t,participant:a?{kind:"user",id:a,displayName:u??void 0}:void 0,context:{userId:a,username:t.author?.username,channelType:i?"dm":"channel",channelId:n,channelName:t.channel?.name,guildId:t.guildId,threadId:t.thread?.id,messageId:t.id,mentions:c.length>0?c:void 0,isMentioned:this.botUserId?c.includes(this.botUserId):void 0}}}async resolveParticipant(e){let t=e.participant?.id??e.context?.userId;if(!t)return;let n=this.participantCache.get(t);if(n)return n;try{let r=await fetch(`${cn}/users/${t}`,{headers:{Authorization:`Bot ${this.config.token}`}});if(!r.ok)return console.warn(`[DiscordChannel] Failed to resolve user ${t}: HTTP ${r.status}`),{kind:"user",id:t};let s=await r.json(),i=s.global_name??s.username,a={kind:"user",id:s.id,displayName:i};return this.participantCache.set(t,a),a}catch(r){return console.warn(`[DiscordChannel] resolveParticipant error for ${t}:`,r),{kind:"user",id:t}}}invalidateParticipant(e){this.participantCache.delete(e)}async send(e){if(!this.client)throw new Error("[DiscordChannel] Client not initialized. Did you call listen()?");let t=e.metadata?.threadId;if(t){let s=await this.client.channels.fetch(t);if(s&&"send"in s)try{await s.send({content:e.output});return}catch(i){throw console.error("[DiscordChannel] Failed to send to thread:",i),new Error(`[DiscordChannel] Failed to send Discord message: ${i instanceof Error?i.message:String(i)}`)}console.warn(`[DiscordChannel] Thread ${t} not found or not sendable; falling back to channel send.`)}let n=e.metadata?.channelId??(this.allowedChannelIds.size>0?[...this.allowedChannelIds][0]:void 0);if(!n)throw new Error("[DiscordChannel] No channel ID available for sending. Configure channelId or pass output.metadata.channelId.");let r=await this.client.channels.fetch(n);if(!r||!("send"in r))throw new Error(`[DiscordChannel] Channel ${n} not found or is not a text channel`);try{await r.send({content:e.output})}catch(s){throw console.error("[DiscordChannel] Failed to send to channel:",s),new Error(`[DiscordChannel] Failed to send Discord message: ${s instanceof Error?s.message:String(s)}`)}}listen(){typeof process>"u"||import("discord.js").then(e=>{let{Client:t,GatewayIntentBits:n}=e;this.client=new t({intents:[n.Guilds,n.GuildMessages,n.MessageContent,n.DirectMessages]}),this.client.on("ready",()=>{let r=this.client.user;this.botUserId=r?.id;let s=this.allowedChannelIds.size===0?"all channels":[...this.allowedChannelIds].join(", "),i=this.config.guildId??"all guilds";console.log(`[DiscordChannel] Logged in as ${r?.tag??"unknown"} (botUserId=${this.botUserId??"unknown"}) | guild=${i} | channels=${s}`)}),this.client.on("messageCreate",r=>{let s=r;if(!this.shouldProcessEvent(s))return;let i=this.normalize(s);this.handleMessage(i)}),this.client.on("userUpdate",(r,s)=>{let i=s;i?.id&&this.invalidateParticipant(i.id)}),this.client.login(this.config.token).catch(r=>{console.error("[DiscordChannel] Failed to login to Discord:",r)})}).catch(e=>{console.error("[DiscordChannel] Failed to initialize Discord client:",e),console.error("[DiscordChannel] Make sure discord.js is installed: npm install discord.js")})}async stop(){this.client&&(await this.client.destroy(),this.client=void 0)}};d();var Me=class extends b{isTriggerChannel=!0;config;transporter;constructor(e){super(),this.config=e,this.name=e.name}listen(){typeof process<"u"&&import("nodemailer").then(e=>{this.transporter=e.default.createTransport({host:this.config.smtp.host,port:this.config.smtp.port,secure:this.config.smtp.secure??this.config.smtp.port===465,auth:{user:this.config.smtp.auth.user,pass:this.config.smtp.auth.pass}}),console.log(`[EmailChannel] Email transporter initialized for ${this.config.from}`)}).catch(e=>{console.error("[EmailChannel] Failed to initialize nodemailer:",e),console.error("[EmailChannel] Make sure to install nodemailer: npm install nodemailer")})}async send(e){if(!this.transporter)throw new Error("Email transporter not initialized. Did you call listen()?");let t=Array.isArray(this.config.to)?this.config.to:[this.config.to],n=this.config.subject||"Message from Agent",r={from:this.config.from,to:t.join(", "),subject:n,text:e.output,html:this.formatAsHtml(e.output)};try{await this.transporter.sendMail(r)}catch(s){throw console.error("[EmailChannel] Failed to send email:",s),new Error(`Failed to send email: ${s instanceof Error?s.message:String(s)}`)}}normalize(e){throw new Error("EmailChannel is outbound-only. Use WebhookChannel with email webhook events for inbound email.")}formatAsHtml(e){return e.split(`
|
|
15
15
|
|
|
16
|
-
`).map(t=>`<p>${t.replace(/\n/g,"<br>")}</p>`).join("")}async stop(){this.transporter&&(this.transporter.close(),this.transporter=void 0)}};d();var
|
|
17
|
-
`)},
|
|
18
|
-
Recent conversation:`);for(let
|
|
16
|
+
`).map(t=>`<p>${t.replace(/\n/g,"<br>")}</p>`).join("")}async stop(){this.transporter&&(this.transporter.close(),this.transporter=void 0)}};d();var Pe=class extends b{config;twilioClient;server;constructor(e){super(),this.config={port:3e3,...e},this.name=e.name}get isTriggerChannel(){return!this.config.webhookPath}listen(){typeof process<"u"&&import("twilio").then(e=>{this.twilioClient=e.default(this.config.accountSid,this.config.authToken),console.log("[SMSChannel] Twilio client initialized"),this.config.webhookPath&&this.startWebhookServer()}).catch(e=>{console.error("[SMSChannel] Failed to initialize Twilio client:",e),console.error("[SMSChannel] Make sure to install twilio: npm install twilio")})}async send(e){if(!this.twilioClient)throw new Error("Twilio client not initialized. Did you call listen()?");let t=e.metadata?.from||this.config.to;if(!t)throw new Error('No recipient phone number specified. Set "to" in config or provide in output.metadata.from');try{await this.twilioClient.messages.create({body:e.output,from:this.config.from,to:t})}catch(n){throw console.error("[SMSChannel] Failed to send SMS:",n),new Error(`Failed to send SMS: ${n instanceof Error?n.message:String(n)}`)}}normalize(e){let t=e,n=t.From,r=t.Body,s=t.MessageSid;return{message:r,conversationId:n,data:t,context:{from:n,to:t.To,messageSid:s}}}startWebhookServer(){import("http").then(e=>{this.server=e.createServer((t,n)=>{this.handleWebhookRequest(t,n)}),this.server.listen(this.config.port,()=>{console.log(`[SMSChannel] Webhook server listening on port ${this.config.port} at ${this.config.webhookPath}`)})}).catch(e=>{console.error("[SMSChannel] Failed to start webhook server:",e)})}handleWebhookRequest(e,t){if(e.method!=="POST"||e.url!==this.config.webhookPath){t.writeHead(404),t.end("Not found");return}let n="";e.on("data",r=>{n+=r.toString()}),e.on("end",()=>{try{let r=new URLSearchParams(n),s={};r.forEach((a,u)=>{s[u]=a});let i=this.normalize(s);this.handleMessage(i),t.writeHead(200,{"Content-Type":"text/xml"}),t.end('<?xml version="1.0" encoding="UTF-8"?><Response></Response>')}catch(r){console.error("[SMSChannel] Error handling webhook:",r),t.writeHead(400),t.end("Bad request")}})}async stop(){if(this.server)return new Promise(e=>{this.server.close(e)})}};d();var De=class extends b{isTriggerChannel=!1;_timeout;_pendingResolve;constructor(e={}){super(),this._timeout=e.timeout??12e4}listen(){}async send(e){this._pendingResolve?.(e),this._pendingResolve=void 0}normalize(e){let t=e;return{message:typeof t.message=="string"?t.message:JSON.stringify(t),data:t,conversationId:`mcp-${Date.now()}-${Math.random().toString(36).slice(2,7)}`}}async trigger(e){let t=this.normalize(e);return new Promise((n,r)=>{let s=setTimeout(()=>{this._pendingResolve=void 0,r(new Error(`McpChannel: agent did not respond within ${this._timeout}ms`))},this._timeout);this._pendingResolve=i=>{clearTimeout(s),n(i.output)},this.handleMessage(t).catch(i=>{clearTimeout(s),this._pendingResolve=void 0,r(i instanceof Error?i:new Error(String(i)))})})}asAgentDefinition(e,t){return{name:e.name,description:e.description,...t!==void 0&&{inputSchema:t},invoke:n=>this.trigger(n)}}};d();d();var Y=class{agentUrls;constructor(e){this.agentUrls=new Map(Object.entries(e.agents))}async invoke(e,t){let n=this.agentUrls.get(e);if(!n)throw new I(`Agent "${e}" not found in transport configuration. Available agents: ${Array.from(this.agentUrls.keys()).join(", ")}`);let r={jsonrpc:"2.0",method:`agent.invoke:${e}`,params:t,id:Date.now()};try{let s=await fetch(n,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(r)});if(!s.ok)throw new I(`HTTP ${s.status}: ${s.statusText}`);let i=await s.json();if(i.error)throw new I(`JSON-RPC error (${i.error.code}): ${i.error.message}`+(i.error.data?` - ${JSON.stringify(i.error.data)}`:""));if(!i.result)throw new I("No result in JSON-RPC response");return i.result}catch(s){throw s instanceof I?s:new I(`Failed to invoke agent "${e}" at ${n}: ${s instanceof Error?s.message:String(s)}`)}}};d();import dn from"http";var X=class{agents=new Map;server;port;constructor(e){this.port=e.port}registerAgent(e,t){this.agents.set(e,t)}listen(){this.server=dn.createServer(async(e,t)=>{if(e.method!=="POST"){t.writeHead(405,{"Content-Type":"application/json"}),t.end(JSON.stringify({error:"Method not allowed"}));return}let n="";e.on("data",r=>{n+=r.toString()}),e.on("end",async()=>{try{let r=JSON.parse(n),s=await this.handleRequest(r);t.writeHead(200,{"Content-Type":"application/json"}),t.end(JSON.stringify(s))}catch(r){let s={jsonrpc:"2.0",error:{code:-32700,message:"Parse error",data:r instanceof Error?r.message:String(r)},id:null};t.writeHead(200,{"Content-Type":"application/json"}),t.end(JSON.stringify(s))}})}),this.server.listen(this.port,()=>{console.log(`[AgentJsonRpcServer] Listening on port ${this.port}`),console.log(`[AgentJsonRpcServer] Registered agents: ${Array.from(this.agents.keys()).join(", ")}`)})}async stop(){return new Promise((e,t)=>{if(!this.server){e();return}this.server.close(n=>{n?t(n):(console.log("[AgentJsonRpcServer] Server stopped"),e())})})}async handleRequest(e){if(e.jsonrpc!=="2.0")return{jsonrpc:"2.0",error:{code:-32600,message:"Invalid Request",data:'jsonrpc must be "2.0"'},id:e.id||null};let[t,n]=e.method.split(":");if(t!=="agent.invoke")return{jsonrpc:"2.0",error:{code:-32601,message:"Method not found",data:`Unknown method: ${e.method}`},id:e.id||null};if(!n)return{jsonrpc:"2.0",error:{code:-32602,message:"Invalid params",data:'Agent name required in method (e.g., "agent.invoke:data-agent")'},id:e.id||null};let r=this.agents.get(n);if(!r)return{jsonrpc:"2.0",error:{code:-32602,message:"Invalid params",data:`Agent "${n}" not found. Available: ${Array.from(this.agents.keys()).join(", ")}`},id:e.id||null};if(!e.params)return{jsonrpc:"2.0",error:{code:-32602,message:"Invalid params",data:"params (AgentInput) required"},id:e.id||null};try{return{jsonrpc:"2.0",result:await r.invokeAgent(e.params),id:e.id||null}}catch(s){return{jsonrpc:"2.0",error:{code:-32603,message:"Internal error",data:s instanceof Error?s.message:String(s)},id:e.id||null}}}};d();d();import{CHAT_MODE as ln}from"toolpack-sdk";var un={...ln,name:"intent-classifier-mode",systemPrompt:["You classify whether a message is asking an agent to respond.","","Categories:","direct = Message uses @mention, name in greeting, possessive, or commands the agent to act","indirect = Agent is mentioned but unclear if response wanted (talking ABOUT, not TO them)","passive = No addressing detected; agent should only listen, not reply","ignore = Definitely not for this agent (noise, code blocks, other bots)","","Response must start with one of: direct, indirect, passive, ignore"].join(`
|
|
17
|
+
`)},Q=class extends C{name="intent-classifier";description="Classifies whether a message is directly addressing an agent for response";mode=un;constructor(e){super(e)}async invokeAgent(e){let t=e.data;if(t?.isDirectMessage)return{output:"direct",metadata:{classification:"direct",shortCircuit:"dm"}};if(!t?.message)return{output:"ignore",metadata:{error:"No message provided for classification"}};let n=[];if(n.push(`Context: Public channel #${t.channelName}`),n.push(`Target agent: "${t.agentName}" (ID: ${t.agentId})`),n.push(`Message sender: ${t.senderName}`),t.recentContext&&t.recentContext.length>0){n.push(`
|
|
18
|
+
Recent conversation:`);for(let a of t.recentContext)n.push(` ${a.sender}: ${a.content.substring(0,100)}`)}n.push(`
|
|
19
19
|
Message to classify: "${t.message}"`),t.includeExamples&&(n.push(`
|
|
20
20
|
Examples of classifications:`),n.push(` "@${t.agentName} help me" \u2192 direct`),n.push(` "Can someone ask ${t.agentName} about this?" \u2192 indirect`),n.push(` "I was talking to ${t.agentName} earlier" \u2192 passive`),n.push(' "Check the logs" \u2192 ignore')),n.push(`
|
|
21
21
|
Classification (start with direct, indirect, passive, or ignore):`);let r=n.join(`
|
|
22
|
-
`),
|
|
23
|
-
`)},Z=class extends C{name="summarizer";description="Compresses conversation history into compact summaries for prompt assembly";mode=
|
|
24
|
-
`),
|
|
25
|
-
`)}}}
|
|
22
|
+
`),s=await this.run(r),i=this.normalizeClassification(s.output);return{output:i,metadata:{rawOutput:s.output,classification:i,confidence:"high"}}}normalizeClassification(e){let t=e.toLowerCase().trim().split(/\s+/)[0],n=e.toLowerCase();return["direct","indirect","passive","ignore"].includes(t)?t:n.includes("indirect")||n.includes("mention")?"indirect":n.includes("passive")||n.includes("listen")?"passive":n.includes("ignore")||n.includes("skip")?"ignore":n.includes("direct")||n.includes("addressed")?"direct":"ignore"}};d();import{CHAT_MODE as pn}from"toolpack-sdk";var gn={...pn,name:"summarizer-mode",systemPrompt:["You are a conversation summarizer for multi-participant chat histories.","Your job is to compress older conversation turns into a dense summary that preserves:","","1. Key facts and information shared","2. Decisions made or action items assigned","3. Context relevant to the target agent's perspective","4. Important questions asked or problems raised","","Summarize from the perspective of the target agent.","If the agent was not addressed in a turn, note it as observed context.","Use bullet points for clarity. Be concise but complete.","","Output format: Return ONLY a JSON object with these fields:","- summary: string (the summary text)","- turnsSummarized: number (count of turns processed)","- hasDecisions: boolean (whether any decisions/action items were found)","- estimatedTokens: number (rough estimate: characters / 4)","","Do not include markdown code blocks, just the raw JSON."].join(`
|
|
23
|
+
`)},Z=class extends C{name="summarizer";description="Compresses conversation history into compact summaries for prompt assembly";mode=gn;constructor(e){super(e)}async invokeAgent(e){let t=e.data;if(!t?.turns||t.turns.length===0)return{output:JSON.stringify({summary:"(No history to summarize)",turnsSummarized:0,hasDecisions:!1,estimatedTokens:5}),metadata:{emptyInput:!0}};let n=t.maxTokens??800,r=t.extractDecisions??!0,s=[`Target agent: "${t.agentName}" (ID: ${t.agentId})`,`Maximum summary length: ~${n} tokens`,`Extract decisions/action items: ${r?"yes":"no"}`,"",`Conversation turns to summarize (${t.turns.length} turns):`,""];for(let c of t.turns){let l=new Date(c.timestamp).toLocaleString("en-US",{month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"}),g=c.participant.displayName??c.participant.id,p=c.participant.kind==="agent"?`[BOT] ${g}`:g,m=`[${l}] ${p}: ${c.content.substring(0,200)}`;c.content.length>200&&(m+="..."),c.metadata?.isToolCall&&c.metadata.toolName&&(m+=` [tool: ${c.metadata.toolName}]`),s.push(m)}s.push("","Generate a JSON summary object:");let i=s.join(`
|
|
24
|
+
`),a=await this.run(i),u=this.parseSummarizerOutput(a.output,t.turns.length);return{output:JSON.stringify(u),metadata:{turnsProcessed:t.turns.length,rawOutputLength:a.output.length}}}parseSummarizerOutput(e,t){let n=e.trim(),r=n.match(/```(?:json)?\s*([\s\S]*?)\s*```/);r&&(n=r[1].trim());try{let s=JSON.parse(n);return{summary:typeof s.summary=="string"&&s.summary.length>0?s.summary:this.generateFallbackSummary(t),turnsSummarized:typeof s.turnsSummarized=="number"?s.turnsSummarized:t,hasDecisions:typeof s.hasDecisions=="boolean"?s.hasDecisions:!1,estimatedTokens:typeof s.estimatedTokens=="number"&&s.estimatedTokens>0?s.estimatedTokens:Math.ceil(e.length/4)}}catch{return{summary:this.generateFallbackSummary(t),turnsSummarized:t,hasDecisions:e.toLowerCase().includes("decision")||e.toLowerCase().includes("action"),estimatedTokens:Math.ceil(e.length/4)}}}generateFallbackSummary(e){return`(Summary of ${e} conversation turns - key details preserved in full context)`}};d();d();import{InMemoryConversationStore as lt}from"toolpack-sdk";d();function ut(o,e,t={}){let n=t.maxResults??10,r=t.tokenCap??2e3,s={limit:n,tokenCap:r};return{name:"search_conversation_history",description:["Search the conversation history for messages matching a query.","Use this when you need to recall something specific that was said earlier","in this conversation but is not in your immediate context.","Results are limited to this conversation only."].join(" "),input_schema:{type:"object",properties:{query:{type:"string",description:"The search query \u2014 keywords or phrases to look for in the conversation history."}},required:["query"]},execute:async({query:i})=>{if(!i||i.trim()==="")return"Error: query must not be empty.";let a=await o.search(e,i.trim(),s);if(a.length===0)return`No messages found matching "${i}".`;let u=a.map(c=>{let l=c.participant.displayName??c.participant.id,g=c.participant.kind==="agent"?`${l} (agent)`:l;return`[${new Date(c.timestamp).toLocaleString("en-US",{month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"})}] ${g}: ${c.content}`});return[`Found ${a.length} result(s) for "${i}":`,"",...u].join(`
|
|
25
|
+
`)}}}Ae();d();d();d();var Oe=class{constructor(e){this.maxSize=e}maxSize;cache=new Map;has(e){return this.cache.has(e)}set(e,t){if(this.cache.has(e)&&this.cache.delete(e),this.cache.size>=this.maxSize){let n=this.cache.keys().next().value;n!==void 0&&this.cache.delete(n)}this.cache.set(e,t)}clear(){this.cache.clear()}size(){return this.cache.size}};function Ne(o={}){let e=o.maxCacheSize??1e3,t=o.getEventId??(r=>r.context?.eventId),n=new Oe(e);return async(r,s,i)=>{let a=t(r);if(a){if(n.has(a))return o.onDuplicate?.(a,r),s.logger?.debug(`Event dedup: dropping duplicate event ${a}`,{eventId:a}),s.skip();n.set(a,!0)}return await i()}}d();function $e(o){let e=o.getSubtype??(n=>n.context?.subtype),t=new Set(o.denySubtypes);return async(n,r,s)=>{let i=e(n);return i&&t.has(i)?(o.onFiltered?.(i,n),r.logger?.debug(`Noise filter: dropping message with subtype "${i}"`,{subtype:i}),r.skip()):await s()}}d();function je(o){return async(e,t,n)=>{let r=o.getSenderId(e),s=o.agentId??t.agent.name;return r&&r===s?(o.onSelfMessage?.(r,e),t.logger?.debug(`Self filter: dropping self-message from ${r}`,{senderId:r,agentId:s}),t.skip()):await n()}}d();var Be=class{constructor(e){this.maxSize=e}maxSize;cache=new Map;get(e){let t=this.cache.get(e);return t!==void 0&&(this.cache.delete(e),this.cache.set(e,t)),t}set(e,t){if(this.cache.has(e))this.cache.delete(e);else if(this.cache.size>=this.maxSize){let n=this.cache.keys().next().value;n!==void 0&&this.cache.delete(n)}this.cache.set(e,t)}clear(){this.cache.clear()}size(){return this.cache.size}},Le=class{constructor(e,t,n){this.capacity=e;this.refillRate=t;this.refillInterval=n;this.tokens=e,this.lastRefill=Date.now()}capacity;refillRate;refillInterval;tokens;lastRefill;consume(e=1){return this.refill(),this.tokens>=e?(this.tokens-=e,!0):!1}refill(){let e=Date.now(),t=e-this.lastRefill,n=Math.floor(t/this.refillInterval*this.refillRate);n>0&&(this.tokens=Math.min(this.capacity,this.tokens+n),this.lastRefill=e)}getTokens(){return this.refill(),this.tokens}};function Ue(o){let e=o.tokensPerInterval??10,t=o.interval??6e4,n=o.maxBuckets??1e3,r=o.onExceeded??"skip",s=new Be(n);return async(i,a,u)=>{let c=o.getKey(i),l=s.get(c);if(l||(l=new Le(e,e,t),s.set(c,l)),!l.consume()){if(o.onRateLimited?.(c,i),a.logger?.warn(`Rate limit exceeded for key: ${c}`,{key:c}),r==="reject")throw new Error("Rate limit exceeded. Please try again later.");return a.skip()}return await u()}}d();function Fe(o={}){return async(e,t,n)=>{let r;if(o.resolveParticipant)r=await o.resolveParticipant(e);else if(typeof t.channel.resolveParticipant=="function")try{r=await t.channel.resolveParticipant(e)}catch(i){t.logger?.warn("Channel resolveParticipant threw; falling back",{error:i instanceof Error?i.message:"Unknown error"})}let s=r??e.participant;if(s){let i={...e,participant:s,context:{...e.context,_participant:s}};return o.onResolved?.(i,s),t.logger?.debug("Resolved participant",{participantId:s.id,participantKind:s.kind}),await n(i)}return await n()}}d();function mn(o,e){let t=e.toLowerCase();if(!o.toLowerCase().includes(t))return!1;let r=[],s=/```[\s\S]*?```/g,i;for(;(i=s.exec(o))!==null;)r.push([i.index,i.index+i[0].length]);let a=/`[^`\n]*`/g;for(;(i=a.exec(o))!==null;){let p=i.index,m=p+i[0].length;r.some(([v,A])=>p>=v&&m<=A)||r.push([p,m])}if(r.length===0)return!1;r.sort((p,m)=>p[0]-m[0]);let u="",c=0;for(let[p,m]of r)p>c&&(u+=o.slice(c,p)),c=Math.max(c,m);return c<o.length&&(u+=o.slice(c)),u.toLowerCase().includes(t)?!1:r.some(([p,m])=>o.slice(p,m).toLowerCase().includes(t))}function Ge(o){return async(e,t,n)=>{let r=o.getMessageText(e)??"";if(o.isDirectMessage?.(e)){let m={...e,context:{...e.context,_addressCheck:"direct",_isDM:!0}};return o.onClassified?.("direct",e),await n(m)}let s="ambiguous",i=r.toLowerCase(),a=o.agentName.toLowerCase(),u=m=>m.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),c=u(a),l=o.agentId?`|^@${u(o.agentId)}\\b`:"";if(new RegExp(`^(hey\\s+)?@?${c}\\b${l}`,"i").test(i))s="direct";else if(new RegExp(`\\b(my|our|the)\\s+${c}\\b`,"i").test(i))s="ambiguous";else if(mn(r,o.agentName))s="ignore";else if(/^https?:\/\//.test(r))s="ignore";else if(o.getMentions){let m=o.getMentions(e),w=m.some(v=>v.toLowerCase()===a||v===o.agentId);w&&m.length>1?s="indirect":w&&(s="ambiguous")}else i.includes(a)?s="ambiguous":s="passive";let p={...e,context:{...e.context,_addressCheck:s}};return o.onClassified?.(s,e),t.logger?.debug(`Address check classified as: ${s}`,{result:s}),await n(p)}}d();function Je(o){let e=o.classifierAgentName??"intent-classifier";return async(t,n,r)=>{let s=t.context?._addressCheck;if(s==="direct")return await r();if(s==="ignore"||s==="passive")return o.onClassified?.(s,t),n.skip();let i=o.getMessageText(t)??"";if(!i.trim())return await r();let a={message:i,agentName:o.agentName,agentId:o.agentId,senderName:o.getSenderName(t),channelName:o.getChannelName(t),isDirectMessage:o.isDirectMessage?.(t)??!1,recentContext:o.getRecentContext?.(t)};try{let c=(await n.delegateAndWait(e,{message:"classify",data:a,conversationId:t.conversationId})).output.trim();o.onClassified?.(c,t),n.logger?.debug(`Intent classified as: ${c}`,{classification:c});let l={...t,context:{...t.context,_intentClassification:c}};return c==="direct"?await r(l):n.skip()}catch(u){return n.logger?.error("Intent classification failed, allowing message",{error:u instanceof Error?u.message:"Unknown error"}),await r()}}}d();var N=class extends Error{constructor(t,n){super(`Maximum invocation depth exceeded: ${t} > ${n}`);this.currentDepth=t;this.maxDepth=n;this.name="DepthExceededError"}currentDepth;maxDepth};function ze(o={}){let e=o.maxDepth??5;return async(t,n,r)=>{if(n.invocationDepth>e)throw o.onDepthExceeded?.(n.invocationDepth,e,t),n.logger?.error(`Depth guard: invocation depth ${n.invocationDepth} exceeds maximum ${e}`,{currentDepth:n.invocationDepth,maxDepth:e}),new N(n.invocationDepth,e);return await r()}}d();function qe(o={}){let e=o.level??"debug",t=o.includeInputData??!1,n=o.includeResultOutput??!1;return async(r,s,i)=>{if(o.shouldTrace&&!o.shouldTrace(r))return await i();let a=e==="info"?s.logger?.info:s.logger?.debug;a?.("Interceptor entry",{agent:s.agent.name,channel:s.channel.name,depth:s.invocationDepth,conversationId:r.conversationId,intent:r.intent,input:t?r:void 0});let u=performance.now();try{let c=await i(),l=performance.now()-u;return _(c)?a?.("Interceptor exit: skipped",{agent:s.agent.name,channel:s.channel.name,depth:s.invocationDepth,conversationId:r.conversationId,durationMs:l.toFixed(2)}):a?.("Interceptor exit: success",{agent:s.agent.name,channel:s.channel.name,depth:s.invocationDepth,conversationId:r.conversationId,durationMs:l.toFixed(2),outputLength:c.output.length,result:n?c:void 0}),c}catch(c){let l=performance.now()-u;throw s.logger?.error("Interceptor exit: error",{agent:s.agent.name,channel:s.channel.name,depth:s.invocationDepth,conversationId:r.conversationId,durationMs:l.toFixed(2),error:c instanceof Error?c.message:"Unknown error",errorType:c?.constructor?.name}),c}}}d();var ee=(n=>(n[n.UNSET=0]="UNSET",n[n.OK=1]="OK",n[n.ERROR=2]="ERROR",n))(ee||{});function He(o={}){let{tracerProvider:e,tracerName:t="toolpack-agents",tracerVersion:n,recordSteps:r=!0,shouldTrace:s}=o,i=e?.getTracer(t,n);return async(a,u,c)=>{if(!i)return await c();if(s&&!s(a))return await c();let l=i.startSpan("agent.invocation");l.setAttribute("agent.name",u.agent.name),l.setAttribute("channel.name",u.channel.name??"unknown"),l.setAttribute("invocation.depth",u.invocationDepth),a.conversationId&&l.setAttribute("conversation.id",a.conversationId),a.intent&&l.setAttribute("agent.intent",a.intent);let g=performance.now();try{let p=await c(),m=performance.now()-g;if(l.setAttribute("duration.ms",Math.round(m)),_(p))l.setAttribute("result.skipped",!0),l.setStatus({code:1});else{if(l.setAttribute("result.output.length",p.output.length),r&&p.steps&&p.steps.length>0){l.setAttribute("steps.total",p.steps.length);let w=p.steps.filter(v=>v.status==="failed");w.length>0&&l.setAttribute("steps.failed",w.length),p.steps.forEach((v,A)=>{let k=`step.${A}`;l.setAttribute(`${k}.description`,v.description),l.setAttribute(`${k}.status`,v.status),v.result?.duration!==void 0&&l.setAttribute(`${k}.duration.ms`,v.result.duration),v.result?.toolsUsed&&v.result.toolsUsed.length>0&&l.setAttribute(`${k}.tools`,v.result.toolsUsed.join(","))})}l.setStatus({code:1})}return p}catch(p){let m=performance.now()-g;l.setAttribute("duration.ms",Math.round(m));let w=p instanceof Error?p:String(p);throw l.recordException(w),l.setStatus({code:2,message:p instanceof Error?p.message:String(p)}),p}finally{l.end()}}}d();d();import hn from"better-sqlite3";import{CronExpressionParser as U}from"cron-parser";var te=class{db;constructor({dbPath:e=":memory:"}={}){this.db=new hn(e),this.db.pragma("journal_mode = WAL"),this.db.pragma("foreign_keys = ON"),this._migrate()}_migrate(){this.db.exec(`
|
|
26
26
|
CREATE TABLE IF NOT EXISTS scheduled_jobs (
|
|
27
27
|
id TEXT PRIMARY KEY,
|
|
28
28
|
channel_name TEXT,
|
|
@@ -42,17 +42,17 @@ Classification (start with direct, indirect, passive, or ignore):`);let r=n.join
|
|
|
42
42
|
|
|
43
43
|
CREATE INDEX IF NOT EXISTS idx_jobs_channel
|
|
44
44
|
ON scheduled_jobs (channel_name, status);
|
|
45
|
-
`)}create(e){if(!e.cron&&!e.runAt)throw new Error("SchedulerStore.create: either cron or runAt must be provided.");if(e.cron&&e.runAt)throw new Error("SchedulerStore.create: provide cron OR runAt, not both.");let t;if(e.cron)try{t=
|
|
45
|
+
`)}create(e){if(!e.cron&&!e.runAt)throw new Error("SchedulerStore.create: either cron or runAt must be provided.");if(e.cron&&e.runAt)throw new Error("SchedulerStore.create: provide cron OR runAt, not both.");let t;if(e.cron)try{t=U.parse(e.cron,{currentDate:new Date}).next().toDate().getTime()}catch{throw new Error(`SchedulerStore.create: invalid cron expression '${e.cron}'`)}else if(t=e.runAt instanceof Date?e.runAt.getTime():e.runAt,isNaN(t))throw new Error(`SchedulerStore.create: invalid runAt value '${e.runAt}'`);let n=this._findDuplicate(e,t);if(n)return{job:n,duplicate:!0};let r=crypto.randomUUID(),s=Date.now();return this.db.prepare(`
|
|
46
46
|
INSERT INTO scheduled_jobs
|
|
47
47
|
(id, channel_name, next_run_at, cron, intent, message, payload, status, created_at)
|
|
48
48
|
VALUES
|
|
49
49
|
(@id, @channelName, @nextRunAt, @cron, @intent, @message, @payload, 'pending', @createdAt)
|
|
50
|
-
`).run({id:r,channelName:e.channelName??null,nextRunAt:t,cron:e.cron??null,intent:e.intent??null,message:e.message??null,payload:e.payload?JSON.stringify(e.payload):null,createdAt:
|
|
50
|
+
`).run({id:r,channelName:e.channelName??null,nextRunAt:t,cron:e.cron??null,intent:e.intent??null,message:e.message??null,payload:e.payload?JSON.stringify(e.payload):null,createdAt:s}),{job:this._getById(r),duplicate:!1}}get(e){return this._getById(e)??void 0}list(e={}){let{status:t="pending",channelName:n,limit:r=20}=e,s=[],i={limit:r};t!=="all"&&(s.push("status = @status"),i.status=t),n!==void 0&&(s.push("channel_name = @channelName"),i.channelName=n);let a=s.length?`WHERE ${s.join(" AND ")}`:"";return this.db.prepare(`
|
|
51
51
|
SELECT * FROM scheduled_jobs
|
|
52
|
-
${
|
|
52
|
+
${a}
|
|
53
53
|
ORDER BY next_run_at ASC
|
|
54
54
|
LIMIT @limit
|
|
55
|
-
`).all(
|
|
55
|
+
`).all(i).map(F)}getDue(e=Date.now(),t){return(t?this.db.prepare(`
|
|
56
56
|
SELECT * FROM scheduled_jobs
|
|
57
57
|
WHERE status = 'pending' AND next_run_at <= @now AND channel_name = @channelName
|
|
58
58
|
ORDER BY next_run_at ASC
|
|
@@ -60,7 +60,7 @@ Classification (start with direct, indirect, passive, or ignore):`);let r=n.join
|
|
|
60
60
|
SELECT * FROM scheduled_jobs
|
|
61
61
|
WHERE status = 'pending' AND next_run_at <= @now
|
|
62
62
|
ORDER BY next_run_at ASC
|
|
63
|
-
`).all({now:e})).map(
|
|
63
|
+
`).all({now:e})).map(F)}getNextPending(e){let t=e?this.db.prepare(`
|
|
64
64
|
SELECT * FROM scheduled_jobs
|
|
65
65
|
WHERE status = 'pending' AND channel_name = @channelName
|
|
66
66
|
ORDER BY next_run_at ASC LIMIT 1
|
|
@@ -68,9 +68,9 @@ Classification (start with direct, indirect, passive, or ignore):`);let r=n.join
|
|
|
68
68
|
SELECT * FROM scheduled_jobs
|
|
69
69
|
WHERE status = 'pending'
|
|
70
70
|
ORDER BY next_run_at ASC LIMIT 1
|
|
71
|
-
`).get();return t?
|
|
71
|
+
`).get();return t?F(t):void 0}update(e,t){let n=this._getById(e);if(!n)return;if(n.status!=="pending")throw new Error(`Cannot update job ${e}: status is '${n.status}', expected 'pending'.`);if(t.cron!==void 0&&t.runAt!==void 0)throw new Error(`Cannot update job ${e}: provide cron OR runAt, not both.`);let r=[],s={id:e};if(t.cron!==void 0){try{U.parse(t.cron)}catch{throw new Error(`Invalid cron expression '${t.cron}'`)}r.push("cron = @cron"),s.cron=t.cron;let i=U.parse(t.cron,{currentDate:new Date});s.nextRunAt=i.next().toDate().getTime(),r.push("next_run_at = @nextRunAt")}if(t.runAt!==void 0){let i=t.runAt instanceof Date?t.runAt.getTime():t.runAt;if(isNaN(i))throw new Error(`Cannot update job ${e}: invalid runAt value '${t.runAt}'`);s.nextRunAt=i,r.push("next_run_at = @nextRunAt"),r.push("cron = NULL")}return t.message!==void 0&&(r.push("message = @message"),s.message=t.message),t.intent!==void 0&&(r.push("intent = @intent"),s.intent=t.intent),t.payload!==void 0&&(r.push("payload = @payload"),s.payload=JSON.stringify(t.payload)),r.length===0?n:(this.db.prepare(`
|
|
72
72
|
UPDATE scheduled_jobs SET ${r.join(", ")} WHERE id = @id
|
|
73
|
-
`).run(
|
|
73
|
+
`).run(s),this._getById(e))}cancel(e){return this.db.prepare(`
|
|
74
74
|
UPDATE scheduled_jobs SET status = 'cancelled'
|
|
75
75
|
WHERE id = @id AND status = 'pending'
|
|
76
76
|
`).run({id:e}).changes>0}resetStuck(e){return(e?this.db.prepare(`
|
|
@@ -80,7 +80,7 @@ Classification (start with direct, indirect, passive, or ignore):`);let r=n.join
|
|
|
80
80
|
UPDATE scheduled_jobs SET status = 'pending' WHERE status = 'running'
|
|
81
81
|
`).run()).changes}markRunning(e){this.db.prepare(`
|
|
82
82
|
UPDATE scheduled_jobs SET status = 'running' WHERE id = @id
|
|
83
|
-
`).run({id:e})}markCompleted(e){let t=this._getById(e);if(!t)return;let n=Date.now();if(t.cron){let r;try{r=
|
|
83
|
+
`).run({id:e})}markCompleted(e){let t=this._getById(e);if(!t)return;let n=Date.now();if(t.cron){let r;try{r=U.parse(t.cron,{currentDate:new Date}).next().toDate().getTime()}catch{this.markFailed(e,`markCompleted: corrupt cron expression '${t.cron}'`);return}this.db.prepare(`
|
|
84
84
|
UPDATE scheduled_jobs
|
|
85
85
|
SET status = 'pending', last_run_at = @now, next_run_at = @nextRunAt, last_error = NULL
|
|
86
86
|
WHERE id = @id
|
|
@@ -88,7 +88,7 @@ Classification (start with direct, indirect, passive, or ignore):`);let r=n.join
|
|
|
88
88
|
UPDATE scheduled_jobs
|
|
89
89
|
SET status = 'completed', last_run_at = @now, last_error = NULL
|
|
90
90
|
WHERE id = @id
|
|
91
|
-
`).run({id:e,now:n})}markFailed(e,t){let n=this._getById(e);if(!n)return;let r=Date.now();if(n.cron){let
|
|
91
|
+
`).run({id:e,now:n})}markFailed(e,t){let n=this._getById(e);if(!n)return;let r=Date.now();if(n.cron){let s;try{s=U.parse(n.cron,{currentDate:new Date}).next().toDate().getTime()}catch{this.db.prepare(`
|
|
92
92
|
UPDATE scheduled_jobs
|
|
93
93
|
SET status = 'failed', last_run_at = @now,
|
|
94
94
|
last_error = @compositeError
|
|
@@ -97,11 +97,11 @@ Classification (start with direct, indirect, passive, or ignore):`);let r=n.join
|
|
|
97
97
|
UPDATE scheduled_jobs
|
|
98
98
|
SET status = 'pending', last_run_at = @now, last_error = @error, next_run_at = @nextRunAt
|
|
99
99
|
WHERE id = @id
|
|
100
|
-
`).run({id:e,now:r,error:t,nextRunAt:
|
|
100
|
+
`).run({id:e,now:r,error:t,nextRunAt:s})}else this.db.prepare(`
|
|
101
101
|
UPDATE scheduled_jobs
|
|
102
102
|
SET status = 'failed', last_run_at = @now, last_error = @error
|
|
103
103
|
WHERE id = @id
|
|
104
|
-
`).run({id:e,now:r,error:t})}_getById(e){let t=this.db.prepare("SELECT * FROM scheduled_jobs WHERE id = @id").get({id:e});return t?
|
|
104
|
+
`).run({id:e,now:r,error:t})}_getById(e){let t=this.db.prepare("SELECT * FROM scheduled_jobs WHERE id = @id").get({id:e});return t?F(t):null}_findDuplicate(e,t){let n;return e.cron?n=this.db.prepare(`
|
|
105
105
|
SELECT * FROM scheduled_jobs
|
|
106
106
|
WHERE status = 'pending'
|
|
107
107
|
AND cron = @cron
|
|
@@ -115,5 +115,19 @@ Classification (start with direct, indirect, passive, or ignore):`);let r=n.join
|
|
|
115
115
|
AND (intent IS @intent OR (intent IS NULL AND @intent IS NULL))
|
|
116
116
|
AND (channel_name IS @channelName OR (channel_name IS NULL AND @channelName IS NULL))
|
|
117
117
|
LIMIT 1
|
|
118
|
-
`).get({nextRunAt:t,intent:e.intent??null,channelName:e.channelName??null}),n?
|
|
119
|
-
`)}},{name:"scheduler.cancel",displayName:"Cancel Scheduled Job",category:"scheduler",description:"Cancel a pending scheduled job by its ID.",parameters:{type:"object",properties:{job_id:{type:"string",description:"The ID of the job to cancel."}},required:["job_id"]},execute:async e=>e.job_id?
|
|
118
|
+
`).get({nextRunAt:t,intent:e.intent??null,channelName:e.channelName??null}),n?F(n):null}close(){this.db.close()}};function F(o){return{id:o.id,channelName:o.channel_name??void 0,nextRunAt:o.next_run_at,cron:o.cron??void 0,intent:o.intent??void 0,message:o.message??void 0,payload:o.payload?JSON.parse(o.payload):void 0,status:o.status,lastRunAt:o.last_run_at??void 0,lastError:o.last_error??void 0,createdAt:o.created_at}}d();function pt(o){return{manifest:{key:"scheduler",name:"scheduler",displayName:"Scheduler",version:"1.0.0",description:"Tools for the agent to manage its own scheduled invocations.",category:"scheduler",tools:["scheduler.create","scheduler.list","scheduler.cancel","scheduler.update"]},tools:[{name:"scheduler.create",displayName:"Schedule Job",category:"scheduler",description:["Schedule a future agent invocation.","Provide `cron` for a recurring job or `run_at` (ISO timestamp) for a one-shot job.","The scheduler deduplicates: if a pending job with the same intent + cron (or run_at) + channel already exists, it returns the existing job without creating a duplicate."].join(" "),parameters:{type:"object",properties:{intent:{type:"string",description:'Intent hint forwarded to the agent on trigger (e.g. "weekly_report").'},message:{type:"string",description:"Message forwarded to the agent on trigger."},cron:{type:"string",description:'Cron expression for recurring jobs. E.g. "0 9 * * 1" = 9am every Monday.'},run_at:{type:"string",description:'ISO 8601 timestamp for a one-shot job. E.g. "2026-07-01T09:00:00Z".'},channel_name:{type:"string",description:"Optional channel name to scope this job."},payload:{type:"object",description:"Optional extra data merged into AgentInput.data on trigger."}},required:[]},execute:async e=>{if(!e.cron&&!e.run_at)return"Error: provide either `cron` (recurring) or `run_at` (one-shot).";if(e.cron&&e.run_at)return"Error: provide `cron` OR `run_at`, not both.";if(e.run_at){let t=new Date(e.run_at);if(isNaN(t.getTime()))return`Error: invalid run_at value "${e.run_at}". Provide an ISO 8601 timestamp, e.g. "2026-07-01T09:00:00Z".`}try{let{job:t,duplicate:n}=o.create({intent:e.intent,message:e.message,cron:e.cron,runAt:e.run_at?new Date(e.run_at):void 0,channelName:e.channel_name,payload:e.payload});return n?[`A pending job with the same schedule already exists (id: ${t.id}).`,`Next run: ${new Date(t.nextRunAt).toISOString()}`,"No new job was created."].join(" "):[`Job scheduled (id: ${t.id}).`,t.cron?`Recurring \u2014 cron: "${t.cron}". Next run: ${new Date(t.nextRunAt).toISOString()}.`:`One-shot \u2014 runs at: ${new Date(t.nextRunAt).toISOString()}.`].join(" ")}catch(t){return`Error: ${t.message}`}}},{name:"scheduler.list",displayName:"List Scheduled Jobs",category:"scheduler",description:'List scheduled jobs. Defaults to pending jobs only. Use status="all" to include completed/failed/cancelled.',parameters:{type:"object",properties:{status:{type:"string",enum:["pending","running","completed","failed","cancelled","all"],description:'Filter by job status. Default: "pending".'},channel_name:{type:"string",description:"Filter by channel name."},limit:{type:"number",description:"Maximum number of jobs to return (default: 10, max: 50)."}},required:[]},execute:async e=>{let t=Math.min(e.limit??10,50),n=o.list({status:e.status??"pending",channelName:e.channel_name,limit:t});if(n.length===0)return"No scheduled jobs found.";let r=n.map(s=>{let i=new Date(s.nextRunAt).toISOString(),a=s.cron?`recurring (${s.cron})`:"one-shot",u=s.intent?` intent="${s.intent}"`:"",c=s.lastError?` [last_error: ${s.lastError}]`:"";return`- id=${s.id} status=${s.status} type=${a}${u} next_run=${i}${c}`});return[`${n.length} job(s):`,...r].join(`
|
|
119
|
+
`)}},{name:"scheduler.cancel",displayName:"Cancel Scheduled Job",category:"scheduler",description:"Cancel a pending scheduled job by its ID.",parameters:{type:"object",properties:{job_id:{type:"string",description:"The ID of the job to cancel."}},required:["job_id"]},execute:async e=>e.job_id?o.cancel(e.job_id)?`Job ${e.job_id} has been cancelled.`:`Job ${e.job_id} not found or is not in pending state.`:"Error: job_id is required."},{name:"scheduler.update",displayName:"Update Scheduled Job",category:"scheduler",description:"Modify an existing pending job \u2014 change its cron expression, run time, intent, message, or payload.",parameters:{type:"object",properties:{job_id:{type:"string",description:"The ID of the job to update."},cron:{type:"string",description:"New cron expression (updates nextRunAt automatically)."},run_at:{type:"string",description:"Override the next run time (ISO 8601). Also clears the cron expression, converting the job to a one-shot. Use `cron` if you want the job to remain recurring."},intent:{type:"string",description:"New intent."},message:{type:"string",description:"New message."},payload:{type:"object",description:"New payload (replaces existing)."}},required:["job_id"]},execute:async e=>{if(!e.job_id)return"Error: job_id is required.";if(e.cron&&e.run_at)return"Error: provide `cron` OR `run_at`, not both.";if(e.run_at){let t=new Date(e.run_at);if(isNaN(t.getTime()))return`Error: invalid run_at value "${e.run_at}". Provide an ISO 8601 timestamp, e.g. "2026-07-01T09:00:00Z".`}try{let t=o.update(e.job_id,{cron:e.cron,runAt:e.run_at?new Date(e.run_at):void 0,intent:e.intent,message:e.message,payload:e.payload});return t?[`Job ${t.id} updated.`,`Next run: ${new Date(t.nextRunAt).toISOString()}.`].join(" "):`Job ${e.job_id} not found.`}catch(t){return`Error: ${t.message}`}}}]}}d();d();d();d();d();import{readFileSync as yn,writeFileSync as vn}from"fs";var ne=class o{_cases;constructor(e=[]){this._cases=[...e]}get cases(){return[...this._cases]}get size(){return this._cases.length}get(e){return this._cases.find(t=>t.id===e)}add(...e){let t=new Set(this._cases.map(n=>n.id));for(let n of e){if(t.has(n.id))throw new Error(`EvalDataset: case with id "${n.id}" already exists.`);t.add(n.id)}return this._cases.push(...e),this}remove(e){let t=this._cases.length;return this._cases=this._cases.filter(n=>n.id!==e),this._cases.length<t}filter(e){return new o(this._cases.filter(e))}toJSON(){return[...this._cases]}save(e){vn(e,JSON.stringify(this._cases,null,2),"utf-8")}static load(e){let t=yn(e,"utf-8"),n=JSON.parse(t);return new o(n)}static from(e){return new o(e)}};d();var re=class{agent;constructor(e){this.agent=e}async run(e,t={}){let n=t.runId??new Date().toISOString(),r=Math.max(1,t.concurrency??1),s=new Date().toISOString(),i=Date.now(),a=e.cases,u=[];for(let c=0;c<a.length;c+=r){let l=a.slice(c,c+r),g=await Promise.all(l.map(async p=>{let m=Date.now();try{let w=await this.agent.invokeAgent({message:p.input.message,intent:p.input.intent,conversationId:p.input.conversationId,context:p.input.context});return{evalCase:p,actualOutput:w.output,durationMs:Date.now()-m}}catch(w){return{evalCase:p,actualOutput:"",durationMs:Date.now()-m,error:w instanceof Error?w.message:String(w)}}}));u.push(...g)}return{runId:n,startedAt:s,completedAt:new Date().toISOString(),totalDurationMs:Date.now()-i,results:u}}};d();function ce(o,e){let t=e.filter(r=>r.verdict==="pass").length,n=e.length-t;return{run:o,scoredResults:e,passCount:t,failCount:n,passRate:e.length===0?0:t/e.length}}function S(o,e,t){let n={caseResult:o,verdict:e};return t!==void 0&&(n.explanation=t),n}var se=class{trim;caseInsensitive;constructor(e={}){this.trim=e.trim??!0,this.caseInsensitive=e.caseInsensitive??!1}async score(e){let t=e.results.map(n=>{if(n.error)return S(n,"fail",`Agent threw: ${n.error}`);let r=n.actualOutput,s=n.evalCase.expectedOutput;return this.trim&&(r=r.trim(),s=s.trim()),this.caseInsensitive&&(r=r.toLowerCase(),s=s.toLowerCase()),S(n,r===s?"pass":"fail")});return ce(e,t)}},oe=class{caseInsensitive;constructor(e={}){this.caseInsensitive=e.caseInsensitive??!0}async score(e){let t=e.results.map(n=>{if(n.error)return S(n,"fail",`Agent threw: ${n.error}`);let r=n.actualOutput,s=n.evalCase.expectedOutput;this.caseInsensitive&&(r=r.toLowerCase(),s=s.toLowerCase());let i=r.includes(s);return S(n,i?"pass":"fail")});return ce(e,t)}},wn=`You are an impartial evaluator assessing whether an AI agent's answer is correct.
|
|
120
|
+
|
|
121
|
+
Question / Task:
|
|
122
|
+
{{question}}
|
|
123
|
+
|
|
124
|
+
Expected answer:
|
|
125
|
+
{{expected}}
|
|
126
|
+
|
|
127
|
+
Actual answer:
|
|
128
|
+
{{actual}}
|
|
129
|
+
|
|
130
|
+
Is the actual answer correct or equivalent to the expected answer?
|
|
131
|
+
Respond with ONLY "pass" or "fail" on the first line, then optionally a one-sentence explanation.`,ie=class{judgeAgent;promptTemplate;constructor(e,t={}){this.judgeAgent=e,this.promptTemplate=t.promptTemplate??wn}async score(e){let t=[];for(let n of e.results){if(n.error){t.push(S(n,"fail",`Agent threw: ${n.error}`));continue}let r=this.promptTemplate.replace("{{question}}",n.evalCase.input.message).replace("{{expected}}",n.evalCase.expectedOutput).replace("{{actual}}",n.actualOutput);try{let i=(await this.judgeAgent.invokeAgent({message:r})).output.trim().split(`
|
|
132
|
+
`),a=i[0].toLowerCase().startsWith("pass")?"pass":"fail",u=i.slice(1).join(" ").trim()||void 0;t.push(S(n,a,u))}catch(s){t.push(S(n,"fail",`Judge threw: ${s instanceof Error?s.message:String(s)}`))}}return ce(e,t)}},ae=class{fn;constructor(e){this.fn=e}async score(e){let t=[];for(let n of e.results){if(n.error){t.push(S(n,"fail",`Agent threw: ${n.error}`));continue}try{let{verdict:r,explanation:s}=await this.fn(n);t.push(S(n,r,s))}catch(r){t.push(S(n,"fail",`Scorer threw: ${r instanceof Error?r.message:String(r)}`))}}return ce(e,t)}};d();function gt(o,e){let t=new Map(o.scoredResults.map(l=>[l.caseResult.evalCase.id,l])),n=new Map(e.scoredResults.map(l=>[l.caseResult.evalCase.id,l])),r=[],s=[],i=[],a=[],u=new Set([...t.keys(),...n.keys()]);for(let l of u){let g=t.get(l),p=n.get(l);!g||!p||(g.verdict==="pass"&&p.verdict==="fail"?r.push({caseId:l,baselineOutput:g.caseResult.actualOutput,candidateOutput:p.caseResult.actualOutput}):g.verdict==="fail"&&p.verdict==="pass"?s.push({caseId:l,baselineOutput:g.caseResult.actualOutput,candidateOutput:p.caseResult.actualOutput}):g.verdict==="pass"&&p.verdict==="pass"?i.push(l):a.push(l))}let c=e.passRate-o.passRate;return{baselineRunId:o.run.runId,candidateRunId:e.run.runId,baselinePassRate:o.passRate,candidatePassRate:e.passRate,delta:c,regressions:r,improvements:s,stablePasses:i,stableFails:a}}function mt(o){let e=[],t=o.delta>=0?"+":"",n=r=>`${(r*100).toFixed(1)}%`;if(e.push(`Eval Report: ${o.baselineRunId} \u2192 ${o.candidateRunId}`),e.push(`Pass rate: ${n(o.baselinePassRate)} \u2192 ${n(o.candidatePassRate)} (\u0394${t}${n(o.delta)})`),e.push(""),o.regressions.length>0){e.push(`Regressions (${o.regressions.length}):`);for(let r of o.regressions)e.push(` \u2717 ${r.caseId}`),e.push(` baseline: ${de(r.baselineOutput)}`),e.push(` candidate: ${de(r.candidateOutput)}`);e.push("")}if(o.improvements.length>0){e.push(`Improvements (${o.improvements.length}):`);for(let r of o.improvements)e.push(` \u2713 ${r.caseId}`),e.push(` baseline: ${de(r.baselineOutput)}`),e.push(` candidate: ${de(r.candidateOutput)}`);e.push("")}return e.push(`Stable passes: ${o.stablePasses.length} | Stable fails: ${o.stableFails.length}`),e.join(`
|
|
133
|
+
`)}function de(o,e=80){let t=o.replace(/\n/g," ");return t.length>e?`${t.slice(0,e)}\u2026`:t}d();export{I as AgentError,X as AgentJsonRpcServer,V as AgentMind,Ie as AgentRegistry,C as BaseAgent,b as BaseChannel,Re as BrowserAgent,Ce as CodingAgent,oe as ContainsScorer,ae as CustomScorer,ke as DataAgent,N as DepthExceededError,_e as DiscordChannel,Me as EmailChannel,ne as EvalDataset,re as EvalRunner,se as ExactMatchScorer,lt as InMemoryConversationStore,Q as IntentClassifierAgent,j as InvocationDepthExceededError,Y as JsonRpcTransport,ie as LLMJudgeScorer,O as LocalTransport,De as McpChannel,ee as OTelSpanStatusCode,be as ResearchAgent,D as SKIP_SENTINEL,Pe as SMSChannel,Ee as ScheduledChannel,te as SchedulerStore,xe as SlackChannel,Z as SummarizerAgent,Te as TelegramChannel,Se as WebhookChannel,H as assemblePrompt,gt as compareEvalRuns,z as composeChain,Ge as createAddressCheckInterceptor,L as createCaptureInterceptor,ut as createConversationSearchTool,ze as createDepthGuardInterceptor,Ne as createEventDedupInterceptor,Je as createIntentClassifierInterceptor,$e as createNoiseFilterInterceptor,He as createOTelTracerInterceptor,Fe as createParticipantResolverInterceptor,Ue as createRateLimitInterceptor,pt as createSchedulerTools,je as createSelfFilterInterceptor,qe as createTracerInterceptor,q as executeChain,mt as formatEvalReport,_ as isSkipSentinel,J as skip};
|