opencode-metis 0.1.8 → 0.1.9

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 +1 -1
  2. package/package.json +1 -1
package/dist/worker.cjs CHANGED
@@ -315,7 +315,7 @@ END`;function Mm(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=Bn,i=!Gi.jitless,c=i&&vu.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],fe=E._zod.run({value:m[x],issues:[]},p),ke=E._zod.optin==="optional"&&E._zod.optout==="optional";fe instanceof Promise?f.push(fe.then(Lt=>ke?Yh(Lt,d,x,m):ta(Lt,d,x))):ke?Yh(fe,d,x,m):ta(fe,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 Qh(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 Cu=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=>Qh(i,r,t,n)):Qh(o,r,t,n)}}),Mg=b("$ZodDiscriminatedUnion",(t,e)=>{Cu.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=Fs(()=>{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(!Bn(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)}}),Dg=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])=>eg(r,c,u)):eg(r,o,i)}});function Ou(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(Kn(t)&&Kn(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=Ou(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=Ou(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 eg(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=Ou(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 qg=b("$ZodRecord",(t,e)=>{he.init(t,e),t._zod.parse=(r,n)=>{let s=r.value;if(!Kn(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 Lg=b("$ZodEnum",(t,e)=>{he.init(t,e);let r=hu(e.entries);t._zod.values=new Set(r),t._zod.pattern=new RegExp(`^(${r.filter(n=>bu.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}}),Zg=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 Ug=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 or;return r.value=s,r}}),Fg=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)}),Vg=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)}),Hg=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=>tg(o,e)):tg(s,e)}});function tg(t,e){return t.value===void 0&&(t.value=e.defaultValue),t}var Bg=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))}),Kg=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=>rg(o,t)):rg(s,t)}});function rg(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 Gg=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 Wg=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=>ng(o,e,n)):ng(s,e,n)}});function ng(t,e,r){return ln(t)?t:e.out._zod.run({value:t.value,issues:t.issues},r)}var Jg=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(sg):sg(s)}});function sg(t){return t.value=Object.freeze(t.value),t}var Xg=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=>og(o,r,n,t));og(s,r,n,t)}});function og(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(Su(s))}}var RT=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},PT=()=>{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 ${RT(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 Yg(){return{localeError:PT()}}var Au=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 IT(){return new Au}var Ws=IT();function Qg(t,e){return new t({type:"string",...A(e)})}function e_(t,e){return new t({type:"string",format:"email",check:"string_format",abort:!1,...A(e)})}function ju(t,e){return new t({type:"string",format:"guid",check:"string_format",abort:!1,...A(e)})}function t_(t,e){return new t({type:"string",format:"uuid",check:"string_format",abort:!1,...A(e)})}function r_(t,e){return new t({type:"string",format:"uuid",check:"string_format",abort:!1,version:"v4",...A(e)})}function n_(t,e){return new t({type:"string",format:"uuid",check:"string_format",abort:!1,version:"v6",...A(e)})}function s_(t,e){return new t({type:"string",format:"uuid",check:"string_format",abort:!1,version:"v7",...A(e)})}function o_(t,e){return new t({type:"string",format:"url",check:"string_format",abort:!1,...A(e)})}function i_(t,e){return new t({type:"string",format:"emoji",check:"string_format",abort:!1,...A(e)})}function a_(t,e){return new t({type:"string",format:"nanoid",check:"string_format",abort:!1,...A(e)})}function c_(t,e){return new t({type:"string",format:"cuid",check:"string_format",abort:!1,...A(e)})}function u_(t,e){return new t({type:"string",format:"cuid2",check:"string_format",abort:!1,...A(e)})}function l_(t,e){return new t({type:"string",format:"ulid",check:"string_format",abort:!1,...A(e)})}function d_(t,e){return new t({type:"string",format:"xid",check:"string_format",abort:!1,...A(e)})}function p_(t,e){return new t({type:"string",format:"ksuid",check:"string_format",abort:!1,...A(e)})}function f_(t,e){return new t({type:"string",format:"ipv4",check:"string_format",abort:!1,...A(e)})}function m_(t,e){return new t({type:"string",format:"ipv6",check:"string_format",abort:!1,...A(e)})}function h_(t,e){return new t({type:"string",format:"cidrv4",check:"string_format",abort:!1,...A(e)})}function g_(t,e){return new t({type:"string",format:"cidrv6",check:"string_format",abort:!1,...A(e)})}function __(t,e){return new t({type:"string",format:"base64",check:"string_format",abort:!1,...A(e)})}function y_(t,e){return new t({type:"string",format:"base64url",check:"string_format",abort:!1,...A(e)})}function v_(t,e){return new t({type:"string",format:"e164",check:"string_format",abort:!1,...A(e)})}function b_(t,e){return new t({type:"string",format:"jwt",check:"string_format",abort:!1,...A(e)})}function $_(t,e){return new t({type:"string",format:"datetime",check:"string_format",offset:!1,local:!1,precision:null,...A(e)})}function w_(t,e){return new t({type:"string",format:"date",check:"string_format",...A(e)})}function S_(t,e){return new t({type:"string",format:"time",check:"string_format",precision:null,...A(e)})}function E_(t,e){return new t({type:"string",format:"duration",check:"string_format",...A(e)})}function x_(t,e){return new t({type:"number",checks:[],...A(e)})}function T_(t,e){return new t({type:"number",check:"number_format",abort:!1,format:"safeint",...A(e)})}function k_(t,e){return new t({type:"boolean",...A(e)})}function R_(t,e){return new t({type:"null",...A(e)})}function P_(t){return new t({type:"unknown"})}function I_(t,e){return new t({type:"never",...A(e)})}function na(t,e){return new Iu({check:"less_than",...A(e),value:t,inclusive:!1})}function Js(t,e){return new Iu({check:"less_than",...A(e),value:t,inclusive:!0})}function sa(t,e){return new Nu({check:"greater_than",...A(e),value:t,inclusive:!1})}function Xs(t,e){return new Nu({check:"greater_than",...A(e),value:t,inclusive:!0})}function oa(t,e){return new Mh({check:"multiple_of",...A(e),value:t})}function ia(t,e){return new qh({check:"max_length",...A(e),maximum:t})}function Gn(t,e){return new Lh({check:"min_length",...A(e),minimum:t})}function aa(t,e){return new Zh({check:"length_equals",...A(e),length:t})}function Mu(t,e){return new Uh({check:"string_format",format:"regex",...A(e),pattern:t})}function Du(t){return new Fh({check:"string_format",format:"lowercase",...A(t)})}function qu(t){return new Vh({check:"string_format",format:"uppercase",...A(t)})}function Lu(t,e){return new Hh({check:"string_format",format:"includes",...A(e),includes:t})}function Zu(t,e){return new Bh({check:"string_format",format:"starts_with",...A(e),prefix:t})}function Uu(t,e){return new Kh({check:"string_format",format:"ends_with",...A(e),suffix:t})}function dn(t){return new Gh({check:"overwrite",tx:t})}function Fu(t){return dn(e=>e.normalize(t))}function Vu(){return dn(t=>t.trim())}function Hu(){return dn(t=>t.toLowerCase())}function Bu(){return dn(t=>t.toUpperCase())}function N_(t,e,r){return new t({type:"array",element:e,...A(r)})}function O_(t,e,r){let n=A(r);return n.abort??(n.abort=!0),new t({type:"custom",check:"custom",fn:e,...n})}function z_(t,e,r){return new t({type:"custom",check:"custom",fn:e,...A(r)})}function Wn(t){return!!t._zod}function Pt(t,e){return Wn(t)?Ks(t,e):t.safeParse(e)}function ca(t){if(!t)return;let e;if(Wn(t)?e=t._zod?.def?.shape:e=t.shape,!!e){if(typeof e=="function")try{return e()}catch{return}return e}}function C_(t){if(Wn(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 Qs={};wi(Qs,{ZodISODate:()=>j_,ZodISODateTime:()=>A_,ZodISODuration:()=>D_,ZodISOTime:()=>M_,date:()=>Gu,datetime:()=>Ku,duration:()=>Ju,time:()=>Wu});var A_=b("ZodISODateTime",(t,e)=>{_g.init(t,e),we.init(t,e)});function Ku(t){return $_(A_,t)}var j_=b("ZodISODate",(t,e)=>{yg.init(t,e),we.init(t,e)});function Gu(t){return w_(j_,t)}var M_=b("ZodISOTime",(t,e)=>{vg.init(t,e),we.init(t,e)});function Wu(t){return S_(M_,t)}var D_=b("ZodISODuration",(t,e)=>{bg.init(t,e),we.init(t,e)});function Ju(t){return E_(D_,t)}var q_=(t,e)=>{Yi.init(t,e),t.name="ZodError",Object.defineProperties(t,{format:{value:r=>sh(t,r)},flatten:{value:r=>nh(t,r)},addIssue:{value:r=>t.issues.push(r)},addIssues:{value:r=>t.issues.push(...r)},isEmpty:{get(){return t.issues.length===0}}})},oU=b("ZodError",q_),eo=b("ZodError",q_,{Parent:Error});var L_=oh(eo),Z_=ih(eo),U_=xu(eo),F_=Tu(eo);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)=>Vt(t,r,n),t.brand=()=>t,t.register=((r,n)=>(r.add(t,n),t)),t.parse=(r,n)=>L_(t,r,n,{callee:t.parse}),t.safeParse=(r,n)=>U_(t,r,n),t.parseAsync=async(r,n)=>Z_(t,r,n,{callee:t.parseAsync}),t.safeParseAsync=async(r,n)=>F_(t,r,n),t.spa=t.safeParseAsync,t.refine=(r,n)=>t.check(kk(r,n)),t.superRefine=r=>t.check(Rk(r)),t.overwrite=r=>t.check(dn(r)),t.optional=()=>xe(t),t.nullable=()=>B_(t),t.nullish=()=>xe(B_(t)),t.nonoptional=r=>bk(t,r),t.array=()=>X(t),t.or=r=>ge([t,r]),t.and=r=>la(t,r),t.transform=r=>Yu(t,X_(r)),t.default=r=>_k(t,r),t.prefault=r=>vk(t,r),t.catch=r=>wk(t,r),t.pipe=r=>Yu(t,r),t.readonly=()=>xk(t),t.describe=r=>{let n=t.clone();return Ws.add(n,{description:r}),n},Object.defineProperty(t,"description",{get(){return Ws.get(t)?.description},configurable:!0}),t.meta=(...r)=>{if(r.length===0)return Ws.get(t);let n=t.clone();return Ws.add(n,r[0]),n},t.isOptional=()=>t.safeParse(void 0).success,t.isNullable=()=>t.safeParse(null).success,t)),K_=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(Mu(...n)),t.includes=(...n)=>t.check(Lu(...n)),t.startsWith=(...n)=>t.check(Zu(...n)),t.endsWith=(...n)=>t.check(Uu(...n)),t.min=(...n)=>t.check(Gn(...n)),t.max=(...n)=>t.check(ia(...n)),t.length=(...n)=>t.check(aa(...n)),t.nonempty=(...n)=>t.check(Gn(1,...n)),t.lowercase=n=>t.check(Du(n)),t.uppercase=n=>t.check(qu(n)),t.trim=()=>t.check(Vu()),t.normalize=(...n)=>t.check(Fu(...n)),t.toLowerCase=()=>t.check(Hu()),t.toUpperCase=()=>t.check(Bu())}),qT=b("ZodString",(t,e)=>{ra.init(t,e),K_.init(t,e),t.email=r=>t.check(e_(LT,r)),t.url=r=>t.check(o_(ZT,r)),t.jwt=r=>t.check(b_(rk,r)),t.emoji=r=>t.check(i_(UT,r)),t.guid=r=>t.check(ju(V_,r)),t.uuid=r=>t.check(t_(ua,r)),t.uuidv4=r=>t.check(r_(ua,r)),t.uuidv6=r=>t.check(n_(ua,r)),t.uuidv7=r=>t.check(s_(ua,r)),t.nanoid=r=>t.check(a_(FT,r)),t.guid=r=>t.check(ju(V_,r)),t.cuid=r=>t.check(c_(VT,r)),t.cuid2=r=>t.check(u_(HT,r)),t.ulid=r=>t.check(l_(BT,r)),t.base64=r=>t.check(__(QT,r)),t.base64url=r=>t.check(y_(ek,r)),t.xid=r=>t.check(d_(KT,r)),t.ksuid=r=>t.check(p_(GT,r)),t.ipv4=r=>t.check(f_(WT,r)),t.ipv6=r=>t.check(m_(JT,r)),t.cidrv4=r=>t.check(h_(XT,r)),t.cidrv6=r=>t.check(g_(YT,r)),t.e164=r=>t.check(v_(tk,r)),t.datetime=r=>t.check(Ku(r)),t.date=r=>t.check(Gu(r)),t.time=r=>t.check(Wu(r)),t.duration=r=>t.check(Ju(r))});function v(t){return Qg(qT,t)}var we=b("ZodStringFormat",(t,e)=>{_e.init(t,e),K_.init(t,e)}),LT=b("ZodEmail",(t,e)=>{cg.init(t,e),we.init(t,e)});var V_=b("ZodGUID",(t,e)=>{ig.init(t,e),we.init(t,e)});var ua=b("ZodUUID",(t,e)=>{ag.init(t,e),we.init(t,e)});var ZT=b("ZodURL",(t,e)=>{ug.init(t,e),we.init(t,e)});var UT=b("ZodEmoji",(t,e)=>{lg.init(t,e),we.init(t,e)});var FT=b("ZodNanoID",(t,e)=>{dg.init(t,e),we.init(t,e)});var VT=b("ZodCUID",(t,e)=>{pg.init(t,e),we.init(t,e)});var HT=b("ZodCUID2",(t,e)=>{fg.init(t,e),we.init(t,e)});var BT=b("ZodULID",(t,e)=>{mg.init(t,e),we.init(t,e)});var KT=b("ZodXID",(t,e)=>{hg.init(t,e),we.init(t,e)});var GT=b("ZodKSUID",(t,e)=>{gg.init(t,e),we.init(t,e)});var WT=b("ZodIPv4",(t,e)=>{$g.init(t,e),we.init(t,e)});var JT=b("ZodIPv6",(t,e)=>{wg.init(t,e),we.init(t,e)});var XT=b("ZodCIDRv4",(t,e)=>{Sg.init(t,e),we.init(t,e)});var YT=b("ZodCIDRv6",(t,e)=>{Eg.init(t,e),we.init(t,e)});var QT=b("ZodBase64",(t,e)=>{Tg.init(t,e),we.init(t,e)});var ek=b("ZodBase64URL",(t,e)=>{kg.init(t,e),we.init(t,e)});var tk=b("ZodE164",(t,e)=>{Rg.init(t,e),we.init(t,e)});var rk=b("ZodJWT",(t,e)=>{Pg.init(t,e),we.init(t,e)});var G_=b("ZodNumber",(t,e)=>{zu.init(t,e),Te.init(t,e),t.gt=(n,s)=>t.check(sa(n,s)),t.gte=(n,s)=>t.check(Xs(n,s)),t.min=(n,s)=>t.check(Xs(n,s)),t.lt=(n,s)=>t.check(na(n,s)),t.lte=(n,s)=>t.check(Js(n,s)),t.max=(n,s)=>t.check(Js(n,s)),t.int=n=>t.check(H_(n)),t.safe=n=>t.check(H_(n)),t.positive=n=>t.check(sa(0,n)),t.nonnegative=n=>t.check(Xs(0,n)),t.negative=n=>t.check(na(0,n)),t.nonpositive=n=>t.check(Js(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 x_(G_,t)}var nk=b("ZodNumberFormat",(t,e)=>{Ig.init(t,e),G_.init(t,e)});function H_(t){return T_(nk,t)}var sk=b("ZodBoolean",(t,e)=>{Ng.init(t,e),Te.init(t,e)});function Ie(t){return k_(sk,t)}var ok=b("ZodNull",(t,e)=>{Og.init(t,e),Te.init(t,e)});function Qu(t){return R_(ok,t)}var ik=b("ZodUnknown",(t,e)=>{zg.init(t,e),Te.init(t,e)});function Se(){return P_(ik)}var ak=b("ZodNever",(t,e)=>{Cg.init(t,e),Te.init(t,e)});function ck(t){return I_(ak,t)}var uk=b("ZodArray",(t,e)=>{Ag.init(t,e),Te.init(t,e),t.element=e.element,t.min=(r,n)=>t.check(Gn(r,n)),t.nonempty=r=>t.check(Gn(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 N_(uk,t,e)}var W_=b("ZodObject",(t,e)=>{jg.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:ck()}),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(Y_,t,r[0]),t.required=(...r)=>ie.required(Q_,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 W_(r)}function We(t,e){return new W_({type:"object",get shape(){return ie.assignProp(this,"shape",{...t}),this.shape},catchall:Se(),...ie.normalizeParams(e)})}var J_=b("ZodUnion",(t,e)=>{Cu.init(t,e),Te.init(t,e),t.options=e.options});function ge(t,e){return new J_({type:"union",options:t,...ie.normalizeParams(e)})}var lk=b("ZodDiscriminatedUnion",(t,e)=>{J_.init(t,e),Mg.init(t,e)});function el(t,e,r){return new lk({type:"union",options:e,discriminator:t,...ie.normalizeParams(r)})}var dk=b("ZodIntersection",(t,e)=>{Dg.init(t,e),Te.init(t,e)});function la(t,e){return new dk({type:"intersection",left:t,right:e})}var pk=b("ZodRecord",(t,e)=>{qg.init(t,e),Te.init(t,e),t.keyType=e.keyType,t.valueType=e.valueType});function Ee(t,e,r){return new pk({type:"record",keyType:t,valueType:e,...ie.normalizeParams(r)})}var Xu=b("ZodEnum",(t,e)=>{Lg.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 Xu({...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 Xu({...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 Xu({type:"enum",entries:r,...ie.normalizeParams(e)})}var fk=b("ZodLiteral",(t,e)=>{Zg.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 fk({type:"literal",values:Array.isArray(t)?t:[t],...ie.normalizeParams(e)})}var mk=b("ZodTransform",(t,e)=>{Ug.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 X_(t){return new mk({type:"transform",transform:t})}var Y_=b("ZodOptional",(t,e)=>{Fg.init(t,e),Te.init(t,e),t.unwrap=()=>t._zod.def.innerType});function xe(t){return new Y_({type:"optional",innerType:t})}var hk=b("ZodNullable",(t,e)=>{Vg.init(t,e),Te.init(t,e),t.unwrap=()=>t._zod.def.innerType});function B_(t){return new hk({type:"nullable",innerType:t})}var gk=b("ZodDefault",(t,e)=>{Hg.init(t,e),Te.init(t,e),t.unwrap=()=>t._zod.def.innerType,t.removeDefault=t.unwrap});function _k(t,e){return new gk({type:"default",innerType:t,get defaultValue(){return typeof e=="function"?e():e}})}var yk=b("ZodPrefault",(t,e)=>{Bg.init(t,e),Te.init(t,e),t.unwrap=()=>t._zod.def.innerType});function vk(t,e){return new yk({type:"prefault",innerType:t,get defaultValue(){return typeof e=="function"?e():e}})}var Q_=b("ZodNonOptional",(t,e)=>{Kg.init(t,e),Te.init(t,e),t.unwrap=()=>t._zod.def.innerType});function bk(t,e){return new Q_({type:"nonoptional",innerType:t,...ie.normalizeParams(e)})}var $k=b("ZodCatch",(t,e)=>{Gg.init(t,e),Te.init(t,e),t.unwrap=()=>t._zod.def.innerType,t.removeCatch=t.unwrap});function wk(t,e){return new $k({type:"catch",innerType:t,catchValue:typeof e=="function"?e:()=>e})}var Sk=b("ZodPipe",(t,e)=>{Wg.init(t,e),Te.init(t,e),t.in=e.in,t.out=e.out});function Yu(t,e){return new Sk({type:"pipe",in:t,out:e})}var Ek=b("ZodReadonly",(t,e)=>{Jg.init(t,e),Te.init(t,e)});function xk(t){return new Ek({type:"readonly",innerType:t})}var ey=b("ZodCustom",(t,e)=>{Xg.init(t,e),Te.init(t,e)});function Tk(t){let e=new Ue({check:"custom"});return e._zod.check=t,e}function ty(t,e){return O_(ey,t??(()=>!0),e)}function kk(t,e={}){return z_(ey,t,e)}function Rk(t){let e=Tk(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 tl(t,e){return Yu(X_(t),e)}ht(Yg());var nl="2025-11-25";var ry=[nl,"2025-06-18","2025-03-26","2024-11-05","2024-10-07"],xr="io.modelcontextprotocol/related-task",pa="2.0",Oe=ty(t=>t!==null&&(typeof t=="object"||typeof t=="function")),ny=ge([v(),ae().int()]),sy=v(),YU=We({ttl:ge([ae(),Qu()]).optional(),pollInterval:ae().optional()}),Pk=R({ttl:ae().optional()}),Ik=R({taskId:v()}),sl=We({progressToken:ny.optional(),[xr]:Ik.optional()}),dt=R({_meta:sl.optional()}),to=dt.extend({task:Pk.optional()}),oy=t=>to.safeParse(t).success,ze=R({method:v(),params:dt.loose().optional()}),gt=R({_meta:sl.optional()}),_t=R({method:v(),params:gt.loose().optional()}),Ce=We({_meta:sl.optional()}),fa=ge([v(),ae().int()]),iy=R({jsonrpc:I(pa),id:fa,...ze.shape}).strict(),ol=t=>iy.safeParse(t).success,ay=R({jsonrpc:I(pa),..._t.shape}).strict(),cy=t=>ay.safeParse(t).success,il=R({jsonrpc:I(pa),id:fa,result:Ce}).strict(),ro=t=>il.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 al=R({jsonrpc:I(pa),id:fa.optional(),error:R({code:ae().int(),message:v(),data:Se().optional()})}).strict();var uy=t=>al.safeParse(t).success;var ly=ge([iy,ay,il,al]),QU=ge([il,al]),pn=Ce.strict(),Nk=gt.extend({requestId:fa.optional(),reason:v().optional()}),ma=_t.extend({method:I("notifications/cancelled"),params:Nk}),Ok=R({src:v(),mimeType:v().optional(),sizes:X(v()).optional(),theme:rt(["light","dark"]).optional()}),no=R({icons:X(Ok).optional()}),Jn=R({name:v(),title:v().optional()}),dy=Jn.extend({...Jn.shape,...no.shape,version:v(),websiteUrl:v().optional(),description:v().optional()}),zk=la(R({applyDefaults:Ie().optional()}),Ee(v(),Se())),Ck=tl(t=>t&&typeof t=="object"&&!Array.isArray(t)&&Object.keys(t).length===0?{form:{}}:t,la(R({form:zk.optional(),url:Oe.optional()}),Ee(v(),Se()).optional())),Ak=We({list:Oe.optional(),cancel:Oe.optional(),requests:We({sampling:We({createMessage:Oe.optional()}).optional(),elicitation:We({create:Oe.optional()}).optional()}).optional()}),jk=We({list:Oe.optional(),cancel:Oe.optional(),requests:We({tools:We({call:Oe.optional()}).optional()}).optional()}),Mk=R({experimental:Ee(v(),Oe).optional(),sampling:R({context:Oe.optional(),tools:Oe.optional()}).optional(),elicitation:Ck.optional(),roots:R({listChanged:Ie().optional()}).optional(),tasks:Ak.optional()}),Dk=dt.extend({protocolVersion:v(),capabilities:Mk,clientInfo:dy}),qk=ze.extend({method:I("initialize"),params:Dk});var Lk=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:jk.optional()}),cl=Ce.extend({protocolVersion:v(),capabilities:Lk,serverInfo:dy,instructions:v().optional()}),Zk=_t.extend({method:I("notifications/initialized"),params:gt.optional()});var ha=ze.extend({method:I("ping"),params:dt.optional()}),Uk=R({progress:ae(),total:xe(ae()),message:xe(v())}),Fk=R({...gt.shape,...Uk.shape,progressToken:ny}),ga=_t.extend({method:I("notifications/progress"),params:Fk}),Vk=dt.extend({cursor:sy.optional()}),so=ze.extend({params:Vk.optional()}),oo=Ce.extend({nextCursor:sy.optional()}),Hk=rt(["working","input_required","completed","failed","cancelled"]),io=R({taskId:v(),status:Hk,ttl:ge([ae(),Qu()]),createdAt:v(),lastUpdatedAt:v(),pollInterval:xe(ae()),statusMessage:xe(v())}),fn=Ce.extend({task:io}),Bk=gt.merge(io),ao=_t.extend({method:I("notifications/tasks/status"),params:Bk}),_a=ze.extend({method:I("tasks/get"),params:dt.extend({taskId:v()})}),ya=Ce.merge(io),va=ze.extend({method:I("tasks/result"),params:dt.extend({taskId:v()})}),eF=Ce.loose(),ba=so.extend({method:I("tasks/list")}),$a=oo.extend({tasks:X(io)}),wa=ze.extend({method:I("tasks/cancel"),params:dt.extend({taskId:v()})}),py=Ce.merge(io),fy=R({uri:v(),mimeType:xe(v()),_meta:Ee(v(),Se()).optional()}),my=fy.extend({text:v()}),ul=v().refine(t=>{try{return atob(t),!0}catch{return!1}},{message:"Invalid Base64 string"}),hy=fy.extend({blob:ul}),co=rt(["user","assistant"]),Xn=R({audience:X(co).optional(),priority:ae().min(0).max(1).optional(),lastModified:Qs.datetime({offset:!0}).optional()}),gy=R({...Jn.shape,...no.shape,uri:v(),description:xe(v()),mimeType:xe(v()),annotations:Xn.optional(),_meta:xe(We({}))}),Kk=R({...Jn.shape,...no.shape,uriTemplate:v(),description:xe(v()),mimeType:xe(v()),annotations:Xn.optional(),_meta:xe(We({}))}),Gk=so.extend({method:I("resources/list")}),ll=oo.extend({resources:X(gy)}),Wk=so.extend({method:I("resources/templates/list")}),dl=oo.extend({resourceTemplates:X(Kk)}),pl=dt.extend({uri:v()}),Jk=pl,Xk=ze.extend({method:I("resources/read"),params:Jk}),fl=Ce.extend({contents:X(ge([my,hy]))}),ml=_t.extend({method:I("notifications/resources/list_changed"),params:gt.optional()}),Yk=pl,Qk=ze.extend({method:I("resources/subscribe"),params:Yk}),eR=pl,tR=ze.extend({method:I("resources/unsubscribe"),params:eR}),rR=gt.extend({uri:v()}),nR=_t.extend({method:I("notifications/resources/updated"),params:rR}),sR=R({name:v(),description:xe(v()),required:xe(Ie())}),oR=R({...Jn.shape,...no.shape,description:xe(v()),arguments:xe(X(sR)),_meta:xe(We({}))}),iR=so.extend({method:I("prompts/list")}),hl=oo.extend({prompts:X(oR)}),aR=dt.extend({name:v(),arguments:Ee(v(),v()).optional()}),cR=ze.extend({method:I("prompts/get"),params:aR}),gl=R({type:I("text"),text:v(),annotations:Xn.optional(),_meta:Ee(v(),Se()).optional()}),_l=R({type:I("image"),data:ul,mimeType:v(),annotations:Xn.optional(),_meta:Ee(v(),Se()).optional()}),yl=R({type:I("audio"),data:ul,mimeType:v(),annotations:Xn.optional(),_meta:Ee(v(),Se()).optional()}),uR=R({type:I("tool_use"),name:v(),id:v(),input:Ee(v(),Se()),_meta:Ee(v(),Se()).optional()}),lR=R({type:I("resource"),resource:ge([my,hy]),annotations:Xn.optional(),_meta:Ee(v(),Se()).optional()}),dR=gy.extend({type:I("resource_link")}),vl=ge([gl,_l,yl,dR,lR]),pR=R({role:co,content:vl}),bl=Ce.extend({description:v().optional(),messages:X(pR)}),$l=_t.extend({method:I("notifications/prompts/list_changed"),params:gt.optional()}),fR=R({title:v().optional(),readOnlyHint:Ie().optional(),destructiveHint:Ie().optional(),idempotentHint:Ie().optional(),openWorldHint:Ie().optional()}),mR=R({taskSupport:rt(["required","optional","forbidden"]).optional()}),_y=R({...Jn.shape,...no.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:fR.optional(),execution:mR.optional(),_meta:Ee(v(),Se()).optional()}),hR=so.extend({method:I("tools/list")}),wl=oo.extend({tools:X(_y)}),Yn=Ce.extend({content:X(vl).default([]),structuredContent:Ee(v(),Se()).optional(),isError:Ie().optional()}),tF=Yn.or(Ce.extend({toolResult:Se()})),gR=to.extend({name:v(),arguments:Ee(v(),Se()).optional()}),_R=ze.extend({method:I("tools/call"),params:gR}),Sl=_t.extend({method:I("notifications/tools/list_changed"),params:gt.optional()}),yy=R({autoRefresh:Ie().default(!0),debounceMs:ae().int().nonnegative().default(300)}),vy=rt(["debug","info","notice","warning","error","critical","alert","emergency"]),yR=dt.extend({level:vy}),vR=ze.extend({method:I("logging/setLevel"),params:yR}),bR=gt.extend({level:vy,logger:v().optional(),data:Se()}),$R=_t.extend({method:I("notifications/message"),params:bR}),wR=R({name:v().optional()}),SR=R({hints:X(wR).optional(),costPriority:ae().min(0).max(1).optional(),speedPriority:ae().min(0).max(1).optional(),intelligencePriority:ae().min(0).max(1).optional()}),ER=R({mode:rt(["auto","required","none"]).optional()}),xR=R({type:I("tool_result"),toolUseId:v().describe("The unique identifier for the corresponding tool call."),content:X(vl).default([]),structuredContent:R({}).loose().optional(),isError:Ie().optional(),_meta:Ee(v(),Se()).optional()}),TR=el("type",[gl,_l,yl]),da=el("type",[gl,_l,yl,uR,xR]),kR=R({role:co,content:ge([da,X(da)]),_meta:Ee(v(),Se()).optional()}),RR=to.extend({messages:X(kR),modelPreferences:SR.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(_y).optional(),toolChoice:ER.optional()}),El=ze.extend({method:I("sampling/createMessage"),params:RR}),xl=Ce.extend({model:v(),stopReason:xe(rt(["endTurn","stopSequence","maxTokens"]).or(v())),role:co,content:TR}),Tl=Ce.extend({model:v(),stopReason:xe(rt(["endTurn","stopSequence","maxTokens","toolUse"]).or(v())),role:co,content:ge([da,X(da)])}),PR=R({type:I("boolean"),title:v().optional(),description:v().optional(),default:Ie().optional()}),IR=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()}),NR=R({type:rt(["number","integer"]),title:v().optional(),description:v().optional(),minimum:ae().optional(),maximum:ae().optional(),default:ae().optional()}),OR=R({type:I("string"),title:v().optional(),description:v().optional(),enum:X(v()),default:v().optional()}),zR=R({type:I("string"),title:v().optional(),description:v().optional(),oneOf:X(R({const:v(),title:v()})),default:v().optional()}),CR=R({type:I("string"),title:v().optional(),description:v().optional(),enum:X(v()),enumNames:X(v()).optional(),default:v().optional()}),AR=ge([OR,zR]),jR=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()}),MR=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()}),DR=ge([jR,MR]),qR=ge([CR,AR,DR]),LR=ge([qR,PR,IR,NR]),ZR=to.extend({mode:I("form").optional(),message:v(),requestedSchema:R({type:I("object"),properties:Ee(v(),LR),required:X(v()).optional()})}),UR=to.extend({mode:I("url"),message:v(),elicitationId:v(),url:v().url()}),FR=ge([ZR,UR]),kl=ze.extend({method:I("elicitation/create"),params:FR}),VR=gt.extend({elicitationId:v()}),HR=_t.extend({method:I("notifications/elicitation/complete"),params:VR}),Rl=Ce.extend({action:rt(["accept","decline","cancel"]),content:tl(t=>t===null?void 0:t,Ee(v(),ge([v(),ae(),Ie(),X(v())])).optional())}),BR=R({type:I("ref/resource"),uri:v()});var KR=R({type:I("ref/prompt"),name:v()}),GR=dt.extend({ref:ge([KR,BR]),argument:R({name:v(),value:v()}),context:R({arguments:Ee(v(),v()).optional()}).optional()}),WR=ze.extend({method:I("completion/complete"),params:GR});var Pl=Ce.extend({completion:We({values:X(v()).max(100),total:xe(ae().int()),hasMore:xe(Ie())})}),JR=R({uri:v().startsWith("file://"),name:v().optional(),_meta:Ee(v(),Se()).optional()}),XR=ze.extend({method:I("roots/list"),params:dt.optional()}),YR=Ce.extend({roots:X(JR)}),QR=_t.extend({method:I("notifications/roots/list_changed"),params:gt.optional()}),rF=ge([ha,qk,WR,vR,cR,iR,Gk,Wk,Xk,Qk,tR,_R,hR,_a,va,ba,wa]),nF=ge([ma,ga,Zk,QR,ao]),sF=ge([pn,xl,Tl,Rl,YR,ya,$a,fn]),oF=ge([ha,El,kl,XR,_a,va,ba,wa]),iF=ge([ma,ga,$R,nR,ml,Sl,$l,ao,HR]),aF=ge([pn,cl,Pl,bl,hl,ll,dl,fl,Yn,wl,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 rl(s.elicitations,r)}return new t(e,r,n)}},rl=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 LF=new Set("ABCDEFGHIJKLMNOPQRSTUVXYZabcdefghijklmnopqrstuvxyz0123456789");function Il(t){let r=ca(t)?.method;if(!r)throw new Error("Schema is missing a method literal");let n=C_(r);if(typeof n!="string")throw new Error("Schema method literal must be a string");return n}function Nl(t,e){let r=Pt(t,e);if(!r.success)throw r.error;return r.data}var oP=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),ro(o)||uy(o)?this._onresponse(o):ol(o)?this._onrequest(o,i):cy(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=oy(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),ro(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(ro(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),ro(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??oP,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},py,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=Il(e);this.assertRequestHandlerCapability(n),this._requestHandlers.set(n,(s,o)=>{let i=Nl(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=Il(e);this._notificationHandlers.set(n,s=>{let o=Nl(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"&&ol(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=ao.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=ao.parse({method:"notifications/tasks/status",params:c});await this.notification(u),Tr(c.status)&&this._cleanupTaskProgressHandler(s)}},listTasks:s=>n.listTasks(s,r)}}};function by(t){return t!==null&&typeof t=="object"&&!Array.isArray(t)}function $y(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];by(i)&&by(o)?r[s]={...i,...o}:r[s]=o}return r}var $w=Si(Kb(),1),ww=Si(bw(),1);function HD(){let t=new $w.default({strict:!1,validateFormats:!0,validateSchema:!1,allErrors:!0});return(0,ww.default)(t),t}var Ac=class{constructor(e){this._ajv=e??HD()}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=Yn,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 Sw(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 Ew(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 BD(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",Sl,e.tools,async()=>(await this.listTools()).tools),e.prompts&&this._serverCapabilities?.prompts?.listChanged&&this._setupListChangedHandler("prompts",$l,e.prompts,async()=>(await this.listPrompts()).prompts),e.resources&&this._serverCapabilities?.resources?.listChanged&&this._setupListChangedHandler("resources",ml,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=$y(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(Wn(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(kl,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}=BD(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(Rl,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(El,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?Tl:xl,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:nl,capabilities:this._capabilities,clientInfo:this._clientInfo}},cl,r);if(n===void 0)throw new Error(`Server sent invalid initialize result: ${n}`);if(!ry.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){Sw(this._serverCapabilities?.tasks?.requests,e,"Server")}assertTaskHandlerCapability(e){this._capabilities&&Ew(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},Pl,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},bl,r)}async listPrompts(e,r){return this.request({method:"prompts/list",params:e},hl,r)}async listResources(e,r){return this.request({method:"resources/list",params:e},ll,r)}async listResourceTemplates(e,r){return this.request({method:"resources/templates/list",params:e},dl,r)}async readResource(e,r){return this.request({method:"resources/read",params:e},fl,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=Yn,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},wl,r);return this.cacheToolMetadata(n.tools),n}_setupListChangedHandler(e,r,n,s){let o=yy.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 mS=Si(pS(),1),mi=Si(require("node:process"),1),hS=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),vq(r)}clear(){this._buffer=void 0}};function vq(t){return ly.parse(JSON.parse(t))}function fS(t){return JSON.stringify(t)+`
318
- `}var bq=mi.default.platform==="win32"?["APPDATA","HOMEDRIVE","HOMEPATH","LOCALAPPDATA","PATH","PROCESSOR_ARCHITECTURE","SYSTEMDRIVE","SYSTEMROOT","TEMP","USERNAME","USERPROFILE","PROGRAMFILES"]:["HOME","LOGNAME","PATH","SHELL","TERM","USER"];function $q(){let t={};for(let e of bq){let r=mi.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 hS.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,mS.default)(this._serverParams.command,this._serverParams.args??[],{env:{...$q(),...this._serverParams.env},stdio:["pipe","pipe",this._serverParams.stderr??"inherit"],shell:!1,windowsHide:mi.default.platform==="win32"&&wq(),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=fS(e);this._process.stdin.write(n)?r():this._process.stdin.once("drain",r)})}};function wq(){return"type"in mi.default}var Sq=3,Eq=6e4,Uc=class{client=null;transport=null;circuit={failures:0,openUntil:0};maxFailures;cooldownMs;cleanupRegistered=!1;constructor(e){this.maxFailures=e?.maxFailures??Sq,this.cooldownMs=e?.cooldownMs??Eq}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 xq(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 xq(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:[[]]}}}function gS(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 _S(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 Tq=10,kq=90,Rq=100;function Fc(t){return`cm__${t.length>0?t.toLowerCase():"default"}`}function Pq(t){let e=/^obs_(\d+)_/.exec(t);return e===null||e[1]===void 0?null:parseInt(e[1],10)}function Iq(t){let e=t.split("_");return e.length<3?"unknown":e[2]??"unknown"}var Vc=class{manager;constructor(e){this.manager=e}async syncObservation(e){if(!this.manager.isAvailable())return;let r=gS(e);if(r.length===0)return;let n=Fc(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=_S(e);if(r.length===0)return;let n=Fc(e.project);await this.manager.addDocuments(n,r.map(s=>({id:s.id,document:s.document,metadata:s.metadata})))}async query(e,r,n=Tq,s=kq,o){if(!this.manager.isAvailable())return[];let i=o??"";if(i.length===0)return[];let a=Fc(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=Pq(f);if(h===null||d.has(h))continue;d.add(h);let g=l[m]??0;p.push({observationId:h,score:1-g,field:Iq(f)})}return p}async vacuum(e){if(!this.manager.isAvailable()||e===void 0)return;let r=Fc(e);await this.manager.deleteCollection(r)}async backfill(e,r=Rq){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 yS(t){return t===null||!t.isAvailable()?new gr:new Vc(t)}var Hc=require("node:crypto");function vS(){return(0,Hc.randomBytes)(32).toString("hex")}function dm(t){return(0,Hc.createHash)("sha256").update(t).digest("hex")}function bS(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:dm(n)===t}}function pm(t){return t.split("/").filter(Boolean).map(e=>e.startsWith(":")?{kind:"param",name:e.slice(1)}:{kind:"literal",value:e})}function Nq(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 $S(t,e){return new Response(JSON.stringify({error:t}),{status:e,headers:{"Content-Type":"application/json"}})}var Bc=class{routes=[];get(e,r){this.routes.push({method:"GET",segments:pm(e),handler:r})}post(e,r){this.routes.push({method:"POST",segments:pm(e),handler:r})}delete(e,r){this.routes.push({method:"DELETE",segments:pm(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=Nq(i.segments,n);if(a!==null&&(o=!0,i.method===s))return await i.handler(e,a)}return o?$S(`Method ${s} not allowed`,405):$S(`Route not found: ${r.pathname}`,404)}};function fm(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function Oq(t,e){return fm({error:t},e)}function zq(t){return t.sessionManager?.getSessionCount()??0}function Cq(t){return t.db===void 0?0:t.db.query("SELECT COUNT(*) as count FROM observations").get()?.count??0}function Aq(t){return t.retentionManager?.getStats().dbSizeBytes??0}function wS(t,e,r){t.post("/api/admin/shutdown",()=>{let n=fm({shutting_down:!0});return r(),n}),t.get("/api/admin/stats",()=>{if(e.sessionManager===void 0||e.retentionManager===void 0)return Oq("Services not available",503);let n=zq(e),s=Cq(e),o=Aq(e);return fm({sessions:n,observations:s,dbSize:o})})}function hi(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function Cn(t,e){return hi({error:t},e)}function SS(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 hi({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),hi({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 hi({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 hi({deleted:o.deleted})})}function mm(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function ES(t){return t==="core-ready"||t==="ready"}async function jq(t){if(ES(t.initState))return!0;let e=Date.now()+5e3;for(;Date.now()<e;)if(await new Promise(r=>setTimeout(r,100)),ES(t.initState))return!0;return!1}function gi(t){if(t===null||t==="")return[];try{let e=JSON.parse(t);return Array.isArray(e)?e:[]}catch{return[]}}function xS(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:gi(t.facts),narrative:t.narrative,concepts:gi(t.concepts),filesRead:gi(t.files_read),filesModified:gi(t.files_modified),promptNumber:t.prompt_number,discoveryTokens:t.discovery_tokens,tags:gi(t.tags),createdAt:t.created_at,createdAtEpoch:t.created_at_epoch}}function TS(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 kS(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 RS(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(xS):t.db.query("SELECT * FROM observations WHERE created_at_epoch >= ? ORDER BY created_at_epoch DESC").all(n).map(xS)}function PS(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(TS):t.db.query("SELECT * FROM session_summaries ORDER BY created_at_epoch DESC LIMIT 5").all().map(TS)}function Mq(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 bq=mi.default.platform==="win32"?["APPDATA","HOMEDRIVE","HOMEPATH","LOCALAPPDATA","PATH","PROCESSOR_ARCHITECTURE","SYSTEMDRIVE","SYSTEMROOT","TEMP","USERNAME","USERPROFILE","PROGRAMFILES"]:["HOME","LOGNAME","PATH","SHELL","TERM","USER"];function $q(){let t={};for(let e of bq){let r=mi.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 hS.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,mS.default)(this._serverParams.command,this._serverParams.args??[],{env:{...$q(),...this._serverParams.env},stdio:["pipe","pipe",this._serverParams.stderr??"inherit"],shell:!1,windowsHide:mi.default.platform==="win32"&&wq(),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=fS(e);this._process.stdin.write(n)?r():this._process.stdin.once("drain",r)})}};function wq(){return"type"in mi.default}var Sq=3,Eq=6e4,Uc=class{client=null;transport=null;circuit={failures:0,openUntil:0};maxFailures;cooldownMs;cleanupRegistered=!1;constructor(e){this.maxFailures=e?.maxFailures??Sq,this.cooldownMs=e?.cooldownMs??Eq}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:"chroma_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:"chroma_query_documents",arguments:{collection_name:e,query_texts:r,n_results:n}});return xq(s)})}async deleteCollection(e){await this.executeWithCircuitBreaker(async()=>{await this.client?.callTool({name:"chroma_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 xq(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:[[]]}}}function gS(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 _S(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 Tq=10,kq=90,Rq=100;function Fc(t){return`cm__${t.length>0?t.toLowerCase():"default"}`}function Pq(t){let e=/^obs_(\d+)_/.exec(t);return e===null||e[1]===void 0?null:parseInt(e[1],10)}function Iq(t){let e=t.split("_");return e.length<3?"unknown":e[2]??"unknown"}var Vc=class{manager;constructor(e){this.manager=e}async syncObservation(e){if(!this.manager.isAvailable())return;let r=gS(e);if(r.length===0)return;let n=Fc(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=_S(e);if(r.length===0)return;let n=Fc(e.project);await this.manager.addDocuments(n,r.map(s=>({id:s.id,document:s.document,metadata:s.metadata})))}async query(e,r,n=Tq,s=kq,o){if(!this.manager.isAvailable())return[];let i=o??"";if(i.length===0)return[];let a=Fc(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=Pq(f);if(h===null||d.has(h))continue;d.add(h);let g=l[m]??0;p.push({observationId:h,score:1-g,field:Iq(f)})}return p}async vacuum(e){if(!this.manager.isAvailable()||e===void 0)return;let r=Fc(e);await this.manager.deleteCollection(r)}async backfill(e,r=Rq){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 yS(t){return t===null||!t.isAvailable()?new gr:new Vc(t)}var Hc=require("node:crypto");function vS(){return(0,Hc.randomBytes)(32).toString("hex")}function dm(t){return(0,Hc.createHash)("sha256").update(t).digest("hex")}function bS(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:dm(n)===t}}function pm(t){return t.split("/").filter(Boolean).map(e=>e.startsWith(":")?{kind:"param",name:e.slice(1)}:{kind:"literal",value:e})}function Nq(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 $S(t,e){return new Response(JSON.stringify({error:t}),{status:e,headers:{"Content-Type":"application/json"}})}var Bc=class{routes=[];get(e,r){this.routes.push({method:"GET",segments:pm(e),handler:r})}post(e,r){this.routes.push({method:"POST",segments:pm(e),handler:r})}delete(e,r){this.routes.push({method:"DELETE",segments:pm(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=Nq(i.segments,n);if(a!==null&&(o=!0,i.method===s))return await i.handler(e,a)}return o?$S(`Method ${s} not allowed`,405):$S(`Route not found: ${r.pathname}`,404)}};function fm(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function Oq(t,e){return fm({error:t},e)}function zq(t){return t.sessionManager?.getSessionCount()??0}function Cq(t){return t.db===void 0?0:t.db.query("SELECT COUNT(*) as count FROM observations").get()?.count??0}function Aq(t){return t.retentionManager?.getStats().dbSizeBytes??0}function wS(t,e,r){t.post("/api/admin/shutdown",()=>{let n=fm({shutting_down:!0});return r(),n}),t.get("/api/admin/stats",()=>{if(e.sessionManager===void 0||e.retentionManager===void 0)return Oq("Services not available",503);let n=zq(e),s=Cq(e),o=Aq(e);return fm({sessions:n,observations:s,dbSize:o})})}function hi(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function Cn(t,e){return hi({error:t},e)}function SS(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 hi({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),hi({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 hi({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 hi({deleted:o.deleted})})}function mm(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function ES(t){return t==="core-ready"||t==="ready"}async function jq(t){if(ES(t.initState))return!0;let e=Date.now()+5e3;for(;Date.now()<e;)if(await new Promise(r=>setTimeout(r,100)),ES(t.initState))return!0;return!1}function gi(t){if(t===null||t==="")return[];try{let e=JSON.parse(t);return Array.isArray(e)?e:[]}catch{return[]}}function xS(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:gi(t.facts),narrative:t.narrative,concepts:gi(t.concepts),filesRead:gi(t.files_read),filesModified:gi(t.files_modified),promptNumber:t.prompt_number,discoveryTokens:t.discovery_tokens,tags:gi(t.tags),createdAt:t.created_at,createdAtEpoch:t.created_at_epoch}}function TS(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 kS(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 RS(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(xS):t.db.query("SELECT * FROM observations WHERE created_at_epoch >= ? ORDER BY created_at_epoch DESC").all(n).map(xS)}function PS(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(TS):t.db.query("SELECT * FROM session_summaries ORDER BY created_at_epoch DESC LIMIT 5").all().map(TS)}function Mq(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 IS(t,e){t.get("/api/context/inject",async r=>{if(!await jq(e))return mm({context:""});let s=kS(r),o=RS(e,s,24),i=PS(e,s),a=Mq(o,i);return mm({context:a})}),t.get("/api/context/recent",r=>{let n=kS(r),o=new URL(r.url).searchParams.get("hours"),i=o!==null?parseInt(o,10):24,a=RS(e,n,i),c=PS(e,n);return mm({observations:a,summaries:c})})}var Dq=process.env.npm_package_version??"0.1.0",qq=Date.now();function Lq(t){return t==="core-ready"||t==="ready"}function Zq(t){return t==="ready"}function zs(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function NS(t,e){t.get("/api/health",()=>zs({build:Dq,initState:e.initState,pid:process.pid,uptime:Math.floor((Date.now()-qq)/1e3)})),t.get("/api/core-ready",()=>Lq(e.initState)?zs({ready:!0}):zs({ready:!1,initState:e.initState},503)),t.get("/api/readiness",()=>Zq(e.initState)?zs({ready:!0}):zs({ready:!1,initState:e.initState},503)),t.get("/api/process-stats",()=>{let r=process.memoryUsage();return zs({rss:r.rss,heapUsed:r.heapUsed,uptime:process.uptime()})})}var OS=le.object({text:le.string().min(1),title:le.string().optional(),project:le.string().optional()}),zS=le.object({query:le.string().optional(),limit:le.number().int().min(1).max(100).default(20),type:le.string().optional(),project:le.string().optional(),dateStart:le.string().optional(),dateEnd:le.string().optional()}),CS=le.object({query:le.string().min(1)}),AS=le.object({anchor:le.string().min(1),depth_before:le.number().int().min(0).default(5),depth_after:le.number().int().min(0).default(5)}),hm=le.object({ids:le.array(le.number().int()).min(1)}),r5=le.object({contentSessionId:le.string().min(1),project:le.string().min(1),memorySessionId:le.string().optional()});var Uq="default";function jS(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function Kc(t,e){return jS({error:t},e)}function MS(t,e){t.post("/api/memory/save",async r=>{let{observationWriter:n,sessionManager:s}=e;if(n===void 0||s===void 0)return Kc("Service unavailable",503);let o;try{o=await r.json()}catch{return Kc("Invalid JSON body",400)}let i=OS.safeParse(o);if(!i.success)return Kc(i.error.issues[0]?.message??"Validation error",400);let{text:a,title:c,project:u=Uq}=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 jS({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 Kc(d,500)}})}function Gc(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function qt(t,e){return Gc({error:t},e)}function DS(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=hm.safeParse(s);if(!o.success)return qt(o.error.issues[0]?.message??"Validation error",400);try{let i=n.batchFetch(o.data.ids);return Gc({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),Gc({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=hm.safeParse(s);if(!o.success)return qt(o.error.issues[0]?.message??"Validation error",400);try{let i=n.bulkDelete(o.data.ids);return Gc({deleted:i})}catch(i){let a=i instanceof Error?i.message:"Bulk delete failed";return qt(a,500)}})}function Wc(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function _i(t,e){return Wc({error:t},e)}function qS(t,e){t.post("/api/retention/purge-age",async r=>{if(e.retentionManager===void 0)return _i("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 Wc({deleted:o.deleted})}),t.post("/api/retention/purge-project",async r=>{if(e.retentionManager===void 0)return _i("Retention manager not available",503);let n;try{n=await r.json()}catch{return _i("Invalid JSON body",400)}let s=n.project;if(typeof s!="string"||s.length===0)return _i("project is required",400);let o=e.retentionManager.purgeByProject(s);return Wc({deleted:o.deleted})}),t.post("/api/retention/vacuum",()=>e.retentionManager===void 0?_i("Retention manager not available",503):(e.retentionManager.vacuum(),Wc({success:!0})))}function gm(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function Cs(t,e){return gm({error:t},e)}function Fq(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 LS(t,e){t.get("/api/search",async r=>{let{searchManager:n}=e;if(n===void 0)return Cs("Service unavailable",503);let s=new URL(r.url),o=Fq(s),i=zS.safeParse(o);if(!i.success)return Cs(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 gm({results:f.results,total:f.total,mode:f.mode})}catch(m){let f=m instanceof Error?m.message:"Search failed";return Cs(f,500)}}),t.get("/api/search/semantic",async r=>{let{searchManager:n}=e;if(n===void 0)return Cs("Service unavailable",503);let o=new URL(r.url).searchParams.get("query")??"",i=CS.safeParse({query:o});if(!i.success)return Cs(i.error.issues[0]?.message??"Validation error",400);try{let a=await n.searchSemantic(i.data.query);return gm({results:a})}catch(a){let c=a instanceof Error?a.message:"Semantic search failed";return Cs(c,500)}})}function yi(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function Ur(t,e){return yi({error:t},e)}function ZS(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 yi({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 yi({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 yi({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),yi({success:!0}))})}function US(t,e=200){return new Response(JSON.stringify(t),{status:e,headers:{"Content-Type":"application/json"}})}function _m(t,e){return US({error:t},e)}function Vq(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 FS(t,e){t.get("/api/timeline",r=>{let{searchManager:n}=e;if(n===void 0)return _m("Service unavailable",503);let s=new URL(r.url),o=Vq(s),i=AS.safeParse(o);if(!i.success)return _m(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 US({entries:l.entries})}catch(l){let d=l instanceof Error?l.message:"Timeline query failed";return _m(d,500)}})}function Hq(){return`${Date.now()}-${Math.random().toString(36).slice(2,9)}`}function VS(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.8",
3
+ "version": "0.1.9",
4
4
  "type": "module",
5
5
  "description": "Persistent memory system for OpenCode sessions",
6
6
  "license": "MIT",