opencode-metis 0.1.6 → 0.1.7

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.
Files changed (2) hide show
  1. package/dist/worker.cjs +2 -2
  2. package/package.json +1 -1
package/dist/worker.cjs CHANGED
@@ -84,7 +84,7 @@ ${r}`}var nE="claude-haiku-4-5-20251001",sE=15e3,oE="https://api.anthropic.com/v
84
84
  SET status='pending', retry_count = retry_count + 1
85
85
  WHERE id=?`,[e])}markProcessed(e){this.db.run("DELETE FROM pending_messages WHERE id=?",[e])}markFailed(e){let r=Math.floor(Date.now()/1e3);this.db.run(`UPDATE pending_messages
86
86
  SET status='failed', retry_count = retry_count + 1, failed_at_epoch=?
87
- WHERE id=?`,[r,e])}recover(){return this.db.run("UPDATE pending_messages SET status='pending' WHERE status='processing'").changes}purgeFailed(e=6048e5){let r=Math.floor((Date.now()-e)/1e3);return this.db.run("DELETE FROM pending_messages WHERE status='failed' AND failed_at_epoch <= ?",[r]).changes}getPendingCount(){return this.db.query("SELECT COUNT(*) AS count FROM pending_messages WHERE status='pending'").get()?.count??0}getFailedItems(){return this.db.query("SELECT * FROM pending_messages WHERE status='failed' ORDER BY created_at_epoch ASC, id ASC").all().map(nu)}};function Rm(t){return t.query("SELECT changes() as changes").get()?.changes??0}function SE(t){let e=t.query("SELECT page_count, page_size FROM pragma_page_count(), pragma_page_size()").get();return e===null?0:e.page_count*e.page_size}var Ai=class{constructor(e,r){this.db=e;this.vectorSync=r}purgeByAge(e){let r=Math.floor(Date.now()/1e3)-e*86400;this.db.run("DELETE FROM observations WHERE created_at_epoch < ?",[r]);let n=Rm(this.db);return n>0&&this.vectorSync?.vacuum().catch(()=>{}),{deleted:n}}purgeByProject(e){return this.db.run("DELETE FROM observations WHERE project = ?",[e]),{deleted:Rm(this.db)}}vacuum(){this.db.run("VACUUM")}getStats(){let r=this.db.query("SELECT COUNT(*) as count FROM observations").get()?.count??0,s=this.db.query("SELECT created_at FROM observations ORDER BY created_at_epoch ASC LIMIT 1").get()?.created_at??null,o=SE(this.db);return{observationCount:r,oldestObservation:s,dbSizeBytes:o}}};var _r=class{async syncObservation(e){}async syncSummary(e){}async query(e,r,n,s){return[]}async vacuum(e){}async backfill(e,r){}};var su=20,Pm=5,Im=90,Nm=400;function Mn(t){if(t===null||t==="")return[];try{let e=JSON.parse(t);return Array.isArray(e)?e:[]}catch{return[]}}function EE(t){return{id:t.id,memorySessionId:t.memory_session_id,project:t.project,text:t.text,type:t.type,title:t.title,subtitle:t.subtitle,facts:Mn(t.facts),narrative:t.narrative,concepts:Mn(t.concepts),filesRead:Mn(t.files_read),filesModified:Mn(t.files_modified),promptNumber:t.prompt_number,discoveryTokens:t.discovery_tokens,tags:Mn(t.tags),createdAt:t.created_at,createdAtEpoch:t.created_at_epoch}}function Om(t){let e=t.type,r=t.title??"(untitled)",n=t.narrative??"",s=Mn(t.files_modified),o=n.length>200?`${n.slice(0,200)}...`:n,i=s.length>0?` Files: ${s.slice(0,3).join(", ")}`:"",a=`${e}: ${r}. ${o}.${i}`;return a.length>Nm?a.slice(0,Nm):a}function ji(t,e=null){return{id:t.id,title:t.title??"(untitled)",type:t.type,project:t.project,summary:Om(t),createdAt:t.created_at,relevanceScore:e}}function xE(t){return t instanceof _r}var Mi=class{constructor(e,r,n=null){this.db=e;this.vectorSync=r;this.embeddingService=n}async search(e){let r=e.query;return r===void 0||r===""||r==="*"?this.searchFilterOnly(e):xE(this.vectorSync)?this.searchFallback(r,e):this.searchSemantic_internal(r,e)}async searchSemantic(e,r){let n=this.embeddingService!==null?await this.embeddingService.getEmbedding(e):[],s=await this.vectorSync.query(n,r??"",void 0,Im);if(s.length===0)return[];let o=s.map(c=>c.observationId),i=new Map(s.map(c=>[c.observationId,c.score]));return this.fetchRowsByIds(o).map(c=>ji(c,i.get(c.id)??null))}timeline(e){let{anchor:r,depthBefore:n=Pm,depthAfter:s=Pm}=e,o=this.resolveAnchorId(r);if(o===null)return{entries:[]};let i=this.db.query("SELECT id, created_at_epoch FROM observations WHERE id = ?").get(o);if(i===null)return{entries:[]};let a=this.db.query("SELECT * FROM observations WHERE created_at_epoch < ? ORDER BY created_at_epoch DESC LIMIT ?").all(i.created_at_epoch,n),c=this.db.query("SELECT * FROM observations WHERE created_at_epoch > ? ORDER BY created_at_epoch ASC LIMIT ?").all(i.created_at_epoch,s),u=this.db.query("SELECT * FROM observations WHERE id = ?").get(o);return u===null?{entries:[]}:{entries:[...a.reverse(),u,...c].map(p=>({id:p.id,type:p.type,title:p.title,summary:Om(p),createdAt:p.created_at,isAnchor:p.id===o}))}}batchFetch(e){return e.length===0?[]:this.fetchRowsByIds(e).map(EE)}searchFilterOnly(e){let r=e.limit??su,n=[],s=[];e.type!==void 0&&(n.push("type = ?"),s.push(e.type)),e.project!==void 0&&(n.push("project = ?"),s.push(e.project)),e.dateStart!==void 0&&(n.push("created_at >= ?"),s.push(e.dateStart)),e.dateEnd!==void 0&&(n.push("created_at <= ?"),s.push(e.dateEnd));let o=n.length>0?`WHERE ${n.join(" AND ")}`:"",i=`SELECT * FROM observations ${o} ORDER BY created_at_epoch DESC LIMIT ?`;s.push(r);let a=this.db.query(i).all(...s),c=this.db.query(`SELECT COUNT(*) as count FROM observations ${o}`).get(...s.slice(0,-1));return{results:a.map(u=>ji(u)),total:c?.count??0,mode:"FILTER_ONLY"}}async searchSemantic_internal(e,r){let n=this.embeddingService!==null?await this.embeddingService.getEmbedding(e):[],s=r.limit??su,o=await this.vectorSync.query(n,r.project??"",s,Im);if(o.length===0)return{results:[],total:0,mode:"SEMANTIC"};let i=o.map(l=>l.observationId),a=new Map(o.map(l=>[l.observationId,l.score])),u=this.fetchRowsByIds(i).map(l=>ji(l,a.get(l.id)??null));return{results:u,total:u.length,mode:"SEMANTIC"}}searchFallback(e,r){let n=r.limit??su;try{let s=this.db.query(`SELECT o.* FROM observations o
87
+ WHERE id=?`,[r,e])}recover(){return this.db.run("UPDATE pending_messages SET status='pending' WHERE status='processing'").changes}purgeFailed(e=6048e5){let r=Math.floor((Date.now()-e)/1e3);return this.db.run("DELETE FROM pending_messages WHERE status='failed' AND failed_at_epoch <= ?",[r]).changes}getPendingCount(){return this.db.query("SELECT COUNT(*) AS count FROM pending_messages WHERE status='pending'").get()?.count??0}getFailedItems(){return this.db.query("SELECT * FROM pending_messages WHERE status='failed' ORDER BY created_at_epoch ASC, id ASC").all().map(nu)}};function Rm(t){return t.query("SELECT changes() as changes").get()?.changes??0}function SE(t){let e=t.query("SELECT page_count, page_size FROM pragma_page_count(), pragma_page_size()").get();return e===null?0:e.page_count*e.page_size}var Ai=class{constructor(e,r){this.db=e;this.vectorSync=r}purgeByAge(e){let r=Math.floor(Date.now()/1e3)-e*86400;this.db.run("DELETE FROM observations WHERE created_at_epoch < ?",[r]);let n=Rm(this.db);return n>0&&this.vectorSync?.vacuum().catch(()=>{}),{deleted:n}}purgeByProject(e){return this.db.run("DELETE FROM observations WHERE project = ?",[e]),{deleted:Rm(this.db)}}vacuum(){this.db.run("VACUUM")}getStats(){let r=this.db.query("SELECT COUNT(*) as count FROM observations").get()?.count??0,s=this.db.query("SELECT created_at FROM observations ORDER BY created_at_epoch ASC LIMIT 1").get()?.created_at??null,o=SE(this.db);return{observationCount:r,oldestObservation:s,dbSizeBytes:o}}};var _r=class{async syncObservation(e){}async syncSummary(e){}async query(e,r,n,s,o){return[]}async vacuum(e){}async backfill(e,r){}};var su=20,Pm=5,Im=90,Nm=400;function Mn(t){if(t===null||t==="")return[];try{let e=JSON.parse(t);return Array.isArray(e)?e:[]}catch{return[]}}function EE(t){return{id:t.id,memorySessionId:t.memory_session_id,project:t.project,text:t.text,type:t.type,title:t.title,subtitle:t.subtitle,facts:Mn(t.facts),narrative:t.narrative,concepts:Mn(t.concepts),filesRead:Mn(t.files_read),filesModified:Mn(t.files_modified),promptNumber:t.prompt_number,discoveryTokens:t.discovery_tokens,tags:Mn(t.tags),createdAt:t.created_at,createdAtEpoch:t.created_at_epoch}}function Om(t){let e=t.type,r=t.title??"(untitled)",n=t.narrative??"",s=Mn(t.files_modified),o=n.length>200?`${n.slice(0,200)}...`:n,i=s.length>0?` Files: ${s.slice(0,3).join(", ")}`:"",a=`${e}: ${r}. ${o}.${i}`;return a.length>Nm?a.slice(0,Nm):a}function ji(t,e=null){return{id:t.id,title:t.title??"(untitled)",type:t.type,project:t.project,summary:Om(t),createdAt:t.created_at,relevanceScore:e}}function xE(t){return t instanceof _r}var Mi=class{constructor(e,r,n=null){this.db=e;this.vectorSync=r;this.embeddingService=n}async search(e){let r=e.query;return r===void 0||r===""||r==="*"?this.searchFilterOnly(e):xE(this.vectorSync)?this.searchFallback(r,e):this.searchSemantic_internal(r,e)}async searchSemantic(e,r){let n=this.embeddingService!==null?await this.embeddingService.getEmbedding(e):[],s=await this.vectorSync.query(n,r??"",void 0,Im,e);if(s.length===0)return[];let o=s.map(c=>c.observationId),i=new Map(s.map(c=>[c.observationId,c.score]));return this.fetchRowsByIds(o).map(c=>ji(c,i.get(c.id)??null))}timeline(e){let{anchor:r,depthBefore:n=Pm,depthAfter:s=Pm}=e,o=this.resolveAnchorId(r);if(o===null)return{entries:[]};let i=this.db.query("SELECT id, created_at_epoch FROM observations WHERE id = ?").get(o);if(i===null)return{entries:[]};let a=this.db.query("SELECT * FROM observations WHERE created_at_epoch < ? ORDER BY created_at_epoch DESC LIMIT ?").all(i.created_at_epoch,n),c=this.db.query("SELECT * FROM observations WHERE created_at_epoch > ? ORDER BY created_at_epoch ASC LIMIT ?").all(i.created_at_epoch,s),u=this.db.query("SELECT * FROM observations WHERE id = ?").get(o);return u===null?{entries:[]}:{entries:[...a.reverse(),u,...c].map(p=>({id:p.id,type:p.type,title:p.title,summary:Om(p),createdAt:p.created_at,isAnchor:p.id===o}))}}batchFetch(e){return e.length===0?[]:this.fetchRowsByIds(e).map(EE)}searchFilterOnly(e){let r=e.limit??su,n=[],s=[];e.type!==void 0&&(n.push("type = ?"),s.push(e.type)),e.project!==void 0&&(n.push("project = ?"),s.push(e.project)),e.dateStart!==void 0&&(n.push("created_at >= ?"),s.push(e.dateStart)),e.dateEnd!==void 0&&(n.push("created_at <= ?"),s.push(e.dateEnd));let o=n.length>0?`WHERE ${n.join(" AND ")}`:"",i=`SELECT * FROM observations ${o} ORDER BY created_at_epoch DESC LIMIT ?`;s.push(r);let a=this.db.query(i).all(...s),c=this.db.query(`SELECT COUNT(*) as count FROM observations ${o}`).get(...s.slice(0,-1));return{results:a.map(u=>ji(u)),total:c?.count??0,mode:"FILTER_ONLY"}}async searchSemantic_internal(e,r){let n=this.embeddingService!==null?await this.embeddingService.getEmbedding(e):[],s=r.limit??su,o=await this.vectorSync.query(n,r.project??"",s,Im,e);if(o.length===0)return{results:[],total:0,mode:"SEMANTIC"};let i=o.map(l=>l.observationId),a=new Map(o.map(l=>[l.observationId,l.score])),u=this.fetchRowsByIds(i).map(l=>ji(l,a.get(l.id)??null));return{results:u,total:u.length,mode:"SEMANTIC"}}searchFallback(e,r){let n=r.limit??su;try{let s=this.db.query(`SELECT o.* FROM observations o
88
88
  INNER JOIN observations_fts fts ON o.id = fts.rowid
89
89
  WHERE observations_fts MATCH ?
90
90
  ORDER BY o.created_at_epoch DESC
@@ -315,7 +315,7 @@ END`;function Lm(t,e){for(let r of e.split(";")){let n=r.trim();n.length>0&&t.ru
315
315
  path: iss.path ? [${un($)}, ...iss.path] : [${un($)}]
316
316
  })));`),p.write(`newResult[${un($)}] = ${w}.value`)}p.write("payload.value = newResult;"),p.write("return payload;");let _=p.compile();return($,w)=>_(d,$,w)},s,o=Kn,i=!Gi.jitless,c=i&&bu.value,u=e.catchall,l;t._zod.parse=(d,p)=>{l??(l=r.value);let m=d.value;if(!o(m))return d.issues.push({expected:"object",code:"invalid_type",input:m,inst:t}),d;let f=[];if(i&&c&&p?.async===!1&&p.jitless!==!0)s||(s=n(e.shape)),d=s(d,p);else{d.value={};let w=l.shape;for(let x of l.keys){let E=w[x],ce=E._zod.run({value:m[x],issues:[]},p),ke=E._zod.optin==="optional"&&E._zod.optout==="optional";ce instanceof Promise?f.push(ce.then(Lt=>ke?tg(Lt,d,x,m):ta(Lt,d,x))):ke?tg(ce,d,x,m):ta(ce,d,x)}}if(!u)return f.length?Promise.all(f).then(()=>d):d;let h=[],g=l.keySet,_=u._zod,$=_.def.type;for(let w of Object.keys(m)){if(g.has(w))continue;if($==="never"){h.push(w);continue}let x=_.run({value:m[w],issues:[]},p);x instanceof Promise?f.push(x.then(E=>ta(E,d,w))):ta(x,d,w)}return h.length&&d.issues.push({code:"unrecognized_keys",keys:h,input:m,inst:t}),f.length?Promise.all(f).then(()=>d):d}});function rg(t,e,r,n){for(let s of t)if(s.issues.length===0)return e.value=s.value,e;return e.issues.push({code:"invalid_union",input:e.value,inst:r,errors:t.map(s=>s.issues.map(o=>Rt(o,n,ht())))}),e}var Au=b("$ZodUnion",(t,e)=>{he.init(t,e),me(t._zod,"optin",()=>e.options.some(r=>r._zod.optin==="optional")?"optional":void 0),me(t._zod,"optout",()=>e.options.some(r=>r._zod.optout==="optional")?"optional":void 0),me(t._zod,"values",()=>{if(e.options.every(r=>r._zod.values))return new Set(e.options.flatMap(r=>Array.from(r._zod.values)))}),me(t._zod,"pattern",()=>{if(e.options.every(r=>r._zod.pattern)){let r=e.options.map(n=>n._zod.pattern);return new RegExp(`^(${r.map(n=>Hs(n.source)).join("|")})$`)}}),t._zod.parse=(r,n)=>{let s=!1,o=[];for(let i of e.options){let a=i._zod.run({value:r.value,issues:[]},n);if(a instanceof Promise)o.push(a),s=!0;else{if(a.issues.length===0)return a;o.push(a)}}return s?Promise.all(o).then(i=>rg(i,r,t,n)):rg(o,r,t,n)}}),Lg=b("$ZodDiscriminatedUnion",(t,e)=>{Au.init(t,e);let r=t._zod.parse;me(t._zod,"propValues",()=>{let s={};for(let o of e.options){let i=o._zod.propValues;if(!i||Object.keys(i).length===0)throw new Error(`Invalid discriminated union option at index "${e.options.indexOf(o)}"`);for(let[a,c]of Object.entries(i)){s[a]||(s[a]=new Set);for(let u of c)s[a].add(u)}}return s});let n=Vs(()=>{let s=e.options,o=new Map;for(let i of s){let a=i._zod.propValues[e.discriminator];if(!a||a.size===0)throw new Error(`Invalid discriminated union option at index "${e.options.indexOf(i)}"`);for(let c of a){if(o.has(c))throw new Error(`Duplicate discriminator value "${String(c)}"`);o.set(c,i)}}return o});t._zod.parse=(s,o)=>{let i=s.value;if(!Kn(i))return s.issues.push({code:"invalid_type",expected:"object",input:i,inst:t}),s;let a=n.value.get(i?.[e.discriminator]);return a?a._zod.run(s,o):e.unionFallback?r(s,o):(s.issues.push({code:"invalid_union",errors:[],note:"No matching discriminator",input:i,path:[e.discriminator],inst:t}),s)}}),Zg=b("$ZodIntersection",(t,e)=>{he.init(t,e),t._zod.parse=(r,n)=>{let s=r.value,o=e.left._zod.run({value:s,issues:[]},n),i=e.right._zod.run({value:s,issues:[]},n);return o instanceof Promise||i instanceof Promise?Promise.all([o,i]).then(([c,u])=>ng(r,c,u)):ng(r,o,i)}});function zu(t,e){if(t===e)return{valid:!0,data:t};if(t instanceof Date&&e instanceof Date&&+t==+e)return{valid:!0,data:t};if(Gn(t)&&Gn(e)){let r=Object.keys(e),n=Object.keys(t).filter(o=>r.indexOf(o)!==-1),s={...t,...e};for(let o of n){let i=zu(t[o],e[o]);if(!i.valid)return{valid:!1,mergeErrorPath:[o,...i.mergeErrorPath]};s[o]=i.data}return{valid:!0,data:s}}if(Array.isArray(t)&&Array.isArray(e)){if(t.length!==e.length)return{valid:!1,mergeErrorPath:[]};let r=[];for(let n=0;n<t.length;n++){let s=t[n],o=e[n],i=zu(s,o);if(!i.valid)return{valid:!1,mergeErrorPath:[n,...i.mergeErrorPath]};r.push(i.data)}return{valid:!0,data:r}}return{valid:!1,mergeErrorPath:[]}}function ng(t,e,r){if(e.issues.length&&t.issues.push(...e.issues),r.issues.length&&t.issues.push(...r.issues),ln(t))return t;let n=zu(e.value,r.value);if(!n.valid)throw new Error(`Unmergable intersection. Error path: ${JSON.stringify(n.mergeErrorPath)}`);return t.value=n.data,t}var Ug=b("$ZodRecord",(t,e)=>{he.init(t,e),t._zod.parse=(r,n)=>{let s=r.value;if(!Gn(s))return r.issues.push({expected:"record",code:"invalid_type",input:s,inst:t}),r;let o=[];if(e.keyType._zod.values){let i=e.keyType._zod.values;r.value={};for(let c of i)if(typeof c=="string"||typeof c=="number"||typeof c=="symbol"){let u=e.valueType._zod.run({value:s[c],issues:[]},n);u instanceof Promise?o.push(u.then(l=>{l.issues.length&&r.issues.push(...Ht(c,l.issues)),r.value[c]=l.value})):(u.issues.length&&r.issues.push(...Ht(c,u.issues)),r.value[c]=u.value)}let a;for(let c in s)i.has(c)||(a=a??[],a.push(c));a&&a.length>0&&r.issues.push({code:"unrecognized_keys",input:s,inst:t,keys:a})}else{r.value={};for(let i of Reflect.ownKeys(s)){if(i==="__proto__")continue;let a=e.keyType._zod.run({value:i,issues:[]},n);if(a instanceof Promise)throw new Error("Async schemas not supported in object keys currently");if(a.issues.length){r.issues.push({origin:"record",code:"invalid_key",issues:a.issues.map(u=>Rt(u,n,ht())),input:i,path:[i],inst:t}),r.value[a.value]=a.value;continue}let c=e.valueType._zod.run({value:s[i],issues:[]},n);c instanceof Promise?o.push(c.then(u=>{u.issues.length&&r.issues.push(...Ht(i,u.issues)),r.value[a.value]=u.value})):(c.issues.length&&r.issues.push(...Ht(i,c.issues)),r.value[a.value]=c.value)}}return o.length?Promise.all(o).then(()=>r):r}});var Fg=b("$ZodEnum",(t,e)=>{he.init(t,e);let r=gu(e.entries);t._zod.values=new Set(r),t._zod.pattern=new RegExp(`^(${r.filter(n=>$u.has(typeof n)).map(n=>typeof n=="string"?Er(n):n.toString()).join("|")})$`),t._zod.parse=(n,s)=>{let o=n.value;return t._zod.values.has(o)||n.issues.push({code:"invalid_value",values:r,input:o,inst:t}),n}}),Vg=b("$ZodLiteral",(t,e)=>{he.init(t,e),t._zod.values=new Set(e.values),t._zod.pattern=new RegExp(`^(${e.values.map(r=>typeof r=="string"?Er(r):r?r.toString():String(r)).join("|")})$`),t._zod.parse=(r,n)=>{let s=r.value;return t._zod.values.has(s)||r.issues.push({code:"invalid_value",values:e.values,input:s,inst:t}),r}});var Bg=b("$ZodTransform",(t,e)=>{he.init(t,e),t._zod.parse=(r,n)=>{let s=e.transform(r.value,r);if(n.async)return(s instanceof Promise?s:Promise.resolve(s)).then(i=>(r.value=i,r));if(s instanceof Promise)throw new ir;return r.value=s,r}}),Hg=b("$ZodOptional",(t,e)=>{he.init(t,e),t._zod.optin="optional",t._zod.optout="optional",me(t._zod,"values",()=>e.innerType._zod.values?new Set([...e.innerType._zod.values,void 0]):void 0),me(t._zod,"pattern",()=>{let r=e.innerType._zod.pattern;return r?new RegExp(`^(${Hs(r.source)})?$`):void 0}),t._zod.parse=(r,n)=>e.innerType._zod.optin==="optional"?e.innerType._zod.run(r,n):r.value===void 0?r:e.innerType._zod.run(r,n)}),Kg=b("$ZodNullable",(t,e)=>{he.init(t,e),me(t._zod,"optin",()=>e.innerType._zod.optin),me(t._zod,"optout",()=>e.innerType._zod.optout),me(t._zod,"pattern",()=>{let r=e.innerType._zod.pattern;return r?new RegExp(`^(${Hs(r.source)}|null)$`):void 0}),me(t._zod,"values",()=>e.innerType._zod.values?new Set([...e.innerType._zod.values,null]):void 0),t._zod.parse=(r,n)=>r.value===null?r:e.innerType._zod.run(r,n)}),Gg=b("$ZodDefault",(t,e)=>{he.init(t,e),t._zod.optin="optional",me(t._zod,"values",()=>e.innerType._zod.values),t._zod.parse=(r,n)=>{if(r.value===void 0)return r.value=e.defaultValue,r;let s=e.innerType._zod.run(r,n);return s instanceof Promise?s.then(o=>sg(o,e)):sg(s,e)}});function sg(t,e){return t.value===void 0&&(t.value=e.defaultValue),t}var Wg=b("$ZodPrefault",(t,e)=>{he.init(t,e),t._zod.optin="optional",me(t._zod,"values",()=>e.innerType._zod.values),t._zod.parse=(r,n)=>(r.value===void 0&&(r.value=e.defaultValue),e.innerType._zod.run(r,n))}),Jg=b("$ZodNonOptional",(t,e)=>{he.init(t,e),me(t._zod,"values",()=>{let r=e.innerType._zod.values;return r?new Set([...r].filter(n=>n!==void 0)):void 0}),t._zod.parse=(r,n)=>{let s=e.innerType._zod.run(r,n);return s instanceof Promise?s.then(o=>og(o,t)):og(s,t)}});function og(t,e){return!t.issues.length&&t.value===void 0&&t.issues.push({code:"invalid_type",expected:"nonoptional",input:t.value,inst:e}),t}var Xg=b("$ZodCatch",(t,e)=>{he.init(t,e),t._zod.optin="optional",me(t._zod,"optout",()=>e.innerType._zod.optout),me(t._zod,"values",()=>e.innerType._zod.values),t._zod.parse=(r,n)=>{let s=e.innerType._zod.run(r,n);return s instanceof Promise?s.then(o=>(r.value=o.value,o.issues.length&&(r.value=e.catchValue({...r,error:{issues:o.issues.map(i=>Rt(i,n,ht()))},input:r.value}),r.issues=[]),r)):(r.value=s.value,s.issues.length&&(r.value=e.catchValue({...r,error:{issues:s.issues.map(o=>Rt(o,n,ht()))},input:r.value}),r.issues=[]),r)}});var Yg=b("$ZodPipe",(t,e)=>{he.init(t,e),me(t._zod,"values",()=>e.in._zod.values),me(t._zod,"optin",()=>e.in._zod.optin),me(t._zod,"optout",()=>e.out._zod.optout),t._zod.parse=(r,n)=>{let s=e.in._zod.run(r,n);return s instanceof Promise?s.then(o=>ig(o,e,n)):ig(s,e,n)}});function ig(t,e,r){return ln(t)?t:e.out._zod.run({value:t.value,issues:t.issues},r)}var Qg=b("$ZodReadonly",(t,e)=>{he.init(t,e),me(t._zod,"propValues",()=>e.innerType._zod.propValues),me(t._zod,"values",()=>e.innerType._zod.values),me(t._zod,"optin",()=>e.innerType._zod.optin),me(t._zod,"optout",()=>e.innerType._zod.optout),t._zod.parse=(r,n)=>{let s=e.innerType._zod.run(r,n);return s instanceof Promise?s.then(ag):ag(s)}});function ag(t){return t.value=Object.freeze(t.value),t}var e_=b("$ZodCustom",(t,e)=>{Ue.init(t,e),he.init(t,e),t._zod.parse=(r,n)=>r,t._zod.check=r=>{let n=r.value,s=e.fn(n);if(s instanceof Promise)return s.then(o=>cg(o,r,n,t));cg(s,r,n,t)}});function cg(t,e,r,n){if(!t){let s={code:"custom",input:r,inst:n,path:[...n._zod.def.path??[]],continue:!n._zod.def.abort};n._zod.def.params&&(s.params=n._zod.def.params),e.issues.push(Eu(s))}}var OT=t=>{let e=typeof t;switch(e){case"number":return Number.isNaN(t)?"NaN":"number";case"object":{if(Array.isArray(t))return"array";if(t===null)return"null";if(Object.getPrototypeOf(t)!==Object.prototype&&t.constructor)return t.constructor.name}}return e},zT=()=>{let t={string:{unit:"characters",verb:"to have"},file:{unit:"bytes",verb:"to have"},array:{unit:"items",verb:"to have"},set:{unit:"items",verb:"to have"}};function e(n){return t[n]??null}let r={regex:"input",email:"email address",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO datetime",date:"ISO date",time:"ISO time",duration:"ISO duration",ipv4:"IPv4 address",ipv6:"IPv6 address",cidrv4:"IPv4 range",cidrv6:"IPv6 range",base64:"base64-encoded string",base64url:"base64url-encoded string",json_string:"JSON string",e164:"E.164 number",jwt:"JWT",template_literal:"input"};return n=>{switch(n.code){case"invalid_type":return`Invalid input: expected ${n.expected}, received ${OT(n.input)}`;case"invalid_value":return n.values.length===1?`Invalid input: expected ${Xi(n.values[0])}`:`Invalid option: expected one of ${Wi(n.values,"|")}`;case"too_big":{let s=n.inclusive?"<=":"<",o=e(n.origin);return o?`Too big: expected ${n.origin??"value"} to have ${s}${n.maximum.toString()} ${o.unit??"elements"}`:`Too big: expected ${n.origin??"value"} to be ${s}${n.maximum.toString()}`}case"too_small":{let s=n.inclusive?">=":">",o=e(n.origin);return o?`Too small: expected ${n.origin} to have ${s}${n.minimum.toString()} ${o.unit}`:`Too small: expected ${n.origin} to be ${s}${n.minimum.toString()}`}case"invalid_format":{let s=n;return s.format==="starts_with"?`Invalid string: must start with "${s.prefix}"`:s.format==="ends_with"?`Invalid string: must end with "${s.suffix}"`:s.format==="includes"?`Invalid string: must include "${s.includes}"`:s.format==="regex"?`Invalid string: must match pattern ${s.pattern}`:`Invalid ${r[s.format]??n.format}`}case"not_multiple_of":return`Invalid number: must be a multiple of ${n.divisor}`;case"unrecognized_keys":return`Unrecognized key${n.keys.length>1?"s":""}: ${Wi(n.keys,", ")}`;case"invalid_key":return`Invalid key in ${n.origin}`;case"invalid_union":return"Invalid input";case"invalid_element":return`Invalid value in ${n.origin}`;default:return"Invalid input"}}};function t_(){return{localeError:zT()}}var ju=class{constructor(){this._map=new Map,this._idmap=new Map}add(e,...r){let n=r[0];if(this._map.set(e,n),n&&typeof n=="object"&&"id"in n){if(this._idmap.has(n.id))throw new Error(`ID ${n.id} already exists in the registry`);this._idmap.set(n.id,e)}return this}clear(){return this._map=new Map,this._idmap=new Map,this}remove(e){let r=this._map.get(e);return r&&typeof r=="object"&&"id"in r&&this._idmap.delete(r.id),this._map.delete(e),this}get(e){let r=e._zod.parent;if(r){let n={...this.get(r)??{}};return delete n.id,{...n,...this._map.get(e)}}return this._map.get(e)}has(e){return this._map.has(e)}};function CT(){return new ju}var Js=CT();function r_(t,e){return new t({type:"string",...A(e)})}function n_(t,e){return new t({type:"string",format:"email",check:"string_format",abort:!1,...A(e)})}function Mu(t,e){return new t({type:"string",format:"guid",check:"string_format",abort:!1,...A(e)})}function s_(t,e){return new t({type:"string",format:"uuid",check:"string_format",abort:!1,...A(e)})}function o_(t,e){return new t({type:"string",format:"uuid",check:"string_format",abort:!1,version:"v4",...A(e)})}function i_(t,e){return new t({type:"string",format:"uuid",check:"string_format",abort:!1,version:"v6",...A(e)})}function a_(t,e){return new t({type:"string",format:"uuid",check:"string_format",abort:!1,version:"v7",...A(e)})}function c_(t,e){return new t({type:"string",format:"url",check:"string_format",abort:!1,...A(e)})}function u_(t,e){return new t({type:"string",format:"emoji",check:"string_format",abort:!1,...A(e)})}function l_(t,e){return new t({type:"string",format:"nanoid",check:"string_format",abort:!1,...A(e)})}function d_(t,e){return new t({type:"string",format:"cuid",check:"string_format",abort:!1,...A(e)})}function p_(t,e){return new t({type:"string",format:"cuid2",check:"string_format",abort:!1,...A(e)})}function f_(t,e){return new t({type:"string",format:"ulid",check:"string_format",abort:!1,...A(e)})}function m_(t,e){return new t({type:"string",format:"xid",check:"string_format",abort:!1,...A(e)})}function h_(t,e){return new t({type:"string",format:"ksuid",check:"string_format",abort:!1,...A(e)})}function g_(t,e){return new t({type:"string",format:"ipv4",check:"string_format",abort:!1,...A(e)})}function __(t,e){return new t({type:"string",format:"ipv6",check:"string_format",abort:!1,...A(e)})}function y_(t,e){return new t({type:"string",format:"cidrv4",check:"string_format",abort:!1,...A(e)})}function v_(t,e){return new t({type:"string",format:"cidrv6",check:"string_format",abort:!1,...A(e)})}function b_(t,e){return new t({type:"string",format:"base64",check:"string_format",abort:!1,...A(e)})}function $_(t,e){return new t({type:"string",format:"base64url",check:"string_format",abort:!1,...A(e)})}function w_(t,e){return new t({type:"string",format:"e164",check:"string_format",abort:!1,...A(e)})}function S_(t,e){return new t({type:"string",format:"jwt",check:"string_format",abort:!1,...A(e)})}function E_(t,e){return new t({type:"string",format:"datetime",check:"string_format",offset:!1,local:!1,precision:null,...A(e)})}function x_(t,e){return new t({type:"string",format:"date",check:"string_format",...A(e)})}function T_(t,e){return new t({type:"string",format:"time",check:"string_format",precision:null,...A(e)})}function k_(t,e){return new t({type:"string",format:"duration",check:"string_format",...A(e)})}function R_(t,e){return new t({type:"number",checks:[],...A(e)})}function P_(t,e){return new t({type:"number",check:"number_format",abort:!1,format:"safeint",...A(e)})}function I_(t,e){return new t({type:"boolean",...A(e)})}function N_(t,e){return new t({type:"null",...A(e)})}function O_(t){return new t({type:"unknown"})}function z_(t,e){return new t({type:"never",...A(e)})}function na(t,e){return new Nu({check:"less_than",...A(e),value:t,inclusive:!1})}function Xs(t,e){return new Nu({check:"less_than",...A(e),value:t,inclusive:!0})}function sa(t,e){return new Ou({check:"greater_than",...A(e),value:t,inclusive:!1})}function Ys(t,e){return new Ou({check:"greater_than",...A(e),value:t,inclusive:!0})}function oa(t,e){return new Lh({check:"multiple_of",...A(e),value:t})}function ia(t,e){return new Uh({check:"max_length",...A(e),maximum:t})}function Wn(t,e){return new Fh({check:"min_length",...A(e),minimum:t})}function aa(t,e){return new Vh({check:"length_equals",...A(e),length:t})}function Du(t,e){return new Bh({check:"string_format",format:"regex",...A(e),pattern:t})}function qu(t){return new Hh({check:"string_format",format:"lowercase",...A(t)})}function Lu(t){return new Kh({check:"string_format",format:"uppercase",...A(t)})}function Zu(t,e){return new Gh({check:"string_format",format:"includes",...A(e),includes:t})}function Uu(t,e){return new Wh({check:"string_format",format:"starts_with",...A(e),prefix:t})}function Fu(t,e){return new Jh({check:"string_format",format:"ends_with",...A(e),suffix:t})}function dn(t){return new Xh({check:"overwrite",tx:t})}function Vu(t){return dn(e=>e.normalize(t))}function Bu(){return dn(t=>t.trim())}function Hu(){return dn(t=>t.toLowerCase())}function Ku(){return dn(t=>t.toUpperCase())}function C_(t,e,r){return new t({type:"array",element:e,...A(r)})}function A_(t,e,r){let n=A(r);return n.abort??(n.abort=!0),new t({type:"custom",check:"custom",fn:e,...n})}function j_(t,e,r){return new t({type:"custom",check:"custom",fn:e,...A(r)})}function Jn(t){return!!t._zod}function Pt(t,e){return Jn(t)?Gs(t,e):t.safeParse(e)}function ca(t){if(!t)return;let e;if(Jn(t)?e=t._zod?.def?.shape:e=t.shape,!!e){if(typeof e=="function")try{return e()}catch{return}return e}}function M_(t){if(Jn(t)){let o=t._zod?.def;if(o){if(o.value!==void 0)return o.value;if(Array.isArray(o.values)&&o.values.length>0)return o.values[0]}}let r=t._def;if(r){if(r.value!==void 0)return r.value;if(Array.isArray(r.values)&&r.values.length>0)return r.values[0]}let n=t.value;if(n!==void 0)return n}var eo={};Si(eo,{ZodISODate:()=>q_,ZodISODateTime:()=>D_,ZodISODuration:()=>Z_,ZodISOTime:()=>L_,date:()=>Wu,datetime:()=>Gu,duration:()=>Xu,time:()=>Ju});var D_=b("ZodISODateTime",(t,e)=>{bg.init(t,e),we.init(t,e)});function Gu(t){return E_(D_,t)}var q_=b("ZodISODate",(t,e)=>{$g.init(t,e),we.init(t,e)});function Wu(t){return x_(q_,t)}var L_=b("ZodISOTime",(t,e)=>{wg.init(t,e),we.init(t,e)});function Ju(t){return T_(L_,t)}var Z_=b("ZodISODuration",(t,e)=>{Sg.init(t,e),we.init(t,e)});function Xu(t){return k_(Z_,t)}var U_=(t,e)=>{Yi.init(t,e),t.name="ZodError",Object.defineProperties(t,{format:{value:r=>ah(t,r)},flatten:{value:r=>ih(t,r)},addIssue:{value:r=>t.issues.push(r)},addIssues:{value:r=>t.issues.push(...r)},isEmpty:{get(){return t.issues.length===0}}})},gU=b("ZodError",U_),to=b("ZodError",U_,{Parent:Error});var F_=ch(to),V_=uh(to),B_=Tu(to),H_=ku(to);var Te=b("ZodType",(t,e)=>(he.init(t,e),t.def=e,Object.defineProperty(t,"_def",{value:e}),t.check=(...r)=>t.clone({...e,checks:[...e.checks??[],...r.map(n=>typeof n=="function"?{_zod:{check:n,def:{check:"custom"},onattach:[]}}:n)]}),t.clone=(r,n)=>Bt(t,r,n),t.brand=()=>t,t.register=((r,n)=>(r.add(t,n),t)),t.parse=(r,n)=>F_(t,r,n,{callee:t.parse}),t.safeParse=(r,n)=>B_(t,r,n),t.parseAsync=async(r,n)=>V_(t,r,n,{callee:t.parseAsync}),t.safeParseAsync=async(r,n)=>H_(t,r,n),t.spa=t.safeParseAsync,t.refine=(r,n)=>t.check(Nk(r,n)),t.superRefine=r=>t.check(Ok(r)),t.overwrite=r=>t.check(dn(r)),t.optional=()=>xe(t),t.nullable=()=>W_(t),t.nullish=()=>xe(W_(t)),t.nonoptional=r=>Ek(t,r),t.array=()=>X(t),t.or=r=>ge([t,r]),t.and=r=>la(t,r),t.transform=r=>Qu(t,ey(r)),t.default=r=>$k(t,r),t.prefault=r=>Sk(t,r),t.catch=r=>Tk(t,r),t.pipe=r=>Qu(t,r),t.readonly=()=>Pk(t),t.describe=r=>{let n=t.clone();return Js.add(n,{description:r}),n},Object.defineProperty(t,"description",{get(){return Js.get(t)?.description},configurable:!0}),t.meta=(...r)=>{if(r.length===0)return Js.get(t);let n=t.clone();return Js.add(n,r[0]),n},t.isOptional=()=>t.safeParse(void 0).success,t.isNullable=()=>t.safeParse(null).success,t)),J_=b("_ZodString",(t,e)=>{ra.init(t,e),Te.init(t,e);let r=t._zod.bag;t.format=r.format??null,t.minLength=r.minimum??null,t.maxLength=r.maximum??null,t.regex=(...n)=>t.check(Du(...n)),t.includes=(...n)=>t.check(Zu(...n)),t.startsWith=(...n)=>t.check(Uu(...n)),t.endsWith=(...n)=>t.check(Fu(...n)),t.min=(...n)=>t.check(Wn(...n)),t.max=(...n)=>t.check(ia(...n)),t.length=(...n)=>t.check(aa(...n)),t.nonempty=(...n)=>t.check(Wn(1,...n)),t.lowercase=n=>t.check(qu(n)),t.uppercase=n=>t.check(Lu(n)),t.trim=()=>t.check(Bu()),t.normalize=(...n)=>t.check(Vu(...n)),t.toLowerCase=()=>t.check(Hu()),t.toUpperCase=()=>t.check(Ku())}),FT=b("ZodString",(t,e)=>{ra.init(t,e),J_.init(t,e),t.email=r=>t.check(n_(VT,r)),t.url=r=>t.check(c_(BT,r)),t.jwt=r=>t.check(S_(ik,r)),t.emoji=r=>t.check(u_(HT,r)),t.guid=r=>t.check(Mu(K_,r)),t.uuid=r=>t.check(s_(ua,r)),t.uuidv4=r=>t.check(o_(ua,r)),t.uuidv6=r=>t.check(i_(ua,r)),t.uuidv7=r=>t.check(a_(ua,r)),t.nanoid=r=>t.check(l_(KT,r)),t.guid=r=>t.check(Mu(K_,r)),t.cuid=r=>t.check(d_(GT,r)),t.cuid2=r=>t.check(p_(WT,r)),t.ulid=r=>t.check(f_(JT,r)),t.base64=r=>t.check(b_(nk,r)),t.base64url=r=>t.check($_(sk,r)),t.xid=r=>t.check(m_(XT,r)),t.ksuid=r=>t.check(h_(YT,r)),t.ipv4=r=>t.check(g_(QT,r)),t.ipv6=r=>t.check(__(ek,r)),t.cidrv4=r=>t.check(y_(tk,r)),t.cidrv6=r=>t.check(v_(rk,r)),t.e164=r=>t.check(w_(ok,r)),t.datetime=r=>t.check(Gu(r)),t.date=r=>t.check(Wu(r)),t.time=r=>t.check(Ju(r)),t.duration=r=>t.check(Xu(r))});function v(t){return r_(FT,t)}var we=b("ZodStringFormat",(t,e)=>{_e.init(t,e),J_.init(t,e)}),VT=b("ZodEmail",(t,e)=>{dg.init(t,e),we.init(t,e)});var K_=b("ZodGUID",(t,e)=>{ug.init(t,e),we.init(t,e)});var ua=b("ZodUUID",(t,e)=>{lg.init(t,e),we.init(t,e)});var BT=b("ZodURL",(t,e)=>{pg.init(t,e),we.init(t,e)});var HT=b("ZodEmoji",(t,e)=>{fg.init(t,e),we.init(t,e)});var KT=b("ZodNanoID",(t,e)=>{mg.init(t,e),we.init(t,e)});var GT=b("ZodCUID",(t,e)=>{hg.init(t,e),we.init(t,e)});var WT=b("ZodCUID2",(t,e)=>{gg.init(t,e),we.init(t,e)});var JT=b("ZodULID",(t,e)=>{_g.init(t,e),we.init(t,e)});var XT=b("ZodXID",(t,e)=>{yg.init(t,e),we.init(t,e)});var YT=b("ZodKSUID",(t,e)=>{vg.init(t,e),we.init(t,e)});var QT=b("ZodIPv4",(t,e)=>{Eg.init(t,e),we.init(t,e)});var ek=b("ZodIPv6",(t,e)=>{xg.init(t,e),we.init(t,e)});var tk=b("ZodCIDRv4",(t,e)=>{Tg.init(t,e),we.init(t,e)});var rk=b("ZodCIDRv6",(t,e)=>{kg.init(t,e),we.init(t,e)});var nk=b("ZodBase64",(t,e)=>{Pg.init(t,e),we.init(t,e)});var sk=b("ZodBase64URL",(t,e)=>{Ig.init(t,e),we.init(t,e)});var ok=b("ZodE164",(t,e)=>{Ng.init(t,e),we.init(t,e)});var ik=b("ZodJWT",(t,e)=>{Og.init(t,e),we.init(t,e)});var X_=b("ZodNumber",(t,e)=>{Cu.init(t,e),Te.init(t,e),t.gt=(n,s)=>t.check(sa(n,s)),t.gte=(n,s)=>t.check(Ys(n,s)),t.min=(n,s)=>t.check(Ys(n,s)),t.lt=(n,s)=>t.check(na(n,s)),t.lte=(n,s)=>t.check(Xs(n,s)),t.max=(n,s)=>t.check(Xs(n,s)),t.int=n=>t.check(G_(n)),t.safe=n=>t.check(G_(n)),t.positive=n=>t.check(sa(0,n)),t.nonnegative=n=>t.check(Ys(0,n)),t.negative=n=>t.check(na(0,n)),t.nonpositive=n=>t.check(Xs(0,n)),t.multipleOf=(n,s)=>t.check(oa(n,s)),t.step=(n,s)=>t.check(oa(n,s)),t.finite=()=>t;let r=t._zod.bag;t.minValue=Math.max(r.minimum??Number.NEGATIVE_INFINITY,r.exclusiveMinimum??Number.NEGATIVE_INFINITY)??null,t.maxValue=Math.min(r.maximum??Number.POSITIVE_INFINITY,r.exclusiveMaximum??Number.POSITIVE_INFINITY)??null,t.isInt=(r.format??"").includes("int")||Number.isSafeInteger(r.multipleOf??.5),t.isFinite=!0,t.format=r.format??null});function ae(t){return R_(X_,t)}var ak=b("ZodNumberFormat",(t,e)=>{zg.init(t,e),X_.init(t,e)});function G_(t){return P_(ak,t)}var ck=b("ZodBoolean",(t,e)=>{Cg.init(t,e),Te.init(t,e)});function Ie(t){return I_(ck,t)}var uk=b("ZodNull",(t,e)=>{Ag.init(t,e),Te.init(t,e)});function el(t){return N_(uk,t)}var lk=b("ZodUnknown",(t,e)=>{jg.init(t,e),Te.init(t,e)});function Se(){return O_(lk)}var dk=b("ZodNever",(t,e)=>{Mg.init(t,e),Te.init(t,e)});function pk(t){return z_(dk,t)}var fk=b("ZodArray",(t,e)=>{Dg.init(t,e),Te.init(t,e),t.element=e.element,t.min=(r,n)=>t.check(Wn(r,n)),t.nonempty=r=>t.check(Wn(1,r)),t.max=(r,n)=>t.check(ia(r,n)),t.length=(r,n)=>t.check(aa(r,n)),t.unwrap=()=>t.element});function X(t,e){return C_(fk,t,e)}var Y_=b("ZodObject",(t,e)=>{qg.init(t,e),Te.init(t,e),ie.defineLazy(t,"shape",()=>e.shape),t.keyof=()=>rt(Object.keys(t._zod.def.shape)),t.catchall=r=>t.clone({...t._zod.def,catchall:r}),t.passthrough=()=>t.clone({...t._zod.def,catchall:Se()}),t.loose=()=>t.clone({...t._zod.def,catchall:Se()}),t.strict=()=>t.clone({...t._zod.def,catchall:pk()}),t.strip=()=>t.clone({...t._zod.def,catchall:void 0}),t.extend=r=>ie.extend(t,r),t.merge=r=>ie.merge(t,r),t.pick=r=>ie.pick(t,r),t.omit=r=>ie.omit(t,r),t.partial=(...r)=>ie.partial(ty,t,r[0]),t.required=(...r)=>ie.required(ry,t,r[0])});function R(t,e){let r={type:"object",get shape(){return ie.assignProp(this,"shape",{...t}),this.shape},...ie.normalizeParams(e)};return new Y_(r)}function We(t,e){return new Y_({type:"object",get shape(){return ie.assignProp(this,"shape",{...t}),this.shape},catchall:Se(),...ie.normalizeParams(e)})}var Q_=b("ZodUnion",(t,e)=>{Au.init(t,e),Te.init(t,e),t.options=e.options});function ge(t,e){return new Q_({type:"union",options:t,...ie.normalizeParams(e)})}var mk=b("ZodDiscriminatedUnion",(t,e)=>{Q_.init(t,e),Lg.init(t,e)});function tl(t,e,r){return new mk({type:"union",options:e,discriminator:t,...ie.normalizeParams(r)})}var hk=b("ZodIntersection",(t,e)=>{Zg.init(t,e),Te.init(t,e)});function la(t,e){return new hk({type:"intersection",left:t,right:e})}var gk=b("ZodRecord",(t,e)=>{Ug.init(t,e),Te.init(t,e),t.keyType=e.keyType,t.valueType=e.valueType});function Ee(t,e,r){return new gk({type:"record",keyType:t,valueType:e,...ie.normalizeParams(r)})}var Yu=b("ZodEnum",(t,e)=>{Fg.init(t,e),Te.init(t,e),t.enum=e.entries,t.options=Object.values(e.entries);let r=new Set(Object.keys(e.entries));t.extract=(n,s)=>{let o={};for(let i of n)if(r.has(i))o[i]=e.entries[i];else throw new Error(`Key ${i} not found in enum`);return new Yu({...e,checks:[],...ie.normalizeParams(s),entries:o})},t.exclude=(n,s)=>{let o={...e.entries};for(let i of n)if(r.has(i))delete o[i];else throw new Error(`Key ${i} not found in enum`);return new Yu({...e,checks:[],...ie.normalizeParams(s),entries:o})}});function rt(t,e){let r=Array.isArray(t)?Object.fromEntries(t.map(n=>[n,n])):t;return new Yu({type:"enum",entries:r,...ie.normalizeParams(e)})}var _k=b("ZodLiteral",(t,e)=>{Vg.init(t,e),Te.init(t,e),t.values=new Set(e.values),Object.defineProperty(t,"value",{get(){if(e.values.length>1)throw new Error("This schema contains multiple valid literal values. Use `.values` instead.");return e.values[0]}})});function I(t,e){return new _k({type:"literal",values:Array.isArray(t)?t:[t],...ie.normalizeParams(e)})}var yk=b("ZodTransform",(t,e)=>{Bg.init(t,e),Te.init(t,e),t._zod.parse=(r,n)=>{r.addIssue=o=>{if(typeof o=="string")r.issues.push(ie.issue(o,r.value,e));else{let i=o;i.fatal&&(i.continue=!1),i.code??(i.code="custom"),i.input??(i.input=r.value),i.inst??(i.inst=t),i.continue??(i.continue=!0),r.issues.push(ie.issue(i))}};let s=e.transform(r.value,r);return s instanceof Promise?s.then(o=>(r.value=o,r)):(r.value=s,r)}});function ey(t){return new yk({type:"transform",transform:t})}var ty=b("ZodOptional",(t,e)=>{Hg.init(t,e),Te.init(t,e),t.unwrap=()=>t._zod.def.innerType});function xe(t){return new ty({type:"optional",innerType:t})}var vk=b("ZodNullable",(t,e)=>{Kg.init(t,e),Te.init(t,e),t.unwrap=()=>t._zod.def.innerType});function W_(t){return new vk({type:"nullable",innerType:t})}var bk=b("ZodDefault",(t,e)=>{Gg.init(t,e),Te.init(t,e),t.unwrap=()=>t._zod.def.innerType,t.removeDefault=t.unwrap});function $k(t,e){return new bk({type:"default",innerType:t,get defaultValue(){return typeof e=="function"?e():e}})}var wk=b("ZodPrefault",(t,e)=>{Wg.init(t,e),Te.init(t,e),t.unwrap=()=>t._zod.def.innerType});function Sk(t,e){return new wk({type:"prefault",innerType:t,get defaultValue(){return typeof e=="function"?e():e}})}var ry=b("ZodNonOptional",(t,e)=>{Jg.init(t,e),Te.init(t,e),t.unwrap=()=>t._zod.def.innerType});function Ek(t,e){return new ry({type:"nonoptional",innerType:t,...ie.normalizeParams(e)})}var xk=b("ZodCatch",(t,e)=>{Xg.init(t,e),Te.init(t,e),t.unwrap=()=>t._zod.def.innerType,t.removeCatch=t.unwrap});function Tk(t,e){return new xk({type:"catch",innerType:t,catchValue:typeof e=="function"?e:()=>e})}var kk=b("ZodPipe",(t,e)=>{Yg.init(t,e),Te.init(t,e),t.in=e.in,t.out=e.out});function Qu(t,e){return new kk({type:"pipe",in:t,out:e})}var Rk=b("ZodReadonly",(t,e)=>{Qg.init(t,e),Te.init(t,e)});function Pk(t){return new Rk({type:"readonly",innerType:t})}var ny=b("ZodCustom",(t,e)=>{e_.init(t,e),Te.init(t,e)});function Ik(t){let e=new Ue({check:"custom"});return e._zod.check=t,e}function sy(t,e){return A_(ny,t??(()=>!0),e)}function Nk(t,e={}){return j_(ny,t,e)}function Ok(t){let e=Ik(r=>(r.addIssue=n=>{if(typeof n=="string")r.issues.push(ie.issue(n,r.value,e._zod.def));else{let s=n;s.fatal&&(s.continue=!1),s.code??(s.code="custom"),s.input??(s.input=r.value),s.inst??(s.inst=e),s.continue??(s.continue=!e._zod.def.abort),r.issues.push(ie.issue(s))}},t(r.value,r)));return e}function rl(t,e){return Qu(ey(t),e)}ht(t_());var sl="2025-11-25";var oy=[sl,"2025-06-18","2025-03-26","2024-11-05","2024-10-07"],xr="io.modelcontextprotocol/related-task",pa="2.0",Oe=sy(t=>t!==null&&(typeof t=="object"||typeof t=="function")),iy=ge([v(),ae().int()]),ay=v(),uF=We({ttl:ge([ae(),el()]).optional(),pollInterval:ae().optional()}),zk=R({ttl:ae().optional()}),Ck=R({taskId:v()}),ol=We({progressToken:iy.optional(),[xr]:Ck.optional()}),dt=R({_meta:ol.optional()}),ro=dt.extend({task:zk.optional()}),cy=t=>ro.safeParse(t).success,ze=R({method:v(),params:dt.loose().optional()}),gt=R({_meta:ol.optional()}),_t=R({method:v(),params:gt.loose().optional()}),Ce=We({_meta:ol.optional()}),fa=ge([v(),ae().int()]),uy=R({jsonrpc:I(pa),id:fa,...ze.shape}).strict(),il=t=>uy.safeParse(t).success,ly=R({jsonrpc:I(pa),..._t.shape}).strict(),dy=t=>ly.safeParse(t).success,al=R({jsonrpc:I(pa),id:fa,result:Ce}).strict(),no=t=>al.safeParse(t).success;var M;(function(t){t[t.ConnectionClosed=-32e3]="ConnectionClosed",t[t.RequestTimeout=-32001]="RequestTimeout",t[t.ParseError=-32700]="ParseError",t[t.InvalidRequest=-32600]="InvalidRequest",t[t.MethodNotFound=-32601]="MethodNotFound",t[t.InvalidParams=-32602]="InvalidParams",t[t.InternalError=-32603]="InternalError",t[t.UrlElicitationRequired=-32042]="UrlElicitationRequired"})(M||(M={}));var cl=R({jsonrpc:I(pa),id:fa.optional(),error:R({code:ae().int(),message:v(),data:Se().optional()})}).strict();var py=t=>cl.safeParse(t).success;var fy=ge([uy,ly,al,cl]),lF=ge([al,cl]),pn=Ce.strict(),Ak=gt.extend({requestId:fa.optional(),reason:v().optional()}),ma=_t.extend({method:I("notifications/cancelled"),params:Ak}),jk=R({src:v(),mimeType:v().optional(),sizes:X(v()).optional(),theme:rt(["light","dark"]).optional()}),so=R({icons:X(jk).optional()}),Xn=R({name:v(),title:v().optional()}),my=Xn.extend({...Xn.shape,...so.shape,version:v(),websiteUrl:v().optional(),description:v().optional()}),Mk=la(R({applyDefaults:Ie().optional()}),Ee(v(),Se())),Dk=rl(t=>t&&typeof t=="object"&&!Array.isArray(t)&&Object.keys(t).length===0?{form:{}}:t,la(R({form:Mk.optional(),url:Oe.optional()}),Ee(v(),Se()).optional())),qk=We({list:Oe.optional(),cancel:Oe.optional(),requests:We({sampling:We({createMessage:Oe.optional()}).optional(),elicitation:We({create:Oe.optional()}).optional()}).optional()}),Lk=We({list:Oe.optional(),cancel:Oe.optional(),requests:We({tools:We({call:Oe.optional()}).optional()}).optional()}),Zk=R({experimental:Ee(v(),Oe).optional(),sampling:R({context:Oe.optional(),tools:Oe.optional()}).optional(),elicitation:Dk.optional(),roots:R({listChanged:Ie().optional()}).optional(),tasks:qk.optional()}),Uk=dt.extend({protocolVersion:v(),capabilities:Zk,clientInfo:my}),Fk=ze.extend({method:I("initialize"),params:Uk});var Vk=R({experimental:Ee(v(),Oe).optional(),logging:Oe.optional(),completions:Oe.optional(),prompts:R({listChanged:Ie().optional()}).optional(),resources:R({subscribe:Ie().optional(),listChanged:Ie().optional()}).optional(),tools:R({listChanged:Ie().optional()}).optional(),tasks:Lk.optional()}),ul=Ce.extend({protocolVersion:v(),capabilities:Vk,serverInfo:my,instructions:v().optional()}),Bk=_t.extend({method:I("notifications/initialized"),params:gt.optional()});var ha=ze.extend({method:I("ping"),params:dt.optional()}),Hk=R({progress:ae(),total:xe(ae()),message:xe(v())}),Kk=R({...gt.shape,...Hk.shape,progressToken:iy}),ga=_t.extend({method:I("notifications/progress"),params:Kk}),Gk=dt.extend({cursor:ay.optional()}),oo=ze.extend({params:Gk.optional()}),io=Ce.extend({nextCursor:ay.optional()}),Wk=rt(["working","input_required","completed","failed","cancelled"]),ao=R({taskId:v(),status:Wk,ttl:ge([ae(),el()]),createdAt:v(),lastUpdatedAt:v(),pollInterval:xe(ae()),statusMessage:xe(v())}),fn=Ce.extend({task:ao}),Jk=gt.merge(ao),co=_t.extend({method:I("notifications/tasks/status"),params:Jk}),_a=ze.extend({method:I("tasks/get"),params:dt.extend({taskId:v()})}),ya=Ce.merge(ao),va=ze.extend({method:I("tasks/result"),params:dt.extend({taskId:v()})}),dF=Ce.loose(),ba=oo.extend({method:I("tasks/list")}),$a=io.extend({tasks:X(ao)}),wa=ze.extend({method:I("tasks/cancel"),params:dt.extend({taskId:v()})}),hy=Ce.merge(ao),gy=R({uri:v(),mimeType:xe(v()),_meta:Ee(v(),Se()).optional()}),_y=gy.extend({text:v()}),ll=v().refine(t=>{try{return atob(t),!0}catch{return!1}},{message:"Invalid Base64 string"}),yy=gy.extend({blob:ll}),uo=rt(["user","assistant"]),Yn=R({audience:X(uo).optional(),priority:ae().min(0).max(1).optional(),lastModified:eo.datetime({offset:!0}).optional()}),vy=R({...Xn.shape,...so.shape,uri:v(),description:xe(v()),mimeType:xe(v()),annotations:Yn.optional(),_meta:xe(We({}))}),Xk=R({...Xn.shape,...so.shape,uriTemplate:v(),description:xe(v()),mimeType:xe(v()),annotations:Yn.optional(),_meta:xe(We({}))}),Yk=oo.extend({method:I("resources/list")}),dl=io.extend({resources:X(vy)}),Qk=oo.extend({method:I("resources/templates/list")}),pl=io.extend({resourceTemplates:X(Xk)}),fl=dt.extend({uri:v()}),eR=fl,tR=ze.extend({method:I("resources/read"),params:eR}),ml=Ce.extend({contents:X(ge([_y,yy]))}),hl=_t.extend({method:I("notifications/resources/list_changed"),params:gt.optional()}),rR=fl,nR=ze.extend({method:I("resources/subscribe"),params:rR}),sR=fl,oR=ze.extend({method:I("resources/unsubscribe"),params:sR}),iR=gt.extend({uri:v()}),aR=_t.extend({method:I("notifications/resources/updated"),params:iR}),cR=R({name:v(),description:xe(v()),required:xe(Ie())}),uR=R({...Xn.shape,...so.shape,description:xe(v()),arguments:xe(X(cR)),_meta:xe(We({}))}),lR=oo.extend({method:I("prompts/list")}),gl=io.extend({prompts:X(uR)}),dR=dt.extend({name:v(),arguments:Ee(v(),v()).optional()}),pR=ze.extend({method:I("prompts/get"),params:dR}),_l=R({type:I("text"),text:v(),annotations:Yn.optional(),_meta:Ee(v(),Se()).optional()}),yl=R({type:I("image"),data:ll,mimeType:v(),annotations:Yn.optional(),_meta:Ee(v(),Se()).optional()}),vl=R({type:I("audio"),data:ll,mimeType:v(),annotations:Yn.optional(),_meta:Ee(v(),Se()).optional()}),fR=R({type:I("tool_use"),name:v(),id:v(),input:Ee(v(),Se()),_meta:Ee(v(),Se()).optional()}),mR=R({type:I("resource"),resource:ge([_y,yy]),annotations:Yn.optional(),_meta:Ee(v(),Se()).optional()}),hR=vy.extend({type:I("resource_link")}),bl=ge([_l,yl,vl,hR,mR]),gR=R({role:uo,content:bl}),$l=Ce.extend({description:v().optional(),messages:X(gR)}),wl=_t.extend({method:I("notifications/prompts/list_changed"),params:gt.optional()}),_R=R({title:v().optional(),readOnlyHint:Ie().optional(),destructiveHint:Ie().optional(),idempotentHint:Ie().optional(),openWorldHint:Ie().optional()}),yR=R({taskSupport:rt(["required","optional","forbidden"]).optional()}),by=R({...Xn.shape,...so.shape,description:v().optional(),inputSchema:R({type:I("object"),properties:Ee(v(),Oe).optional(),required:X(v()).optional()}).catchall(Se()),outputSchema:R({type:I("object"),properties:Ee(v(),Oe).optional(),required:X(v()).optional()}).catchall(Se()).optional(),annotations:_R.optional(),execution:yR.optional(),_meta:Ee(v(),Se()).optional()}),vR=oo.extend({method:I("tools/list")}),Sl=io.extend({tools:X(by)}),Qn=Ce.extend({content:X(bl).default([]),structuredContent:Ee(v(),Se()).optional(),isError:Ie().optional()}),pF=Qn.or(Ce.extend({toolResult:Se()})),bR=ro.extend({name:v(),arguments:Ee(v(),Se()).optional()}),$R=ze.extend({method:I("tools/call"),params:bR}),El=_t.extend({method:I("notifications/tools/list_changed"),params:gt.optional()}),$y=R({autoRefresh:Ie().default(!0),debounceMs:ae().int().nonnegative().default(300)}),wy=rt(["debug","info","notice","warning","error","critical","alert","emergency"]),wR=dt.extend({level:wy}),SR=ze.extend({method:I("logging/setLevel"),params:wR}),ER=gt.extend({level:wy,logger:v().optional(),data:Se()}),xR=_t.extend({method:I("notifications/message"),params:ER}),TR=R({name:v().optional()}),kR=R({hints:X(TR).optional(),costPriority:ae().min(0).max(1).optional(),speedPriority:ae().min(0).max(1).optional(),intelligencePriority:ae().min(0).max(1).optional()}),RR=R({mode:rt(["auto","required","none"]).optional()}),PR=R({type:I("tool_result"),toolUseId:v().describe("The unique identifier for the corresponding tool call."),content:X(bl).default([]),structuredContent:R({}).loose().optional(),isError:Ie().optional(),_meta:Ee(v(),Se()).optional()}),IR=tl("type",[_l,yl,vl]),da=tl("type",[_l,yl,vl,fR,PR]),NR=R({role:uo,content:ge([da,X(da)]),_meta:Ee(v(),Se()).optional()}),OR=ro.extend({messages:X(NR),modelPreferences:kR.optional(),systemPrompt:v().optional(),includeContext:rt(["none","thisServer","allServers"]).optional(),temperature:ae().optional(),maxTokens:ae().int(),stopSequences:X(v()).optional(),metadata:Oe.optional(),tools:X(by).optional(),toolChoice:RR.optional()}),xl=ze.extend({method:I("sampling/createMessage"),params:OR}),Tl=Ce.extend({model:v(),stopReason:xe(rt(["endTurn","stopSequence","maxTokens"]).or(v())),role:uo,content:IR}),kl=Ce.extend({model:v(),stopReason:xe(rt(["endTurn","stopSequence","maxTokens","toolUse"]).or(v())),role:uo,content:ge([da,X(da)])}),zR=R({type:I("boolean"),title:v().optional(),description:v().optional(),default:Ie().optional()}),CR=R({type:I("string"),title:v().optional(),description:v().optional(),minLength:ae().optional(),maxLength:ae().optional(),format:rt(["email","uri","date","date-time"]).optional(),default:v().optional()}),AR=R({type:rt(["number","integer"]),title:v().optional(),description:v().optional(),minimum:ae().optional(),maximum:ae().optional(),default:ae().optional()}),jR=R({type:I("string"),title:v().optional(),description:v().optional(),enum:X(v()),default:v().optional()}),MR=R({type:I("string"),title:v().optional(),description:v().optional(),oneOf:X(R({const:v(),title:v()})),default:v().optional()}),DR=R({type:I("string"),title:v().optional(),description:v().optional(),enum:X(v()),enumNames:X(v()).optional(),default:v().optional()}),qR=ge([jR,MR]),LR=R({type:I("array"),title:v().optional(),description:v().optional(),minItems:ae().optional(),maxItems:ae().optional(),items:R({type:I("string"),enum:X(v())}),default:X(v()).optional()}),ZR=R({type:I("array"),title:v().optional(),description:v().optional(),minItems:ae().optional(),maxItems:ae().optional(),items:R({anyOf:X(R({const:v(),title:v()}))}),default:X(v()).optional()}),UR=ge([LR,ZR]),FR=ge([DR,qR,UR]),VR=ge([FR,zR,CR,AR]),BR=ro.extend({mode:I("form").optional(),message:v(),requestedSchema:R({type:I("object"),properties:Ee(v(),VR),required:X(v()).optional()})}),HR=ro.extend({mode:I("url"),message:v(),elicitationId:v(),url:v().url()}),KR=ge([BR,HR]),Rl=ze.extend({method:I("elicitation/create"),params:KR}),GR=gt.extend({elicitationId:v()}),WR=_t.extend({method:I("notifications/elicitation/complete"),params:GR}),Pl=Ce.extend({action:rt(["accept","decline","cancel"]),content:rl(t=>t===null?void 0:t,Ee(v(),ge([v(),ae(),Ie(),X(v())])).optional())}),JR=R({type:I("ref/resource"),uri:v()});var XR=R({type:I("ref/prompt"),name:v()}),YR=dt.extend({ref:ge([XR,JR]),argument:R({name:v(),value:v()}),context:R({arguments:Ee(v(),v()).optional()}).optional()}),QR=ze.extend({method:I("completion/complete"),params:YR});var Il=Ce.extend({completion:We({values:X(v()).max(100),total:xe(ae().int()),hasMore:xe(Ie())})}),eP=R({uri:v().startsWith("file://"),name:v().optional(),_meta:Ee(v(),Se()).optional()}),tP=ze.extend({method:I("roots/list"),params:dt.optional()}),rP=Ce.extend({roots:X(eP)}),nP=_t.extend({method:I("notifications/roots/list_changed"),params:gt.optional()}),fF=ge([ha,Fk,QR,SR,pR,lR,Yk,Qk,tR,nR,oR,$R,vR,_a,va,ba,wa]),mF=ge([ma,ga,Bk,nP,co]),hF=ge([pn,Tl,kl,Pl,rP,ya,$a,fn]),gF=ge([ha,xl,Rl,tP,_a,va,ba,wa]),_F=ge([ma,ga,xR,aR,hl,El,wl,co,WR]),yF=ge([pn,ul,Il,$l,gl,dl,pl,ml,Qn,Sl,ya,$a,fn]),z=class t extends Error{constructor(e,r,n){super(`MCP error ${e}: ${r}`),this.code=e,this.data=n,this.name="McpError"}static fromError(e,r,n){if(e===M.UrlElicitationRequired&&n){let s=n;if(s.elicitations)return new nl(s.elicitations,r)}return new t(e,r,n)}},nl=class extends z{constructor(e,r=`URL elicitation${e.length>1?"s":""} required`){super(M.UrlElicitationRequired,r,{elicitations:e})}get elicitations(){return this.data?.elicitations??[]}};function Tr(t){return t==="completed"||t==="failed"||t==="cancelled"}var XF=new Set("ABCDEFGHIJKLMNOPQRSTUVXYZabcdefghijklmnopqrstuvxyz0123456789");function Nl(t){let r=ca(t)?.method;if(!r)throw new Error("Schema is missing a method literal");let n=M_(r);if(typeof n!="string")throw new Error("Schema method literal must be a string");return n}function Ol(t,e){let r=Pt(t,e);if(!r.success)throw r.error;return r.data}var uP=6e4,Sa=class{constructor(e){this._options=e,this._requestMessageId=0,this._requestHandlers=new Map,this._requestHandlerAbortControllers=new Map,this._notificationHandlers=new Map,this._responseHandlers=new Map,this._progressHandlers=new Map,this._timeoutInfo=new Map,this._pendingDebouncedNotifications=new Set,this._taskProgressTokens=new Map,this._requestResolvers=new Map,this.setNotificationHandler(ma,r=>{this._oncancel(r)}),this.setNotificationHandler(ga,r=>{this._onprogress(r)}),this.setRequestHandler(ha,r=>({})),this._taskStore=e?.taskStore,this._taskMessageQueue=e?.taskMessageQueue,this._taskStore&&(this.setRequestHandler(_a,async(r,n)=>{let s=await this._taskStore.getTask(r.params.taskId,n.sessionId);if(!s)throw new z(M.InvalidParams,"Failed to retrieve task: Task not found");return{...s}}),this.setRequestHandler(va,async(r,n)=>{let s=async()=>{let o=r.params.taskId;if(this._taskMessageQueue){let a;for(;a=await this._taskMessageQueue.dequeue(o,n.sessionId);){if(a.type==="response"||a.type==="error"){let c=a.message,u=c.id,l=this._requestResolvers.get(u);if(l)if(this._requestResolvers.delete(u),a.type==="response")l(c);else{let d=c,p=new z(d.error.code,d.error.message,d.error.data);l(p)}else{let d=a.type==="response"?"Response":"Error";this._onerror(new Error(`${d} handler missing for request ${u}`))}continue}await this._transport?.send(a.message,{relatedRequestId:n.requestId})}}let i=await this._taskStore.getTask(o,n.sessionId);if(!i)throw new z(M.InvalidParams,`Task not found: ${o}`);if(!Tr(i.status))return await this._waitForTaskUpdate(o,n.signal),await s();if(Tr(i.status)){let a=await this._taskStore.getTaskResult(o,n.sessionId);return this._clearTaskQueue(o),{...a,_meta:{...a._meta,[xr]:{taskId:o}}}}return await s()};return await s()}),this.setRequestHandler(ba,async(r,n)=>{try{let{tasks:s,nextCursor:o}=await this._taskStore.listTasks(r.params?.cursor,n.sessionId);return{tasks:s,nextCursor:o,_meta:{}}}catch(s){throw new z(M.InvalidParams,`Failed to list tasks: ${s instanceof Error?s.message:String(s)}`)}}),this.setRequestHandler(wa,async(r,n)=>{try{let s=await this._taskStore.getTask(r.params.taskId,n.sessionId);if(!s)throw new z(M.InvalidParams,`Task not found: ${r.params.taskId}`);if(Tr(s.status))throw new z(M.InvalidParams,`Cannot cancel task in terminal status: ${s.status}`);await this._taskStore.updateTaskStatus(r.params.taskId,"cancelled","Client cancelled task execution.",n.sessionId),this._clearTaskQueue(r.params.taskId);let o=await this._taskStore.getTask(r.params.taskId,n.sessionId);if(!o)throw new z(M.InvalidParams,`Task not found after cancellation: ${r.params.taskId}`);return{_meta:{},...o}}catch(s){throw s instanceof z?s:new z(M.InvalidRequest,`Failed to cancel task: ${s instanceof Error?s.message:String(s)}`)}}))}async _oncancel(e){if(!e.params.requestId)return;this._requestHandlerAbortControllers.get(e.params.requestId)?.abort(e.params.reason)}_setupTimeout(e,r,n,s,o=!1){this._timeoutInfo.set(e,{timeoutId:setTimeout(s,r),startTime:Date.now(),timeout:r,maxTotalTimeout:n,resetTimeoutOnProgress:o,onTimeout:s})}_resetTimeout(e){let r=this._timeoutInfo.get(e);if(!r)return!1;let n=Date.now()-r.startTime;if(r.maxTotalTimeout&&n>=r.maxTotalTimeout)throw this._timeoutInfo.delete(e),z.fromError(M.RequestTimeout,"Maximum total timeout exceeded",{maxTotalTimeout:r.maxTotalTimeout,totalElapsed:n});return clearTimeout(r.timeoutId),r.timeoutId=setTimeout(r.onTimeout,r.timeout),!0}_cleanupTimeout(e){let r=this._timeoutInfo.get(e);r&&(clearTimeout(r.timeoutId),this._timeoutInfo.delete(e))}async connect(e){if(this._transport)throw new Error("Already connected to a transport. Call close() before connecting to a new transport, or use a separate Protocol instance per connection.");this._transport=e;let r=this.transport?.onclose;this._transport.onclose=()=>{r?.(),this._onclose()};let n=this.transport?.onerror;this._transport.onerror=o=>{n?.(o),this._onerror(o)};let s=this._transport?.onmessage;this._transport.onmessage=(o,i)=>{s?.(o,i),no(o)||py(o)?this._onresponse(o):il(o)?this._onrequest(o,i):dy(o)?this._onnotification(o):this._onerror(new Error(`Unknown message type: ${JSON.stringify(o)}`))},await this._transport.start()}_onclose(){let e=this._responseHandlers;this._responseHandlers=new Map,this._progressHandlers.clear(),this._taskProgressTokens.clear(),this._pendingDebouncedNotifications.clear();for(let n of this._requestHandlerAbortControllers.values())n.abort();this._requestHandlerAbortControllers.clear();let r=z.fromError(M.ConnectionClosed,"Connection closed");this._transport=void 0,this.onclose?.();for(let n of e.values())n(r)}_onerror(e){this.onerror?.(e)}_onnotification(e){let r=this._notificationHandlers.get(e.method)??this.fallbackNotificationHandler;r!==void 0&&Promise.resolve().then(()=>r(e)).catch(n=>this._onerror(new Error(`Uncaught error in notification handler: ${n}`)))}_onrequest(e,r){let n=this._requestHandlers.get(e.method)??this.fallbackRequestHandler,s=this._transport,o=e.params?._meta?.[xr]?.taskId;if(n===void 0){let l={jsonrpc:"2.0",id:e.id,error:{code:M.MethodNotFound,message:"Method not found"}};o&&this._taskMessageQueue?this._enqueueTaskMessage(o,{type:"error",message:l,timestamp:Date.now()},s?.sessionId).catch(d=>this._onerror(new Error(`Failed to enqueue error response: ${d}`))):s?.send(l).catch(d=>this._onerror(new Error(`Failed to send an error response: ${d}`)));return}let i=new AbortController;this._requestHandlerAbortControllers.set(e.id,i);let a=cy(e.params)?e.params.task:void 0,c=this._taskStore?this.requestTaskStore(e,s?.sessionId):void 0,u={signal:i.signal,sessionId:s?.sessionId,_meta:e.params?._meta,sendNotification:async l=>{if(i.signal.aborted)return;let d={relatedRequestId:e.id};o&&(d.relatedTask={taskId:o}),await this.notification(l,d)},sendRequest:async(l,d,p)=>{if(i.signal.aborted)throw new z(M.ConnectionClosed,"Request was cancelled");let m={...p,relatedRequestId:e.id};o&&!m.relatedTask&&(m.relatedTask={taskId:o});let f=m.relatedTask?.taskId??o;return f&&c&&await c.updateTaskStatus(f,"input_required"),await this.request(l,d,m)},authInfo:r?.authInfo,requestId:e.id,requestInfo:r?.requestInfo,taskId:o,taskStore:c,taskRequestedTtl:a?.ttl,closeSSEStream:r?.closeSSEStream,closeStandaloneSSEStream:r?.closeStandaloneSSEStream};Promise.resolve().then(()=>{a&&this.assertTaskHandlerCapability(e.method)}).then(()=>n(e,u)).then(async l=>{if(i.signal.aborted)return;let d={result:l,jsonrpc:"2.0",id:e.id};o&&this._taskMessageQueue?await this._enqueueTaskMessage(o,{type:"response",message:d,timestamp:Date.now()},s?.sessionId):await s?.send(d)},async l=>{if(i.signal.aborted)return;let d={jsonrpc:"2.0",id:e.id,error:{code:Number.isSafeInteger(l.code)?l.code:M.InternalError,message:l.message??"Internal error",...l.data!==void 0&&{data:l.data}}};o&&this._taskMessageQueue?await this._enqueueTaskMessage(o,{type:"error",message:d,timestamp:Date.now()},s?.sessionId):await s?.send(d)}).catch(l=>this._onerror(new Error(`Failed to send response: ${l}`))).finally(()=>{this._requestHandlerAbortControllers.delete(e.id)})}_onprogress(e){let{progressToken:r,...n}=e.params,s=Number(r),o=this._progressHandlers.get(s);if(!o){this._onerror(new Error(`Received a progress notification for an unknown token: ${JSON.stringify(e)}`));return}let i=this._responseHandlers.get(s),a=this._timeoutInfo.get(s);if(a&&i&&a.resetTimeoutOnProgress)try{this._resetTimeout(s)}catch(c){this._responseHandlers.delete(s),this._progressHandlers.delete(s),this._cleanupTimeout(s),i(c);return}o(n)}_onresponse(e){let r=Number(e.id),n=this._requestResolvers.get(r);if(n){if(this._requestResolvers.delete(r),no(e))n(e);else{let i=new z(e.error.code,e.error.message,e.error.data);n(i)}return}let s=this._responseHandlers.get(r);if(s===void 0){this._onerror(new Error(`Received a response for an unknown message ID: ${JSON.stringify(e)}`));return}this._responseHandlers.delete(r),this._cleanupTimeout(r);let o=!1;if(no(e)&&e.result&&typeof e.result=="object"){let i=e.result;if(i.task&&typeof i.task=="object"){let a=i.task;typeof a.taskId=="string"&&(o=!0,this._taskProgressTokens.set(a.taskId,r))}}if(o||this._progressHandlers.delete(r),no(e))s(e);else{let i=z.fromError(e.error.code,e.error.message,e.error.data);s(i)}}get transport(){return this._transport}async close(){await this._transport?.close()}async*requestStream(e,r,n){let{task:s}=n??{};if(!s){try{yield{type:"result",result:await this.request(e,r,n)}}catch(i){yield{type:"error",error:i instanceof z?i:new z(M.InternalError,String(i))}}return}let o;try{let i=await this.request(e,fn,n);if(i.task)o=i.task.taskId,yield{type:"taskCreated",task:i.task};else throw new z(M.InternalError,"Task creation did not return a task");for(;;){let a=await this.getTask({taskId:o},n);if(yield{type:"taskStatus",task:a},Tr(a.status)){a.status==="completed"?yield{type:"result",result:await this.getTaskResult({taskId:o},r,n)}:a.status==="failed"?yield{type:"error",error:new z(M.InternalError,`Task ${o} failed`)}:a.status==="cancelled"&&(yield{type:"error",error:new z(M.InternalError,`Task ${o} was cancelled`)});return}if(a.status==="input_required"){yield{type:"result",result:await this.getTaskResult({taskId:o},r,n)};return}let c=a.pollInterval??this._options?.defaultTaskPollInterval??1e3;await new Promise(u=>setTimeout(u,c)),n?.signal?.throwIfAborted()}}catch(i){yield{type:"error",error:i instanceof z?i:new z(M.InternalError,String(i))}}}request(e,r,n){let{relatedRequestId:s,resumptionToken:o,onresumptiontoken:i,task:a,relatedTask:c}=n??{};return new Promise((u,l)=>{let d=$=>{l($)};if(!this._transport){d(new Error("Not connected"));return}if(this._options?.enforceStrictCapabilities===!0)try{this.assertCapabilityForMethod(e.method),a&&this.assertTaskCapability(e.method)}catch($){d($);return}n?.signal?.throwIfAborted();let p=this._requestMessageId++,m={...e,jsonrpc:"2.0",id:p};n?.onprogress&&(this._progressHandlers.set(p,n.onprogress),m.params={...e.params,_meta:{...e.params?._meta||{},progressToken:p}}),a&&(m.params={...m.params,task:a}),c&&(m.params={...m.params,_meta:{...m.params?._meta||{},[xr]:c}});let f=$=>{this._responseHandlers.delete(p),this._progressHandlers.delete(p),this._cleanupTimeout(p),this._transport?.send({jsonrpc:"2.0",method:"notifications/cancelled",params:{requestId:p,reason:String($)}},{relatedRequestId:s,resumptionToken:o,onresumptiontoken:i}).catch(x=>this._onerror(new Error(`Failed to send cancellation: ${x}`)));let w=$ instanceof z?$:new z(M.RequestTimeout,String($));l(w)};this._responseHandlers.set(p,$=>{if(!n?.signal?.aborted){if($ instanceof Error)return l($);try{let w=Pt(r,$.result);w.success?u(w.data):l(w.error)}catch(w){l(w)}}}),n?.signal?.addEventListener("abort",()=>{f(n?.signal?.reason)});let h=n?.timeout??uP,g=()=>f(z.fromError(M.RequestTimeout,"Request timed out",{timeout:h}));this._setupTimeout(p,h,n?.maxTotalTimeout,g,n?.resetTimeoutOnProgress??!1);let _=c?.taskId;if(_){let $=w=>{let x=this._responseHandlers.get(p);x?x(w):this._onerror(new Error(`Response handler missing for side-channeled request ${p}`))};this._requestResolvers.set(p,$),this._enqueueTaskMessage(_,{type:"request",message:m,timestamp:Date.now()}).catch(w=>{this._cleanupTimeout(p),l(w)})}else this._transport.send(m,{relatedRequestId:s,resumptionToken:o,onresumptiontoken:i}).catch($=>{this._cleanupTimeout(p),l($)})})}async getTask(e,r){return this.request({method:"tasks/get",params:e},ya,r)}async getTaskResult(e,r,n){return this.request({method:"tasks/result",params:e},r,n)}async listTasks(e,r){return this.request({method:"tasks/list",params:e},$a,r)}async cancelTask(e,r){return this.request({method:"tasks/cancel",params:e},hy,r)}async notification(e,r){if(!this._transport)throw new Error("Not connected");this.assertNotificationCapability(e.method);let n=r?.relatedTask?.taskId;if(n){let a={...e,jsonrpc:"2.0",params:{...e.params,_meta:{...e.params?._meta||{},[xr]:r.relatedTask}}};await this._enqueueTaskMessage(n,{type:"notification",message:a,timestamp:Date.now()});return}if((this._options?.debouncedNotificationMethods??[]).includes(e.method)&&!e.params&&!r?.relatedRequestId&&!r?.relatedTask){if(this._pendingDebouncedNotifications.has(e.method))return;this._pendingDebouncedNotifications.add(e.method),Promise.resolve().then(()=>{if(this._pendingDebouncedNotifications.delete(e.method),!this._transport)return;let a={...e,jsonrpc:"2.0"};r?.relatedTask&&(a={...a,params:{...a.params,_meta:{...a.params?._meta||{},[xr]:r.relatedTask}}}),this._transport?.send(a,r).catch(c=>this._onerror(c))});return}let i={...e,jsonrpc:"2.0"};r?.relatedTask&&(i={...i,params:{...i.params,_meta:{...i.params?._meta||{},[xr]:r.relatedTask}}}),await this._transport.send(i,r)}setRequestHandler(e,r){let n=Nl(e);this.assertRequestHandlerCapability(n),this._requestHandlers.set(n,(s,o)=>{let i=Ol(e,s);return Promise.resolve(r(i,o))})}removeRequestHandler(e){this._requestHandlers.delete(e)}assertCanSetRequestHandler(e){if(this._requestHandlers.has(e))throw new Error(`A request handler for ${e} already exists, which would be overridden`)}setNotificationHandler(e,r){let n=Nl(e);this._notificationHandlers.set(n,s=>{let o=Ol(e,s);return Promise.resolve(r(o))})}removeNotificationHandler(e){this._notificationHandlers.delete(e)}_cleanupTaskProgressHandler(e){let r=this._taskProgressTokens.get(e);r!==void 0&&(this._progressHandlers.delete(r),this._taskProgressTokens.delete(e))}async _enqueueTaskMessage(e,r,n){if(!this._taskStore||!this._taskMessageQueue)throw new Error("Cannot enqueue task message: taskStore and taskMessageQueue are not configured");let s=this._options?.maxTaskQueueSize;await this._taskMessageQueue.enqueue(e,r,n,s)}async _clearTaskQueue(e,r){if(this._taskMessageQueue){let n=await this._taskMessageQueue.dequeueAll(e,r);for(let s of n)if(s.type==="request"&&il(s.message)){let o=s.message.id,i=this._requestResolvers.get(o);i?(i(new z(M.InternalError,"Task cancelled or completed")),this._requestResolvers.delete(o)):this._onerror(new Error(`Resolver missing for request ${o} during task ${e} cleanup`))}}}async _waitForTaskUpdate(e,r){let n=this._options?.defaultTaskPollInterval??1e3;try{let s=await this._taskStore?.getTask(e);s?.pollInterval&&(n=s.pollInterval)}catch{}return new Promise((s,o)=>{if(r.aborted){o(new z(M.InvalidRequest,"Request cancelled"));return}let i=setTimeout(s,n);r.addEventListener("abort",()=>{clearTimeout(i),o(new z(M.InvalidRequest,"Request cancelled"))},{once:!0})})}requestTaskStore(e,r){let n=this._taskStore;if(!n)throw new Error("No task store configured");return{createTask:async s=>{if(!e)throw new Error("No request provided");return await n.createTask(s,e.id,{method:e.method,params:e.params},r)},getTask:async s=>{let o=await n.getTask(s,r);if(!o)throw new z(M.InvalidParams,"Failed to retrieve task: Task not found");return o},storeTaskResult:async(s,o,i)=>{await n.storeTaskResult(s,o,i,r);let a=await n.getTask(s,r);if(a){let c=co.parse({method:"notifications/tasks/status",params:a});await this.notification(c),Tr(a.status)&&this._cleanupTaskProgressHandler(s)}},getTaskResult:s=>n.getTaskResult(s,r),updateTaskStatus:async(s,o,i)=>{let a=await n.getTask(s,r);if(!a)throw new z(M.InvalidParams,`Task "${s}" not found - it may have been cleaned up`);if(Tr(a.status))throw new z(M.InvalidParams,`Cannot update task "${s}" from terminal status "${a.status}" to "${o}". Terminal states (completed, failed, cancelled) cannot transition to other states.`);await n.updateTaskStatus(s,o,i,r);let c=await n.getTask(s,r);if(c){let u=co.parse({method:"notifications/tasks/status",params:c});await this.notification(u),Tr(c.status)&&this._cleanupTaskProgressHandler(s)}},listTasks:s=>n.listTasks(s,r)}}};function Sy(t){return t!==null&&typeof t=="object"&&!Array.isArray(t)}function Ey(t,e){let r={...t};for(let n in e){let s=n,o=e[s];if(o===void 0)continue;let i=r[s];Sy(i)&&Sy(o)?r[s]={...i,...o}:r[s]=o}return r}var Ew=Ei(Jb(),1),xw=Ei(Sw(),1);function WD(){let t=new Ew.default({strict:!1,validateFormats:!0,validateSchema:!1,allErrors:!0});return(0,xw.default)(t),t}var Ac=class{constructor(e){this._ajv=e??WD()}getValidator(e){let r="$id"in e&&typeof e.$id=="string"?this._ajv.getSchema(e.$id)??this._ajv.compile(e):this._ajv.compile(e);return n=>r(n)?{valid:!0,data:n,errorMessage:void 0}:{valid:!1,data:void 0,errorMessage:this._ajv.errorsText(r.errors)}}};var jc=class{constructor(e){this._client=e}async*callToolStream(e,r=Qn,n){let s=this._client,o={...n,task:n?.task??(s.isToolTask(e.name)?{}:void 0)},i=s.requestStream({method:"tools/call",params:e},r,o),a=s.getToolOutputValidator(e.name);for await(let c of i){if(c.type==="result"&&a){let u=c.result;if(!u.structuredContent&&!u.isError){yield{type:"error",error:new z(M.InvalidRequest,`Tool ${e.name} has an output schema but did not return structured content`)};return}if(u.structuredContent)try{let l=a(u.structuredContent);if(!l.valid){yield{type:"error",error:new z(M.InvalidParams,`Structured content does not match the tool's output schema: ${l.errorMessage}`)};return}}catch(l){if(l instanceof z){yield{type:"error",error:l};return}yield{type:"error",error:new z(M.InvalidParams,`Failed to validate structured content: ${l instanceof Error?l.message:String(l)}`)};return}}yield c}}async getTask(e,r){return this._client.getTask({taskId:e},r)}async getTaskResult(e,r,n){return this._client.getTaskResult({taskId:e},r,n)}async listTasks(e,r){return this._client.listTasks(e?{cursor:e}:void 0,r)}async cancelTask(e,r){return this._client.cancelTask({taskId:e},r)}requestStream(e,r,n){return this._client.requestStream(e,r,n)}};function Tw(t,e,r){if(!t)throw new Error(`${r} does not support task creation (required for ${e})`);switch(e){case"tools/call":if(!t.tools?.call)throw new Error(`${r} does not support task creation for tools/call (required for ${e})`);break;default:break}}function kw(t,e,r){if(!t)throw new Error(`${r} does not support task creation (required for ${e})`);switch(e){case"sampling/createMessage":if(!t.sampling?.createMessage)throw new Error(`${r} does not support task creation for sampling/createMessage (required for ${e})`);break;case"elicitation/create":if(!t.elicitation?.create)throw new Error(`${r} does not support task creation for elicitation/create (required for ${e})`);break;default:break}}function Mc(t,e){if(!(!t||e===null||typeof e!="object")){if(t.type==="object"&&t.properties&&typeof t.properties=="object"){let r=e,n=t.properties;for(let s of Object.keys(n)){let o=n[s];r[s]===void 0&&Object.prototype.hasOwnProperty.call(o,"default")&&(r[s]=o.default),r[s]!==void 0&&Mc(o,r[s])}}if(Array.isArray(t.anyOf))for(let r of t.anyOf)typeof r!="boolean"&&Mc(r,e);if(Array.isArray(t.oneOf))for(let r of t.oneOf)typeof r!="boolean"&&Mc(r,e)}}function JD(t){if(!t)return{supportsFormMode:!1,supportsUrlMode:!1};let e=t.form!==void 0,r=t.url!==void 0;return{supportsFormMode:e||!e&&!r,supportsUrlMode:r}}var Dc=class extends Sa{constructor(e,r){super(r),this._clientInfo=e,this._cachedToolOutputValidators=new Map,this._cachedKnownTaskTools=new Set,this._cachedRequiredTaskTools=new Set,this._listChangedDebounceTimers=new Map,this._capabilities=r?.capabilities??{},this._jsonSchemaValidator=r?.jsonSchemaValidator??new Ac,r?.listChanged&&(this._pendingListChangedConfig=r.listChanged)}_setupListChangedHandlers(e){e.tools&&this._serverCapabilities?.tools?.listChanged&&this._setupListChangedHandler("tools",El,e.tools,async()=>(await this.listTools()).tools),e.prompts&&this._serverCapabilities?.prompts?.listChanged&&this._setupListChangedHandler("prompts",wl,e.prompts,async()=>(await this.listPrompts()).prompts),e.resources&&this._serverCapabilities?.resources?.listChanged&&this._setupListChangedHandler("resources",hl,e.resources,async()=>(await this.listResources()).resources)}get experimental(){return this._experimental||(this._experimental={tasks:new jc(this)}),this._experimental}registerCapabilities(e){if(this.transport)throw new Error("Cannot register capabilities after connecting to transport");this._capabilities=Ey(this._capabilities,e)}setRequestHandler(e,r){let s=ca(e)?.method;if(!s)throw new Error("Schema is missing a method literal");let o;if(Jn(s)){let a=s;o=a._zod?.def?.value??a.value}else{let a=s;o=a._def?.value??a.value}if(typeof o!="string")throw new Error("Schema method literal must be a string");let i=o;if(i==="elicitation/create"){let a=async(c,u)=>{let l=Pt(Rl,c);if(!l.success){let $=l.error instanceof Error?l.error.message:String(l.error);throw new z(M.InvalidParams,`Invalid elicitation request: ${$}`)}let{params:d}=l.data;d.mode=d.mode??"form";let{supportsFormMode:p,supportsUrlMode:m}=JD(this._capabilities.elicitation);if(d.mode==="form"&&!p)throw new z(M.InvalidParams,"Client does not support form-mode elicitation requests");if(d.mode==="url"&&!m)throw new z(M.InvalidParams,"Client does not support URL-mode elicitation requests");let f=await Promise.resolve(r(c,u));if(d.task){let $=Pt(fn,f);if(!$.success){let w=$.error instanceof Error?$.error.message:String($.error);throw new z(M.InvalidParams,`Invalid task creation result: ${w}`)}return $.data}let h=Pt(Pl,f);if(!h.success){let $=h.error instanceof Error?h.error.message:String(h.error);throw new z(M.InvalidParams,`Invalid elicitation result: ${$}`)}let g=h.data,_=d.mode==="form"?d.requestedSchema:void 0;if(d.mode==="form"&&g.action==="accept"&&g.content&&_&&this._capabilities.elicitation?.form?.applyDefaults)try{Mc(_,g.content)}catch{}return g};return super.setRequestHandler(e,a)}if(i==="sampling/createMessage"){let a=async(c,u)=>{let l=Pt(xl,c);if(!l.success){let g=l.error instanceof Error?l.error.message:String(l.error);throw new z(M.InvalidParams,`Invalid sampling request: ${g}`)}let{params:d}=l.data,p=await Promise.resolve(r(c,u));if(d.task){let g=Pt(fn,p);if(!g.success){let _=g.error instanceof Error?g.error.message:String(g.error);throw new z(M.InvalidParams,`Invalid task creation result: ${_}`)}return g.data}let f=d.tools||d.toolChoice?kl:Tl,h=Pt(f,p);if(!h.success){let g=h.error instanceof Error?h.error.message:String(h.error);throw new z(M.InvalidParams,`Invalid sampling result: ${g}`)}return h.data};return super.setRequestHandler(e,a)}return super.setRequestHandler(e,r)}assertCapability(e,r){if(!this._serverCapabilities?.[e])throw new Error(`Server does not support ${e} (required for ${r})`)}async connect(e,r){if(await super.connect(e),e.sessionId===void 0)try{let n=await this.request({method:"initialize",params:{protocolVersion:sl,capabilities:this._capabilities,clientInfo:this._clientInfo}},ul,r);if(n===void 0)throw new Error(`Server sent invalid initialize result: ${n}`);if(!oy.includes(n.protocolVersion))throw new Error(`Server's protocol version is not supported: ${n.protocolVersion}`);this._serverCapabilities=n.capabilities,this._serverVersion=n.serverInfo,e.setProtocolVersion&&e.setProtocolVersion(n.protocolVersion),this._instructions=n.instructions,await this.notification({method:"notifications/initialized"}),this._pendingListChangedConfig&&(this._setupListChangedHandlers(this._pendingListChangedConfig),this._pendingListChangedConfig=void 0)}catch(n){throw this.close(),n}}getServerCapabilities(){return this._serverCapabilities}getServerVersion(){return this._serverVersion}getInstructions(){return this._instructions}assertCapabilityForMethod(e){switch(e){case"logging/setLevel":if(!this._serverCapabilities?.logging)throw new Error(`Server does not support logging (required for ${e})`);break;case"prompts/get":case"prompts/list":if(!this._serverCapabilities?.prompts)throw new Error(`Server does not support prompts (required for ${e})`);break;case"resources/list":case"resources/templates/list":case"resources/read":case"resources/subscribe":case"resources/unsubscribe":if(!this._serverCapabilities?.resources)throw new Error(`Server does not support resources (required for ${e})`);if(e==="resources/subscribe"&&!this._serverCapabilities.resources.subscribe)throw new Error(`Server does not support resource subscriptions (required for ${e})`);break;case"tools/call":case"tools/list":if(!this._serverCapabilities?.tools)throw new Error(`Server does not support tools (required for ${e})`);break;case"completion/complete":if(!this._serverCapabilities?.completions)throw new Error(`Server does not support completions (required for ${e})`);break;case"initialize":break;case"ping":break}}assertNotificationCapability(e){switch(e){case"notifications/roots/list_changed":if(!this._capabilities.roots?.listChanged)throw new Error(`Client does not support roots list changed notifications (required for ${e})`);break;case"notifications/initialized":break;case"notifications/cancelled":break;case"notifications/progress":break}}assertRequestHandlerCapability(e){if(this._capabilities)switch(e){case"sampling/createMessage":if(!this._capabilities.sampling)throw new Error(`Client does not support sampling capability (required for ${e})`);break;case"elicitation/create":if(!this._capabilities.elicitation)throw new Error(`Client does not support elicitation capability (required for ${e})`);break;case"roots/list":if(!this._capabilities.roots)throw new Error(`Client does not support roots capability (required for ${e})`);break;case"tasks/get":case"tasks/list":case"tasks/result":case"tasks/cancel":if(!this._capabilities.tasks)throw new Error(`Client does not support tasks capability (required for ${e})`);break;case"ping":break}}assertTaskCapability(e){Tw(this._serverCapabilities?.tasks?.requests,e,"Server")}assertTaskHandlerCapability(e){this._capabilities&&kw(this._capabilities.tasks?.requests,e,"Client")}async ping(e){return this.request({method:"ping"},pn,e)}async complete(e,r){return this.request({method:"completion/complete",params:e},Il,r)}async setLoggingLevel(e,r){return this.request({method:"logging/setLevel",params:{level:e}},pn,r)}async getPrompt(e,r){return this.request({method:"prompts/get",params:e},$l,r)}async listPrompts(e,r){return this.request({method:"prompts/list",params:e},gl,r)}async listResources(e,r){return this.request({method:"resources/list",params:e},dl,r)}async listResourceTemplates(e,r){return this.request({method:"resources/templates/list",params:e},pl,r)}async readResource(e,r){return this.request({method:"resources/read",params:e},ml,r)}async subscribeResource(e,r){return this.request({method:"resources/subscribe",params:e},pn,r)}async unsubscribeResource(e,r){return this.request({method:"resources/unsubscribe",params:e},pn,r)}async callTool(e,r=Qn,n){if(this.isToolTaskRequired(e.name))throw new z(M.InvalidRequest,`Tool "${e.name}" requires task-based execution. Use client.experimental.tasks.callToolStream() instead.`);let s=await this.request({method:"tools/call",params:e},r,n),o=this.getToolOutputValidator(e.name);if(o){if(!s.structuredContent&&!s.isError)throw new z(M.InvalidRequest,`Tool ${e.name} has an output schema but did not return structured content`);if(s.structuredContent)try{let i=o(s.structuredContent);if(!i.valid)throw new z(M.InvalidParams,`Structured content does not match the tool's output schema: ${i.errorMessage}`)}catch(i){throw i instanceof z?i:new z(M.InvalidParams,`Failed to validate structured content: ${i instanceof Error?i.message:String(i)}`)}}return s}isToolTask(e){return this._serverCapabilities?.tasks?.requests?.tools?.call?this._cachedKnownTaskTools.has(e):!1}isToolTaskRequired(e){return this._cachedRequiredTaskTools.has(e)}cacheToolMetadata(e){this._cachedToolOutputValidators.clear(),this._cachedKnownTaskTools.clear(),this._cachedRequiredTaskTools.clear();for(let r of e){if(r.outputSchema){let s=this._jsonSchemaValidator.getValidator(r.outputSchema);this._cachedToolOutputValidators.set(r.name,s)}let n=r.execution?.taskSupport;(n==="required"||n==="optional")&&this._cachedKnownTaskTools.add(r.name),n==="required"&&this._cachedRequiredTaskTools.add(r.name)}}getToolOutputValidator(e){return this._cachedToolOutputValidators.get(e)}async listTools(e,r){let n=await this.request({method:"tools/list",params:e},Sl,r);return this.cacheToolMetadata(n.tools),n}_setupListChangedHandler(e,r,n,s){let o=$y.safeParse(n);if(!o.success)throw new Error(`Invalid ${e} listChanged options: ${o.error.message}`);if(typeof n.onChanged!="function")throw new Error(`Invalid ${e} listChanged options: onChanged must be a function`);let{autoRefresh:i,debounceMs:a}=o.data,{onChanged:c}=n,u=async()=>{if(!i){c(null,null);return}try{let d=await s();c(null,d)}catch(d){let p=d instanceof Error?d:new Error(String(d));c(p,null)}},l=()=>{if(a){let d=this._listChangedDebounceTimers.get(e);d&&clearTimeout(d);let p=setTimeout(u,a);this._listChangedDebounceTimers.set(e,p)}else u()};this.setNotificationHandler(r,l)}async sendRootsListChanged(){return this.notification({method:"notifications/roots/list_changed"})}};var _S=Ei(hS(),1),hi=Ei(require("node:process"),1),yS=require("node:stream");var Lc=class{append(e){this._buffer=this._buffer?Buffer.concat([this._buffer,e]):e}readMessage(){if(!this._buffer)return null;let e=this._buffer.indexOf(`
317
317
  `);if(e===-1)return null;let r=this._buffer.toString("utf8",0,e).replace(/\r$/,"");return this._buffer=this._buffer.subarray(e+1),Sq(r)}clear(){this._buffer=void 0}};function Sq(t){return fy.parse(JSON.parse(t))}function gS(t){return JSON.stringify(t)+`
318
- `}var Eq=hi.default.platform==="win32"?["APPDATA","HOMEDRIVE","HOMEPATH","LOCALAPPDATA","PATH","PROCESSOR_ARCHITECTURE","SYSTEMDRIVE","SYSTEMROOT","TEMP","USERNAME","USERPROFILE","PROGRAMFILES"]:["HOME","LOGNAME","PATH","SHELL","TERM","USER"];function xq(){let t={};for(let e of Eq){let r=hi.default.env[e];r!==void 0&&(r.startsWith("()")||(t[e]=r))}return t}var Zc=class{constructor(e){this._readBuffer=new Lc,this._stderrStream=null,this._serverParams=e,(e.stderr==="pipe"||e.stderr==="overlapped")&&(this._stderrStream=new yS.PassThrough)}async start(){if(this._process)throw new Error("StdioClientTransport already started! If using Client class, note that connect() calls start() automatically.");return new Promise((e,r)=>{this._process=(0,_S.default)(this._serverParams.command,this._serverParams.args??[],{env:{...xq(),...this._serverParams.env},stdio:["pipe","pipe",this._serverParams.stderr??"inherit"],shell:!1,windowsHide:hi.default.platform==="win32"&&Tq(),cwd:this._serverParams.cwd}),this._process.on("error",n=>{r(n),this.onerror?.(n)}),this._process.on("spawn",()=>{e()}),this._process.on("close",n=>{this._process=void 0,this.onclose?.()}),this._process.stdin?.on("error",n=>{this.onerror?.(n)}),this._process.stdout?.on("data",n=>{this._readBuffer.append(n),this.processReadBuffer()}),this._process.stdout?.on("error",n=>{this.onerror?.(n)}),this._stderrStream&&this._process.stderr&&this._process.stderr.pipe(this._stderrStream)})}get stderr(){return this._stderrStream?this._stderrStream:this._process?.stderr??null}get pid(){return this._process?.pid??null}processReadBuffer(){for(;;)try{let e=this._readBuffer.readMessage();if(e===null)break;this.onmessage?.(e)}catch(e){this.onerror?.(e)}}async close(){if(this._process){let e=this._process;this._process=void 0;let r=new Promise(n=>{e.once("close",()=>{n()})});try{e.stdin?.end()}catch{}if(await Promise.race([r,new Promise(n=>setTimeout(n,2e3).unref())]),e.exitCode===null){try{e.kill("SIGTERM")}catch{}await Promise.race([r,new Promise(n=>setTimeout(n,2e3).unref())])}if(e.exitCode===null)try{e.kill("SIGKILL")}catch{}}this._readBuffer.clear()}send(e){return new Promise(r=>{if(!this._process?.stdin)throw new Error("Not connected");let n=gS(e);this._process.stdin.write(n)?r():this._process.stdin.once("drain",r)})}};function Tq(){return"type"in hi.default}var kq=3,Rq=6e4,Uc=class{client=null;transport=null;circuit={failures:0,openUntil:0};maxFailures;cooldownMs;cleanupRegistered=!1;constructor(e){this.maxFailures=e?.maxFailures??kq,this.cooldownMs=e?.cooldownMs??Rq}async start(){this.transport=new Zc({command:"uvx",args:["chroma-mcp"]}),this.client=new Dc({name:"opencode-metis",version:"1.0"}),this.transport.onclose=()=>{this.recordFailure()},await this.client.connect(this.transport),this.registerCleanupHandlers()}async stop(){try{await this.transport?.close()}catch{}this.client=null,this.transport=null}isAvailable(){return!(this.client===null||this.isCircuitOpen())}async addDocuments(e,r){await this.executeWithCircuitBreaker(async()=>{await this.client?.callTool({name:"add_documents",arguments:{collection_name:e,documents:r.map(n=>n.document),ids:r.map(n=>n.id),metadatas:r.map(n=>n.metadata)}})})}async queryDocuments(e,r,n=10){return this.executeWithCircuitBreaker(async()=>{let s=await this.client?.callTool({name:"query_documents",arguments:{collection_name:e,query_texts:r,n_results:n}});return Pq(s)})}async deleteCollection(e){await this.executeWithCircuitBreaker(async()=>{await this.client?.callTool({name:"delete_collection",arguments:{collection_name:e}})})}getCircuitState(){return this.isCircuitOpen()?"open":"closed"}getCircuitFailures(){return this.circuit.failures}isCircuitOpen(){return this.circuit.openUntil===0?!1:Date.now()<this.circuit.openUntil?!0:(this.circuit={failures:0,openUntil:0},!1)}recordFailure(){this.circuit.failures++,this.circuit.failures>=this.maxFailures&&(this.circuit.openUntil=Date.now()+this.cooldownMs)}async executeWithCircuitBreaker(e){if(this.isCircuitOpen())throw new Error("Circuit breaker open: chroma-mcp unavailable");if(this.client===null)throw new Error("ChromaMcpManager not started");try{let r=await e();return this.circuit={failures:0,openUntil:0},r}catch(r){throw this.recordFailure(),r}}registerCleanupHandlers(){if(this.cleanupRegistered)return;this.cleanupRegistered=!0;let e=()=>{this.stop()};process.once("SIGTERM",e),process.once("exit",e)}};function Pq(t){if(t===null||typeof t!="object")return{ids:[[]],distances:[[]]};let r=t.content;if(!Array.isArray(r)||r.length===0)return{ids:[[]],distances:[[]]};let n=r[0];if(n.type!=="text"||typeof n.text!="string")return{ids:[[]],distances:[[]]};try{let s=JSON.parse(n.text),o=s.ids,i=s.distances;return{ids:Array.isArray(o)?o:[[]],distances:Array.isArray(i)?i:[[]]}}catch{return{ids:[[]],distances:[[]]}}}var vS=384,bS=2e3,Iq=32,Nq="Xenova/all-MiniLM-L6-v2",rH=`https://huggingface.co/${Nq}/resolve/main`;function Oq(t){return t.length>bS?t.slice(0,bS):t}function zq(t){let e=0;for(let r=0;r<t.length;r++)e+=(t[r]??0)*(t[r]??0);return e=Math.sqrt(e),e===0?Array.from(t):Array.from(t).map(r=>r/e)}function Cq(t){let e=0;for(let r=0;r<t.length;r++)e=e*31+t.charCodeAt(r)>>>0;return e}function Aq(t){let e=new Float32Array(vS),r=t;for(let n=0;n<vS;n++)r=r*1664525+1013904223>>>0,e[n]=r/4294967295*2-1;return zq(e)}var Fc=class{async getEmbedding(e){let r=Oq(e),n=Cq(r);return Aq(n)}async getBatchEmbeddings(e,r=Iq){return Promise.all(e.map(n=>this.getEmbedding(n)))}};function pm(t){let e=[],r={observationId:t.id,project:t.project,type:t.type,createdAtEpoch:t.createdAtEpoch};t.narrative&&e.push({id:`obs_${t.id}_narrative`,document:t.narrative,metadata:{...r,field:"narrative"}}),t.text&&e.push({id:`obs_${t.id}_text`,document:t.text,metadata:{...r,field:"text"}});for(let n=0;n<t.facts.length;n++){let s=t.facts[n];s!==void 0&&e.push({id:`obs_${t.id}_fact_${n}`,document:s,metadata:{...r,field:"fact"}})}return e}function fm(t){let e=[],r={summaryId:t.id,project:t.project,createdAtEpoch:t.createdAtEpoch},n=[["request",t.request],["investigated",t.investigated],["learned",t.learned],["completed",t.completed],["next_steps",t.nextSteps],["notes",t.notes]];for(let[s,o]of n)o&&e.push({id:`summary_${t.id}_${s}`,document:o,metadata:{...r,field:s}});return e}var jq=10,Mq=90,Dq=100;function Vc(t){return`cm__${t.length>0?t.toLowerCase():"default"}`}function qq(t){let e=/^obs_(\d+)_/.exec(t);return e===null||e[1]===void 0?null:parseInt(e[1],10)}function Lq(t){let e=t.split("_");return e.length<3?"unknown":e[2]??"unknown"}var Bc=class{manager;constructor(e){this.manager=e}async syncObservation(e){if(!this.manager.isAvailable())return;let r=pm(e);if(r.length===0)return;let n=Vc(e.project);await this.manager.addDocuments(n,r.map(s=>({id:s.id,document:s.document,metadata:s.metadata})))}async syncSummary(e){if(!this.manager.isAvailable())return;let r=fm(e);if(r.length===0)return;let n=Vc(e.project);await this.manager.addDocuments(n,r.map(s=>({id:s.id,document:s.document,metadata:s.metadata})))}async query(e,r,n=jq,s=Mq){if(!this.manager.isAvailable())return[];let o=Vc(r),a=`recency:${Math.floor(Date.now()/1e3)-s*24*60*60}`,c=await this.manager.queryDocuments(o,[a],n),u=c.ids[0]??[],l=c.distances[0]??[],d=new Set,p=[];for(let m=0;m<u.length;m++){let f=u[m];if(f==null)continue;let h=qq(f);if(h===null||d.has(h))continue;d.add(h);let g=l[m]??0;p.push({observationId:h,score:1-g,field:Lq(f)})}return p}async vacuum(e){if(!this.manager.isAvailable()||e===void 0)return;let r=Vc(e);await this.manager.deleteCollection(r)}async backfill(e,r=Dq){if(this.manager.isAvailable())for(let n=0;n<e.length;n+=r){let s=e.slice(n,n+r);await Promise.all(s.map(o=>this.syncObservation(o)))}}};function $S(t){return t===null||!t.isAvailable()?new _r:new Bc(t)}var Hc=require("node:crypto");function wS(){return(0,Hc.randomBytes)(32).toString("hex")}function mm(t){return(0,Hc.createHash)("sha256").update(t).digest("hex")}function SS(t){return e=>{let r=e.headers.get("authorization");if(r===null||!r.startsWith("Bearer "))return!1;let n=r.slice(7);return n.length===0?!1:mm(n)===t}}function hm(t){return t.split("/").filter(Boolean).map(e=>e.startsWith(":")?{kind:"param",name:e.slice(1)}:{kind:"literal",value:e})}function Zq(t,e){if(t.length!==e.length)return null;let r={};for(let n=0;n<t.length;n++){let s=t[n],o=e[n];if(s===void 0||o===void 0)return null;if(s.kind==="literal"){if(s.value!==o)return null}else r[s.name]=o}return r}function ES(t,e){return new Response(JSON.stringify({error:t}),{status:e,headers:{"Content-Type":"application/json"}})}var Kc=class{routes=[];get(e,r){this.routes.push({method:"GET",segments:hm(e),handler:r})}post(e,r){this.routes.push({method:"POST",segments:hm(e),handler:r})}delete(e,r){this.routes.push({method:"DELETE",segments:hm(e),handler:r})}async handle(e){let r=new URL(e.url),n=r.pathname.split("/").filter(Boolean),s=e.method.toUpperCase(),o=!1;for(let i of this.routes){let a=Zq(i.segments,n);if(a!==null&&(o=!0,i.method===s))return await i.handler(e,a)}return o?ES(`Method ${s} not allowed`,405):ES(`Route not found: ${r.pathname}`,404)}};function gm(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function Uq(t,e){return gm({error:t},e)}function Fq(t){return t.sessionManager?.getSessionCount()??0}function Vq(t){return t.db===void 0?0:t.db.query("SELECT COUNT(*) as count FROM observations").get()?.count??0}function Bq(t){return t.retentionManager?.getStats().dbSizeBytes??0}function xS(t,e,r){t.post("/api/admin/shutdown",()=>{let n=gm({shutting_down:!0});return r(),n}),t.get("/api/admin/stats",()=>{if(e.sessionManager===void 0||e.retentionManager===void 0)return Uq("Services not available",503);let n=Fq(e),s=Vq(e),o=Bq(e);return gm({sessions:n,observations:s,dbSize:o})})}function gi(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function Cn(t,e){return gi({error:t},e)}function TS(t,e){t.post("/api/backup/create",async()=>{if(e.backupManager===void 0)return Cn("Backup manager not available",503);let r=await e.backupManager.create();return gi({path:r.path,sizeBytes:r.sizeBytes})}),t.post("/api/backup/restore",async r=>{if(e.backupManager===void 0)return Cn("Backup manager not available",503);let n;try{n=await r.json()}catch{return Cn("Invalid JSON body",400)}let s=n.path;if(typeof s!="string"||s.length===0)return Cn("path is required",400);try{return await e.backupManager.restore(s),gi({success:!0})}catch(o){let i=o instanceof Error?o.message:"Restore failed";return Cn(i,400)}}),t.get("/api/backup/list",async()=>{if(e.backupManager===void 0)return Cn("Backup manager not available",503);let r=await e.backupManager.list();return gi({backups:r})}),t.post("/api/backup/rotate",async r=>{if(e.backupManager===void 0)return Cn("Backup manager not available",503);let n={};try{n=await r.json()}catch{}let s=typeof n.keepCount=="number"?n.keepCount:5,o=await e.backupManager.rotate(s);return gi({deleted:o.deleted})})}function _m(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function kS(t){return t==="core-ready"||t==="ready"}async function Hq(t){if(kS(t.initState))return!0;let e=Date.now()+5e3;for(;Date.now()<e;)if(await new Promise(r=>setTimeout(r,100)),kS(t.initState))return!0;return!1}function _i(t){if(t===null||t==="")return[];try{let e=JSON.parse(t);return Array.isArray(e)?e:[]}catch{return[]}}function RS(t){return{id:t.id,memorySessionId:t.memory_session_id,project:t.project,text:t.text,type:t.type,title:t.title,subtitle:t.subtitle,facts:_i(t.facts),narrative:t.narrative,concepts:_i(t.concepts),filesRead:_i(t.files_read),filesModified:_i(t.files_modified),promptNumber:t.prompt_number,discoveryTokens:t.discovery_tokens,tags:_i(t.tags),createdAt:t.created_at,createdAtEpoch:t.created_at_epoch}}function PS(t){return{id:t.id,memorySessionId:t.memory_session_id,project:t.project,request:t.request,investigated:t.investigated,learned:t.learned,completed:t.completed,nextSteps:t.next_steps,notes:t.notes,createdAt:t.created_at,createdAtEpoch:t.created_at_epoch}}function IS(t){let r=new URL(t.url).searchParams.get("project");if(r!==null)return r;let n=t.headers.get("x-project");if(n!==null)return n}function NS(t,e,r){if(t.db===void 0)return[];let n=Math.floor(Date.now()/1e3)-r*3600;return e!==void 0?t.db.query("SELECT * FROM observations WHERE created_at_epoch >= ? AND project = ? ORDER BY created_at_epoch DESC").all(n,e).map(RS):t.db.query("SELECT * FROM observations WHERE created_at_epoch >= ? ORDER BY created_at_epoch DESC").all(n).map(RS)}function OS(t,e){return t.db===void 0?[]:e!==void 0?t.db.query("SELECT * FROM session_summaries WHERE project = ? ORDER BY created_at_epoch DESC LIMIT 5").all(e).map(PS):t.db.query("SELECT * FROM session_summaries ORDER BY created_at_epoch DESC LIMIT 5").all().map(PS)}function Kq(t,e){let r=e.length>0?e[0]:null,n=r?.completed??r?.request??"None",s=t.filter(c=>c.type==="decision").flatMap(c=>c.facts).filter(c=>c.length>0).slice(0,5),o=t.flatMap(c=>[...c.filesModified,...c.filesRead]).filter((c,u,l)=>c.length>0&&l.indexOf(c)===u).slice(0,10),i=s.length>0?s.join(", "):"None",a=o.length>0?o.join(", "):"None";return["[Memory Context]",`Recent observations: ${t.length}`,`Last session: ${n}`,`Key decisions: ${i}`,`Recent files: ${a}`].join(`
318
+ `}var Eq=hi.default.platform==="win32"?["APPDATA","HOMEDRIVE","HOMEPATH","LOCALAPPDATA","PATH","PROCESSOR_ARCHITECTURE","SYSTEMDRIVE","SYSTEMROOT","TEMP","USERNAME","USERPROFILE","PROGRAMFILES"]:["HOME","LOGNAME","PATH","SHELL","TERM","USER"];function xq(){let t={};for(let e of Eq){let r=hi.default.env[e];r!==void 0&&(r.startsWith("()")||(t[e]=r))}return t}var Zc=class{constructor(e){this._readBuffer=new Lc,this._stderrStream=null,this._serverParams=e,(e.stderr==="pipe"||e.stderr==="overlapped")&&(this._stderrStream=new yS.PassThrough)}async start(){if(this._process)throw new Error("StdioClientTransport already started! If using Client class, note that connect() calls start() automatically.");return new Promise((e,r)=>{this._process=(0,_S.default)(this._serverParams.command,this._serverParams.args??[],{env:{...xq(),...this._serverParams.env},stdio:["pipe","pipe",this._serverParams.stderr??"inherit"],shell:!1,windowsHide:hi.default.platform==="win32"&&Tq(),cwd:this._serverParams.cwd}),this._process.on("error",n=>{r(n),this.onerror?.(n)}),this._process.on("spawn",()=>{e()}),this._process.on("close",n=>{this._process=void 0,this.onclose?.()}),this._process.stdin?.on("error",n=>{this.onerror?.(n)}),this._process.stdout?.on("data",n=>{this._readBuffer.append(n),this.processReadBuffer()}),this._process.stdout?.on("error",n=>{this.onerror?.(n)}),this._stderrStream&&this._process.stderr&&this._process.stderr.pipe(this._stderrStream)})}get stderr(){return this._stderrStream?this._stderrStream:this._process?.stderr??null}get pid(){return this._process?.pid??null}processReadBuffer(){for(;;)try{let e=this._readBuffer.readMessage();if(e===null)break;this.onmessage?.(e)}catch(e){this.onerror?.(e)}}async close(){if(this._process){let e=this._process;this._process=void 0;let r=new Promise(n=>{e.once("close",()=>{n()})});try{e.stdin?.end()}catch{}if(await Promise.race([r,new Promise(n=>setTimeout(n,2e3).unref())]),e.exitCode===null){try{e.kill("SIGTERM")}catch{}await Promise.race([r,new Promise(n=>setTimeout(n,2e3).unref())])}if(e.exitCode===null)try{e.kill("SIGKILL")}catch{}}this._readBuffer.clear()}send(e){return new Promise(r=>{if(!this._process?.stdin)throw new Error("Not connected");let n=gS(e);this._process.stdin.write(n)?r():this._process.stdin.once("drain",r)})}};function Tq(){return"type"in hi.default}var kq=3,Rq=6e4,Uc=class{client=null;transport=null;circuit={failures:0,openUntil:0};maxFailures;cooldownMs;cleanupRegistered=!1;constructor(e){this.maxFailures=e?.maxFailures??kq,this.cooldownMs=e?.cooldownMs??Rq}async start(){this.transport=new Zc({command:"uvx",args:["chroma-mcp"]}),this.client=new Dc({name:"opencode-metis",version:"1.0"}),this.transport.onclose=()=>{this.recordFailure()},await this.client.connect(this.transport),this.registerCleanupHandlers()}async stop(){try{await this.transport?.close()}catch{}this.client=null,this.transport=null}isAvailable(){return!(this.client===null||this.isCircuitOpen())}async addDocuments(e,r){await this.executeWithCircuitBreaker(async()=>{await this.client?.callTool({name:"add_documents",arguments:{collection_name:e,documents:r.map(n=>n.document),ids:r.map(n=>n.id),metadatas:r.map(n=>n.metadata)}})})}async queryDocuments(e,r,n=10){return this.executeWithCircuitBreaker(async()=>{let s=await this.client?.callTool({name:"query_documents",arguments:{collection_name:e,query_texts:r,n_results:n}});return Pq(s)})}async deleteCollection(e){await this.executeWithCircuitBreaker(async()=>{await this.client?.callTool({name:"delete_collection",arguments:{collection_name:e}})})}getCircuitState(){return this.isCircuitOpen()?"open":"closed"}getCircuitFailures(){return this.circuit.failures}isCircuitOpen(){return this.circuit.openUntil===0?!1:Date.now()<this.circuit.openUntil?!0:(this.circuit={failures:0,openUntil:0},!1)}recordFailure(){this.circuit.failures++,this.circuit.failures>=this.maxFailures&&(this.circuit.openUntil=Date.now()+this.cooldownMs)}async executeWithCircuitBreaker(e){if(this.isCircuitOpen())throw new Error("Circuit breaker open: chroma-mcp unavailable");if(this.client===null)throw new Error("ChromaMcpManager not started");try{let r=await e();return this.circuit={failures:0,openUntil:0},r}catch(r){throw this.recordFailure(),r}}registerCleanupHandlers(){if(this.cleanupRegistered)return;this.cleanupRegistered=!0;let e=()=>{this.stop()};process.once("SIGTERM",e),process.once("exit",e)}};function Pq(t){if(t===null||typeof t!="object")return{ids:[[]],distances:[[]]};let r=t.content;if(!Array.isArray(r)||r.length===0)return{ids:[[]],distances:[[]]};let n=r[0];if(n.type!=="text"||typeof n.text!="string")return{ids:[[]],distances:[[]]};try{let s=JSON.parse(n.text),o=s.ids,i=s.distances;return{ids:Array.isArray(o)?o:[[]],distances:Array.isArray(i)?i:[[]]}}catch{return{ids:[[]],distances:[[]]}}}var vS=384,bS=2e3,Iq=32,Nq="Xenova/all-MiniLM-L6-v2",rH=`https://huggingface.co/${Nq}/resolve/main`;function Oq(t){return t.length>bS?t.slice(0,bS):t}function zq(t){let e=0;for(let r=0;r<t.length;r++)e+=(t[r]??0)*(t[r]??0);return e=Math.sqrt(e),e===0?Array.from(t):Array.from(t).map(r=>r/e)}function Cq(t){let e=0;for(let r=0;r<t.length;r++)e=e*31+t.charCodeAt(r)>>>0;return e}function Aq(t){let e=new Float32Array(vS),r=t;for(let n=0;n<vS;n++)r=r*1664525+1013904223>>>0,e[n]=r/4294967295*2-1;return zq(e)}var Fc=class{async getEmbedding(e){let r=Oq(e),n=Cq(r);return Aq(n)}async getBatchEmbeddings(e,r=Iq){return Promise.all(e.map(n=>this.getEmbedding(n)))}};function pm(t){let e=[],r={observationId:t.id,project:t.project,type:t.type,createdAtEpoch:t.createdAtEpoch};t.narrative&&e.push({id:`obs_${t.id}_narrative`,document:t.narrative,metadata:{...r,field:"narrative"}}),t.text&&e.push({id:`obs_${t.id}_text`,document:t.text,metadata:{...r,field:"text"}});for(let n=0;n<t.facts.length;n++){let s=t.facts[n];s!==void 0&&e.push({id:`obs_${t.id}_fact_${n}`,document:s,metadata:{...r,field:"fact"}})}return e}function fm(t){let e=[],r={summaryId:t.id,project:t.project,createdAtEpoch:t.createdAtEpoch},n=[["request",t.request],["investigated",t.investigated],["learned",t.learned],["completed",t.completed],["next_steps",t.nextSteps],["notes",t.notes]];for(let[s,o]of n)o&&e.push({id:`summary_${t.id}_${s}`,document:o,metadata:{...r,field:s}});return e}var jq=10,Mq=90,Dq=100;function Vc(t){return`cm__${t.length>0?t.toLowerCase():"default"}`}function qq(t){let e=/^obs_(\d+)_/.exec(t);return e===null||e[1]===void 0?null:parseInt(e[1],10)}function Lq(t){let e=t.split("_");return e.length<3?"unknown":e[2]??"unknown"}var Bc=class{manager;constructor(e){this.manager=e}async syncObservation(e){if(!this.manager.isAvailable())return;let r=pm(e);if(r.length===0)return;let n=Vc(e.project);await this.manager.addDocuments(n,r.map(s=>({id:s.id,document:s.document,metadata:s.metadata})))}async syncSummary(e){if(!this.manager.isAvailable())return;let r=fm(e);if(r.length===0)return;let n=Vc(e.project);await this.manager.addDocuments(n,r.map(s=>({id:s.id,document:s.document,metadata:s.metadata})))}async query(e,r,n=jq,s=Mq,o){if(!this.manager.isAvailable())return[];let i=o??"";if(i.length===0)return[];let a=Vc(r),c=await this.manager.queryDocuments(a,[i],n),u=c.ids[0]??[],l=c.distances[0]??[],d=new Set,p=[];for(let m=0;m<u.length;m++){let f=u[m];if(f==null)continue;let h=qq(f);if(h===null||d.has(h))continue;d.add(h);let g=l[m]??0;p.push({observationId:h,score:1-g,field:Lq(f)})}return p}async vacuum(e){if(!this.manager.isAvailable()||e===void 0)return;let r=Vc(e);await this.manager.deleteCollection(r)}async backfill(e,r=Dq){if(this.manager.isAvailable())for(let n=0;n<e.length;n+=r){let s=e.slice(n,n+r);await Promise.all(s.map(o=>this.syncObservation(o)))}}};function $S(t){return t===null||!t.isAvailable()?new _r:new Bc(t)}var Hc=require("node:crypto");function wS(){return(0,Hc.randomBytes)(32).toString("hex")}function mm(t){return(0,Hc.createHash)("sha256").update(t).digest("hex")}function SS(t){return e=>{let r=e.headers.get("authorization");if(r===null||!r.startsWith("Bearer "))return!1;let n=r.slice(7);return n.length===0?!1:mm(n)===t}}function hm(t){return t.split("/").filter(Boolean).map(e=>e.startsWith(":")?{kind:"param",name:e.slice(1)}:{kind:"literal",value:e})}function Zq(t,e){if(t.length!==e.length)return null;let r={};for(let n=0;n<t.length;n++){let s=t[n],o=e[n];if(s===void 0||o===void 0)return null;if(s.kind==="literal"){if(s.value!==o)return null}else r[s.name]=o}return r}function ES(t,e){return new Response(JSON.stringify({error:t}),{status:e,headers:{"Content-Type":"application/json"}})}var Kc=class{routes=[];get(e,r){this.routes.push({method:"GET",segments:hm(e),handler:r})}post(e,r){this.routes.push({method:"POST",segments:hm(e),handler:r})}delete(e,r){this.routes.push({method:"DELETE",segments:hm(e),handler:r})}async handle(e){let r=new URL(e.url),n=r.pathname.split("/").filter(Boolean),s=e.method.toUpperCase(),o=!1;for(let i of this.routes){let a=Zq(i.segments,n);if(a!==null&&(o=!0,i.method===s))return await i.handler(e,a)}return o?ES(`Method ${s} not allowed`,405):ES(`Route not found: ${r.pathname}`,404)}};function gm(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function Uq(t,e){return gm({error:t},e)}function Fq(t){return t.sessionManager?.getSessionCount()??0}function Vq(t){return t.db===void 0?0:t.db.query("SELECT COUNT(*) as count FROM observations").get()?.count??0}function Bq(t){return t.retentionManager?.getStats().dbSizeBytes??0}function xS(t,e,r){t.post("/api/admin/shutdown",()=>{let n=gm({shutting_down:!0});return r(),n}),t.get("/api/admin/stats",()=>{if(e.sessionManager===void 0||e.retentionManager===void 0)return Uq("Services not available",503);let n=Fq(e),s=Vq(e),o=Bq(e);return gm({sessions:n,observations:s,dbSize:o})})}function gi(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function Cn(t,e){return gi({error:t},e)}function TS(t,e){t.post("/api/backup/create",async()=>{if(e.backupManager===void 0)return Cn("Backup manager not available",503);let r=await e.backupManager.create();return gi({path:r.path,sizeBytes:r.sizeBytes})}),t.post("/api/backup/restore",async r=>{if(e.backupManager===void 0)return Cn("Backup manager not available",503);let n;try{n=await r.json()}catch{return Cn("Invalid JSON body",400)}let s=n.path;if(typeof s!="string"||s.length===0)return Cn("path is required",400);try{return await e.backupManager.restore(s),gi({success:!0})}catch(o){let i=o instanceof Error?o.message:"Restore failed";return Cn(i,400)}}),t.get("/api/backup/list",async()=>{if(e.backupManager===void 0)return Cn("Backup manager not available",503);let r=await e.backupManager.list();return gi({backups:r})}),t.post("/api/backup/rotate",async r=>{if(e.backupManager===void 0)return Cn("Backup manager not available",503);let n={};try{n=await r.json()}catch{}let s=typeof n.keepCount=="number"?n.keepCount:5,o=await e.backupManager.rotate(s);return gi({deleted:o.deleted})})}function _m(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function kS(t){return t==="core-ready"||t==="ready"}async function Hq(t){if(kS(t.initState))return!0;let e=Date.now()+5e3;for(;Date.now()<e;)if(await new Promise(r=>setTimeout(r,100)),kS(t.initState))return!0;return!1}function _i(t){if(t===null||t==="")return[];try{let e=JSON.parse(t);return Array.isArray(e)?e:[]}catch{return[]}}function RS(t){return{id:t.id,memorySessionId:t.memory_session_id,project:t.project,text:t.text,type:t.type,title:t.title,subtitle:t.subtitle,facts:_i(t.facts),narrative:t.narrative,concepts:_i(t.concepts),filesRead:_i(t.files_read),filesModified:_i(t.files_modified),promptNumber:t.prompt_number,discoveryTokens:t.discovery_tokens,tags:_i(t.tags),createdAt:t.created_at,createdAtEpoch:t.created_at_epoch}}function PS(t){return{id:t.id,memorySessionId:t.memory_session_id,project:t.project,request:t.request,investigated:t.investigated,learned:t.learned,completed:t.completed,nextSteps:t.next_steps,notes:t.notes,createdAt:t.created_at,createdAtEpoch:t.created_at_epoch}}function IS(t){let r=new URL(t.url).searchParams.get("project");if(r!==null)return r;let n=t.headers.get("x-project");if(n!==null)return n}function NS(t,e,r){if(t.db===void 0)return[];let n=Math.floor(Date.now()/1e3)-r*3600;return e!==void 0?t.db.query("SELECT * FROM observations WHERE created_at_epoch >= ? AND project = ? ORDER BY created_at_epoch DESC").all(n,e).map(RS):t.db.query("SELECT * FROM observations WHERE created_at_epoch >= ? ORDER BY created_at_epoch DESC").all(n).map(RS)}function OS(t,e){return t.db===void 0?[]:e!==void 0?t.db.query("SELECT * FROM session_summaries WHERE project = ? ORDER BY created_at_epoch DESC LIMIT 5").all(e).map(PS):t.db.query("SELECT * FROM session_summaries ORDER BY created_at_epoch DESC LIMIT 5").all().map(PS)}function Kq(t,e){let r=e.length>0?e[0]:null,n=r?.completed??r?.request??"None",s=t.filter(c=>c.type==="decision").flatMap(c=>c.facts).filter(c=>c.length>0).slice(0,5),o=t.flatMap(c=>[...c.filesModified,...c.filesRead]).filter((c,u,l)=>c.length>0&&l.indexOf(c)===u).slice(0,10),i=s.length>0?s.join(", "):"None",a=o.length>0?o.join(", "):"None";return["[Memory Context]",`Recent observations: ${t.length}`,`Last session: ${n}`,`Key decisions: ${i}`,`Recent files: ${a}`].join(`
319
319
  `)}function zS(t,e){t.get("/api/context/inject",async r=>{if(!await Hq(e))return _m({context:""});let s=IS(r),o=NS(e,s,24),i=OS(e,s),a=Kq(o,i);return _m({context:a})}),t.get("/api/context/recent",r=>{let n=IS(r),o=new URL(r.url).searchParams.get("hours"),i=o!==null?parseInt(o,10):24,a=NS(e,n,i),c=OS(e,n);return _m({observations:a,summaries:c})})}var Gq=process.env.npm_package_version??"0.1.0",Wq=Date.now();function Jq(t){return t==="core-ready"||t==="ready"}function Xq(t){return t==="ready"}function Cs(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function CS(t,e){t.get("/api/health",()=>Cs({build:Gq,initState:e.initState,pid:process.pid,uptime:Math.floor((Date.now()-Wq)/1e3)})),t.get("/api/core-ready",()=>Jq(e.initState)?Cs({ready:!0}):Cs({ready:!1,initState:e.initState},503)),t.get("/api/readiness",()=>Xq(e.initState)?Cs({ready:!0}):Cs({ready:!1,initState:e.initState},503)),t.get("/api/process-stats",()=>{let r=process.memoryUsage();return Cs({rss:r.rss,heapUsed:r.heapUsed,uptime:process.uptime()})})}var AS=de.object({text:de.string().min(1),title:de.string().optional(),project:de.string().optional()}),jS=de.object({query:de.string().optional(),limit:de.number().int().min(1).max(100).default(20),type:de.string().optional(),project:de.string().optional(),dateStart:de.string().optional(),dateEnd:de.string().optional()}),MS=de.object({query:de.string().min(1)}),DS=de.object({anchor:de.string().min(1),depth_before:de.number().int().min(0).default(5),depth_after:de.number().int().min(0).default(5)}),ym=de.object({ids:de.array(de.number().int()).min(1)}),bH=de.object({contentSessionId:de.string().min(1),project:de.string().min(1),memorySessionId:de.string().optional()});var Yq="default";function qS(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function Gc(t,e){return qS({error:t},e)}function LS(t,e){t.post("/api/memory/save",async r=>{let{observationWriter:n,sessionManager:s}=e;if(n===void 0||s===void 0)return Gc("Service unavailable",503);let o;try{o=await r.json()}catch{return Gc("Invalid JSON body",400)}let i=AS.safeParse(o);if(!i.success)return Gc(i.error.issues[0]?.message??"Validation error",400);let{text:a,title:c,project:u=Yq}=i.data;try{let l=s.createSession({contentSessionId:crypto.randomUUID(),project:u}),d={memorySessionId:l.memorySessionId,sessionDbId:l.id,contentSessionId:l.contentSessionId,project:u,text:a,...c!==void 0?{title:c}:{}},p=await n.write(d);return qS({success:!0,id:p.id,title:p.title??c??"",project:p.project,message:"Observation saved"})}catch(l){let d=l instanceof Error?l.message:"Failed to save observation";return Gc(d,500)}})}function Wc(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function qt(t,e){return Wc({error:t},e)}function ZS(t,e){t.post("/api/observations/batch",async r=>{let{searchManager:n}=e;if(n===void 0)return qt("Service unavailable",503);let s;try{s=await r.json()}catch{return qt("Invalid JSON body",400)}let o=ym.safeParse(s);if(!o.success)return qt(o.error.issues[0]?.message??"Validation error",400);try{let i=n.batchFetch(o.data.ids);return Wc({observations:i})}catch(i){let a=i instanceof Error?i.message:"Batch fetch failed";return qt(a,500)}}),t.delete("/api/observation/:id",(r,n)=>{let{observationWriter:s}=e;if(s===void 0)return qt("Service unavailable",503);let o=parseInt(n.id??"",10);if(Number.isNaN(o))return qt("Invalid observation id",400);try{return s.delete(o),Wc({deleted:!0})}catch(i){let a=i instanceof Error?i.message:"Delete failed";return qt(a,500)}}),t.post("/api/observations/delete",async r=>{let{observationWriter:n}=e;if(n===void 0)return qt("Service unavailable",503);let s;try{s=await r.json()}catch{return qt("Invalid JSON body",400)}let o=ym.safeParse(s);if(!o.success)return qt(o.error.issues[0]?.message??"Validation error",400);try{let i=n.bulkDelete(o.data.ids);return Wc({deleted:i})}catch(i){let a=i instanceof Error?i.message:"Bulk delete failed";return qt(a,500)}})}function Jc(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function yi(t,e){return Jc({error:t},e)}function US(t,e){t.post("/api/retention/purge-age",async r=>{if(e.retentionManager===void 0)return yi("Retention manager not available",503);let n={};try{n=await r.json()}catch{}let s=typeof n.retentionDays=="number"?n.retentionDays:365,o=e.retentionManager.purgeByAge(s);return Jc({deleted:o.deleted})}),t.post("/api/retention/purge-project",async r=>{if(e.retentionManager===void 0)return yi("Retention manager not available",503);let n;try{n=await r.json()}catch{return yi("Invalid JSON body",400)}let s=n.project;if(typeof s!="string"||s.length===0)return yi("project is required",400);let o=e.retentionManager.purgeByProject(s);return Jc({deleted:o.deleted})}),t.post("/api/retention/vacuum",()=>e.retentionManager===void 0?yi("Retention manager not available",503):(e.retentionManager.vacuum(),Jc({success:!0})))}function vm(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function As(t,e){return vm({error:t},e)}function Qq(t){let e={},r=t.searchParams.get("query");r!==null&&(e.query=r);let n=t.searchParams.get("limit");if(n!==null){let c=Number(n);e.limit=Number.isNaN(c)?n:c}let s=t.searchParams.get("type");s!==null&&(e.type=s);let o=t.searchParams.get("project");o!==null&&(e.project=o);let i=t.searchParams.get("dateStart");i!==null&&(e.dateStart=i);let a=t.searchParams.get("dateEnd");return a!==null&&(e.dateEnd=a),e}function FS(t,e){t.get("/api/search",async r=>{let{searchManager:n}=e;if(n===void 0)return As("Service unavailable",503);let s=new URL(r.url),o=Qq(s),i=jS.safeParse(o);if(!i.success)return As(i.error.issues[0]?.message??"Validation error",400);let{query:a,limit:c,type:u,project:l,dateStart:d,dateEnd:p}=i.data;try{let m={limit:c,...a!==void 0?{query:a}:{},...u!==void 0?{type:u}:{},...l!==void 0?{project:l}:{},...d!==void 0?{dateStart:d}:{},...p!==void 0?{dateEnd:p}:{}},f=await n.search(m);return vm({results:f.results,total:f.total,mode:f.mode})}catch(m){let f=m instanceof Error?m.message:"Search failed";return As(f,500)}}),t.get("/api/search/semantic",async r=>{let{searchManager:n}=e;if(n===void 0)return As("Service unavailable",503);let o=new URL(r.url).searchParams.get("query")??"",i=MS.safeParse({query:o});if(!i.success)return As(i.error.issues[0]?.message??"Validation error",400);try{let a=await n.searchSemantic(i.data.query);return vm({results:a})}catch(a){let c=a instanceof Error?a.message:"Semantic search failed";return As(c,500)}})}function vi(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function Ur(t,e){return vi({error:t},e)}function VS(t,e){t.get("/api/sessions/active",()=>{if(e.sessionManager===void 0)return Ur("Session manager not available",503);let r=e.sessionManager.getActiveSessions();return vi({sessions:r})}),t.get("/api/sessions/count",r=>{if(e.sessionManager===void 0)return Ur("Session manager not available",503);let s=new URL(r.url).searchParams.get("project")??void 0,o=e.sessionManager.getSessionCount(s);return vi({count:o})}),t.post("/api/sessions/create",async r=>{if(e.sessionManager===void 0)return Ur("Session manager not available",503);let n;try{n=await r.json()}catch{return Ur("Invalid JSON body",400)}let s=n.contentSessionId,o=n.project;if(typeof s!="string"||s.length===0)return Ur("contentSessionId is required",400);if(typeof o!="string"||o.length===0)return Ur("project is required",400);let i={contentSessionId:s,project:o};typeof n.memorySessionId=="string"&&(i.memorySessionId=n.memorySessionId),typeof n.workerPort=="number"&&(i.workerPort=n.workerPort);let a=e.sessionManager.createSession(i);return vi({session:a})}),t.post("/api/sessions/:id/complete",(r,n)=>{if(e.sessionManager===void 0)return Ur("Session manager not available",503);let s=n.id;return s===void 0||s.length===0?Ur("Session ID is required",400):(e.sessionManager.completeSession(s),vi({success:!0}))})}function BS(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function bm(t,e){return BS({error:t},e)}function eL(t){let e={},r=t.searchParams.get("anchor");r!==null&&(e.anchor=r);let n=t.searchParams.get("depth_before");if(n!==null){let o=Number(n);e.depth_before=Number.isNaN(o)?n:o}let s=t.searchParams.get("depth_after");if(s!==null){let o=Number(s);e.depth_after=Number.isNaN(o)?s:o}return e}function HS(t,e){t.get("/api/timeline",r=>{let{searchManager:n}=e;if(n===void 0)return bm("Service unavailable",503);let s=new URL(r.url),o=eL(s),i=DS.safeParse(o);if(!i.success)return bm(i.error.issues[0]?.message??"Validation error",400);let{anchor:a,depth_before:c,depth_after:u}=i.data;try{let l=n.timeline({anchor:a,depthBefore:c,depthAfter:u});return BS({entries:l.entries})}catch(l){let d=l instanceof Error?l.message:"Timeline query failed";return bm(d,500)}})}function tL(){return`${Date.now()}-${Math.random().toString(36).slice(2,9)}`}function KS(t,e){return`event: ${t}
320
320
  data: ${JSON.stringify(e)}
321
321
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "opencode-metis",
3
- "version": "0.1.6",
3
+ "version": "0.1.7",
4
4
  "type": "module",
5
5
  "description": "Persistent memory system for OpenCode sessions",
6
6
  "license": "MIT",