diff --git a/plugin/.mcp.json b/plugin/.mcp.json index e0ce825c..aa68ee7b 100644 --- a/plugin/.mcp.json +++ b/plugin/.mcp.json @@ -2,7 +2,7 @@ "mcpServers": { "claude-mem-search": { "type": "stdio", - "command": "${CLAUDE_PLUGIN_ROOT}/scripts/search-server.cjs" + "command": "${CLAUDE_PLUGIN_ROOT}/scripts/mcp-server.cjs" } } } diff --git a/plugin/scripts/mcp-server.cjs b/plugin/scripts/mcp-server.cjs new file mode 100755 index 00000000..0c3693f1 --- /dev/null +++ b/plugin/scripts/mcp-server.cjs @@ -0,0 +1,658 @@ +#!/usr/bin/env node +"use strict";var eu=Object.create;var zs=Object.defineProperty;var tu=Object.getOwnPropertyDescriptor;var ru=Object.getOwnPropertyNames;var su=Object.getPrototypeOf,au=Object.prototype.hasOwnProperty;var z=(s,e)=>()=>(e||s((e={exports:{}}).exports,e),e.exports),nu=(s,e)=>{for(var r in e)zs(s,r,{get:e[r],enumerable:!0})},ou=(s,e,r,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of ru(e))!au.call(s,t)&&t!==r&&zs(s,t,{get:()=>e[t],enumerable:!(a=tu(e,t))||a.enumerable});return s};var Ut=(s,e,r)=>(r=s!=null?eu(su(s)):{},ou(e||!s||!s.__esModule?zs(r,"default",{value:s,enumerable:!0}):r,s));var Jn=z((ls,Kn)=>{(function(s,e){typeof ls=="object"&&typeof Kn<"u"?e(ls):typeof define=="function"&&define.amd?define(["exports"],e):e(s.URI=s.URI||{})})(ls,(function(s){"use strict";function e(){for(var _=arguments.length,m=Array(_),b=0;b<_;b++)m[b]=arguments[b];if(m.length>1){m[0]=m[0].slice(0,-1);for(var w=m.length-1,O=1;O= 0x80 (not a basic code point)","invalid-input":"Invalid input"},$=p-g,L=Math.floor,C=String.fromCharCode;function k(_){throw new RangeError(D[_])}function N(_,m){for(var b=[],w=_.length;w--;)b[w]=m(_[w]);return b}function A(_,m){var b=_.split("@"),w="";b.length>1&&(w=b[0]+"@",_=b[1]),_=_.replace(I,".");var O=_.split("."),V=N(O,m).join(".");return w+V}function M(_){for(var m=[],b=0,w=_.length;b=55296&&O<=56319&&b>1,m+=L(m/b);m>$*y>>1;O+=p)m=L(m/$);return L(O+($+1)*m/(m+v))},Z=function(m){var b=[],w=m.length,O=0,V=E,Y=P,ne=m.lastIndexOf(R);ne<0&&(ne=0);for(var ue=0;ue=128&&k("not-basic"),b.push(m.charCodeAt(ue));for(var xe=ne>0?ne+1:0;xe=w&&k("invalid-input");var he=Q(m.charCodeAt(xe++));(he>=p||he>L((h-O)/ve))&&k("overflow"),O+=he*ve;var ce=Re<=Y?g:Re>=Y+y?y:Re-Y;if(heL(h/ge)&&k("overflow"),ve*=ge}var de=b.length+1;Y=K(O-ae,de,ae==0),L(O/de)>h-V&&k("overflow"),V+=L(O/de),O%=de,b.splice(O++,0,V)}return String.fromCodePoint.apply(String,b)},fe=function(m){var b=[];m=M(m);var w=m.length,O=E,V=0,Y=P,ne=!0,ue=!1,xe=void 0;try{for(var ae=m[Symbol.iterator](),ve;!(ne=(ve=ae.next()).done);ne=!0){var Re=ve.value;Re<128&&b.push(C(Re))}}catch(qt){ue=!0,xe=qt}finally{try{!ne&&ae.return&&ae.return()}finally{if(ue)throw xe}}var he=b.length,ce=he;for(he&&b.push(R);ce=O&&zeL((h-V)/We)&&k("overflow"),V+=(ge-O)*We,O=ge;var ct=!0,Mt=!1,vt=void 0;try{for(var Pr=m[Symbol.iterator](),zr;!(ct=(zr=Pr.next()).done);ct=!0){var Zr=zr.value;if(Zrh&&k("overflow"),Zr==O){for(var cr=V,lr=p;;lr+=p){var gt=lr<=Y?g:lr>=Y+y?y:lr-Y;if(cr>6|192).toString(16).toUpperCase()+"%"+(m&63|128).toString(16).toUpperCase():b="%"+(m>>12|224).toString(16).toUpperCase()+"%"+(m>>6&63|128).toString(16).toUpperCase()+"%"+(m&63|128).toString(16).toUpperCase(),b}function ke(_){for(var m="",b=0,w=_.length;b=194&&O<224){if(w-b>=6){var V=parseInt(_.substr(b+4,2),16);m+=String.fromCharCode((O&31)<<6|V&63)}else m+=_.substr(b,6);b+=6}else if(O>=224){if(w-b>=9){var Y=parseInt(_.substr(b+4,2),16),ne=parseInt(_.substr(b+7,2),16);m+=String.fromCharCode((O&15)<<12|(Y&63)<<6|ne&63)}else m+=_.substr(b,9);b+=9}else m+=_.substr(b,3),b+=3}return m}function Rt(_,m){function b(w){var O=ke(w);return O.match(m.UNRESERVED)?O:w}return _.scheme&&(_.scheme=String(_.scheme).replace(m.PCT_ENCODED,b).toLowerCase().replace(m.NOT_SCHEME,"")),_.userinfo!==void 0&&(_.userinfo=String(_.userinfo).replace(m.PCT_ENCODED,b).replace(m.NOT_USERINFO,we).replace(m.PCT_ENCODED,t)),_.host!==void 0&&(_.host=String(_.host).replace(m.PCT_ENCODED,b).toLowerCase().replace(m.NOT_HOST,we).replace(m.PCT_ENCODED,t)),_.path!==void 0&&(_.path=String(_.path).replace(m.PCT_ENCODED,b).replace(_.scheme?m.NOT_PATH:m.NOT_PATH_NOSCHEME,we).replace(m.PCT_ENCODED,t)),_.query!==void 0&&(_.query=String(_.query).replace(m.PCT_ENCODED,b).replace(m.NOT_QUERY,we).replace(m.PCT_ENCODED,t)),_.fragment!==void 0&&(_.fragment=String(_.fragment).replace(m.PCT_ENCODED,b).replace(m.NOT_FRAGMENT,we).replace(m.PCT_ENCODED,t)),_}function ht(_){return _.replace(/^0*(.*)/,"$1")||"0"}function Se(_,m){var b=_.match(m.IPV4ADDRESS)||[],w=d(b,2),O=w[1];return O?O.split(".").map(ht).join("."):_}function ye(_,m){var b=_.match(m.IPV6ADDRESS)||[],w=d(b,3),O=w[1],V=w[2];if(O){for(var Y=O.toLowerCase().split("::").reverse(),ne=d(Y,2),ue=ne[0],xe=ne[1],ae=xe?xe.split(":").map(ht):[],ve=ue.split(":").map(ht),Re=m.IPV4ADDRESS.test(ve[ve.length-1]),he=Re?7:8,ce=ve.length-he,ge=Array(he),de=0;de1){var pe=ge.slice(0,He.index),ze=ge.slice(He.index+He.length);Xe=pe.join(":")+"::"+ze.join(":")}else Xe=ge.join(":");return V&&(Xe+="%"+V),Xe}else return _}var kt=/^(?:([^:\/?#]+):)?(?:\/\/((?:([^\/?#@]*)@)?(\[[^\/?#\]]+\]|[^\/?#:]*)(?:\:(\d*))?))?([^?#]*)(?:\?([^#]*))?(?:#((?:.|\n|\r)*))?/i,Ne="".match(/(){0}/)[1]===void 0;function le(_){var m=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},b={},w=m.iri!==!1?u:l;m.reference==="suffix"&&(_=(m.scheme?m.scheme+":":"")+"//"+_);var O=_.match(kt);if(O){Ne?(b.scheme=O[1],b.userinfo=O[3],b.host=O[4],b.port=parseInt(O[5],10),b.path=O[6]||"",b.query=O[7],b.fragment=O[8],isNaN(b.port)&&(b.port=O[5])):(b.scheme=O[1]||void 0,b.userinfo=_.indexOf("@")!==-1?O[3]:void 0,b.host=_.indexOf("//")!==-1?O[4]:void 0,b.port=parseInt(O[5],10),b.path=O[6]||"",b.query=_.indexOf("?")!==-1?O[7]:void 0,b.fragment=_.indexOf("#")!==-1?O[8]:void 0,isNaN(b.port)&&(b.port=_.match(/\/\/(?:.|\n)*\:(?:\/|\?|\#|$)/)?O[4]:void 0)),b.host&&(b.host=ye(Se(b.host,w),w)),b.scheme===void 0&&b.userinfo===void 0&&b.host===void 0&&b.port===void 0&&!b.path&&b.query===void 0?b.reference="same-document":b.scheme===void 0?b.reference="relative":b.fragment===void 0?b.reference="absolute":b.reference="uri",m.reference&&m.reference!=="suffix"&&m.reference!==b.reference&&(b.error=b.error||"URI is not a "+m.reference+" reference.");var V=Ee[(m.scheme||b.scheme||"").toLowerCase()];if(!m.unicodeSupport&&(!V||!V.unicodeSupport)){if(b.host&&(m.domainHost||V&&V.domainHost))try{b.host=ie.toASCII(b.host.replace(w.PCT_ENCODED,ke).toLowerCase())}catch(Y){b.error=b.error||"Host's domain name can not be converted to ASCII via punycode: "+Y}Rt(b,l)}else Rt(b,w);V&&V.parse&&V.parse(b,m)}else b.error=b.error||"URI can not be parsed.";return b}function Tt(_,m){var b=m.iri!==!1?u:l,w=[];return _.userinfo!==void 0&&(w.push(_.userinfo),w.push("@")),_.host!==void 0&&w.push(ye(Se(String(_.host),b),b).replace(b.IPV6ADDRESS,function(O,V,Y){return"["+V+(Y?"%25"+Y:"")+"]"})),(typeof _.port=="number"||typeof _.port=="string")&&(w.push(":"),w.push(String(_.port))),w.length?w.join(""):void 0}var mt=/^\.\.?\//,Lt=/^\/\.(\/|$)/,jt=/^\/\.\.(\/|$)/,Pe=/^\/?(?:.|\n)*?(?=\/|$)/;function Ge(_){for(var m=[];_.length;)if(_.match(mt))_=_.replace(mt,"");else if(_.match(Lt))_=_.replace(Lt,"/");else if(_.match(jt))_=_.replace(jt,"/"),m.pop();else if(_==="."||_==="..")_="";else{var b=_.match(Pe);if(b){var w=b[0];_=_.slice(w.length),m.push(w)}else throw new Error("Unexpected dot segment condition")}return m.join("")}function Me(_){var m=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},b=m.iri?u:l,w=[],O=Ee[(m.scheme||_.scheme||"").toLowerCase()];if(O&&O.serialize&&O.serialize(_,m),_.host&&!b.IPV6ADDRESS.test(_.host)){if(m.domainHost||O&&O.domainHost)try{_.host=m.iri?ie.toUnicode(_.host):ie.toASCII(_.host.replace(b.PCT_ENCODED,ke).toLowerCase())}catch(ne){_.error=_.error||"Host's domain name can not be converted to "+(m.iri?"Unicode":"ASCII")+" via punycode: "+ne}}Rt(_,b),m.reference!=="suffix"&&_.scheme&&(w.push(_.scheme),w.push(":"));var V=Tt(_,m);if(V!==void 0&&(m.reference!=="suffix"&&w.push("//"),w.push(V),_.path&&_.path.charAt(0)!=="/"&&w.push("/")),_.path!==void 0){var Y=_.path;!m.absolutePath&&(!O||!O.absolutePath)&&(Y=Ge(Y)),V===void 0&&(Y=Y.replace(/^\/\//,"/%2F")),w.push(Y)}return _.query!==void 0&&(w.push("?"),w.push(_.query)),_.fragment!==void 0&&(w.push("#"),w.push(_.fragment)),w.join("")}function Le(_,m){var b=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{},w=arguments[3],O={};return w||(_=le(Me(_,b),b),m=le(Me(m,b),b)),b=b||{},!b.tolerant&&m.scheme?(O.scheme=m.scheme,O.userinfo=m.userinfo,O.host=m.host,O.port=m.port,O.path=Ge(m.path||""),O.query=m.query):(m.userinfo!==void 0||m.host!==void 0||m.port!==void 0?(O.userinfo=m.userinfo,O.host=m.host,O.port=m.port,O.path=Ge(m.path||""),O.query=m.query):(m.path?(m.path.charAt(0)==="/"?O.path=Ge(m.path):((_.userinfo!==void 0||_.host!==void 0||_.port!==void 0)&&!_.path?O.path="/"+m.path:_.path?O.path=_.path.slice(0,_.path.lastIndexOf("/")+1)+m.path:O.path=m.path,O.path=Ge(O.path)),O.query=m.query):(O.path=_.path,m.query!==void 0?O.query=m.query:O.query=_.query),O.userinfo=_.userinfo,O.host=_.host,O.port=_.port),O.scheme=_.scheme),O.fragment=m.fragment,O}function ot(_,m,b){var w=i({scheme:"null"},b);return Me(Le(le(_,w),le(m,w),w,!0),w)}function Ve(_,m){return typeof _=="string"?_=Me(le(_,m),m):a(_)==="object"&&(_=le(Me(_,m),m)),_}function Hr(_,m,b){return typeof _=="string"?_=Me(le(_,b),b):a(_)==="object"&&(_=Me(_,b)),typeof m=="string"?m=Me(le(m,b),b):a(m)==="object"&&(m=Me(m,b)),_===m}function Us(_,m){return _&&_.toString().replace(!m||!m.iri?l.ESCAPE:u.ESCAPE,we)}function tt(_,m){return _&&_.toString().replace(!m||!m.iri?l.PCT_ENCODED:u.PCT_ENCODED,ke)}var wr={scheme:"http",domainHost:!0,parse:function(m,b){return m.host||(m.error=m.error||"HTTP URIs must have a host."),m},serialize:function(m,b){var w=String(m.scheme).toLowerCase()==="https";return(m.port===(w?443:80)||m.port==="")&&(m.port=void 0),m.path||(m.path="/"),m}},pn={scheme:"https",domainHost:wr.domainHost,parse:wr.parse,serialize:wr.serialize};function fn(_){return typeof _.secure=="boolean"?_.secure:String(_.scheme).toLowerCase()==="wss"}var Or={scheme:"ws",domainHost:!0,parse:function(m,b){var w=m;return w.secure=fn(w),w.resourceName=(w.path||"/")+(w.query?"?"+w.query:""),w.path=void 0,w.query=void 0,w},serialize:function(m,b){if((m.port===(fn(m)?443:80)||m.port==="")&&(m.port=void 0),typeof m.secure=="boolean"&&(m.scheme=m.secure?"wss":"ws",m.secure=void 0),m.resourceName){var w=m.resourceName.split("?"),O=d(w,2),V=O[0],Y=O[1];m.path=V&&V!=="/"?V:void 0,m.query=Y,m.resourceName=void 0}return m.fragment=void 0,m}},hn={scheme:"wss",domainHost:Or.domainHost,parse:Or.parse,serialize:Or.serialize},kl={},Ll=!0,mn="[A-Za-z0-9\\-\\.\\_\\~"+(Ll?"\\xA0-\\u200D\\u2010-\\u2029\\u202F-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF":"")+"]",it="[0-9A-Fa-f]",jl=r(r("%[EFef]"+it+"%"+it+it+"%"+it+it)+"|"+r("%[89A-Fa-f]"+it+"%"+it+it)+"|"+r("%"+it+it)),Fl="[A-Za-z0-9\\!\\$\\%\\'\\*\\+\\-\\^\\_\\`\\{\\|\\}\\~]",Ml="[\\!\\$\\%\\'\\(\\)\\*\\+\\,\\-\\.0-9\\<\\>A-Z\\x5E-\\x7E]",ql=e(Ml,'[\\"\\\\]'),Ul="[\\!\\$\\'\\(\\)\\*\\+\\,\\;\\:\\@]",Bl=new RegExp(mn,"g"),ir=new RegExp(jl,"g"),Vl=new RegExp(e("[^]",Fl,"[\\.]",'[\\"]',ql),"g"),vn=new RegExp(e("[^]",mn,Ul),"g"),Hl=vn;function Bs(_){var m=ke(_);return m.match(Bl)?m:_}var gn={scheme:"mailto",parse:function(m,b){var w=m,O=w.to=w.path?w.path.split(","):[];if(w.path=void 0,w.query){for(var V=!1,Y={},ne=w.query.split("&"),ue=0,xe=ne.length;ue{"use strict";Yn.exports=function s(e,r){if(e===r)return!0;if(e&&r&&typeof e=="object"&&typeof r=="object"){if(e.constructor!==r.constructor)return!1;var a,t,n;if(Array.isArray(e)){if(a=e.length,a!=r.length)return!1;for(t=a;t--!==0;)if(!s(e[t],r[t]))return!1;return!0}if(e.constructor===RegExp)return e.source===r.source&&e.flags===r.flags;if(e.valueOf!==Object.prototype.valueOf)return e.valueOf()===r.valueOf();if(e.toString!==Object.prototype.toString)return e.toString()===r.toString();if(n=Object.keys(e),a=n.length,a!==Object.keys(r).length)return!1;for(t=a;t--!==0;)if(!Object.prototype.hasOwnProperty.call(r,n[t]))return!1;for(t=a;t--!==0;){var i=n[t];if(!s(e[i],r[i]))return!1}return!0}return e!==e&&r!==r}});var to=z((Em,eo)=>{"use strict";eo.exports=function(e){for(var r=0,a=e.length,t=0,n;t=55296&&n<=56319&&t{"use strict";ao.exports={copy:np,checkDataType:va,checkDataTypes:op,coerceToTypes:ip,toHash:ya,getProperty:_a,escapeQuotes:ba,equal:us(),ucs2length:to(),varOccurences:up,varReplace:dp,schemaHasRules:pp,schemaHasRulesExcept:fp,schemaUnknownRules:hp,toQuotedString:ga,getPathExpr:mp,getPath:vp,getData:_p,unescapeFragment:bp,unescapeJsonPointer:Sa,escapeFragment:Ep,escapeJsonPointer:Ea};function np(s,e){e=e||{};for(var r in s)e[r]=s[r];return e}function va(s,e,r,a){var t=a?" !== ":" === ",n=a?" || ":" && ",i=a?"!":"",o=a?"":"!";switch(s){case"null":return e+t+"null";case"array":return i+"Array.isArray("+e+")";case"object":return"("+i+e+n+"typeof "+e+t+'"object"'+n+o+"Array.isArray("+e+"))";case"integer":return"(typeof "+e+t+'"number"'+n+o+"("+e+" % 1)"+n+e+t+e+(r?n+i+"isFinite("+e+")":"")+")";case"number":return"(typeof "+e+t+'"'+s+'"'+(r?n+i+"isFinite("+e+")":"")+")";default:return"typeof "+e+t+'"'+s+'"'}}function op(s,e,r){switch(s.length){case 1:return va(s[0],e,r,!0);default:var a="",t=ya(s);t.array&&t.object&&(a=t.null?"(":"(!"+e+" || ",a+="typeof "+e+' !== "object")',delete t.null,delete t.array,delete t.object),t.number&&delete t.integer;for(var n in t)a+=(a?" && ":"")+va(n,e,r,!0);return a}}var ro=ya(["string","number","integer","boolean","null"]);function ip(s,e){if(Array.isArray(e)){for(var r=[],a=0;a=e)throw new Error("Cannot access property/index "+a+" levels up, current level is "+e);return r[e-a]}if(a>e)throw new Error("Cannot access data "+a+" levels up, current level is "+e);if(n="data"+(e-a||""),!t)return n}for(var o=n,l=t.split("/"),u=0;u{"use strict";var Sp=ar();no.exports=xp;function xp(s){Sp.copy(s,this)}});var io=z((Rm,oo)=>{"use strict";var Nt=oo.exports=function(s,e,r){typeof e=="function"&&(r=e,e={}),r=e.cb||r;var a=typeof r=="function"?r:r.pre||function(){},t=r.post||function(){};ds(e,a,t,s,"",s)};Nt.keywords={additionalItems:!0,items:!0,contains:!0,additionalProperties:!0,propertyNames:!0,not:!0};Nt.arrayKeywords={items:!0,allOf:!0,anyOf:!0,oneOf:!0};Nt.propsKeywords={definitions:!0,properties:!0,patternProperties:!0,dependencies:!0};Nt.skipKeywords={default:!0,enum:!0,const:!0,required:!0,maximum:!0,minimum:!0,exclusiveMaximum:!0,exclusiveMinimum:!0,multipleOf:!0,maxLength:!0,minLength:!0,pattern:!0,format:!0,maxItems:!0,minItems:!0,uniqueItems:!0,maxProperties:!0,minProperties:!0};function ds(s,e,r,a,t,n,i,o,l,u){if(a&&typeof a=="object"&&!Array.isArray(a)){e(a,t,n,i,o,l,u);for(var d in a){var f=a[d];if(Array.isArray(f)){if(d in Nt.arrayKeywords)for(var h=0;h{"use strict";var Ur=Jn(),co=us(),ms=ar(),ps=xa(),Tp=io();po.exports=$t;$t.normalizeId=At;$t.fullPath=fs;$t.url=hs;$t.ids=Np;$t.inlineRef=Ra;$t.schema=vs;function $t(s,e,r){var a=this._refs[r];if(typeof a=="string")if(this._refs[a])a=this._refs[a];else return $t.call(this,s,e,a);if(a=a||this._schemas[r],a instanceof ps)return Ra(a.schema,this._opts.inlineRefs)?a.schema:a.validate||this._compile(a);var t=vs.call(this,e,r),n,i,o;return t&&(n=t.schema,e=t.root,o=t.baseId),n instanceof ps?i=n.validate||s.call(this,n.schema,e,void 0,o):n!==void 0&&(i=Ra(n,this._opts.inlineRefs)?n:s.call(this,n,e,void 0,o)),i}function vs(s,e){var r=Ur.parse(e),a=uo(r),t=fs(this._getId(s.schema));if(Object.keys(s.schema).length===0||a!==t){var n=At(a),i=this._refs[n];if(typeof i=="string")return wp.call(this,s,i,r);if(i instanceof ps)i.validate||this._compile(i),s=i;else if(i=this._schemas[n],i instanceof ps){if(i.validate||this._compile(i),n==At(e))return{schema:i,root:s,baseId:t};s=i}else return;if(!s.schema)return;t=fs(this._getId(s.schema))}return lo.call(this,r,t,s.schema,s)}function wp(s,e,r){var a=vs.call(this,s,e);if(a){var t=a.schema,n=a.baseId;s=a.root;var i=this._getId(t);return i&&(n=hs(n,i)),lo.call(this,r,n,t,s)}}var Op=ms.toHash(["properties","patternProperties","enum","dependencies","definitions"]);function lo(s,e,r,a){if(s.fragment=s.fragment||"",s.fragment.slice(0,1)=="/"){for(var t=s.fragment.split("/"),n=1;n{"use strict";var Oa=gs();ho.exports={Validation:fo(Ap),MissingRef:fo(Pa)};function Ap(s){this.message="validation failed",this.errors=s,this.ajv=this.validation=!0}Pa.message=function(s,e){return"can't resolve reference "+e+" from id "+s};function Pa(s,e,r){this.message=r||Pa.message(s,e),this.missingRef=Oa.url(s,e),this.missingSchema=Oa.normalizeId(Oa.fullPath(this.missingRef))}function fo(s){return s.prototype=Object.create(Error.prototype),s.prototype.constructor=s,s}});var Ia=z((Om,mo)=>{"use strict";mo.exports=function(s,e){e||(e={}),typeof e=="function"&&(e={cmp:e});var r=typeof e.cycles=="boolean"?e.cycles:!1,a=e.cmp&&(function(n){return function(i){return function(o,l){var u={key:o,value:i[o]},d={key:l,value:i[l]};return n(u,d)}}})(e.cmp),t=[];return(function n(i){if(i&&i.toJSON&&typeof i.toJSON=="function"&&(i=i.toJSON()),i!==void 0){if(typeof i=="number")return isFinite(i)?""+i:"null";if(typeof i!="object")return JSON.stringify(i);var o,l;if(Array.isArray(i)){for(l="[",o=0;o{"use strict";vo.exports=function(e,r,a){var t="",n=e.schema.$async===!0,i=e.util.schemaHasRulesExcept(e.schema,e.RULES.all,"$ref"),o=e.self._getId(e.schema);if(e.opts.strictKeywords){var l=e.util.schemaUnknownRules(e.schema,e.RULES.keywords);if(l){var u="unknown keyword: "+l;if(e.opts.strictKeywords==="log")e.logger.warn(u);else throw new Error(u)}}if(e.isTop&&(t+=" var validate = ",n&&(e.async=!0,t+="async "),t+="function(data, dataPath, parentData, parentDataProperty, rootData) { 'use strict'; ",o&&(e.opts.sourceCode||e.opts.processCode)&&(t+=" "+("/*# sourceURL="+o+" */")+" ")),typeof e.schema=="boolean"||!(i||e.schema.$ref)){var r="false schema",d=e.level,f=e.dataLevel,h=e.schema[r],p=e.schemaPath+e.util.getProperty(r),g=e.errSchemaPath+"/"+r,T=!e.opts.allErrors,D,y="data"+(f||""),R="valid"+d;if(e.schema===!1){e.isTop?T=!0:t+=" var "+R+" = false; ";var v=v||[];v.push(t),t="",e.createErrors!==!1?(t+=" { keyword: '"+(D||"false schema")+"' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(g)+" , params: {} ",e.opts.messages!==!1&&(t+=" , message: 'boolean schema is false' "),e.opts.verbose&&(t+=" , schema: false , parentSchema: validate.schema"+e.schemaPath+" , data: "+y+" "),t+=" } "):t+=" {} ";var x=t;t=v.pop(),!e.compositeRule&&T?e.async?t+=" throw new ValidationError(["+x+"]); ":t+=" validate.errors = ["+x+"]; return false; ":t+=" var err = "+x+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; "}else e.isTop?n?t+=" return data; ":t+=" validate.errors = null; return true; ":t+=" var "+R+" = true; ";return e.isTop&&(t+=" }; return validate; "),t}if(e.isTop){var P=e.isTop,d=e.level=0,f=e.dataLevel=0,y="data";if(e.rootId=e.resolve.fullPath(e.self._getId(e.root.schema)),e.baseId=e.baseId||e.rootId,delete e.isTop,e.dataPathArr=[""],e.schema.default!==void 0&&e.opts.useDefaults&&e.opts.strictDefaults){var E="default is ignored in the schema root";if(e.opts.strictDefaults==="log")e.logger.warn(E);else throw new Error(E)}t+=" var vErrors = null; ",t+=" var errors = 0; ",t+=" if (rootData === undefined) rootData = data; "}else{var d=e.level,f=e.dataLevel,y="data"+(f||"");if(o&&(e.baseId=e.resolve.url(e.baseId,o)),n&&!e.async)throw new Error("async schema in sync schema");t+=" var errs_"+d+" = errors;"}var R="valid"+d,T=!e.opts.allErrors,S="",I="",D,$=e.schema.type,L=Array.isArray($);if($&&e.opts.nullable&&e.schema.nullable===!0&&(L?$.indexOf("null")==-1&&($=$.concat("null")):$!="null"&&($=[$,"null"],L=!0)),L&&$.length==1&&($=$[0],L=!1),e.schema.$ref&&i){if(e.opts.extendRefs=="fail")throw new Error('$ref: validation keywords used in schema at path "'+e.errSchemaPath+'" (see option extendRefs)');e.opts.extendRefs!==!0&&(i=!1,e.logger.warn('$ref: keywords ignored in schema at path "'+e.errSchemaPath+'"'))}if(e.schema.$comment&&e.opts.$comment&&(t+=" "+e.RULES.all.$comment.code(e,"$comment")),$){if(e.opts.coerceTypes)var C=e.util.coerceToTypes(e.opts.coerceTypes,$);var k=e.RULES.types[$];if(C||L||k===!0||k&&!Pe(k)){var p=e.schemaPath+".type",g=e.errSchemaPath+"/type",p=e.schemaPath+".type",g=e.errSchemaPath+"/type",N=L?"checkDataTypes":"checkDataType";if(t+=" if ("+e.util[N]($,y,e.opts.strictNumbers,!0)+") { ",C){var A="dataType"+d,M="coerced"+d;t+=" var "+A+" = typeof "+y+"; var "+M+" = undefined; ",e.opts.coerceTypes=="array"&&(t+=" if ("+A+" == 'object' && Array.isArray("+y+") && "+y+".length == 1) { "+y+" = "+y+"[0]; "+A+" = typeof "+y+"; if ("+e.util.checkDataType(e.schema.type,y,e.opts.strictNumbers)+") "+M+" = "+y+"; } "),t+=" if ("+M+" !== undefined) ; ";var W=C;if(W)for(var Q,te=-1,K=W.length-1;te{"use strict";var _s=gs(),Es=ar(),yo=ys(),$p=Ia(),go=Na(),Dp=Es.ucs2length,Cp=us(),kp=yo.Validation;bo.exports=Aa;function Aa(s,e,r,a){var t=this,n=this._opts,i=[void 0],o={},l=[],u={},d=[],f={},h=[];e=e||{schema:s,refVal:i,refs:o};var p=Lp.call(this,s,e,a),g=this._compilations[p.index];if(p.compiling)return g.callValidate=E;var y=this._formats,v=this.RULES;try{var x=R(s,e,r,a);g.validate=x;var P=g.callValidate;return P&&(P.schema=x.schema,P.errors=null,P.refs=x.refs,P.refVal=x.refVal,P.root=x.root,P.$async=x.$async,n.sourceCode&&(P.source=x.source)),x}finally{jp.call(this,s,e,a)}function E(){var N=g.validate,A=N.apply(this,arguments);return E.errors=N.errors,A}function R(N,A,M,W){var Q=!A||A&&A.schema==N;if(A.schema!=e.schema)return Aa.call(t,N,A,M,W);var te=N.$async===!0,K=go({isTop:!0,schema:N,isRoot:Q,baseId:W,root:A,schemaPath:"",errSchemaPath:"#",errorPath:'""',MissingRefError:yo.MissingRef,RULES:v,validate:go,util:Es,resolve:_s,resolveRef:T,usePattern:L,useDefault:C,useCustomRule:k,opts:n,formats:y,logger:t.logger,self:t});K=bs(i,qp)+bs(l,Fp)+bs(d,Mp)+bs(h,Up)+K,n.processCode&&(K=n.processCode(K,N));var Z;try{var fe=new Function("self","RULES","formats","root","refVal","defaults","customRules","equal","ucs2length","ValidationError",K);Z=fe(t,v,y,e,i,d,h,Cp,Dp,kp),i[0]=Z}catch(Te){throw t.logger.error("Error compiling schema, function code:",K),Te}return Z.schema=N,Z.errors=null,Z.refs=o,Z.refVal=i,Z.root=Q?Z:A,te&&(Z.$async=!0),n.sourceCode===!0&&(Z.source={code:K,patterns:l,defaults:d}),Z}function T(N,A,M){A=_s.url(N,A);var W=o[A],Q,te;if(W!==void 0)return Q=i[W],te="refVal["+W+"]",$(Q,te);if(!M&&e.refs){var K=e.refs[A];if(K!==void 0)return Q=e.refVal[K],te=S(A,Q),$(Q,te)}te=S(A);var Z=_s.call(t,R,e,A);if(Z===void 0){var fe=r&&r[A];fe&&(Z=_s.inlineRef(fe,n.inlineRefs)?fe:Aa.call(t,fe,e,r,N))}if(Z===void 0)I(A);else return D(A,Z),$(Z,te)}function S(N,A){var M=i.length;return i[M]=A,o[N]=M,"refVal"+M}function I(N){delete o[N]}function D(N,A){var M=o[N];i[M]=A}function $(N,A){return typeof N=="object"||typeof N=="boolean"?{code:A,schema:N,inline:!0}:{code:A,$async:N&&!!N.$async}}function L(N){var A=u[N];return A===void 0&&(A=u[N]=l.length,l[A]=N),"pattern"+A}function C(N){switch(typeof N){case"boolean":case"number":return""+N;case"string":return Es.toQuotedString(N);case"object":if(N===null)return"null";var A=$p(N),M=f[A];return M===void 0&&(M=f[A]=d.length,d[M]=N),"default"+M}}function k(N,A,M,W){if(t._opts.validateSchema!==!1){var Q=N.definition.dependencies;if(Q&&!Q.every(function(we){return Object.prototype.hasOwnProperty.call(M,we)}))throw new Error("parent schema must have all required keywords: "+Q.join(","));var te=N.definition.validateSchema;if(te){var K=te(A);if(!K){var Z="keyword schema is invalid: "+t.errorsText(te.errors);if(t._opts.validateSchema=="log")t.logger.error(Z);else throw new Error(Z)}}}var fe=N.definition.compile,Te=N.definition.inline,Ce=N.definition.macro,ie;if(fe)ie=fe.call(t,A,M,W);else if(Ce)ie=Ce.call(t,A,M,W),n.validateSchema!==!1&&t.validateSchema(ie,!0);else if(Te)ie=Te.call(t,W,N.keyword,A,M);else if(ie=N.definition.validate,!ie)return;if(ie===void 0)throw new Error('custom keyword "'+N.keyword+'"failed to compile');var Ee=h.length;return h[Ee]=ie,{code:"customRule"+Ee,validate:ie}}}function Lp(s,e,r){var a=_o.call(this,s,e,r);return a>=0?{index:a,compiling:!0}:(a=this._compilations.length,this._compilations[a]={schema:s,root:e,baseId:r},{index:a,compiling:!1})}function jp(s,e,r){var a=_o.call(this,s,e,r);a>=0&&this._compilations.splice(a,1)}function _o(s,e,r){for(var a=0;a{"use strict";var Ss=So.exports=function(){this._cache={}};Ss.prototype.put=function(e,r){this._cache[e]=r};Ss.prototype.get=function(e){return this._cache[e]};Ss.prototype.del=function(e){delete this._cache[e]};Ss.prototype.clear=function(){this._cache={}}});var ko=z((Am,Co)=>{"use strict";var Bp=ar(),Vp=/^(\d\d\d\d)-(\d\d)-(\d\d)$/,Hp=[0,31,28,31,30,31,30,31,31,30,31,30,31],zp=/^(\d\d):(\d\d):(\d\d)(\.\d+)?(z|[+-]\d\d(?::?\d\d)?)?$/i,Ro=/^(?=.{1,253}\.?$)[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[-0-9a-z]{0,61}[0-9a-z])?)*\.?$/i,Zp=/^(?:[a-z][a-z0-9+\-.]*:)(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|[Vv][0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)|(?:[a-z0-9\-._~!$&'()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*|\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)?|(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)(?:\?(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i,Gp=/^(?:[a-z][a-z0-9+\-.]*:)?(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|[Vv][0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)|(?:[a-z0-9\-._~!$&'"()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*|\/(?:(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*)?|(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*)?(?:\?(?:[a-z0-9\-._~!$&'"()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'"()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i,To=/^(?:(?:[^\x00-\x20"'<>%\\^`{|}]|%[0-9a-f]{2})|\{[+#./;?&=,!@|]?(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?(?:,(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?)*\})*$/i,wo=/^(?:(?:http[s\u017F]?|ftp):\/\/)(?:(?:[\0-\x08\x0E-\x1F!-\x9F\xA1-\u167F\u1681-\u1FFF\u200B-\u2027\u202A-\u202E\u2030-\u205E\u2060-\u2FFF\u3001-\uD7FF\uE000-\uFEFE\uFF00-\uFFFF]|[\uD800-\uDBFF][\uDC00-\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+(?::(?:[\0-\x08\x0E-\x1F!-\x9F\xA1-\u167F\u1681-\u1FFF\u200B-\u2027\u202A-\u202E\u2030-\u205E\u2060-\u2FFF\u3001-\uD7FF\uE000-\uFEFE\uFF00-\uFFFF]|[\uD800-\uDBFF][\uDC00-\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])*)?@)?(?:(?!10(?:\.[0-9]{1,3}){3})(?!127(?:\.[0-9]{1,3}){3})(?!169\.254(?:\.[0-9]{1,3}){2})(?!192\.168(?:\.[0-9]{1,3}){2})(?!172\.(?:1[6-9]|2[0-9]|3[01])(?:\.[0-9]{1,3}){2})(?:[1-9][0-9]?|1[0-9][0-9]|2[01][0-9]|22[0-3])(?:\.(?:1?[0-9]{1,2}|2[0-4][0-9]|25[0-5])){2}(?:\.(?:[1-9][0-9]?|1[0-9][0-9]|2[0-4][0-9]|25[0-4]))|(?:(?:(?:[0-9a-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+-)*(?:[0-9a-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+)(?:\.(?:(?:[0-9a-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+-)*(?:[0-9a-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+)*(?:\.(?:(?:[a-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF]){2,})))(?::[0-9]{2,5})?(?:\/(?:[\0-\x08\x0E-\x1F!-\x9F\xA1-\u167F\u1681-\u1FFF\u200B-\u2027\u202A-\u202E\u2030-\u205E\u2060-\u2FFF\u3001-\uD7FF\uE000-\uFEFE\uFF00-\uFFFF]|[\uD800-\uDBFF][\uDC00-\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])*)?$/i,Oo=/^(?:urn:uuid:)?[0-9a-f]{8}-(?:[0-9a-f]{4}-){3}[0-9a-f]{12}$/i,Po=/^(?:\/(?:[^~/]|~0|~1)*)*$/,Io=/^#(?:\/(?:[a-z0-9_\-.!$&'()*+,;:=@]|%[0-9a-f]{2}|~0|~1)*)*$/i,No=/^(?:0|[1-9][0-9]*)(?:#|(?:\/(?:[^~/]|~0|~1)*)*)$/;Co.exports=xs;function xs(s){return s=s=="full"?"full":"fast",Bp.copy(xs[s])}xs.fast={date:/^\d\d\d\d-[0-1]\d-[0-3]\d$/,time:/^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)?$/i,"date-time":/^\d\d\d\d-[0-1]\d-[0-3]\d[t\s](?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)$/i,uri:/^(?:[a-z][a-z0-9+\-.]*:)(?:\/?\/)?[^\s]*$/i,"uri-reference":/^(?:(?:[a-z][a-z0-9+\-.]*:)?\/?\/)?(?:[^\\\s#][^\s#]*)?(?:#[^\\\s]*)?$/i,"uri-template":To,url:wo,email:/^[a-z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?)*$/i,hostname:Ro,ipv4:/^(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)$/,ipv6:/^\s*(?:(?:(?:[0-9a-f]{1,4}:){7}(?:[0-9a-f]{1,4}|:))|(?:(?:[0-9a-f]{1,4}:){6}(?::[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){5}(?:(?:(?::[0-9a-f]{1,4}){1,2})|:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){4}(?:(?:(?::[0-9a-f]{1,4}){1,3})|(?:(?::[0-9a-f]{1,4})?:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){3}(?:(?:(?::[0-9a-f]{1,4}){1,4})|(?:(?::[0-9a-f]{1,4}){0,2}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){2}(?:(?:(?::[0-9a-f]{1,4}){1,5})|(?:(?::[0-9a-f]{1,4}){0,3}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){1}(?:(?:(?::[0-9a-f]{1,4}){1,6})|(?:(?::[0-9a-f]{1,4}){0,4}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?::(?:(?:(?::[0-9a-f]{1,4}){1,7})|(?:(?::[0-9a-f]{1,4}){0,5}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(?:%.+)?\s*$/i,regex:Do,uuid:Oo,"json-pointer":Po,"json-pointer-uri-fragment":Io,"relative-json-pointer":No};xs.full={date:Ao,time:$o,"date-time":Qp,uri:Jp,"uri-reference":Gp,"uri-template":To,url:wo,email:/^[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?$/i,hostname:Ro,ipv4:/^(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)$/,ipv6:/^\s*(?:(?:(?:[0-9a-f]{1,4}:){7}(?:[0-9a-f]{1,4}|:))|(?:(?:[0-9a-f]{1,4}:){6}(?::[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){5}(?:(?:(?::[0-9a-f]{1,4}){1,2})|:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){4}(?:(?:(?::[0-9a-f]{1,4}){1,3})|(?:(?::[0-9a-f]{1,4})?:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){3}(?:(?:(?::[0-9a-f]{1,4}){1,4})|(?:(?::[0-9a-f]{1,4}){0,2}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){2}(?:(?:(?::[0-9a-f]{1,4}){1,5})|(?:(?::[0-9a-f]{1,4}){0,3}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){1}(?:(?:(?::[0-9a-f]{1,4}){1,6})|(?:(?::[0-9a-f]{1,4}){0,4}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?::(?:(?:(?::[0-9a-f]{1,4}){1,7})|(?:(?::[0-9a-f]{1,4}){0,5}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(?:%.+)?\s*$/i,regex:Do,uuid:Oo,"json-pointer":Po,"json-pointer-uri-fragment":Io,"relative-json-pointer":No};function Xp(s){return s%4===0&&(s%100!==0||s%400===0)}function Ao(s){var e=s.match(Vp);if(!e)return!1;var r=+e[1],a=+e[2],t=+e[3];return a>=1&&a<=12&&t>=1&&t<=(a==2&&Xp(r)?29:Hp[a])}function $o(s,e){var r=s.match(zp);if(!r)return!1;var a=r[1],t=r[2],n=r[3],i=r[5];return(a<=23&&t<=59&&n<=59||a==23&&t==59&&n==60)&&(!e||i)}var Wp=/t|\s/i;function Qp(s){var e=s.split(Wp);return e.length==2&&Ao(e[0])&&$o(e[1],!0)}var Kp=/\/|:/;function Jp(s){return Kp.test(s)&&Zp.test(s)}var Yp=/[^\\]\\Z/;function Do(s){if(Yp.test(s))return!1;try{return new RegExp(s),!0}catch{return!1}}});var jo=z(($m,Lo)=>{"use strict";Lo.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.errSchemaPath+"/"+r,u=!e.opts.allErrors,d="data"+(i||""),f="valid"+n,h,p;if(o=="#"||o=="#/")e.isRoot?(h=e.async,p="validate"):(h=e.root.schema.$async===!0,p="root.refVal[0]");else{var g=e.resolveRef(e.baseId,o,e.isRoot);if(g===void 0){var y=e.MissingRefError.message(e.baseId,o);if(e.opts.missingRefs=="fail"){e.logger.error(y);var v=v||[];v.push(t),t="",e.createErrors!==!1?(t+=" { keyword: '$ref' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(l)+" , params: { ref: '"+e.util.escapeQuotes(o)+"' } ",e.opts.messages!==!1&&(t+=" , message: 'can\\'t resolve reference "+e.util.escapeQuotes(o)+"' "),e.opts.verbose&&(t+=" , schema: "+e.util.toQuotedString(o)+" , parentSchema: validate.schema"+e.schemaPath+" , data: "+d+" "),t+=" } "):t+=" {} ";var x=t;t=v.pop(),!e.compositeRule&&u?e.async?t+=" throw new ValidationError(["+x+"]); ":t+=" validate.errors = ["+x+"]; return false; ":t+=" var err = "+x+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",u&&(t+=" if (false) { ")}else if(e.opts.missingRefs=="ignore")e.logger.warn(y),u&&(t+=" if (true) { ");else throw new e.MissingRefError(e.baseId,o,y)}else if(g.inline){var P=e.util.copy(e);P.level++;var E="valid"+P.level;P.schema=g.schema,P.schemaPath="",P.errSchemaPath=o;var R=e.validate(P).replace(/validate\.schema/g,g.code);t+=" "+R+" ",u&&(t+=" if ("+E+") { ")}else h=g.$async===!0||e.async&&g.$async!==!1,p=g.code}if(p){var v=v||[];v.push(t),t="",e.opts.passContext?t+=" "+p+".call(this, ":t+=" "+p+"( ",t+=" "+d+", (dataPath || '')",e.errorPath!='""'&&(t+=" + "+e.errorPath);var T=i?"data"+(i-1||""):"parentData",S=i?e.dataPathArr[i]:"parentDataProperty";t+=" , "+T+" , "+S+", rootData) ";var I=t;if(t=v.pop(),h){if(!e.async)throw new Error("async schema referenced by sync schema");u&&(t+=" var "+f+"; "),t+=" try { await "+I+"; ",u&&(t+=" "+f+" = true; "),t+=" } catch (e) { if (!(e instanceof ValidationError)) throw e; if (vErrors === null) vErrors = e.errors; else vErrors = vErrors.concat(e.errors); errors = vErrors.length; ",u&&(t+=" "+f+" = false; "),t+=" } ",u&&(t+=" if ("+f+") { ")}else t+=" if (!"+I+") { if (vErrors === null) vErrors = "+p+".errors; else vErrors = vErrors.concat("+p+".errors); errors = vErrors.length; } ",u&&(t+=" else { ")}return t}});var Mo=z((Dm,Fo)=>{"use strict";Fo.exports=function(e,r,a){var t=" ",n=e.schema[r],i=e.schemaPath+e.util.getProperty(r),o=e.errSchemaPath+"/"+r,l=!e.opts.allErrors,u=e.util.copy(e),d="";u.level++;var f="valid"+u.level,h=u.baseId,p=!0,g=n;if(g)for(var y,v=-1,x=g.length-1;v0||y===!1:e.util.schemaHasRules(y,e.RULES.all))&&(p=!1,u.schema=y,u.schemaPath=i+"["+v+"]",u.errSchemaPath=o+"/"+v,t+=" "+e.validate(u)+" ",u.baseId=h,l&&(t+=" if ("+f+") { ",d+="}"));return l&&(p?t+=" if (true) { ":t+=" "+d.slice(0,-1)+" "),t}});var Uo=z((Cm,qo)=>{"use strict";qo.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h="valid"+n,p="errs__"+n,g=e.util.copy(e),y="";g.level++;var v="valid"+g.level,x=o.every(function(D){return e.opts.strictKeywords?typeof D=="object"&&Object.keys(D).length>0||D===!1:e.util.schemaHasRules(D,e.RULES.all)});if(x){var P=g.baseId;t+=" var "+p+" = errors; var "+h+" = false; ";var E=e.compositeRule;e.compositeRule=g.compositeRule=!0;var R=o;if(R)for(var T,S=-1,I=R.length-1;S{"use strict";Bo.exports=function(e,r,a){var t=" ",n=e.schema[r],i=e.errSchemaPath+"/"+r,o=!e.opts.allErrors,l=e.util.toQuotedString(n);return e.opts.$comment===!0?t+=" console.log("+l+");":typeof e.opts.$comment=="function"&&(t+=" self._opts.$comment("+l+", "+e.util.toQuotedString(i)+", validate.root.schema);"),t}});var zo=z((Lm,Ho)=>{"use strict";Ho.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h="valid"+n,p=e.opts.$data&&o&&o.$data,g;p?(t+=" var schema"+n+" = "+e.util.getData(o.$data,i,e.dataPathArr)+"; ",g="schema"+n):g=o,p||(t+=" var schema"+n+" = validate.schema"+l+";"),t+="var "+h+" = equal("+f+", schema"+n+"); if (!"+h+") { ";var y=y||[];y.push(t),t="",e.createErrors!==!1?(t+=" { keyword: 'const' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { allowedValue: schema"+n+" } ",e.opts.messages!==!1&&(t+=" , message: 'should be equal to constant' "),e.opts.verbose&&(t+=" , schema: validate.schema"+l+" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var v=t;return t=y.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+v+"]); ":t+=" validate.errors = ["+v+"]; return false; ":t+=" var err = "+v+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+=" }",d&&(t+=" else { "),t}});var Go=z((jm,Zo)=>{"use strict";Zo.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h="valid"+n,p="errs__"+n,g=e.util.copy(e),y="";g.level++;var v="valid"+g.level,x="i"+n,P=g.dataLevel=e.dataLevel+1,E="data"+P,R=e.baseId,T=e.opts.strictKeywords?typeof o=="object"&&Object.keys(o).length>0||o===!1:e.util.schemaHasRules(o,e.RULES.all);if(t+="var "+p+" = errors;var "+h+";",T){var S=e.compositeRule;e.compositeRule=g.compositeRule=!0,g.schema=o,g.schemaPath=l,g.errSchemaPath=u,t+=" var "+v+" = false; for (var "+x+" = 0; "+x+" < "+f+".length; "+x+"++) { ",g.errorPath=e.util.getPathExpr(e.errorPath,x,e.opts.jsonPointers,!0);var I=f+"["+x+"]";g.dataPathArr[P]=x;var D=e.validate(g);g.baseId=R,e.util.varOccurences(D,E)<2?t+=" "+e.util.varReplace(D,E,I)+" ":t+=" var "+E+" = "+I+"; "+D+" ",t+=" if ("+v+") break; } ",e.compositeRule=g.compositeRule=S,t+=" "+y+" if (!"+v+") {"}else t+=" if ("+f+".length == 0) {";var $=$||[];$.push(t),t="",e.createErrors!==!1?(t+=" { keyword: 'contains' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: {} ",e.opts.messages!==!1&&(t+=" , message: 'should contain a valid item' "),e.opts.verbose&&(t+=" , schema: validate.schema"+l+" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var L=t;return t=$.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+L+"]); ":t+=" validate.errors = ["+L+"]; return false; ":t+=" var err = "+L+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+=" } else { ",T&&(t+=" errors = "+p+"; if (vErrors !== null) { if ("+p+") vErrors.length = "+p+"; else vErrors = null; } "),e.opts.allErrors&&(t+=" } "),t}});var Wo=z((Fm,Xo)=>{"use strict";Xo.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h="errs__"+n,p=e.util.copy(e),g="";p.level++;var y="valid"+p.level,v={},x={},P=e.opts.ownProperties;for(S in o)if(S!="__proto__"){var E=o[S],R=Array.isArray(E)?x:v;R[S]=E}t+="var "+h+" = errors;";var T=e.errorPath;t+="var missing"+n+";";for(var S in x)if(R=x[S],R.length){if(t+=" if ( "+f+e.util.getProperty(S)+" !== undefined ",P&&(t+=" && Object.prototype.hasOwnProperty.call("+f+", '"+e.util.escapeQuotes(S)+"') "),d){t+=" && ( ";var I=R;if(I)for(var D,$=-1,L=I.length-1;$0||E===!1:e.util.schemaHasRules(E,e.RULES.all))&&(t+=" "+y+" = true; if ( "+f+e.util.getProperty(S)+" !== undefined ",P&&(t+=" && Object.prototype.hasOwnProperty.call("+f+", '"+e.util.escapeQuotes(S)+"') "),t+=") { ",p.schema=E,p.schemaPath=l+e.util.getProperty(S),p.errSchemaPath=u+"/"+e.util.escapeFragment(S),t+=" "+e.validate(p)+" ",p.baseId=Z,t+=" } ",d&&(t+=" if ("+y+") { ",g+="}"))}return d&&(t+=" "+g+" if ("+h+" == errors) {"),t}});var Ko=z((Mm,Qo)=>{"use strict";Qo.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h="valid"+n,p=e.opts.$data&&o&&o.$data,g;p?(t+=" var schema"+n+" = "+e.util.getData(o.$data,i,e.dataPathArr)+"; ",g="schema"+n):g=o;var y="i"+n,v="schema"+n;p||(t+=" var "+v+" = validate.schema"+l+";"),t+="var "+h+";",p&&(t+=" if (schema"+n+" === undefined) "+h+" = true; else if (!Array.isArray(schema"+n+")) "+h+" = false; else {"),t+=""+h+" = false;for (var "+y+"=0; "+y+"<"+v+".length; "+y+"++) if (equal("+f+", "+v+"["+y+"])) { "+h+" = true; break; }",p&&(t+=" } "),t+=" if (!"+h+") { ";var x=x||[];x.push(t),t="",e.createErrors!==!1?(t+=" { keyword: 'enum' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { allowedValues: schema"+n+" } ",e.opts.messages!==!1&&(t+=" , message: 'should be equal to one of the allowed values' "),e.opts.verbose&&(t+=" , schema: validate.schema"+l+" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var P=t;return t=x.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+P+"]); ":t+=" validate.errors = ["+P+"]; return false; ":t+=" var err = "+P+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+=" }",d&&(t+=" else { "),t}});var Yo=z((qm,Jo)=>{"use strict";Jo.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||"");if(e.opts.format===!1)return d&&(t+=" if (true) { "),t;var h=e.opts.$data&&o&&o.$data,p;h?(t+=" var schema"+n+" = "+e.util.getData(o.$data,i,e.dataPathArr)+"; ",p="schema"+n):p=o;var g=e.opts.unknownFormats,y=Array.isArray(g);if(h){var v="format"+n,x="isObject"+n,P="formatType"+n;t+=" var "+v+" = formats["+p+"]; var "+x+" = typeof "+v+" == 'object' && !("+v+" instanceof RegExp) && "+v+".validate; var "+P+" = "+x+" && "+v+".type || 'string'; if ("+x+") { ",e.async&&(t+=" var async"+n+" = "+v+".async; "),t+=" "+v+" = "+v+".validate; } if ( ",h&&(t+=" ("+p+" !== undefined && typeof "+p+" != 'string') || "),t+=" (",g!="ignore"&&(t+=" ("+p+" && !"+v+" ",y&&(t+=" && self._opts.unknownFormats.indexOf("+p+") == -1 "),t+=") || "),t+=" ("+v+" && "+P+" == '"+a+"' && !(typeof "+v+" == 'function' ? ",e.async?t+=" (async"+n+" ? await "+v+"("+f+") : "+v+"("+f+")) ":t+=" "+v+"("+f+") ",t+=" : "+v+".test("+f+"))))) {"}else{var v=e.formats[o];if(!v){if(g=="ignore")return e.logger.warn('unknown format "'+o+'" ignored in schema at path "'+e.errSchemaPath+'"'),d&&(t+=" if (true) { "),t;if(y&&g.indexOf(o)>=0)return d&&(t+=" if (true) { "),t;throw new Error('unknown format "'+o+'" is used in schema at path "'+e.errSchemaPath+'"')}var x=typeof v=="object"&&!(v instanceof RegExp)&&v.validate,P=x&&v.type||"string";if(x){var E=v.async===!0;v=v.validate}if(P!=a)return d&&(t+=" if (true) { "),t;if(E){if(!e.async)throw new Error("async format in sync schema");var R="formats"+e.util.getProperty(o)+".validate";t+=" if (!(await "+R+"("+f+"))) { "}else{t+=" if (! ";var R="formats"+e.util.getProperty(o);x&&(R+=".validate"),typeof v=="function"?t+=" "+R+"("+f+") ":t+=" "+R+".test("+f+") ",t+=") { "}}var T=T||[];T.push(t),t="",e.createErrors!==!1?(t+=" { keyword: 'format' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { format: ",h?t+=""+p:t+=""+e.util.toQuotedString(o),t+=" } ",e.opts.messages!==!1&&(t+=` , message: 'should match format "`,h?t+="' + "+p+" + '":t+=""+e.util.escapeQuotes(o),t+=`"' `),e.opts.verbose&&(t+=" , schema: ",h?t+="validate.schema"+l:t+=""+e.util.toQuotedString(o),t+=" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var S=t;return t=T.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+S+"]); ":t+=" validate.errors = ["+S+"]; return false; ":t+=" var err = "+S+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+=" } ",d&&(t+=" else { "),t}});var ti=z((Um,ei)=>{"use strict";ei.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h="valid"+n,p="errs__"+n,g=e.util.copy(e);g.level++;var y="valid"+g.level,v=e.schema.then,x=e.schema.else,P=v!==void 0&&(e.opts.strictKeywords?typeof v=="object"&&Object.keys(v).length>0||v===!1:e.util.schemaHasRules(v,e.RULES.all)),E=x!==void 0&&(e.opts.strictKeywords?typeof x=="object"&&Object.keys(x).length>0||x===!1:e.util.schemaHasRules(x,e.RULES.all)),R=g.baseId;if(P||E){var T;g.createErrors=!1,g.schema=o,g.schemaPath=l,g.errSchemaPath=u,t+=" var "+p+" = errors; var "+h+" = true; ";var S=e.compositeRule;e.compositeRule=g.compositeRule=!0,t+=" "+e.validate(g)+" ",g.baseId=R,g.createErrors=!0,t+=" errors = "+p+"; if (vErrors !== null) { if ("+p+") vErrors.length = "+p+"; else vErrors = null; } ",e.compositeRule=g.compositeRule=S,P?(t+=" if ("+y+") { ",g.schema=e.schema.then,g.schemaPath=e.schemaPath+".then",g.errSchemaPath=e.errSchemaPath+"/then",t+=" "+e.validate(g)+" ",g.baseId=R,t+=" "+h+" = "+y+"; ",P&&E?(T="ifClause"+n,t+=" var "+T+" = 'then'; "):T="'then'",t+=" } ",E&&(t+=" else { ")):t+=" if (!"+y+") { ",E&&(g.schema=e.schema.else,g.schemaPath=e.schemaPath+".else",g.errSchemaPath=e.errSchemaPath+"/else",t+=" "+e.validate(g)+" ",g.baseId=R,t+=" "+h+" = "+y+"; ",P&&E?(T="ifClause"+n,t+=" var "+T+" = 'else'; "):T="'else'",t+=" } "),t+=" if (!"+h+") { var err = ",e.createErrors!==!1?(t+=" { keyword: 'if' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { failingKeyword: "+T+" } ",e.opts.messages!==!1&&(t+=` , message: 'should match "' + `+T+` + '" schema' `),e.opts.verbose&&(t+=" , schema: validate.schema"+l+" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ",t+="; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",!e.compositeRule&&d&&(e.async?t+=" throw new ValidationError(vErrors); ":t+=" validate.errors = vErrors; return false; "),t+=" } ",d&&(t+=" else { ")}else d&&(t+=" if (true) { ");return t}});var si=z((Bm,ri)=>{"use strict";ri.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h="valid"+n,p="errs__"+n,g=e.util.copy(e),y="";g.level++;var v="valid"+g.level,x="i"+n,P=g.dataLevel=e.dataLevel+1,E="data"+P,R=e.baseId;if(t+="var "+p+" = errors;var "+h+";",Array.isArray(o)){var T=e.schema.additionalItems;if(T===!1){t+=" "+h+" = "+f+".length <= "+o.length+"; ";var S=u;u=e.errSchemaPath+"/additionalItems",t+=" if (!"+h+") { ";var I=I||[];I.push(t),t="",e.createErrors!==!1?(t+=" { keyword: 'additionalItems' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { limit: "+o.length+" } ",e.opts.messages!==!1&&(t+=" , message: 'should NOT have more than "+o.length+" items' "),e.opts.verbose&&(t+=" , schema: false , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var D=t;t=I.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+D+"]); ":t+=" validate.errors = ["+D+"]; return false; ":t+=" var err = "+D+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+=" } ",u=S,d&&(y+="}",t+=" else { ")}var $=o;if($){for(var L,C=-1,k=$.length-1;C0||L===!1:e.util.schemaHasRules(L,e.RULES.all)){t+=" "+v+" = true; if ("+f+".length > "+C+") { ";var N=f+"["+C+"]";g.schema=L,g.schemaPath=l+"["+C+"]",g.errSchemaPath=u+"/"+C,g.errorPath=e.util.getPathExpr(e.errorPath,C,e.opts.jsonPointers,!0),g.dataPathArr[P]=C;var A=e.validate(g);g.baseId=R,e.util.varOccurences(A,E)<2?t+=" "+e.util.varReplace(A,E,N)+" ":t+=" var "+E+" = "+N+"; "+A+" ",t+=" } ",d&&(t+=" if ("+v+") { ",y+="}")}}if(typeof T=="object"&&(e.opts.strictKeywords?typeof T=="object"&&Object.keys(T).length>0||T===!1:e.util.schemaHasRules(T,e.RULES.all))){g.schema=T,g.schemaPath=e.schemaPath+".additionalItems",g.errSchemaPath=e.errSchemaPath+"/additionalItems",t+=" "+v+" = true; if ("+f+".length > "+o.length+") { for (var "+x+" = "+o.length+"; "+x+" < "+f+".length; "+x+"++) { ",g.errorPath=e.util.getPathExpr(e.errorPath,x,e.opts.jsonPointers,!0);var N=f+"["+x+"]";g.dataPathArr[P]=x;var A=e.validate(g);g.baseId=R,e.util.varOccurences(A,E)<2?t+=" "+e.util.varReplace(A,E,N)+" ":t+=" var "+E+" = "+N+"; "+A+" ",d&&(t+=" if (!"+v+") break; "),t+=" } } ",d&&(t+=" if ("+v+") { ",y+="}")}}else if(e.opts.strictKeywords?typeof o=="object"&&Object.keys(o).length>0||o===!1:e.util.schemaHasRules(o,e.RULES.all)){g.schema=o,g.schemaPath=l,g.errSchemaPath=u,t+=" for (var "+x+" = 0; "+x+" < "+f+".length; "+x+"++) { ",g.errorPath=e.util.getPathExpr(e.errorPath,x,e.opts.jsonPointers,!0);var N=f+"["+x+"]";g.dataPathArr[P]=x;var A=e.validate(g);g.baseId=R,e.util.varOccurences(A,E)<2?t+=" "+e.util.varReplace(A,E,N)+" ":t+=" var "+E+" = "+N+"; "+A+" ",d&&(t+=" if (!"+v+") break; "),t+=" }"}return d&&(t+=" "+y+" if ("+p+" == errors) {"),t}});var $a=z((Vm,ai)=>{"use strict";ai.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,R,f="data"+(i||""),h=e.opts.$data&&o&&o.$data,p;h?(t+=" var schema"+n+" = "+e.util.getData(o.$data,i,e.dataPathArr)+"; ",p="schema"+n):p=o;var g=r=="maximum",y=g?"exclusiveMaximum":"exclusiveMinimum",v=e.schema[y],x=e.opts.$data&&v&&v.$data,P=g?"<":">",E=g?">":"<",R=void 0;if(!(h||typeof o=="number"||o===void 0))throw new Error(r+" must be number");if(!(x||v===void 0||typeof v=="number"||typeof v=="boolean"))throw new Error(y+" must be number or boolean");if(x){var T=e.util.getData(v.$data,i,e.dataPathArr),S="exclusive"+n,I="exclType"+n,D="exclIsNumber"+n,$="op"+n,L="' + "+$+" + '";t+=" var schemaExcl"+n+" = "+T+"; ",T="schemaExcl"+n,t+=" var "+S+"; var "+I+" = typeof "+T+"; if ("+I+" != 'boolean' && "+I+" != 'undefined' && "+I+" != 'number') { ";var R=y,C=C||[];C.push(t),t="",e.createErrors!==!1?(t+=" { keyword: '"+(R||"_exclusiveLimit")+"' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: {} ",e.opts.messages!==!1&&(t+=" , message: '"+y+" should be boolean' "),e.opts.verbose&&(t+=" , schema: validate.schema"+l+" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var k=t;t=C.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+k+"]); ":t+=" validate.errors = ["+k+"]; return false; ":t+=" var err = "+k+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+=" } else if ( ",h&&(t+=" ("+p+" !== undefined && typeof "+p+" != 'number') || "),t+=" "+I+" == 'number' ? ( ("+S+" = "+p+" === undefined || "+T+" "+P+"= "+p+") ? "+f+" "+E+"= "+T+" : "+f+" "+E+" "+p+" ) : ( ("+S+" = "+T+" === true) ? "+f+" "+E+"= "+p+" : "+f+" "+E+" "+p+" ) || "+f+" !== "+f+") { var op"+n+" = "+S+" ? '"+P+"' : '"+P+"='; ",o===void 0&&(R=y,u=e.errSchemaPath+"/"+y,p=T,h=x)}else{var D=typeof v=="number",L=P;if(D&&h){var $="'"+L+"'";t+=" if ( ",h&&(t+=" ("+p+" !== undefined && typeof "+p+" != 'number') || "),t+=" ( "+p+" === undefined || "+v+" "+P+"= "+p+" ? "+f+" "+E+"= "+v+" : "+f+" "+E+" "+p+" ) || "+f+" !== "+f+") { "}else{D&&o===void 0?(S=!0,R=y,u=e.errSchemaPath+"/"+y,p=v,E+="="):(D&&(p=Math[g?"min":"max"](v,o)),v===(D?p:!0)?(S=!0,R=y,u=e.errSchemaPath+"/"+y,E+="="):(S=!1,L+="="));var $="'"+L+"'";t+=" if ( ",h&&(t+=" ("+p+" !== undefined && typeof "+p+" != 'number') || "),t+=" "+f+" "+E+" "+p+" || "+f+" !== "+f+") { "}}R=R||r;var C=C||[];C.push(t),t="",e.createErrors!==!1?(t+=" { keyword: '"+(R||"_limit")+"' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { comparison: "+$+", limit: "+p+", exclusive: "+S+" } ",e.opts.messages!==!1&&(t+=" , message: 'should be "+L+" ",h?t+="' + "+p:t+=""+p+"'"),e.opts.verbose&&(t+=" , schema: ",h?t+="validate.schema"+l:t+=""+o,t+=" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var k=t;return t=C.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+k+"]); ":t+=" validate.errors = ["+k+"]; return false; ":t+=" var err = "+k+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+=" } ",d&&(t+=" else { "),t}});var Da=z((Hm,ni)=>{"use strict";ni.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,y,f="data"+(i||""),h=e.opts.$data&&o&&o.$data,p;if(h?(t+=" var schema"+n+" = "+e.util.getData(o.$data,i,e.dataPathArr)+"; ",p="schema"+n):p=o,!(h||typeof o=="number"))throw new Error(r+" must be number");var g=r=="maxItems"?">":"<";t+="if ( ",h&&(t+=" ("+p+" !== undefined && typeof "+p+" != 'number') || "),t+=" "+f+".length "+g+" "+p+") { ";var y=r,v=v||[];v.push(t),t="",e.createErrors!==!1?(t+=" { keyword: '"+(y||"_limitItems")+"' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { limit: "+p+" } ",e.opts.messages!==!1&&(t+=" , message: 'should NOT have ",r=="maxItems"?t+="more":t+="fewer",t+=" than ",h?t+="' + "+p+" + '":t+=""+o,t+=" items' "),e.opts.verbose&&(t+=" , schema: ",h?t+="validate.schema"+l:t+=""+o,t+=" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var x=t;return t=v.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+x+"]); ":t+=" validate.errors = ["+x+"]; return false; ":t+=" var err = "+x+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+="} ",d&&(t+=" else { "),t}});var Ca=z((zm,oi)=>{"use strict";oi.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,y,f="data"+(i||""),h=e.opts.$data&&o&&o.$data,p;if(h?(t+=" var schema"+n+" = "+e.util.getData(o.$data,i,e.dataPathArr)+"; ",p="schema"+n):p=o,!(h||typeof o=="number"))throw new Error(r+" must be number");var g=r=="maxLength"?">":"<";t+="if ( ",h&&(t+=" ("+p+" !== undefined && typeof "+p+" != 'number') || "),e.opts.unicode===!1?t+=" "+f+".length ":t+=" ucs2length("+f+") ",t+=" "+g+" "+p+") { ";var y=r,v=v||[];v.push(t),t="",e.createErrors!==!1?(t+=" { keyword: '"+(y||"_limitLength")+"' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { limit: "+p+" } ",e.opts.messages!==!1&&(t+=" , message: 'should NOT be ",r=="maxLength"?t+="longer":t+="shorter",t+=" than ",h?t+="' + "+p+" + '":t+=""+o,t+=" characters' "),e.opts.verbose&&(t+=" , schema: ",h?t+="validate.schema"+l:t+=""+o,t+=" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var x=t;return t=v.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+x+"]); ":t+=" validate.errors = ["+x+"]; return false; ":t+=" var err = "+x+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+="} ",d&&(t+=" else { "),t}});var ka=z((Zm,ii)=>{"use strict";ii.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,y,f="data"+(i||""),h=e.opts.$data&&o&&o.$data,p;if(h?(t+=" var schema"+n+" = "+e.util.getData(o.$data,i,e.dataPathArr)+"; ",p="schema"+n):p=o,!(h||typeof o=="number"))throw new Error(r+" must be number");var g=r=="maxProperties"?">":"<";t+="if ( ",h&&(t+=" ("+p+" !== undefined && typeof "+p+" != 'number') || "),t+=" Object.keys("+f+").length "+g+" "+p+") { ";var y=r,v=v||[];v.push(t),t="",e.createErrors!==!1?(t+=" { keyword: '"+(y||"_limitProperties")+"' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { limit: "+p+" } ",e.opts.messages!==!1&&(t+=" , message: 'should NOT have ",r=="maxProperties"?t+="more":t+="fewer",t+=" than ",h?t+="' + "+p+" + '":t+=""+o,t+=" properties' "),e.opts.verbose&&(t+=" , schema: ",h?t+="validate.schema"+l:t+=""+o,t+=" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var x=t;return t=v.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+x+"]); ":t+=" validate.errors = ["+x+"]; return false; ":t+=" var err = "+x+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+="} ",d&&(t+=" else { "),t}});var li=z((Gm,ci)=>{"use strict";ci.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h=e.opts.$data&&o&&o.$data,p;if(h?(t+=" var schema"+n+" = "+e.util.getData(o.$data,i,e.dataPathArr)+"; ",p="schema"+n):p=o,!(h||typeof o=="number"))throw new Error(r+" must be number");t+="var division"+n+";if (",h&&(t+=" "+p+" !== undefined && ( typeof "+p+" != 'number' || "),t+=" (division"+n+" = "+f+" / "+p+", ",e.opts.multipleOfPrecision?t+=" Math.abs(Math.round(division"+n+") - division"+n+") > 1e-"+e.opts.multipleOfPrecision+" ":t+=" division"+n+" !== parseInt(division"+n+") ",t+=" ) ",h&&(t+=" ) "),t+=" ) { ";var g=g||[];g.push(t),t="",e.createErrors!==!1?(t+=" { keyword: 'multipleOf' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { multipleOf: "+p+" } ",e.opts.messages!==!1&&(t+=" , message: 'should be multiple of ",h?t+="' + "+p:t+=""+p+"'"),e.opts.verbose&&(t+=" , schema: ",h?t+="validate.schema"+l:t+=""+o,t+=" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var y=t;return t=g.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+y+"]); ":t+=" validate.errors = ["+y+"]; return false; ":t+=" var err = "+y+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+="} ",d&&(t+=" else { "),t}});var di=z((Xm,ui)=>{"use strict";ui.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h="errs__"+n,p=e.util.copy(e);p.level++;var g="valid"+p.level;if(e.opts.strictKeywords?typeof o=="object"&&Object.keys(o).length>0||o===!1:e.util.schemaHasRules(o,e.RULES.all)){p.schema=o,p.schemaPath=l,p.errSchemaPath=u,t+=" var "+h+" = errors; ";var y=e.compositeRule;e.compositeRule=p.compositeRule=!0,p.createErrors=!1;var v;p.opts.allErrors&&(v=p.opts.allErrors,p.opts.allErrors=!1),t+=" "+e.validate(p)+" ",p.createErrors=!0,v&&(p.opts.allErrors=v),e.compositeRule=p.compositeRule=y,t+=" if ("+g+") { ";var x=x||[];x.push(t),t="",e.createErrors!==!1?(t+=" { keyword: 'not' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: {} ",e.opts.messages!==!1&&(t+=" , message: 'should NOT be valid' "),e.opts.verbose&&(t+=" , schema: validate.schema"+l+" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var P=t;t=x.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+P+"]); ":t+=" validate.errors = ["+P+"]; return false; ":t+=" var err = "+P+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+=" } else { errors = "+h+"; if (vErrors !== null) { if ("+h+") vErrors.length = "+h+"; else vErrors = null; } ",e.opts.allErrors&&(t+=" } ")}else t+=" var err = ",e.createErrors!==!1?(t+=" { keyword: 'not' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: {} ",e.opts.messages!==!1&&(t+=" , message: 'should NOT be valid' "),e.opts.verbose&&(t+=" , schema: validate.schema"+l+" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ",t+="; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",d&&(t+=" if (false) { ");return t}});var fi=z((Wm,pi)=>{"use strict";pi.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h="valid"+n,p="errs__"+n,g=e.util.copy(e),y="";g.level++;var v="valid"+g.level,x=g.baseId,P="prevValid"+n,E="passingSchemas"+n;t+="var "+p+" = errors , "+P+" = false , "+h+" = false , "+E+" = null; ";var R=e.compositeRule;e.compositeRule=g.compositeRule=!0;var T=o;if(T)for(var S,I=-1,D=T.length-1;I0||S===!1:e.util.schemaHasRules(S,e.RULES.all))?(g.schema=S,g.schemaPath=l+"["+I+"]",g.errSchemaPath=u+"/"+I,t+=" "+e.validate(g)+" ",g.baseId=x):t+=" var "+v+" = true; ",I&&(t+=" if ("+v+" && "+P+") { "+h+" = false; "+E+" = ["+E+", "+I+"]; } else { ",y+="}"),t+=" if ("+v+") { "+h+" = "+P+" = true; "+E+" = "+I+"; }";return e.compositeRule=g.compositeRule=R,t+=""+y+"if (!"+h+") { var err = ",e.createErrors!==!1?(t+=" { keyword: 'oneOf' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { passingSchemas: "+E+" } ",e.opts.messages!==!1&&(t+=" , message: 'should match exactly one schema in oneOf' "),e.opts.verbose&&(t+=" , schema: validate.schema"+l+" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ",t+="; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",!e.compositeRule&&d&&(e.async?t+=" throw new ValidationError(vErrors); ":t+=" validate.errors = vErrors; return false; "),t+="} else { errors = "+p+"; if (vErrors !== null) { if ("+p+") vErrors.length = "+p+"; else vErrors = null; }",e.opts.allErrors&&(t+=" } "),t}});var mi=z((Qm,hi)=>{"use strict";hi.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h=e.opts.$data&&o&&o.$data,p;h?(t+=" var schema"+n+" = "+e.util.getData(o.$data,i,e.dataPathArr)+"; ",p="schema"+n):p=o;var g=h?"(new RegExp("+p+"))":e.usePattern(o);t+="if ( ",h&&(t+=" ("+p+" !== undefined && typeof "+p+" != 'string') || "),t+=" !"+g+".test("+f+") ) { ";var y=y||[];y.push(t),t="",e.createErrors!==!1?(t+=" { keyword: 'pattern' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { pattern: ",h?t+=""+p:t+=""+e.util.toQuotedString(o),t+=" } ",e.opts.messages!==!1&&(t+=` , message: 'should match pattern "`,h?t+="' + "+p+" + '":t+=""+e.util.escapeQuotes(o),t+=`"' `),e.opts.verbose&&(t+=" , schema: ",h?t+="validate.schema"+l:t+=""+e.util.toQuotedString(o),t+=" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var v=t;return t=y.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+v+"]); ":t+=" validate.errors = ["+v+"]; return false; ":t+=" var err = "+v+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+="} ",d&&(t+=" else { "),t}});var gi=z((Km,vi)=>{"use strict";vi.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h="errs__"+n,p=e.util.copy(e),g="";p.level++;var y="valid"+p.level,v="key"+n,x="idx"+n,P=p.dataLevel=e.dataLevel+1,E="data"+P,R="dataProperties"+n,T=Object.keys(o||{}).filter(te),S=e.schema.patternProperties||{},I=Object.keys(S).filter(te),D=e.schema.additionalProperties,$=T.length||I.length,L=D===!1,C=typeof D=="object"&&Object.keys(D).length,k=e.opts.removeAdditional,N=L||C||k,A=e.opts.ownProperties,M=e.baseId,W=e.schema.required;if(W&&!(e.opts.$data&&W.$data)&&W.length8)t+=" || validate.schema"+l+".hasOwnProperty("+v+") ";else{var K=T;if(K)for(var Z,fe=-1,Te=K.length-1;fe0||Pe===!1:e.util.schemaHasRules(Pe,e.RULES.all)){var Ge=e.util.getProperty(Z),Ne=f+Ge,Me=Tt&&Pe.default!==void 0;p.schema=Pe,p.schemaPath=l+Ge,p.errSchemaPath=u+"/"+e.util.escapeFragment(Z),p.errorPath=e.util.getPath(e.errorPath,Z,e.opts.jsonPointers),p.dataPathArr[P]=e.util.toQuotedString(Z);var le=e.validate(p);if(p.baseId=M,e.util.varOccurences(le,E)<2){le=e.util.varReplace(le,E,Ne);var Le=Ne}else{var Le=E;t+=" var "+E+" = "+Ne+"; "}if(Me)t+=" "+le+" ";else{if(Q&&Q[Z]){t+=" if ( "+Le+" === undefined ",A&&(t+=" || ! Object.prototype.hasOwnProperty.call("+f+", '"+e.util.escapeQuotes(Z)+"') "),t+=") { "+y+" = false; ";var ke=e.errorPath,ht=u,ot=e.util.escapeQuotes(Z);e.opts._errorDataPathProperty&&(e.errorPath=e.util.getPath(ke,Z,e.opts.jsonPointers)),u=e.errSchemaPath+"/required";var Se=Se||[];Se.push(t),t="",e.createErrors!==!1?(t+=" { keyword: 'required' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { missingProperty: '"+ot+"' } ",e.opts.messages!==!1&&(t+=" , message: '",e.opts._errorDataPathProperty?t+="is a required property":t+="should have required property \\'"+ot+"\\'",t+="' "),e.opts.verbose&&(t+=" , schema: validate.schema"+l+" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var ye=t;t=Se.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+ye+"]); ":t+=" validate.errors = ["+ye+"]; return false; ":t+=" var err = "+ye+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",u=ht,e.errorPath=ke,t+=" } else { "}else d?(t+=" if ( "+Le+" === undefined ",A&&(t+=" || ! Object.prototype.hasOwnProperty.call("+f+", '"+e.util.escapeQuotes(Z)+"') "),t+=") { "+y+" = true; } else { "):(t+=" if ("+Le+" !== undefined ",A&&(t+=" && Object.prototype.hasOwnProperty.call("+f+", '"+e.util.escapeQuotes(Z)+"') "),t+=" ) { ");t+=" "+le+" } "}}d&&(t+=" if ("+y+") { ",g+="}")}}if(I.length){var Ve=I;if(Ve)for(var ie,Hr=-1,Us=Ve.length-1;Hr0||Pe===!1:e.util.schemaHasRules(Pe,e.RULES.all)){p.schema=Pe,p.schemaPath=e.schemaPath+".patternProperties"+e.util.getProperty(ie),p.errSchemaPath=e.errSchemaPath+"/patternProperties/"+e.util.escapeFragment(ie),A?t+=" "+R+" = "+R+" || Object.keys("+f+"); for (var "+x+"=0; "+x+"<"+R+".length; "+x+"++) { var "+v+" = "+R+"["+x+"]; ":t+=" for (var "+v+" in "+f+") { ",t+=" if ("+e.usePattern(ie)+".test("+v+")) { ",p.errorPath=e.util.getPathExpr(e.errorPath,v,e.opts.jsonPointers);var Ne=f+"["+v+"]";p.dataPathArr[P]=v;var le=e.validate(p);p.baseId=M,e.util.varOccurences(le,E)<2?t+=" "+e.util.varReplace(le,E,Ne)+" ":t+=" var "+E+" = "+Ne+"; "+le+" ",d&&(t+=" if (!"+y+") break; "),t+=" } ",d&&(t+=" else "+y+" = true; "),t+=" } ",d&&(t+=" if ("+y+") { ",g+="}")}}}return d&&(t+=" "+g+" if ("+h+" == errors) {"),t}});var _i=z((Jm,yi)=>{"use strict";yi.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h="errs__"+n,p=e.util.copy(e),g="";p.level++;var y="valid"+p.level;if(t+="var "+h+" = errors;",e.opts.strictKeywords?typeof o=="object"&&Object.keys(o).length>0||o===!1:e.util.schemaHasRules(o,e.RULES.all)){p.schema=o,p.schemaPath=l,p.errSchemaPath=u;var v="key"+n,x="idx"+n,P="i"+n,E="' + "+v+" + '",R=p.dataLevel=e.dataLevel+1,T="data"+R,S="dataProperties"+n,I=e.opts.ownProperties,D=e.baseId;I&&(t+=" var "+S+" = undefined; "),I?t+=" "+S+" = "+S+" || Object.keys("+f+"); for (var "+x+"=0; "+x+"<"+S+".length; "+x+"++) { var "+v+" = "+S+"["+x+"]; ":t+=" for (var "+v+" in "+f+") { ",t+=" var startErrs"+n+" = errors; ";var $=v,L=e.compositeRule;e.compositeRule=p.compositeRule=!0;var C=e.validate(p);p.baseId=D,e.util.varOccurences(C,T)<2?t+=" "+e.util.varReplace(C,T,$)+" ":t+=" var "+T+" = "+$+"; "+C+" ",e.compositeRule=p.compositeRule=L,t+=" if (!"+y+") { for (var "+P+"=startErrs"+n+"; "+P+"{"use strict";bi.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h="valid"+n,p=e.opts.$data&&o&&o.$data,g;p?(t+=" var schema"+n+" = "+e.util.getData(o.$data,i,e.dataPathArr)+"; ",g="schema"+n):g=o;var y="schema"+n;if(!p)if(o.length0||T===!1:e.util.schemaHasRules(T,e.RULES.all))||(v[v.length]=P)}}else var v=o;if(p||v.length){var S=e.errorPath,I=p||v.length>=e.opts.loopRequired,D=e.opts.ownProperties;if(d)if(t+=" var missing"+n+"; ",I){p||(t+=" var "+y+" = validate.schema"+l+"; ");var $="i"+n,L="schema"+n+"["+$+"]",C="' + "+L+" + '";e.opts._errorDataPathProperty&&(e.errorPath=e.util.getPathExpr(S,L,e.opts.jsonPointers)),t+=" var "+h+" = true; ",p&&(t+=" if (schema"+n+" === undefined) "+h+" = true; else if (!Array.isArray(schema"+n+")) "+h+" = false; else {"),t+=" for (var "+$+" = 0; "+$+" < "+y+".length; "+$+"++) { "+h+" = "+f+"["+y+"["+$+"]] !== undefined ",D&&(t+=" && Object.prototype.hasOwnProperty.call("+f+", "+y+"["+$+"]) "),t+="; if (!"+h+") break; } ",p&&(t+=" } "),t+=" if (!"+h+") { ";var k=k||[];k.push(t),t="",e.createErrors!==!1?(t+=" { keyword: 'required' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { missingProperty: '"+C+"' } ",e.opts.messages!==!1&&(t+=" , message: '",e.opts._errorDataPathProperty?t+="is a required property":t+="should have required property \\'"+C+"\\'",t+="' "),e.opts.verbose&&(t+=" , schema: validate.schema"+l+" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var N=t;t=k.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+N+"]); ":t+=" validate.errors = ["+N+"]; return false; ":t+=" var err = "+N+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+=" } else { "}else{t+=" if ( ";var A=v;if(A)for(var M,$=-1,W=A.length-1;${"use strict";Si.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f="data"+(i||""),h="valid"+n,p=e.opts.$data&&o&&o.$data,g;if(p?(t+=" var schema"+n+" = "+e.util.getData(o.$data,i,e.dataPathArr)+"; ",g="schema"+n):g=o,(o||p)&&e.opts.uniqueItems!==!1){p&&(t+=" var "+h+"; if ("+g+" === false || "+g+" === undefined) "+h+" = true; else if (typeof "+g+" != 'boolean') "+h+" = false; else { "),t+=" var i = "+f+".length , "+h+" = true , j; if (i > 1) { ";var y=e.schema.items&&e.schema.items.type,v=Array.isArray(y);if(!y||y=="object"||y=="array"||v&&(y.indexOf("object")>=0||y.indexOf("array")>=0))t+=" outer: for (;i--;) { for (j = i; j--;) { if (equal("+f+"[i], "+f+"[j])) { "+h+" = false; break outer; } } } ";else{t+=" var itemIndices = {}, item; for (;i--;) { var item = "+f+"[i]; ";var x="checkDataType"+(v?"s":"");t+=" if ("+e.util[x](y,"item",e.opts.strictNumbers,!0)+") continue; ",v&&(t+=` if (typeof item == 'string') item = '"' + item; `),t+=" if (typeof itemIndices[item] == 'number') { "+h+" = false; j = itemIndices[item]; break; } itemIndices[item] = i; } "}t+=" } ",p&&(t+=" } "),t+=" if (!"+h+") { ";var P=P||[];P.push(t),t="",e.createErrors!==!1?(t+=" { keyword: 'uniqueItems' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { i: i, j: j } ",e.opts.messages!==!1&&(t+=" , message: 'should NOT have duplicate items (items ## ' + j + ' and ' + i + ' are identical)' "),e.opts.verbose&&(t+=" , schema: ",p?t+="validate.schema"+l:t+=""+o,t+=" , parentSchema: validate.schema"+e.schemaPath+" , data: "+f+" "),t+=" } "):t+=" {} ";var E=t;t=P.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+E+"]); ":t+=" validate.errors = ["+E+"]; return false; ":t+=" var err = "+E+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ",t+=" } ",d&&(t+=" else { ")}else d&&(t+=" if (true) { ");return t}});var Ti=z((tv,Ri)=>{"use strict";Ri.exports={$ref:jo(),allOf:Mo(),anyOf:Uo(),$comment:Vo(),const:zo(),contains:Go(),dependencies:Wo(),enum:Ko(),format:Yo(),if:ti(),items:si(),maximum:$a(),minimum:$a(),maxItems:Da(),minItems:Da(),maxLength:Ca(),minLength:Ca(),maxProperties:ka(),minProperties:ka(),multipleOf:li(),not:di(),oneOf:fi(),pattern:mi(),properties:gi(),propertyNames:_i(),required:Ei(),uniqueItems:xi(),validate:Na()}});var Pi=z((rv,Oi)=>{"use strict";var wi=Ti(),La=ar().toHash;Oi.exports=function(){var e=[{type:"number",rules:[{maximum:["exclusiveMaximum"]},{minimum:["exclusiveMinimum"]},"multipleOf","format"]},{type:"string",rules:["maxLength","minLength","pattern","format"]},{type:"array",rules:["maxItems","minItems","items","contains","uniqueItems"]},{type:"object",rules:["maxProperties","minProperties","required","dependencies","propertyNames",{properties:["additionalProperties","patternProperties"]}]},{rules:["$ref","const","enum","not","anyOf","oneOf","allOf","if"]}],r=["type","$comment"],a=["$schema","$id","id","$data","$async","title","description","default","definitions","examples","readOnly","writeOnly","contentMediaType","contentEncoding","additionalItems","then","else"],t=["number","integer","string","array","object","boolean","null"];return e.all=La(r),e.types=La(t),e.forEach(function(n){n.rules=n.rules.map(function(i){var o;if(typeof i=="object"){var l=Object.keys(i)[0];o=i[l],i=l,o.forEach(function(d){r.push(d),e.all[d]=!0})}r.push(i);var u=e.all[i]={keyword:i,code:wi[i],implements:o};return u}),e.all.$comment={keyword:"$comment",code:wi.$comment},n.type&&(e.types[n.type]=n)}),e.keywords=La(r.concat(a)),e.custom={},e}});var Ai=z((sv,Ni)=>{"use strict";var Ii=["multipleOf","maximum","exclusiveMaximum","minimum","exclusiveMinimum","maxLength","minLength","pattern","additionalItems","maxItems","minItems","uniqueItems","maxProperties","minProperties","required","additionalProperties","enum","format","const"];Ni.exports=function(s,e){for(var r=0;r{"use strict";var ef=ys().MissingRef;Di.exports=$i;function $i(s,e,r){var a=this;if(typeof this._opts.loadSchema!="function")throw new Error("options.loadSchema should be a function");typeof e=="function"&&(r=e,e=void 0);var t=n(s).then(function(){var o=a._addSchema(s,void 0,e);return o.validate||i(o)});return r&&t.then(function(o){r(null,o)},r),t;function n(o){var l=o.$schema;return l&&!a.getSchema(l)?$i.call(a,{$ref:l},!0):Promise.resolve()}function i(o){try{return a._compile(o)}catch(u){if(u instanceof ef)return l(u);throw u}function l(u){var d=u.missingSchema;if(p(d))throw new Error("Schema "+d+" is loaded but "+u.missingRef+" cannot be resolved");var f=a._loadingSchemas[d];return f||(f=a._loadingSchemas[d]=a._opts.loadSchema(d),f.then(h,h)),f.then(function(g){if(!p(d))return n(g).then(function(){p(d)||a.addSchema(g,d,void 0,e)})}).then(function(){return i(o)});function h(){delete a._loadingSchemas[d]}function p(g){return a._refs[g]||a._schemas[g]}}}}});var Li=z((nv,ki)=>{"use strict";ki.exports=function(e,r,a){var t=" ",n=e.level,i=e.dataLevel,o=e.schema[r],l=e.schemaPath+e.util.getProperty(r),u=e.errSchemaPath+"/"+r,d=!e.opts.allErrors,f,h="data"+(i||""),p="valid"+n,g="errs__"+n,y=e.opts.$data&&o&&o.$data,v;y?(t+=" var schema"+n+" = "+e.util.getData(o.$data,i,e.dataPathArr)+"; ",v="schema"+n):v=o;var x=this,P="definition"+n,E=x.definition,R="",T,S,I,D,$;if(y&&E.$data){$="keywordValidate"+n;var L=E.validateSchema;t+=" var "+P+" = RULES.custom['"+r+"'].definition; var "+$+" = "+P+".validate;"}else{if(D=e.useCustomRule(x,o,e.schema,e),!D)return;v="validate.schema"+l,$=D.code,T=E.compile,S=E.inline,I=E.macro}var C=$+".errors",k="i"+n,N="ruleErr"+n,A=E.async;if(A&&!e.async)throw new Error("async keyword in sync schema");if(S||I||(t+=""+C+" = null;"),t+="var "+g+" = errors;var "+p+";",y&&E.$data&&(R+="}",t+=" if ("+v+" === undefined) { "+p+" = true; } else { ",L&&(R+="}",t+=" "+p+" = "+P+".validateSchema("+v+"); if ("+p+") { ")),S)E.statements?t+=" "+D.validate+" ":t+=" "+p+" = "+D.validate+"; ";else if(I){var M=e.util.copy(e),R="";M.level++;var W="valid"+M.level;M.schema=D.validate,M.schemaPath="";var Q=e.compositeRule;e.compositeRule=M.compositeRule=!0;var te=e.validate(M).replace(/validate\.schema/g,$);e.compositeRule=M.compositeRule=Q,t+=" "+te}else{var K=K||[];K.push(t),t="",t+=" "+$+".call( ",e.opts.passContext?t+="this":t+="self",T||E.schema===!1?t+=" , "+h+" ":t+=" , "+v+" , "+h+" , validate.schema"+e.schemaPath+" ",t+=" , (dataPath || '')",e.errorPath!='""'&&(t+=" + "+e.errorPath);var Z=i?"data"+(i-1||""):"parentData",fe=i?e.dataPathArr[i]:"parentDataProperty";t+=" , "+Z+" , "+fe+" , rootData ) ";var Te=t;t=K.pop(),E.errors===!1?(t+=" "+p+" = ",A&&(t+="await "),t+=""+Te+"; "):A?(C="customErrors"+n,t+=" var "+C+" = null; try { "+p+" = await "+Te+"; } catch (e) { "+p+" = false; if (e instanceof ValidationError) "+C+" = e.errors; else throw e; } "):t+=" "+C+" = null; "+p+" = "+Te+"; "}if(E.modifying&&(t+=" if ("+Z+") "+h+" = "+Z+"["+fe+"];"),t+=""+R,E.valid)d&&(t+=" if (true) { ");else{t+=" if ( ",E.valid===void 0?(t+=" !",I?t+=""+W:t+=""+p):t+=" "+!E.valid+" ",t+=") { ",f=x.keyword;var K=K||[];K.push(t),t="";var K=K||[];K.push(t),t="",e.createErrors!==!1?(t+=" { keyword: '"+(f||"custom")+"' , dataPath: (dataPath || '') + "+e.errorPath+" , schemaPath: "+e.util.toQuotedString(u)+" , params: { keyword: '"+x.keyword+"' } ",e.opts.messages!==!1&&(t+=` , message: 'should pass "`+x.keyword+`" keyword validation' `),e.opts.verbose&&(t+=" , schema: validate.schema"+l+" , parentSchema: validate.schema"+e.schemaPath+" , data: "+h+" "),t+=" } "):t+=" {} ";var Ce=t;t=K.pop(),!e.compositeRule&&d?e.async?t+=" throw new ValidationError(["+Ce+"]); ":t+=" validate.errors = ["+Ce+"]; return false; ":t+=" var err = "+Ce+"; if (vErrors === null) vErrors = [err]; else vErrors.push(err); errors++; ";var ie=t;t=K.pop(),S?E.errors?E.errors!="full"&&(t+=" for (var "+k+"="+g+"; "+k+"{tf.exports={$schema:"http://json-schema.org/draft-07/schema#",$id:"http://json-schema.org/draft-07/schema#",title:"Core schema meta-schema",definitions:{schemaArray:{type:"array",minItems:1,items:{$ref:"#"}},nonNegativeInteger:{type:"integer",minimum:0},nonNegativeIntegerDefault0:{allOf:[{$ref:"#/definitions/nonNegativeInteger"},{default:0}]},simpleTypes:{enum:["array","boolean","integer","null","number","object","string"]},stringArray:{type:"array",items:{type:"string"},uniqueItems:!0,default:[]}},type:["object","boolean"],properties:{$id:{type:"string",format:"uri-reference"},$schema:{type:"string",format:"uri"},$ref:{type:"string",format:"uri-reference"},$comment:{type:"string"},title:{type:"string"},description:{type:"string"},default:!0,readOnly:{type:"boolean",default:!1},examples:{type:"array",items:!0},multipleOf:{type:"number",exclusiveMinimum:0},maximum:{type:"number"},exclusiveMaximum:{type:"number"},minimum:{type:"number"},exclusiveMinimum:{type:"number"},maxLength:{$ref:"#/definitions/nonNegativeInteger"},minLength:{$ref:"#/definitions/nonNegativeIntegerDefault0"},pattern:{type:"string",format:"regex"},additionalItems:{$ref:"#"},items:{anyOf:[{$ref:"#"},{$ref:"#/definitions/schemaArray"}],default:!0},maxItems:{$ref:"#/definitions/nonNegativeInteger"},minItems:{$ref:"#/definitions/nonNegativeIntegerDefault0"},uniqueItems:{type:"boolean",default:!1},contains:{$ref:"#"},maxProperties:{$ref:"#/definitions/nonNegativeInteger"},minProperties:{$ref:"#/definitions/nonNegativeIntegerDefault0"},required:{$ref:"#/definitions/stringArray"},additionalProperties:{$ref:"#"},definitions:{type:"object",additionalProperties:{$ref:"#"},default:{}},properties:{type:"object",additionalProperties:{$ref:"#"},default:{}},patternProperties:{type:"object",additionalProperties:{$ref:"#"},propertyNames:{format:"regex"},default:{}},dependencies:{type:"object",additionalProperties:{anyOf:[{$ref:"#"},{$ref:"#/definitions/stringArray"}]}},propertyNames:{$ref:"#"},const:!0,enum:{type:"array",items:!0,minItems:1,uniqueItems:!0},type:{anyOf:[{$ref:"#/definitions/simpleTypes"},{type:"array",items:{$ref:"#/definitions/simpleTypes"},minItems:1,uniqueItems:!0}]},format:{type:"string"},contentMediaType:{type:"string"},contentEncoding:{type:"string"},if:{$ref:"#"},then:{$ref:"#"},else:{$ref:"#"},allOf:{$ref:"#/definitions/schemaArray"},anyOf:{$ref:"#/definitions/schemaArray"},oneOf:{$ref:"#/definitions/schemaArray"},not:{$ref:"#"}},default:!0}});var Mi=z((iv,Fi)=>{"use strict";var ji=ja();Fi.exports={$id:"https://github.com/ajv-validator/ajv/blob/master/lib/definition_schema.js",definitions:{simpleTypes:ji.definitions.simpleTypes},type:"object",dependencies:{schema:["validate"],$data:["validate"],statements:["inline"],valid:{not:{required:["macro"]}}},properties:{type:ji.properties.type,schema:{type:"boolean"},statements:{type:"boolean"},dependencies:{type:"array",items:{type:"string"}},metaSchema:{type:"object"},modifying:{type:"boolean"},valid:{type:"boolean"},$data:{type:"boolean"},async:{type:"boolean"},errors:{anyOf:[{type:"boolean"},{const:"full"}]}}}});var Ui=z((cv,qi)=>{"use strict";var rf=/^[a-z_$][a-z0-9_$-]*$/i,sf=Li(),af=Mi();qi.exports={add:nf,get:of,remove:cf,validate:Fa};function nf(s,e){var r=this.RULES;if(r.keywords[s])throw new Error("Keyword "+s+" is already defined");if(!rf.test(s))throw new Error("Keyword "+s+" is not a valid identifier");if(e){this.validateKeyword(e,!0);var a=e.type;if(Array.isArray(a))for(var t=0;t{lf.exports={$schema:"http://json-schema.org/draft-07/schema#",$id:"https://raw.githubusercontent.com/ajv-validator/ajv/master/lib/refs/data.json#",description:"Meta-schema for $data reference (JSON Schema extension proposal)",type:"object",required:["$data"],properties:{$data:{type:"string",anyOf:[{format:"relative-json-pointer"},{format:"json-pointer"}]}},additionalProperties:!1}});var qa=z((uv,Ki)=>{"use strict";var Hi=Eo(),nr=gs(),uf=xo(),zi=xa(),df=Ia(),pf=ko(),ff=Pi(),Zi=Ai(),Gi=ar();Ki.exports=_e;_e.prototype.validate=mf;_e.prototype.compile=vf;_e.prototype.addSchema=gf;_e.prototype.addMetaSchema=yf;_e.prototype.validateSchema=_f;_e.prototype.getSchema=Ef;_e.prototype.removeSchema=xf;_e.prototype.addFormat=Af;_e.prototype.errorsText=Nf;_e.prototype._addSchema=Rf;_e.prototype._compile=Tf;_e.prototype.compileAsync=Ci();var ws=Ui();_e.prototype.addKeyword=ws.add;_e.prototype.getKeyword=ws.get;_e.prototype.removeKeyword=ws.remove;_e.prototype.validateKeyword=ws.validate;var Xi=ys();_e.ValidationError=Xi.Validation;_e.MissingRefError=Xi.MissingRef;_e.$dataMetaSchema=Zi;var Ts="http://json-schema.org/draft-07/schema",Vi=["removeAdditional","useDefaults","coerceTypes","strictDefaults"],hf=["/properties"];function _e(s){if(!(this instanceof _e))return new _e(s);s=this._opts=Gi.copy(s)||{},jf(this),this._schemas={},this._refs={},this._fragments={},this._formats=pf(s.format),this._cache=s.cache||new uf,this._loadingSchemas={},this._compilations=[],this.RULES=ff(),this._getId=wf(s),s.loopRequired=s.loopRequired||1/0,s.errorDataPath=="property"&&(s._errorDataPathProperty=!0),s.serialize===void 0&&(s.serialize=df),this._metaOpts=Lf(this),s.formats&&Cf(this),s.keywords&&kf(this),$f(this),typeof s.meta=="object"&&this.addMetaSchema(s.meta),s.nullable&&this.addKeyword("nullable",{metaSchema:{type:"boolean"}}),Df(this)}function mf(s,e){var r;if(typeof s=="string"){if(r=this.getSchema(s),!r)throw new Error('no schema with key or ref "'+s+'"')}else{var a=this._addSchema(s);r=a.validate||this._compile(a)}var t=r(e);return r.$async!==!0&&(this.errors=r.errors),t}function vf(s,e){var r=this._addSchema(s,void 0,e);return r.validate||this._compile(r)}function gf(s,e,r,a){if(Array.isArray(s)){for(var t=0;t{sc.exports=rc;rc.sync=qf;var ec=require("fs");function Mf(s,e){var r=e.pathExt!==void 0?e.pathExt:process.env.PATHEXT;if(!r||(r=r.split(";"),r.indexOf("")!==-1))return!0;for(var a=0;a{cc.exports=oc;oc.sync=Uf;var nc=require("fs");function oc(s,e,r){nc.stat(s,function(a,t){r(a,a?!1:ic(t,e))})}function Uf(s,e){return ic(nc.statSync(s),e)}function ic(s,e){return s.isFile()&&Bf(s,e)}function Bf(s,e){var r=s.mode,a=s.uid,t=s.gid,n=e.uid!==void 0?e.uid:process.getuid&&process.getuid(),i=e.gid!==void 0?e.gid:process.getgid&&process.getgid(),o=parseInt("100",8),l=parseInt("010",8),u=parseInt("001",8),d=o|l,f=r&u||r&l&&t===i||r&o&&a===n||r&d&&n===0;return f}});var dc=z((Rv,uc)=>{var xv=require("fs"),As;process.platform==="win32"||global.TESTING_WINDOWS?As=ac():As=lc();uc.exports=Ba;Ba.sync=Vf;function Ba(s,e,r){if(typeof e=="function"&&(r=e,e={}),!r){if(typeof Promise!="function")throw new TypeError("callback not provided");return new Promise(function(a,t){Ba(s,e||{},function(n,i){n?t(n):a(i)})})}As(s,e||{},function(a,t){a&&(a.code==="EACCES"||e&&e.ignoreErrors)&&(a=null,t=!1),r(a,t)})}function Vf(s,e){try{return As.sync(s,e||{})}catch(r){if(e&&e.ignoreErrors||r.code==="EACCES")return!1;throw r}}});var yc=z((Tv,gc)=>{var Rr=process.platform==="win32"||process.env.OSTYPE==="cygwin"||process.env.OSTYPE==="msys",pc=require("path"),Hf=Rr?";":":",fc=dc(),hc=s=>Object.assign(new Error(`not found: ${s}`),{code:"ENOENT"}),mc=(s,e)=>{let r=e.colon||Hf,a=s.match(/\//)||Rr&&s.match(/\\/)?[""]:[...Rr?[process.cwd()]:[],...(e.path||process.env.PATH||"").split(r)],t=Rr?e.pathExt||process.env.PATHEXT||".EXE;.CMD;.BAT;.COM":"",n=Rr?t.split(r):[""];return Rr&&s.indexOf(".")!==-1&&n[0]!==""&&n.unshift(""),{pathEnv:a,pathExt:n,pathExtExe:t}},vc=(s,e,r)=>{typeof e=="function"&&(r=e,e={}),e||(e={});let{pathEnv:a,pathExt:t,pathExtExe:n}=mc(s,e),i=[],o=u=>new Promise((d,f)=>{if(u===a.length)return e.all&&i.length?d(i):f(hc(s));let h=a[u],p=/^".*"$/.test(h)?h.slice(1,-1):h,g=pc.join(p,s),y=!p&&/^\.[\\\/]/.test(s)?s.slice(0,2)+g:g;d(l(y,u,0))}),l=(u,d,f)=>new Promise((h,p)=>{if(f===t.length)return h(o(d+1));let g=t[f];fc(u+g,{pathExt:n},(y,v)=>{if(!y&&v)if(e.all)i.push(u+g);else return h(u+g);return h(l(u,d,f+1))})});return r?o(0).then(u=>r(null,u),r):o(0)},zf=(s,e)=>{e=e||{};let{pathEnv:r,pathExt:a,pathExtExe:t}=mc(s,e),n=[];for(let i=0;i{"use strict";var _c=(s={})=>{let e=s.env||process.env;return(s.platform||process.platform)!=="win32"?"PATH":Object.keys(e).reverse().find(a=>a.toUpperCase()==="PATH")||"Path"};Va.exports=_c;Va.exports.default=_c});var Rc=z((Ov,xc)=>{"use strict";var Ec=require("path"),Zf=yc(),Gf=bc();function Sc(s,e){let r=s.options.env||process.env,a=process.cwd(),t=s.options.cwd!=null,n=t&&process.chdir!==void 0&&!process.chdir.disabled;if(n)try{process.chdir(s.options.cwd)}catch{}let i;try{i=Zf.sync(s.command,{path:r[Gf({env:r})],pathExt:e?Ec.delimiter:void 0})}catch{}finally{n&&process.chdir(a)}return i&&(i=Ec.resolve(t?s.options.cwd:"",i)),i}function Xf(s){return Sc(s)||Sc(s,!0)}xc.exports=Xf});var Tc=z((Pv,za)=>{"use strict";var Ha=/([()\][%!^"`<>&|;, *?])/g;function Wf(s){return s=s.replace(Ha,"^$1"),s}function Qf(s,e){return s=`${s}`,s=s.replace(/(?=(\\+?)?)\1"/g,'$1$1\\"'),s=s.replace(/(?=(\\+?)?)\1$/,"$1$1"),s=`"${s}"`,s=s.replace(Ha,"^$1"),e&&(s=s.replace(Ha,"^$1")),s}za.exports.command=Wf;za.exports.argument=Qf});var Oc=z((Iv,wc)=>{"use strict";wc.exports=/^#!(.*)/});var Ic=z((Nv,Pc)=>{"use strict";var Kf=Oc();Pc.exports=(s="")=>{let e=s.match(Kf);if(!e)return null;let[r,a]=e[0].replace(/#! ?/,"").split(" "),t=r.split("/").pop();return t==="env"?a:a?`${t} ${a}`:t}});var Ac=z((Av,Nc)=>{"use strict";var Za=require("fs"),Jf=Ic();function Yf(s){let r=Buffer.alloc(150),a;try{a=Za.openSync(s,"r"),Za.readSync(a,r,0,150,0),Za.closeSync(a)}catch{}return Jf(r.toString())}Nc.exports=Yf});var kc=z(($v,Cc)=>{"use strict";var eh=require("path"),$c=Rc(),Dc=Tc(),th=Ac(),rh=process.platform==="win32",sh=/\.(?:com|exe)$/i,ah=/node_modules[\\/].bin[\\/][^\\/]+\.cmd$/i;function nh(s){s.file=$c(s);let e=s.file&&th(s.file);return e?(s.args.unshift(s.file),s.command=e,$c(s)):s.file}function oh(s){if(!rh)return s;let e=nh(s),r=!sh.test(e);if(s.options.forceShell||r){let a=ah.test(e);s.command=eh.normalize(s.command),s.command=Dc.command(s.command),s.args=s.args.map(n=>Dc.argument(n,a));let t=[s.command].concat(s.args).join(" ");s.args=["/d","/s","/c",`"${t}"`],s.command=process.env.comspec||"cmd.exe",s.options.windowsVerbatimArguments=!0}return s}function ih(s,e,r){e&&!Array.isArray(e)&&(r=e,e=null),e=e?e.slice(0):[],r=Object.assign({},r);let a={command:s,args:e,options:r,file:void 0,original:{command:s,args:e}};return r.shell?a:oh(a)}Cc.exports=ih});var Fc=z((Dv,jc)=>{"use strict";var Ga=process.platform==="win32";function Xa(s,e){return Object.assign(new Error(`${e} ${s.command} ENOENT`),{code:"ENOENT",errno:"ENOENT",syscall:`${e} ${s.command}`,path:s.command,spawnargs:s.args})}function ch(s,e){if(!Ga)return;let r=s.emit;s.emit=function(a,t){if(a==="exit"){let n=Lc(t,e);if(n)return r.call(s,"error",n)}return r.apply(s,arguments)}}function Lc(s,e){return Ga&&s===1&&!e.file?Xa(e.original,"spawn"):null}function lh(s,e){return Ga&&s===1&&!e.file?Xa(e.original,"spawnSync"):null}jc.exports={hookChildProcess:ch,verifyENOENT:Lc,verifyENOENTSync:lh,notFoundError:Xa}});var Uc=z((Cv,Tr)=>{"use strict";var Mc=require("child_process"),Wa=kc(),Qa=Fc();function qc(s,e,r){let a=Wa(s,e,r),t=Mc.spawn(a.command,a.args,a.options);return Qa.hookChildProcess(t,a),t}function uh(s,e,r){let a=Wa(s,e,r),t=Mc.spawnSync(a.command,a.args,a.options);return t.error=t.error||Qa.verifyENOENTSync(t.status,a),t}Tr.exports=qc;Tr.exports.spawn=qc;Tr.exports.sync=uh;Tr.exports._parse=Wa;Tr.exports._enoent=Qa});var c={};nu(c,{BRAND:()=>$u,DIRTY:()=>Bt,EMPTY_PATH:()=>uu,INVALID:()=>G,NEVER:()=>vd,OK:()=>Ae,ParseStatus:()=>Ie,Schema:()=>ee,ZodAny:()=>Pt,ZodArray:()=>St,ZodBigInt:()=>Ht,ZodBoolean:()=>zt,ZodBranded:()=>Cr,ZodCatch:()=>rr,ZodDate:()=>Zt,ZodDefault:()=>tr,ZodDiscriminatedUnion:()=>Qr,ZodEffects:()=>Je,ZodEnum:()=>Yt,ZodError:()=>qe,ZodFirstPartyTypeKind:()=>F,ZodFunction:()=>Jr,ZodIntersection:()=>Qt,ZodIssueCode:()=>j,ZodLazy:()=>Kt,ZodLiteral:()=>Jt,ZodMap:()=>_r,ZodNaN:()=>Er,ZodNativeEnum:()=>er,ZodNever:()=>rt,ZodNull:()=>Xt,ZodNullable:()=>dt,ZodNumber:()=>Vt,ZodObject:()=>Ue,ZodOptional:()=>Qe,ZodParsedType:()=>B,ZodPipeline:()=>kr,ZodPromise:()=>It,ZodReadonly:()=>sr,ZodRecord:()=>Kr,ZodSchema:()=>ee,ZodSet:()=>br,ZodString:()=>Ot,ZodSymbol:()=>gr,ZodTransformer:()=>Je,ZodTuple:()=>ut,ZodType:()=>ee,ZodUndefined:()=>Gt,ZodUnion:()=>Wt,ZodUnknown:()=>Et,ZodVoid:()=>yr,addIssueToContext:()=>U,any:()=>Uu,array:()=>zu,bigint:()=>Lu,boolean:()=>Cn,coerce:()=>md,custom:()=>An,date:()=>ju,datetimeRegex:()=>In,defaultErrorMap:()=>_t,discriminatedUnion:()=>Wu,effect:()=>id,enum:()=>ad,function:()=>td,getErrorMap:()=>hr,getParsedType:()=>lt,instanceof:()=>Cu,intersection:()=>Qu,isAborted:()=>Xr,isAsync:()=>mr,isDirty:()=>Wr,isValid:()=>wt,late:()=>Du,lazy:()=>rd,literal:()=>sd,makeIssue:()=>Dr,map:()=>Yu,nan:()=>ku,nativeEnum:()=>nd,never:()=>Vu,null:()=>qu,nullable:()=>ld,number:()=>Dn,object:()=>Zu,objectUtil:()=>Zs,oboolean:()=>hd,onumber:()=>fd,optional:()=>cd,ostring:()=>pd,pipeline:()=>dd,preprocess:()=>ud,promise:()=>od,quotelessJson:()=>iu,record:()=>Ju,set:()=>ed,setErrorMap:()=>lu,strictObject:()=>Gu,string:()=>$n,symbol:()=>Fu,transformer:()=>id,tuple:()=>Ku,undefined:()=>Mu,union:()=>Xu,unknown:()=>Bu,util:()=>re,void:()=>Hu});var re;(function(s){s.assertEqual=t=>{};function e(t){}s.assertIs=e;function r(t){throw new Error}s.assertNever=r,s.arrayToEnum=t=>{let n={};for(let i of t)n[i]=i;return n},s.getValidEnumValues=t=>{let n=s.objectKeys(t).filter(o=>typeof t[t[o]]!="number"),i={};for(let o of n)i[o]=t[o];return s.objectValues(i)},s.objectValues=t=>s.objectKeys(t).map(function(n){return t[n]}),s.objectKeys=typeof Object.keys=="function"?t=>Object.keys(t):t=>{let n=[];for(let i in t)Object.prototype.hasOwnProperty.call(t,i)&&n.push(i);return n},s.find=(t,n)=>{for(let i of t)if(n(i))return i},s.isInteger=typeof Number.isInteger=="function"?t=>Number.isInteger(t):t=>typeof t=="number"&&Number.isFinite(t)&&Math.floor(t)===t;function a(t,n=" | "){return t.map(i=>typeof i=="string"?`'${i}'`:i).join(n)}s.joinValues=a,s.jsonStringifyReplacer=(t,n)=>typeof n=="bigint"?n.toString():n})(re||(re={}));var Zs;(function(s){s.mergeShapes=(e,r)=>({...e,...r})})(Zs||(Zs={}));var B=re.arrayToEnum(["string","nan","number","integer","float","boolean","date","bigint","symbol","function","undefined","null","array","object","unknown","promise","void","never","map","set"]),lt=s=>{switch(typeof s){case"undefined":return B.undefined;case"string":return B.string;case"number":return Number.isNaN(s)?B.nan:B.number;case"boolean":return B.boolean;case"function":return B.function;case"bigint":return B.bigint;case"symbol":return B.symbol;case"object":return Array.isArray(s)?B.array:s===null?B.null:s.then&&typeof s.then=="function"&&s.catch&&typeof s.catch=="function"?B.promise:typeof Map<"u"&&s instanceof Map?B.map:typeof Set<"u"&&s instanceof Set?B.set:typeof Date<"u"&&s instanceof Date?B.date:B.object;default:return B.unknown}};var j=re.arrayToEnum(["invalid_type","invalid_literal","custom","invalid_union","invalid_union_discriminator","invalid_enum_value","unrecognized_keys","invalid_arguments","invalid_return_type","invalid_date","invalid_string","too_small","too_big","invalid_intersection_types","not_multiple_of","not_finite"]),iu=s=>JSON.stringify(s,null,2).replace(/"([^"]+)":/g,"$1:"),qe=class s extends Error{get errors(){return this.issues}constructor(e){super(),this.issues=[],this.addIssue=a=>{this.issues=[...this.issues,a]},this.addIssues=(a=[])=>{this.issues=[...this.issues,...a]};let r=new.target.prototype;Object.setPrototypeOf?Object.setPrototypeOf(this,r):this.__proto__=r,this.name="ZodError",this.issues=e}format(e){let r=e||function(n){return n.message},a={_errors:[]},t=n=>{for(let i of n.issues)if(i.code==="invalid_union")i.unionErrors.map(t);else if(i.code==="invalid_return_type")t(i.returnTypeError);else if(i.code==="invalid_arguments")t(i.argumentsError);else if(i.path.length===0)a._errors.push(r(i));else{let o=a,l=0;for(;lr.message){let r={},a=[];for(let t of this.issues)if(t.path.length>0){let n=t.path[0];r[n]=r[n]||[],r[n].push(e(t))}else a.push(e(t));return{formErrors:a,fieldErrors:r}}get formErrors(){return this.flatten()}};qe.create=s=>new qe(s);var cu=(s,e)=>{let r;switch(s.code){case j.invalid_type:s.received===B.undefined?r="Required":r=`Expected ${s.expected}, received ${s.received}`;break;case j.invalid_literal:r=`Invalid literal value, expected ${JSON.stringify(s.expected,re.jsonStringifyReplacer)}`;break;case j.unrecognized_keys:r=`Unrecognized key(s) in object: ${re.joinValues(s.keys,", ")}`;break;case j.invalid_union:r="Invalid input";break;case j.invalid_union_discriminator:r=`Invalid discriminator value. Expected ${re.joinValues(s.options)}`;break;case j.invalid_enum_value:r=`Invalid enum value. Expected ${re.joinValues(s.options)}, received '${s.received}'`;break;case j.invalid_arguments:r="Invalid function arguments";break;case j.invalid_return_type:r="Invalid function return type";break;case j.invalid_date:r="Invalid date";break;case j.invalid_string:typeof s.validation=="object"?"includes"in s.validation?(r=`Invalid input: must include "${s.validation.includes}"`,typeof s.validation.position=="number"&&(r=`${r} at one or more positions greater than or equal to ${s.validation.position}`)):"startsWith"in s.validation?r=`Invalid input: must start with "${s.validation.startsWith}"`:"endsWith"in s.validation?r=`Invalid input: must end with "${s.validation.endsWith}"`:re.assertNever(s.validation):s.validation!=="regex"?r=`Invalid ${s.validation}`:r="Invalid";break;case j.too_small:s.type==="array"?r=`Array must contain ${s.exact?"exactly":s.inclusive?"at least":"more than"} ${s.minimum} element(s)`:s.type==="string"?r=`String must contain ${s.exact?"exactly":s.inclusive?"at least":"over"} ${s.minimum} character(s)`:s.type==="number"?r=`Number must be ${s.exact?"exactly equal to ":s.inclusive?"greater than or equal to ":"greater than "}${s.minimum}`:s.type==="bigint"?r=`Number must be ${s.exact?"exactly equal to ":s.inclusive?"greater than or equal to ":"greater than "}${s.minimum}`:s.type==="date"?r=`Date must be ${s.exact?"exactly equal to ":s.inclusive?"greater than or equal to ":"greater than "}${new Date(Number(s.minimum))}`:r="Invalid input";break;case j.too_big:s.type==="array"?r=`Array must contain ${s.exact?"exactly":s.inclusive?"at most":"less than"} ${s.maximum} element(s)`:s.type==="string"?r=`String must contain ${s.exact?"exactly":s.inclusive?"at most":"under"} ${s.maximum} character(s)`:s.type==="number"?r=`Number must be ${s.exact?"exactly":s.inclusive?"less than or equal to":"less than"} ${s.maximum}`:s.type==="bigint"?r=`BigInt must be ${s.exact?"exactly":s.inclusive?"less than or equal to":"less than"} ${s.maximum}`:s.type==="date"?r=`Date must be ${s.exact?"exactly":s.inclusive?"smaller than or equal to":"smaller than"} ${new Date(Number(s.maximum))}`:r="Invalid input";break;case j.custom:r="Invalid input";break;case j.invalid_intersection_types:r="Intersection results could not be merged";break;case j.not_multiple_of:r=`Number must be a multiple of ${s.multipleOf}`;break;case j.not_finite:r="Number must be finite";break;default:r=e.defaultError,re.assertNever(s)}return{message:r}},_t=cu;var Rn=_t;function lu(s){Rn=s}function hr(){return Rn}var Dr=s=>{let{data:e,path:r,errorMaps:a,issueData:t}=s,n=[...r,...t.path||[]],i={...t,path:n};if(t.message!==void 0)return{...t,path:n,message:t.message};let o="",l=a.filter(u=>!!u).slice().reverse();for(let u of l)o=u(i,{data:e,defaultError:o}).message;return{...t,path:n,message:o}},uu=[];function U(s,e){let r=hr(),a=Dr({issueData:e,data:s.data,path:s.path,errorMaps:[s.common.contextualErrorMap,s.schemaErrorMap,r,r===_t?void 0:_t].filter(t=>!!t)});s.common.issues.push(a)}var Ie=class s{constructor(){this.value="valid"}dirty(){this.value==="valid"&&(this.value="dirty")}abort(){this.value!=="aborted"&&(this.value="aborted")}static mergeArray(e,r){let a=[];for(let t of r){if(t.status==="aborted")return G;t.status==="dirty"&&e.dirty(),a.push(t.value)}return{status:e.value,value:a}}static async mergeObjectAsync(e,r){let a=[];for(let t of r){let n=await t.key,i=await t.value;a.push({key:n,value:i})}return s.mergeObjectSync(e,a)}static mergeObjectSync(e,r){let a={};for(let t of r){let{key:n,value:i}=t;if(n.status==="aborted"||i.status==="aborted")return G;n.status==="dirty"&&e.dirty(),i.status==="dirty"&&e.dirty(),n.value!=="__proto__"&&(typeof i.value<"u"||t.alwaysSet)&&(a[n.value]=i.value)}return{status:e.value,value:a}}},G=Object.freeze({status:"aborted"}),Bt=s=>({status:"dirty",value:s}),Ae=s=>({status:"valid",value:s}),Xr=s=>s.status==="aborted",Wr=s=>s.status==="dirty",wt=s=>s.status==="valid",mr=s=>typeof Promise<"u"&&s instanceof Promise;var H;(function(s){s.errToObj=e=>typeof e=="string"?{message:e}:e||{},s.toString=e=>typeof e=="string"?e:e?.message})(H||(H={}));var Ke=class{constructor(e,r,a,t){this._cachedPath=[],this.parent=e,this.data=r,this._path=a,this._key=t}get path(){return this._cachedPath.length||(Array.isArray(this._key)?this._cachedPath.push(...this._path,...this._key):this._cachedPath.push(...this._path,this._key)),this._cachedPath}},Tn=(s,e)=>{if(wt(e))return{success:!0,data:e.value};if(!s.common.issues.length)throw new Error("Validation failed but no issues detected.");return{success:!1,get error(){if(this._error)return this._error;let r=new qe(s.common.issues);return this._error=r,this._error}}};function J(s){if(!s)return{};let{errorMap:e,invalid_type_error:r,required_error:a,description:t}=s;if(e&&(r||a))throw new Error(`Can't use "invalid_type_error" or "required_error" in conjunction with custom error map.`);return e?{errorMap:e,description:t}:{errorMap:(i,o)=>{let{message:l}=s;return i.code==="invalid_enum_value"?{message:l??o.defaultError}:typeof o.data>"u"?{message:l??a??o.defaultError}:i.code!=="invalid_type"?{message:o.defaultError}:{message:l??r??o.defaultError}},description:t}}var ee=class{get description(){return this._def.description}_getType(e){return lt(e.data)}_getOrReturnCtx(e,r){return r||{common:e.parent.common,data:e.data,parsedType:lt(e.data),schemaErrorMap:this._def.errorMap,path:e.path,parent:e.parent}}_processInputParams(e){return{status:new Ie,ctx:{common:e.parent.common,data:e.data,parsedType:lt(e.data),schemaErrorMap:this._def.errorMap,path:e.path,parent:e.parent}}}_parseSync(e){let r=this._parse(e);if(mr(r))throw new Error("Synchronous parse encountered promise.");return r}_parseAsync(e){let r=this._parse(e);return Promise.resolve(r)}parse(e,r){let a=this.safeParse(e,r);if(a.success)return a.data;throw a.error}safeParse(e,r){let a={common:{issues:[],async:r?.async??!1,contextualErrorMap:r?.errorMap},path:r?.path||[],schemaErrorMap:this._def.errorMap,parent:null,data:e,parsedType:lt(e)},t=this._parseSync({data:e,path:a.path,parent:a});return Tn(a,t)}"~validate"(e){let r={common:{issues:[],async:!!this["~standard"].async},path:[],schemaErrorMap:this._def.errorMap,parent:null,data:e,parsedType:lt(e)};if(!this["~standard"].async)try{let a=this._parseSync({data:e,path:[],parent:r});return wt(a)?{value:a.value}:{issues:r.common.issues}}catch(a){a?.message?.toLowerCase()?.includes("encountered")&&(this["~standard"].async=!0),r.common={issues:[],async:!0}}return this._parseAsync({data:e,path:[],parent:r}).then(a=>wt(a)?{value:a.value}:{issues:r.common.issues})}async parseAsync(e,r){let a=await this.safeParseAsync(e,r);if(a.success)return a.data;throw a.error}async safeParseAsync(e,r){let a={common:{issues:[],contextualErrorMap:r?.errorMap,async:!0},path:r?.path||[],schemaErrorMap:this._def.errorMap,parent:null,data:e,parsedType:lt(e)},t=this._parse({data:e,path:a.path,parent:a}),n=await(mr(t)?t:Promise.resolve(t));return Tn(a,n)}refine(e,r){let a=t=>typeof r=="string"||typeof r>"u"?{message:r}:typeof r=="function"?r(t):r;return this._refinement((t,n)=>{let i=e(t),o=()=>n.addIssue({code:j.custom,...a(t)});return typeof Promise<"u"&&i instanceof Promise?i.then(l=>l?!0:(o(),!1)):i?!0:(o(),!1)})}refinement(e,r){return this._refinement((a,t)=>e(a)?!0:(t.addIssue(typeof r=="function"?r(a,t):r),!1))}_refinement(e){return new Je({schema:this,typeName:F.ZodEffects,effect:{type:"refinement",refinement:e}})}superRefine(e){return this._refinement(e)}constructor(e){this.spa=this.safeParseAsync,this._def=e,this.parse=this.parse.bind(this),this.safeParse=this.safeParse.bind(this),this.parseAsync=this.parseAsync.bind(this),this.safeParseAsync=this.safeParseAsync.bind(this),this.spa=this.spa.bind(this),this.refine=this.refine.bind(this),this.refinement=this.refinement.bind(this),this.superRefine=this.superRefine.bind(this),this.optional=this.optional.bind(this),this.nullable=this.nullable.bind(this),this.nullish=this.nullish.bind(this),this.array=this.array.bind(this),this.promise=this.promise.bind(this),this.or=this.or.bind(this),this.and=this.and.bind(this),this.transform=this.transform.bind(this),this.brand=this.brand.bind(this),this.default=this.default.bind(this),this.catch=this.catch.bind(this),this.describe=this.describe.bind(this),this.pipe=this.pipe.bind(this),this.readonly=this.readonly.bind(this),this.isNullable=this.isNullable.bind(this),this.isOptional=this.isOptional.bind(this),this["~standard"]={version:1,vendor:"zod",validate:r=>this["~validate"](r)}}optional(){return Qe.create(this,this._def)}nullable(){return dt.create(this,this._def)}nullish(){return this.nullable().optional()}array(){return St.create(this)}promise(){return It.create(this,this._def)}or(e){return Wt.create([this,e],this._def)}and(e){return Qt.create(this,e,this._def)}transform(e){return new Je({...J(this._def),schema:this,typeName:F.ZodEffects,effect:{type:"transform",transform:e}})}default(e){let r=typeof e=="function"?e:()=>e;return new tr({...J(this._def),innerType:this,defaultValue:r,typeName:F.ZodDefault})}brand(){return new Cr({typeName:F.ZodBranded,type:this,...J(this._def)})}catch(e){let r=typeof e=="function"?e:()=>e;return new rr({...J(this._def),innerType:this,catchValue:r,typeName:F.ZodCatch})}describe(e){let r=this.constructor;return new r({...this._def,description:e})}pipe(e){return kr.create(this,e)}readonly(){return sr.create(this)}isOptional(){return this.safeParse(void 0).success}isNullable(){return this.safeParse(null).success}},du=/^c[^\s-]{8,}$/i,pu=/^[0-9a-z]+$/,fu=/^[0-9A-HJKMNP-TV-Z]{26}$/i,hu=/^[0-9a-fA-F]{8}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{12}$/i,mu=/^[a-z0-9_-]{21}$/i,vu=/^[A-Za-z0-9-_]+\.[A-Za-z0-9-_]+\.[A-Za-z0-9-_]*$/,gu=/^[-+]?P(?!$)(?:(?:[-+]?\d+Y)|(?:[-+]?\d+[.,]\d+Y$))?(?:(?:[-+]?\d+M)|(?:[-+]?\d+[.,]\d+M$))?(?:(?:[-+]?\d+W)|(?:[-+]?\d+[.,]\d+W$))?(?:(?:[-+]?\d+D)|(?:[-+]?\d+[.,]\d+D$))?(?:T(?=[\d+-])(?:(?:[-+]?\d+H)|(?:[-+]?\d+[.,]\d+H$))?(?:(?:[-+]?\d+M)|(?:[-+]?\d+[.,]\d+M$))?(?:[-+]?\d+(?:[.,]\d+)?S)?)??$/,yu=/^(?!\.)(?!.*\.\.)([A-Z0-9_'+\-\.]*)[A-Z0-9_+-]@([A-Z0-9][A-Z0-9\-]*\.)+[A-Z]{2,}$/i,_u="^(\\p{Extended_Pictographic}|\\p{Emoji_Component})+$",Gs,bu=/^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])$/,Eu=/^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\/(3[0-2]|[12]?[0-9])$/,Su=/^(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))$/,xu=/^(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))\/(12[0-8]|1[01][0-9]|[1-9]?[0-9])$/,Ru=/^([0-9a-zA-Z+/]{4})*(([0-9a-zA-Z+/]{2}==)|([0-9a-zA-Z+/]{3}=))?$/,Tu=/^([0-9a-zA-Z-_]{4})*(([0-9a-zA-Z-_]{2}(==)?)|([0-9a-zA-Z-_]{3}(=)?))?$/,On="((\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-((0[13578]|1[02])-(0[1-9]|[12]\\d|3[01])|(0[469]|11)-(0[1-9]|[12]\\d|30)|(02)-(0[1-9]|1\\d|2[0-8])))",wu=new RegExp(`^${On}$`);function Pn(s){let e="[0-5]\\d";s.precision?e=`${e}\\.\\d{${s.precision}}`:s.precision==null&&(e=`${e}(\\.\\d+)?`);let r=s.precision?"+":"?";return`([01]\\d|2[0-3]):[0-5]\\d(:${e})${r}`}function Ou(s){return new RegExp(`^${Pn(s)}$`)}function In(s){let e=`${On}T${Pn(s)}`,r=[];return r.push(s.local?"Z?":"Z"),s.offset&&r.push("([+-]\\d{2}:?\\d{2})"),e=`${e}(${r.join("|")})`,new RegExp(`^${e}$`)}function Pu(s,e){return!!((e==="v4"||!e)&&bu.test(s)||(e==="v6"||!e)&&Su.test(s))}function Iu(s,e){if(!vu.test(s))return!1;try{let[r]=s.split(".");if(!r)return!1;let a=r.replace(/-/g,"+").replace(/_/g,"/").padEnd(r.length+(4-r.length%4)%4,"="),t=JSON.parse(atob(a));return!(typeof t!="object"||t===null||"typ"in t&&t?.typ!=="JWT"||!t.alg||e&&t.alg!==e)}catch{return!1}}function Nu(s,e){return!!((e==="v4"||!e)&&Eu.test(s)||(e==="v6"||!e)&&xu.test(s))}var Ot=class s extends ee{_parse(e){if(this._def.coerce&&(e.data=String(e.data)),this._getType(e)!==B.string){let n=this._getOrReturnCtx(e);return U(n,{code:j.invalid_type,expected:B.string,received:n.parsedType}),G}let a=new Ie,t;for(let n of this._def.checks)if(n.kind==="min")e.data.lengthn.value&&(t=this._getOrReturnCtx(e,t),U(t,{code:j.too_big,maximum:n.value,type:"string",inclusive:!0,exact:!1,message:n.message}),a.dirty());else if(n.kind==="length"){let i=e.data.length>n.value,o=e.data.lengthe.test(t),{validation:r,code:j.invalid_string,...H.errToObj(a)})}_addCheck(e){return new s({...this._def,checks:[...this._def.checks,e]})}email(e){return this._addCheck({kind:"email",...H.errToObj(e)})}url(e){return this._addCheck({kind:"url",...H.errToObj(e)})}emoji(e){return this._addCheck({kind:"emoji",...H.errToObj(e)})}uuid(e){return this._addCheck({kind:"uuid",...H.errToObj(e)})}nanoid(e){return this._addCheck({kind:"nanoid",...H.errToObj(e)})}cuid(e){return this._addCheck({kind:"cuid",...H.errToObj(e)})}cuid2(e){return this._addCheck({kind:"cuid2",...H.errToObj(e)})}ulid(e){return this._addCheck({kind:"ulid",...H.errToObj(e)})}base64(e){return this._addCheck({kind:"base64",...H.errToObj(e)})}base64url(e){return this._addCheck({kind:"base64url",...H.errToObj(e)})}jwt(e){return this._addCheck({kind:"jwt",...H.errToObj(e)})}ip(e){return this._addCheck({kind:"ip",...H.errToObj(e)})}cidr(e){return this._addCheck({kind:"cidr",...H.errToObj(e)})}datetime(e){return typeof e=="string"?this._addCheck({kind:"datetime",precision:null,offset:!1,local:!1,message:e}):this._addCheck({kind:"datetime",precision:typeof e?.precision>"u"?null:e?.precision,offset:e?.offset??!1,local:e?.local??!1,...H.errToObj(e?.message)})}date(e){return this._addCheck({kind:"date",message:e})}time(e){return typeof e=="string"?this._addCheck({kind:"time",precision:null,message:e}):this._addCheck({kind:"time",precision:typeof e?.precision>"u"?null:e?.precision,...H.errToObj(e?.message)})}duration(e){return this._addCheck({kind:"duration",...H.errToObj(e)})}regex(e,r){return this._addCheck({kind:"regex",regex:e,...H.errToObj(r)})}includes(e,r){return this._addCheck({kind:"includes",value:e,position:r?.position,...H.errToObj(r?.message)})}startsWith(e,r){return this._addCheck({kind:"startsWith",value:e,...H.errToObj(r)})}endsWith(e,r){return this._addCheck({kind:"endsWith",value:e,...H.errToObj(r)})}min(e,r){return this._addCheck({kind:"min",value:e,...H.errToObj(r)})}max(e,r){return this._addCheck({kind:"max",value:e,...H.errToObj(r)})}length(e,r){return this._addCheck({kind:"length",value:e,...H.errToObj(r)})}nonempty(e){return this.min(1,H.errToObj(e))}trim(){return new s({...this._def,checks:[...this._def.checks,{kind:"trim"}]})}toLowerCase(){return new s({...this._def,checks:[...this._def.checks,{kind:"toLowerCase"}]})}toUpperCase(){return new s({...this._def,checks:[...this._def.checks,{kind:"toUpperCase"}]})}get isDatetime(){return!!this._def.checks.find(e=>e.kind==="datetime")}get isDate(){return!!this._def.checks.find(e=>e.kind==="date")}get isTime(){return!!this._def.checks.find(e=>e.kind==="time")}get isDuration(){return!!this._def.checks.find(e=>e.kind==="duration")}get isEmail(){return!!this._def.checks.find(e=>e.kind==="email")}get isURL(){return!!this._def.checks.find(e=>e.kind==="url")}get isEmoji(){return!!this._def.checks.find(e=>e.kind==="emoji")}get isUUID(){return!!this._def.checks.find(e=>e.kind==="uuid")}get isNANOID(){return!!this._def.checks.find(e=>e.kind==="nanoid")}get isCUID(){return!!this._def.checks.find(e=>e.kind==="cuid")}get isCUID2(){return!!this._def.checks.find(e=>e.kind==="cuid2")}get isULID(){return!!this._def.checks.find(e=>e.kind==="ulid")}get isIP(){return!!this._def.checks.find(e=>e.kind==="ip")}get isCIDR(){return!!this._def.checks.find(e=>e.kind==="cidr")}get isBase64(){return!!this._def.checks.find(e=>e.kind==="base64")}get isBase64url(){return!!this._def.checks.find(e=>e.kind==="base64url")}get minLength(){let e=null;for(let r of this._def.checks)r.kind==="min"&&(e===null||r.value>e)&&(e=r.value);return e}get maxLength(){let e=null;for(let r of this._def.checks)r.kind==="max"&&(e===null||r.valuenew Ot({checks:[],typeName:F.ZodString,coerce:s?.coerce??!1,...J(s)});function Au(s,e){let r=(s.toString().split(".")[1]||"").length,a=(e.toString().split(".")[1]||"").length,t=r>a?r:a,n=Number.parseInt(s.toFixed(t).replace(".","")),i=Number.parseInt(e.toFixed(t).replace(".",""));return n%i/10**t}var Vt=class s extends ee{constructor(){super(...arguments),this.min=this.gte,this.max=this.lte,this.step=this.multipleOf}_parse(e){if(this._def.coerce&&(e.data=Number(e.data)),this._getType(e)!==B.number){let n=this._getOrReturnCtx(e);return U(n,{code:j.invalid_type,expected:B.number,received:n.parsedType}),G}let a,t=new Ie;for(let n of this._def.checks)n.kind==="int"?re.isInteger(e.data)||(a=this._getOrReturnCtx(e,a),U(a,{code:j.invalid_type,expected:"integer",received:"float",message:n.message}),t.dirty()):n.kind==="min"?(n.inclusive?e.datan.value:e.data>=n.value)&&(a=this._getOrReturnCtx(e,a),U(a,{code:j.too_big,maximum:n.value,type:"number",inclusive:n.inclusive,exact:!1,message:n.message}),t.dirty()):n.kind==="multipleOf"?Au(e.data,n.value)!==0&&(a=this._getOrReturnCtx(e,a),U(a,{code:j.not_multiple_of,multipleOf:n.value,message:n.message}),t.dirty()):n.kind==="finite"?Number.isFinite(e.data)||(a=this._getOrReturnCtx(e,a),U(a,{code:j.not_finite,message:n.message}),t.dirty()):re.assertNever(n);return{status:t.value,value:e.data}}gte(e,r){return this.setLimit("min",e,!0,H.toString(r))}gt(e,r){return this.setLimit("min",e,!1,H.toString(r))}lte(e,r){return this.setLimit("max",e,!0,H.toString(r))}lt(e,r){return this.setLimit("max",e,!1,H.toString(r))}setLimit(e,r,a,t){return new s({...this._def,checks:[...this._def.checks,{kind:e,value:r,inclusive:a,message:H.toString(t)}]})}_addCheck(e){return new s({...this._def,checks:[...this._def.checks,e]})}int(e){return this._addCheck({kind:"int",message:H.toString(e)})}positive(e){return this._addCheck({kind:"min",value:0,inclusive:!1,message:H.toString(e)})}negative(e){return this._addCheck({kind:"max",value:0,inclusive:!1,message:H.toString(e)})}nonpositive(e){return this._addCheck({kind:"max",value:0,inclusive:!0,message:H.toString(e)})}nonnegative(e){return this._addCheck({kind:"min",value:0,inclusive:!0,message:H.toString(e)})}multipleOf(e,r){return this._addCheck({kind:"multipleOf",value:e,message:H.toString(r)})}finite(e){return this._addCheck({kind:"finite",message:H.toString(e)})}safe(e){return this._addCheck({kind:"min",inclusive:!0,value:Number.MIN_SAFE_INTEGER,message:H.toString(e)})._addCheck({kind:"max",inclusive:!0,value:Number.MAX_SAFE_INTEGER,message:H.toString(e)})}get minValue(){let e=null;for(let r of this._def.checks)r.kind==="min"&&(e===null||r.value>e)&&(e=r.value);return e}get maxValue(){let e=null;for(let r of this._def.checks)r.kind==="max"&&(e===null||r.valuee.kind==="int"||e.kind==="multipleOf"&&re.isInteger(e.value))}get isFinite(){let e=null,r=null;for(let a of this._def.checks){if(a.kind==="finite"||a.kind==="int"||a.kind==="multipleOf")return!0;a.kind==="min"?(r===null||a.value>r)&&(r=a.value):a.kind==="max"&&(e===null||a.valuenew Vt({checks:[],typeName:F.ZodNumber,coerce:s?.coerce||!1,...J(s)});var Ht=class s extends ee{constructor(){super(...arguments),this.min=this.gte,this.max=this.lte}_parse(e){if(this._def.coerce)try{e.data=BigInt(e.data)}catch{return this._getInvalidInput(e)}if(this._getType(e)!==B.bigint)return this._getInvalidInput(e);let a,t=new Ie;for(let n of this._def.checks)n.kind==="min"?(n.inclusive?e.datan.value:e.data>=n.value)&&(a=this._getOrReturnCtx(e,a),U(a,{code:j.too_big,type:"bigint",maximum:n.value,inclusive:n.inclusive,message:n.message}),t.dirty()):n.kind==="multipleOf"?e.data%n.value!==BigInt(0)&&(a=this._getOrReturnCtx(e,a),U(a,{code:j.not_multiple_of,multipleOf:n.value,message:n.message}),t.dirty()):re.assertNever(n);return{status:t.value,value:e.data}}_getInvalidInput(e){let r=this._getOrReturnCtx(e);return U(r,{code:j.invalid_type,expected:B.bigint,received:r.parsedType}),G}gte(e,r){return this.setLimit("min",e,!0,H.toString(r))}gt(e,r){return this.setLimit("min",e,!1,H.toString(r))}lte(e,r){return this.setLimit("max",e,!0,H.toString(r))}lt(e,r){return this.setLimit("max",e,!1,H.toString(r))}setLimit(e,r,a,t){return new s({...this._def,checks:[...this._def.checks,{kind:e,value:r,inclusive:a,message:H.toString(t)}]})}_addCheck(e){return new s({...this._def,checks:[...this._def.checks,e]})}positive(e){return this._addCheck({kind:"min",value:BigInt(0),inclusive:!1,message:H.toString(e)})}negative(e){return this._addCheck({kind:"max",value:BigInt(0),inclusive:!1,message:H.toString(e)})}nonpositive(e){return this._addCheck({kind:"max",value:BigInt(0),inclusive:!0,message:H.toString(e)})}nonnegative(e){return this._addCheck({kind:"min",value:BigInt(0),inclusive:!0,message:H.toString(e)})}multipleOf(e,r){return this._addCheck({kind:"multipleOf",value:e,message:H.toString(r)})}get minValue(){let e=null;for(let r of this._def.checks)r.kind==="min"&&(e===null||r.value>e)&&(e=r.value);return e}get maxValue(){let e=null;for(let r of this._def.checks)r.kind==="max"&&(e===null||r.valuenew Ht({checks:[],typeName:F.ZodBigInt,coerce:s?.coerce??!1,...J(s)});var zt=class extends ee{_parse(e){if(this._def.coerce&&(e.data=!!e.data),this._getType(e)!==B.boolean){let a=this._getOrReturnCtx(e);return U(a,{code:j.invalid_type,expected:B.boolean,received:a.parsedType}),G}return Ae(e.data)}};zt.create=s=>new zt({typeName:F.ZodBoolean,coerce:s?.coerce||!1,...J(s)});var Zt=class s extends ee{_parse(e){if(this._def.coerce&&(e.data=new Date(e.data)),this._getType(e)!==B.date){let n=this._getOrReturnCtx(e);return U(n,{code:j.invalid_type,expected:B.date,received:n.parsedType}),G}if(Number.isNaN(e.data.getTime())){let n=this._getOrReturnCtx(e);return U(n,{code:j.invalid_date}),G}let a=new Ie,t;for(let n of this._def.checks)n.kind==="min"?e.data.getTime()n.value&&(t=this._getOrReturnCtx(e,t),U(t,{code:j.too_big,message:n.message,inclusive:!0,exact:!1,maximum:n.value,type:"date"}),a.dirty()):re.assertNever(n);return{status:a.value,value:new Date(e.data.getTime())}}_addCheck(e){return new s({...this._def,checks:[...this._def.checks,e]})}min(e,r){return this._addCheck({kind:"min",value:e.getTime(),message:H.toString(r)})}max(e,r){return this._addCheck({kind:"max",value:e.getTime(),message:H.toString(r)})}get minDate(){let e=null;for(let r of this._def.checks)r.kind==="min"&&(e===null||r.value>e)&&(e=r.value);return e!=null?new Date(e):null}get maxDate(){let e=null;for(let r of this._def.checks)r.kind==="max"&&(e===null||r.valuenew Zt({checks:[],coerce:s?.coerce||!1,typeName:F.ZodDate,...J(s)});var gr=class extends ee{_parse(e){if(this._getType(e)!==B.symbol){let a=this._getOrReturnCtx(e);return U(a,{code:j.invalid_type,expected:B.symbol,received:a.parsedType}),G}return Ae(e.data)}};gr.create=s=>new gr({typeName:F.ZodSymbol,...J(s)});var Gt=class extends ee{_parse(e){if(this._getType(e)!==B.undefined){let a=this._getOrReturnCtx(e);return U(a,{code:j.invalid_type,expected:B.undefined,received:a.parsedType}),G}return Ae(e.data)}};Gt.create=s=>new Gt({typeName:F.ZodUndefined,...J(s)});var Xt=class extends ee{_parse(e){if(this._getType(e)!==B.null){let a=this._getOrReturnCtx(e);return U(a,{code:j.invalid_type,expected:B.null,received:a.parsedType}),G}return Ae(e.data)}};Xt.create=s=>new Xt({typeName:F.ZodNull,...J(s)});var Pt=class extends ee{constructor(){super(...arguments),this._any=!0}_parse(e){return Ae(e.data)}};Pt.create=s=>new Pt({typeName:F.ZodAny,...J(s)});var Et=class extends ee{constructor(){super(...arguments),this._unknown=!0}_parse(e){return Ae(e.data)}};Et.create=s=>new Et({typeName:F.ZodUnknown,...J(s)});var rt=class extends ee{_parse(e){let r=this._getOrReturnCtx(e);return U(r,{code:j.invalid_type,expected:B.never,received:r.parsedType}),G}};rt.create=s=>new rt({typeName:F.ZodNever,...J(s)});var yr=class extends ee{_parse(e){if(this._getType(e)!==B.undefined){let a=this._getOrReturnCtx(e);return U(a,{code:j.invalid_type,expected:B.void,received:a.parsedType}),G}return Ae(e.data)}};yr.create=s=>new yr({typeName:F.ZodVoid,...J(s)});var St=class s extends ee{_parse(e){let{ctx:r,status:a}=this._processInputParams(e),t=this._def;if(r.parsedType!==B.array)return U(r,{code:j.invalid_type,expected:B.array,received:r.parsedType}),G;if(t.exactLength!==null){let i=r.data.length>t.exactLength.value,o=r.data.lengtht.maxLength.value&&(U(r,{code:j.too_big,maximum:t.maxLength.value,type:"array",inclusive:!0,exact:!1,message:t.maxLength.message}),a.dirty()),r.common.async)return Promise.all([...r.data].map((i,o)=>t.type._parseAsync(new Ke(r,i,r.path,o)))).then(i=>Ie.mergeArray(a,i));let n=[...r.data].map((i,o)=>t.type._parseSync(new Ke(r,i,r.path,o)));return Ie.mergeArray(a,n)}get element(){return this._def.type}min(e,r){return new s({...this._def,minLength:{value:e,message:H.toString(r)}})}max(e,r){return new s({...this._def,maxLength:{value:e,message:H.toString(r)}})}length(e,r){return new s({...this._def,exactLength:{value:e,message:H.toString(r)}})}nonempty(e){return this.min(1,e)}};St.create=(s,e)=>new St({type:s,minLength:null,maxLength:null,exactLength:null,typeName:F.ZodArray,...J(e)});function vr(s){if(s instanceof Ue){let e={};for(let r in s.shape){let a=s.shape[r];e[r]=Qe.create(vr(a))}return new Ue({...s._def,shape:()=>e})}else return s instanceof St?new St({...s._def,type:vr(s.element)}):s instanceof Qe?Qe.create(vr(s.unwrap())):s instanceof dt?dt.create(vr(s.unwrap())):s instanceof ut?ut.create(s.items.map(e=>vr(e))):s}var Ue=class s extends ee{constructor(){super(...arguments),this._cached=null,this.nonstrict=this.passthrough,this.augment=this.extend}_getCached(){if(this._cached!==null)return this._cached;let e=this._def.shape(),r=re.objectKeys(e);return this._cached={shape:e,keys:r},this._cached}_parse(e){if(this._getType(e)!==B.object){let u=this._getOrReturnCtx(e);return U(u,{code:j.invalid_type,expected:B.object,received:u.parsedType}),G}let{status:a,ctx:t}=this._processInputParams(e),{shape:n,keys:i}=this._getCached(),o=[];if(!(this._def.catchall instanceof rt&&this._def.unknownKeys==="strip"))for(let u in t.data)i.includes(u)||o.push(u);let l=[];for(let u of i){let d=n[u],f=t.data[u];l.push({key:{status:"valid",value:u},value:d._parse(new Ke(t,f,t.path,u)),alwaysSet:u in t.data})}if(this._def.catchall instanceof rt){let u=this._def.unknownKeys;if(u==="passthrough")for(let d of o)l.push({key:{status:"valid",value:d},value:{status:"valid",value:t.data[d]}});else if(u==="strict")o.length>0&&(U(t,{code:j.unrecognized_keys,keys:o}),a.dirty());else if(u!=="strip")throw new Error("Internal ZodObject error: invalid unknownKeys value.")}else{let u=this._def.catchall;for(let d of o){let f=t.data[d];l.push({key:{status:"valid",value:d},value:u._parse(new Ke(t,f,t.path,d)),alwaysSet:d in t.data})}}return t.common.async?Promise.resolve().then(async()=>{let u=[];for(let d of l){let f=await d.key,h=await d.value;u.push({key:f,value:h,alwaysSet:d.alwaysSet})}return u}).then(u=>Ie.mergeObjectSync(a,u)):Ie.mergeObjectSync(a,l)}get shape(){return this._def.shape()}strict(e){return H.errToObj,new s({...this._def,unknownKeys:"strict",...e!==void 0?{errorMap:(r,a)=>{let t=this._def.errorMap?.(r,a).message??a.defaultError;return r.code==="unrecognized_keys"?{message:H.errToObj(e).message??t}:{message:t}}}:{}})}strip(){return new s({...this._def,unknownKeys:"strip"})}passthrough(){return new s({...this._def,unknownKeys:"passthrough"})}extend(e){return new s({...this._def,shape:()=>({...this._def.shape(),...e})})}merge(e){return new s({unknownKeys:e._def.unknownKeys,catchall:e._def.catchall,shape:()=>({...this._def.shape(),...e._def.shape()}),typeName:F.ZodObject})}setKey(e,r){return this.augment({[e]:r})}catchall(e){return new s({...this._def,catchall:e})}pick(e){let r={};for(let a of re.objectKeys(e))e[a]&&this.shape[a]&&(r[a]=this.shape[a]);return new s({...this._def,shape:()=>r})}omit(e){let r={};for(let a of re.objectKeys(this.shape))e[a]||(r[a]=this.shape[a]);return new s({...this._def,shape:()=>r})}deepPartial(){return vr(this)}partial(e){let r={};for(let a of re.objectKeys(this.shape)){let t=this.shape[a];e&&!e[a]?r[a]=t:r[a]=t.optional()}return new s({...this._def,shape:()=>r})}required(e){let r={};for(let a of re.objectKeys(this.shape))if(e&&!e[a])r[a]=this.shape[a];else{let n=this.shape[a];for(;n instanceof Qe;)n=n._def.innerType;r[a]=n}return new s({...this._def,shape:()=>r})}keyof(){return Nn(re.objectKeys(this.shape))}};Ue.create=(s,e)=>new Ue({shape:()=>s,unknownKeys:"strip",catchall:rt.create(),typeName:F.ZodObject,...J(e)});Ue.strictCreate=(s,e)=>new Ue({shape:()=>s,unknownKeys:"strict",catchall:rt.create(),typeName:F.ZodObject,...J(e)});Ue.lazycreate=(s,e)=>new Ue({shape:s,unknownKeys:"strip",catchall:rt.create(),typeName:F.ZodObject,...J(e)});var Wt=class extends ee{_parse(e){let{ctx:r}=this._processInputParams(e),a=this._def.options;function t(n){for(let o of n)if(o.result.status==="valid")return o.result;for(let o of n)if(o.result.status==="dirty")return r.common.issues.push(...o.ctx.common.issues),o.result;let i=n.map(o=>new qe(o.ctx.common.issues));return U(r,{code:j.invalid_union,unionErrors:i}),G}if(r.common.async)return Promise.all(a.map(async n=>{let i={...r,common:{...r.common,issues:[]},parent:null};return{result:await n._parseAsync({data:r.data,path:r.path,parent:i}),ctx:i}})).then(t);{let n,i=[];for(let l of a){let u={...r,common:{...r.common,issues:[]},parent:null},d=l._parseSync({data:r.data,path:r.path,parent:u});if(d.status==="valid")return d;d.status==="dirty"&&!n&&(n={result:d,ctx:u}),u.common.issues.length&&i.push(u.common.issues)}if(n)return r.common.issues.push(...n.ctx.common.issues),n.result;let o=i.map(l=>new qe(l));return U(r,{code:j.invalid_union,unionErrors:o}),G}}get options(){return this._def.options}};Wt.create=(s,e)=>new Wt({options:s,typeName:F.ZodUnion,...J(e)});var bt=s=>s instanceof Kt?bt(s.schema):s instanceof Je?bt(s.innerType()):s instanceof Jt?[s.value]:s instanceof Yt?s.options:s instanceof er?re.objectValues(s.enum):s instanceof tr?bt(s._def.innerType):s instanceof Gt?[void 0]:s instanceof Xt?[null]:s instanceof Qe?[void 0,...bt(s.unwrap())]:s instanceof dt?[null,...bt(s.unwrap())]:s instanceof Cr||s instanceof sr?bt(s.unwrap()):s instanceof rr?bt(s._def.innerType):[],Qr=class s extends ee{_parse(e){let{ctx:r}=this._processInputParams(e);if(r.parsedType!==B.object)return U(r,{code:j.invalid_type,expected:B.object,received:r.parsedType}),G;let a=this.discriminator,t=r.data[a],n=this.optionsMap.get(t);return n?r.common.async?n._parseAsync({data:r.data,path:r.path,parent:r}):n._parseSync({data:r.data,path:r.path,parent:r}):(U(r,{code:j.invalid_union_discriminator,options:Array.from(this.optionsMap.keys()),path:[a]}),G)}get discriminator(){return this._def.discriminator}get options(){return this._def.options}get optionsMap(){return this._def.optionsMap}static create(e,r,a){let t=new Map;for(let n of r){let i=bt(n.shape[e]);if(!i.length)throw new Error(`A discriminator value for key \`${e}\` could not be extracted from all schema options`);for(let o of i){if(t.has(o))throw new Error(`Discriminator property ${String(e)} has duplicate value ${String(o)}`);t.set(o,n)}}return new s({typeName:F.ZodDiscriminatedUnion,discriminator:e,options:r,optionsMap:t,...J(a)})}};function Xs(s,e){let r=lt(s),a=lt(e);if(s===e)return{valid:!0,data:s};if(r===B.object&&a===B.object){let t=re.objectKeys(e),n=re.objectKeys(s).filter(o=>t.indexOf(o)!==-1),i={...s,...e};for(let o of n){let l=Xs(s[o],e[o]);if(!l.valid)return{valid:!1};i[o]=l.data}return{valid:!0,data:i}}else if(r===B.array&&a===B.array){if(s.length!==e.length)return{valid:!1};let t=[];for(let n=0;n{if(Xr(n)||Xr(i))return G;let o=Xs(n.value,i.value);return o.valid?((Wr(n)||Wr(i))&&r.dirty(),{status:r.value,value:o.data}):(U(a,{code:j.invalid_intersection_types}),G)};return a.common.async?Promise.all([this._def.left._parseAsync({data:a.data,path:a.path,parent:a}),this._def.right._parseAsync({data:a.data,path:a.path,parent:a})]).then(([n,i])=>t(n,i)):t(this._def.left._parseSync({data:a.data,path:a.path,parent:a}),this._def.right._parseSync({data:a.data,path:a.path,parent:a}))}};Qt.create=(s,e,r)=>new Qt({left:s,right:e,typeName:F.ZodIntersection,...J(r)});var ut=class s extends ee{_parse(e){let{status:r,ctx:a}=this._processInputParams(e);if(a.parsedType!==B.array)return U(a,{code:j.invalid_type,expected:B.array,received:a.parsedType}),G;if(a.data.lengththis._def.items.length&&(U(a,{code:j.too_big,maximum:this._def.items.length,inclusive:!0,exact:!1,type:"array"}),r.dirty());let n=[...a.data].map((i,o)=>{let l=this._def.items[o]||this._def.rest;return l?l._parse(new Ke(a,i,a.path,o)):null}).filter(i=>!!i);return a.common.async?Promise.all(n).then(i=>Ie.mergeArray(r,i)):Ie.mergeArray(r,n)}get items(){return this._def.items}rest(e){return new s({...this._def,rest:e})}};ut.create=(s,e)=>{if(!Array.isArray(s))throw new Error("You must pass an array of schemas to z.tuple([ ... ])");return new ut({items:s,typeName:F.ZodTuple,rest:null,...J(e)})};var Kr=class s extends ee{get keySchema(){return this._def.keyType}get valueSchema(){return this._def.valueType}_parse(e){let{status:r,ctx:a}=this._processInputParams(e);if(a.parsedType!==B.object)return U(a,{code:j.invalid_type,expected:B.object,received:a.parsedType}),G;let t=[],n=this._def.keyType,i=this._def.valueType;for(let o in a.data)t.push({key:n._parse(new Ke(a,o,a.path,o)),value:i._parse(new Ke(a,a.data[o],a.path,o)),alwaysSet:o in a.data});return a.common.async?Ie.mergeObjectAsync(r,t):Ie.mergeObjectSync(r,t)}get element(){return this._def.valueType}static create(e,r,a){return r instanceof ee?new s({keyType:e,valueType:r,typeName:F.ZodRecord,...J(a)}):new s({keyType:Ot.create(),valueType:e,typeName:F.ZodRecord,...J(r)})}},_r=class extends ee{get keySchema(){return this._def.keyType}get valueSchema(){return this._def.valueType}_parse(e){let{status:r,ctx:a}=this._processInputParams(e);if(a.parsedType!==B.map)return U(a,{code:j.invalid_type,expected:B.map,received:a.parsedType}),G;let t=this._def.keyType,n=this._def.valueType,i=[...a.data.entries()].map(([o,l],u)=>({key:t._parse(new Ke(a,o,a.path,[u,"key"])),value:n._parse(new Ke(a,l,a.path,[u,"value"]))}));if(a.common.async){let o=new Map;return Promise.resolve().then(async()=>{for(let l of i){let u=await l.key,d=await l.value;if(u.status==="aborted"||d.status==="aborted")return G;(u.status==="dirty"||d.status==="dirty")&&r.dirty(),o.set(u.value,d.value)}return{status:r.value,value:o}})}else{let o=new Map;for(let l of i){let u=l.key,d=l.value;if(u.status==="aborted"||d.status==="aborted")return G;(u.status==="dirty"||d.status==="dirty")&&r.dirty(),o.set(u.value,d.value)}return{status:r.value,value:o}}}};_r.create=(s,e,r)=>new _r({valueType:e,keyType:s,typeName:F.ZodMap,...J(r)});var br=class s extends ee{_parse(e){let{status:r,ctx:a}=this._processInputParams(e);if(a.parsedType!==B.set)return U(a,{code:j.invalid_type,expected:B.set,received:a.parsedType}),G;let t=this._def;t.minSize!==null&&a.data.sizet.maxSize.value&&(U(a,{code:j.too_big,maximum:t.maxSize.value,type:"set",inclusive:!0,exact:!1,message:t.maxSize.message}),r.dirty());let n=this._def.valueType;function i(l){let u=new Set;for(let d of l){if(d.status==="aborted")return G;d.status==="dirty"&&r.dirty(),u.add(d.value)}return{status:r.value,value:u}}let o=[...a.data.values()].map((l,u)=>n._parse(new Ke(a,l,a.path,u)));return a.common.async?Promise.all(o).then(l=>i(l)):i(o)}min(e,r){return new s({...this._def,minSize:{value:e,message:H.toString(r)}})}max(e,r){return new s({...this._def,maxSize:{value:e,message:H.toString(r)}})}size(e,r){return this.min(e,r).max(e,r)}nonempty(e){return this.min(1,e)}};br.create=(s,e)=>new br({valueType:s,minSize:null,maxSize:null,typeName:F.ZodSet,...J(e)});var Jr=class s extends ee{constructor(){super(...arguments),this.validate=this.implement}_parse(e){let{ctx:r}=this._processInputParams(e);if(r.parsedType!==B.function)return U(r,{code:j.invalid_type,expected:B.function,received:r.parsedType}),G;function a(o,l){return Dr({data:o,path:r.path,errorMaps:[r.common.contextualErrorMap,r.schemaErrorMap,hr(),_t].filter(u=>!!u),issueData:{code:j.invalid_arguments,argumentsError:l}})}function t(o,l){return Dr({data:o,path:r.path,errorMaps:[r.common.contextualErrorMap,r.schemaErrorMap,hr(),_t].filter(u=>!!u),issueData:{code:j.invalid_return_type,returnTypeError:l}})}let n={errorMap:r.common.contextualErrorMap},i=r.data;if(this._def.returns instanceof It){let o=this;return Ae(async function(...l){let u=new qe([]),d=await o._def.args.parseAsync(l,n).catch(p=>{throw u.addIssue(a(l,p)),u}),f=await Reflect.apply(i,this,d);return await o._def.returns._def.type.parseAsync(f,n).catch(p=>{throw u.addIssue(t(f,p)),u})})}else{let o=this;return Ae(function(...l){let u=o._def.args.safeParse(l,n);if(!u.success)throw new qe([a(l,u.error)]);let d=Reflect.apply(i,this,u.data),f=o._def.returns.safeParse(d,n);if(!f.success)throw new qe([t(d,f.error)]);return f.data})}}parameters(){return this._def.args}returnType(){return this._def.returns}args(...e){return new s({...this._def,args:ut.create(e).rest(Et.create())})}returns(e){return new s({...this._def,returns:e})}implement(e){return this.parse(e)}strictImplement(e){return this.parse(e)}static create(e,r,a){return new s({args:e||ut.create([]).rest(Et.create()),returns:r||Et.create(),typeName:F.ZodFunction,...J(a)})}},Kt=class extends ee{get schema(){return this._def.getter()}_parse(e){let{ctx:r}=this._processInputParams(e);return this._def.getter()._parse({data:r.data,path:r.path,parent:r})}};Kt.create=(s,e)=>new Kt({getter:s,typeName:F.ZodLazy,...J(e)});var Jt=class extends ee{_parse(e){if(e.data!==this._def.value){let r=this._getOrReturnCtx(e);return U(r,{received:r.data,code:j.invalid_literal,expected:this._def.value}),G}return{status:"valid",value:e.data}}get value(){return this._def.value}};Jt.create=(s,e)=>new Jt({value:s,typeName:F.ZodLiteral,...J(e)});function Nn(s,e){return new Yt({values:s,typeName:F.ZodEnum,...J(e)})}var Yt=class s extends ee{_parse(e){if(typeof e.data!="string"){let r=this._getOrReturnCtx(e),a=this._def.values;return U(r,{expected:re.joinValues(a),received:r.parsedType,code:j.invalid_type}),G}if(this._cache||(this._cache=new Set(this._def.values)),!this._cache.has(e.data)){let r=this._getOrReturnCtx(e),a=this._def.values;return U(r,{received:r.data,code:j.invalid_enum_value,options:a}),G}return Ae(e.data)}get options(){return this._def.values}get enum(){let e={};for(let r of this._def.values)e[r]=r;return e}get Values(){let e={};for(let r of this._def.values)e[r]=r;return e}get Enum(){let e={};for(let r of this._def.values)e[r]=r;return e}extract(e,r=this._def){return s.create(e,{...this._def,...r})}exclude(e,r=this._def){return s.create(this.options.filter(a=>!e.includes(a)),{...this._def,...r})}};Yt.create=Nn;var er=class extends ee{_parse(e){let r=re.getValidEnumValues(this._def.values),a=this._getOrReturnCtx(e);if(a.parsedType!==B.string&&a.parsedType!==B.number){let t=re.objectValues(r);return U(a,{expected:re.joinValues(t),received:a.parsedType,code:j.invalid_type}),G}if(this._cache||(this._cache=new Set(re.getValidEnumValues(this._def.values))),!this._cache.has(e.data)){let t=re.objectValues(r);return U(a,{received:a.data,code:j.invalid_enum_value,options:t}),G}return Ae(e.data)}get enum(){return this._def.values}};er.create=(s,e)=>new er({values:s,typeName:F.ZodNativeEnum,...J(e)});var It=class extends ee{unwrap(){return this._def.type}_parse(e){let{ctx:r}=this._processInputParams(e);if(r.parsedType!==B.promise&&r.common.async===!1)return U(r,{code:j.invalid_type,expected:B.promise,received:r.parsedType}),G;let a=r.parsedType===B.promise?r.data:Promise.resolve(r.data);return Ae(a.then(t=>this._def.type.parseAsync(t,{path:r.path,errorMap:r.common.contextualErrorMap})))}};It.create=(s,e)=>new It({type:s,typeName:F.ZodPromise,...J(e)});var Je=class extends ee{innerType(){return this._def.schema}sourceType(){return this._def.schema._def.typeName===F.ZodEffects?this._def.schema.sourceType():this._def.schema}_parse(e){let{status:r,ctx:a}=this._processInputParams(e),t=this._def.effect||null,n={addIssue:i=>{U(a,i),i.fatal?r.abort():r.dirty()},get path(){return a.path}};if(n.addIssue=n.addIssue.bind(n),t.type==="preprocess"){let i=t.transform(a.data,n);if(a.common.async)return Promise.resolve(i).then(async o=>{if(r.value==="aborted")return G;let l=await this._def.schema._parseAsync({data:o,path:a.path,parent:a});return l.status==="aborted"?G:l.status==="dirty"?Bt(l.value):r.value==="dirty"?Bt(l.value):l});{if(r.value==="aborted")return G;let o=this._def.schema._parseSync({data:i,path:a.path,parent:a});return o.status==="aborted"?G:o.status==="dirty"?Bt(o.value):r.value==="dirty"?Bt(o.value):o}}if(t.type==="refinement"){let i=o=>{let l=t.refinement(o,n);if(a.common.async)return Promise.resolve(l);if(l instanceof Promise)throw new Error("Async refinement encountered during synchronous parse operation. Use .parseAsync instead.");return o};if(a.common.async===!1){let o=this._def.schema._parseSync({data:a.data,path:a.path,parent:a});return o.status==="aborted"?G:(o.status==="dirty"&&r.dirty(),i(o.value),{status:r.value,value:o.value})}else return this._def.schema._parseAsync({data:a.data,path:a.path,parent:a}).then(o=>o.status==="aborted"?G:(o.status==="dirty"&&r.dirty(),i(o.value).then(()=>({status:r.value,value:o.value}))))}if(t.type==="transform")if(a.common.async===!1){let i=this._def.schema._parseSync({data:a.data,path:a.path,parent:a});if(!wt(i))return G;let o=t.transform(i.value,n);if(o instanceof Promise)throw new Error("Asynchronous transform encountered during synchronous parse operation. Use .parseAsync instead.");return{status:r.value,value:o}}else return this._def.schema._parseAsync({data:a.data,path:a.path,parent:a}).then(i=>wt(i)?Promise.resolve(t.transform(i.value,n)).then(o=>({status:r.value,value:o})):G);re.assertNever(t)}};Je.create=(s,e,r)=>new Je({schema:s,typeName:F.ZodEffects,effect:e,...J(r)});Je.createWithPreprocess=(s,e,r)=>new Je({schema:e,effect:{type:"preprocess",transform:s},typeName:F.ZodEffects,...J(r)});var Qe=class extends ee{_parse(e){return this._getType(e)===B.undefined?Ae(void 0):this._def.innerType._parse(e)}unwrap(){return this._def.innerType}};Qe.create=(s,e)=>new Qe({innerType:s,typeName:F.ZodOptional,...J(e)});var dt=class extends ee{_parse(e){return this._getType(e)===B.null?Ae(null):this._def.innerType._parse(e)}unwrap(){return this._def.innerType}};dt.create=(s,e)=>new dt({innerType:s,typeName:F.ZodNullable,...J(e)});var tr=class extends ee{_parse(e){let{ctx:r}=this._processInputParams(e),a=r.data;return r.parsedType===B.undefined&&(a=this._def.defaultValue()),this._def.innerType._parse({data:a,path:r.path,parent:r})}removeDefault(){return this._def.innerType}};tr.create=(s,e)=>new tr({innerType:s,typeName:F.ZodDefault,defaultValue:typeof e.default=="function"?e.default:()=>e.default,...J(e)});var rr=class extends ee{_parse(e){let{ctx:r}=this._processInputParams(e),a={...r,common:{...r.common,issues:[]}},t=this._def.innerType._parse({data:a.data,path:a.path,parent:{...a}});return mr(t)?t.then(n=>({status:"valid",value:n.status==="valid"?n.value:this._def.catchValue({get error(){return new qe(a.common.issues)},input:a.data})})):{status:"valid",value:t.status==="valid"?t.value:this._def.catchValue({get error(){return new qe(a.common.issues)},input:a.data})}}removeCatch(){return this._def.innerType}};rr.create=(s,e)=>new rr({innerType:s,typeName:F.ZodCatch,catchValue:typeof e.catch=="function"?e.catch:()=>e.catch,...J(e)});var Er=class extends ee{_parse(e){if(this._getType(e)!==B.nan){let a=this._getOrReturnCtx(e);return U(a,{code:j.invalid_type,expected:B.nan,received:a.parsedType}),G}return{status:"valid",value:e.data}}};Er.create=s=>new Er({typeName:F.ZodNaN,...J(s)});var $u=Symbol("zod_brand"),Cr=class extends ee{_parse(e){let{ctx:r}=this._processInputParams(e),a=r.data;return this._def.type._parse({data:a,path:r.path,parent:r})}unwrap(){return this._def.type}},kr=class s extends ee{_parse(e){let{status:r,ctx:a}=this._processInputParams(e);if(a.common.async)return(async()=>{let n=await this._def.in._parseAsync({data:a.data,path:a.path,parent:a});return n.status==="aborted"?G:n.status==="dirty"?(r.dirty(),Bt(n.value)):this._def.out._parseAsync({data:n.value,path:a.path,parent:a})})();{let t=this._def.in._parseSync({data:a.data,path:a.path,parent:a});return t.status==="aborted"?G:t.status==="dirty"?(r.dirty(),{status:"dirty",value:t.value}):this._def.out._parseSync({data:t.value,path:a.path,parent:a})}}static create(e,r){return new s({in:e,out:r,typeName:F.ZodPipeline})}},sr=class extends ee{_parse(e){let r=this._def.innerType._parse(e),a=t=>(wt(t)&&(t.value=Object.freeze(t.value)),t);return mr(r)?r.then(t=>a(t)):a(r)}unwrap(){return this._def.innerType}};sr.create=(s,e)=>new sr({innerType:s,typeName:F.ZodReadonly,...J(e)});function wn(s,e){let r=typeof s=="function"?s(e):typeof s=="string"?{message:s}:s;return typeof r=="string"?{message:r}:r}function An(s,e={},r){return s?Pt.create().superRefine((a,t)=>{let n=s(a);if(n instanceof Promise)return n.then(i=>{if(!i){let o=wn(e,a),l=o.fatal??r??!0;t.addIssue({code:"custom",...o,fatal:l})}});if(!n){let i=wn(e,a),o=i.fatal??r??!0;t.addIssue({code:"custom",...i,fatal:o})}}):Pt.create()}var Du={object:Ue.lazycreate},F;(function(s){s.ZodString="ZodString",s.ZodNumber="ZodNumber",s.ZodNaN="ZodNaN",s.ZodBigInt="ZodBigInt",s.ZodBoolean="ZodBoolean",s.ZodDate="ZodDate",s.ZodSymbol="ZodSymbol",s.ZodUndefined="ZodUndefined",s.ZodNull="ZodNull",s.ZodAny="ZodAny",s.ZodUnknown="ZodUnknown",s.ZodNever="ZodNever",s.ZodVoid="ZodVoid",s.ZodArray="ZodArray",s.ZodObject="ZodObject",s.ZodUnion="ZodUnion",s.ZodDiscriminatedUnion="ZodDiscriminatedUnion",s.ZodIntersection="ZodIntersection",s.ZodTuple="ZodTuple",s.ZodRecord="ZodRecord",s.ZodMap="ZodMap",s.ZodSet="ZodSet",s.ZodFunction="ZodFunction",s.ZodLazy="ZodLazy",s.ZodLiteral="ZodLiteral",s.ZodEnum="ZodEnum",s.ZodEffects="ZodEffects",s.ZodNativeEnum="ZodNativeEnum",s.ZodOptional="ZodOptional",s.ZodNullable="ZodNullable",s.ZodDefault="ZodDefault",s.ZodCatch="ZodCatch",s.ZodPromise="ZodPromise",s.ZodBranded="ZodBranded",s.ZodPipeline="ZodPipeline",s.ZodReadonly="ZodReadonly"})(F||(F={}));var Cu=(s,e={message:`Input not instance of ${s.name}`})=>An(r=>r instanceof s,e),$n=Ot.create,Dn=Vt.create,ku=Er.create,Lu=Ht.create,Cn=zt.create,ju=Zt.create,Fu=gr.create,Mu=Gt.create,qu=Xt.create,Uu=Pt.create,Bu=Et.create,Vu=rt.create,Hu=yr.create,zu=St.create,Zu=Ue.create,Gu=Ue.strictCreate,Xu=Wt.create,Wu=Qr.create,Qu=Qt.create,Ku=ut.create,Ju=Kr.create,Yu=_r.create,ed=br.create,td=Jr.create,rd=Kt.create,sd=Jt.create,ad=Yt.create,nd=er.create,od=It.create,id=Je.create,cd=Qe.create,ld=dt.create,ud=Je.createWithPreprocess,dd=kr.create,pd=()=>$n().optional(),fd=()=>Dn().optional(),hd=()=>Cn().optional(),md={string:(s=>Ot.create({...s,coerce:!0})),number:(s=>Vt.create({...s,coerce:!0})),boolean:(s=>zt.create({...s,coerce:!0})),bigint:(s=>Ht.create({...s,coerce:!0})),date:(s=>Zt.create({...s,coerce:!0}))};var vd=G;var Lr="2025-06-18";var Yr=[Lr,"2025-03-26","2024-11-05","2024-10-07"],es="2.0",kn=c.union([c.string(),c.number().int()]),Ln=c.string(),gd=c.object({progressToken:c.optional(kn)}).passthrough(),Ye=c.object({_meta:c.optional(gd)}).passthrough(),Be=c.object({method:c.string(),params:c.optional(Ye)}),jr=c.object({_meta:c.optional(c.object({}).passthrough())}).passthrough(),pt=c.object({method:c.string(),params:c.optional(jr)}),et=c.object({_meta:c.optional(c.object({}).passthrough())}).passthrough(),ts=c.union([c.string(),c.number().int()]),jn=c.object({jsonrpc:c.literal(es),id:ts}).merge(Be).strict(),Fn=s=>jn.safeParse(s).success,Mn=c.object({jsonrpc:c.literal(es)}).merge(pt).strict(),qn=s=>Mn.safeParse(s).success,Un=c.object({jsonrpc:c.literal(es),id:ts,result:et}).strict(),Ws=s=>Un.safeParse(s).success,je;(function(s){s[s.ConnectionClosed=-32e3]="ConnectionClosed",s[s.RequestTimeout=-32001]="RequestTimeout",s[s.ParseError=-32700]="ParseError",s[s.InvalidRequest=-32600]="InvalidRequest",s[s.MethodNotFound=-32601]="MethodNotFound",s[s.InvalidParams=-32602]="InvalidParams",s[s.InternalError=-32603]="InternalError"})(je||(je={}));var Bn=c.object({jsonrpc:c.literal(es),id:ts,error:c.object({code:c.number().int(),message:c.string(),data:c.optional(c.unknown())})}).strict(),Vn=s=>Bn.safeParse(s).success,Hn=c.union([jn,Mn,Un,Bn]),xt=et.strict(),rs=pt.extend({method:c.literal("notifications/cancelled"),params:jr.extend({requestId:ts,reason:c.string().optional()})}),yd=c.object({src:c.string(),mimeType:c.optional(c.string()),sizes:c.optional(c.array(c.string()))}).passthrough(),Fr=c.object({icons:c.array(yd).optional()}).passthrough(),Mr=c.object({name:c.string(),title:c.optional(c.string())}).passthrough(),zn=Mr.extend({version:c.string(),websiteUrl:c.optional(c.string())}).merge(Fr),_d=c.object({experimental:c.optional(c.object({}).passthrough()),sampling:c.optional(c.object({}).passthrough()),elicitation:c.optional(c.object({}).passthrough()),roots:c.optional(c.object({listChanged:c.optional(c.boolean())}).passthrough())}).passthrough(),Qs=Be.extend({method:c.literal("initialize"),params:Ye.extend({protocolVersion:c.string(),capabilities:_d,clientInfo:zn})});var bd=c.object({experimental:c.optional(c.object({}).passthrough()),logging:c.optional(c.object({}).passthrough()),completions:c.optional(c.object({}).passthrough()),prompts:c.optional(c.object({listChanged:c.optional(c.boolean())}).passthrough()),resources:c.optional(c.object({subscribe:c.optional(c.boolean()),listChanged:c.optional(c.boolean())}).passthrough()),tools:c.optional(c.object({listChanged:c.optional(c.boolean())}).passthrough())}).passthrough(),Ks=et.extend({protocolVersion:c.string(),capabilities:bd,serverInfo:zn,instructions:c.optional(c.string())}),Js=pt.extend({method:c.literal("notifications/initialized")});var ss=Be.extend({method:c.literal("ping")}),Ed=c.object({progress:c.number(),total:c.optional(c.number()),message:c.optional(c.string())}).passthrough(),as=pt.extend({method:c.literal("notifications/progress"),params:jr.merge(Ed).extend({progressToken:kn})}),ns=Be.extend({params:Ye.extend({cursor:c.optional(Ln)}).optional()}),os=et.extend({nextCursor:c.optional(Ln)}),Zn=c.object({uri:c.string(),mimeType:c.optional(c.string()),_meta:c.optional(c.object({}).passthrough())}).passthrough(),Gn=Zn.extend({text:c.string()}),Ys=c.string().refine(s=>{try{return atob(s),!0}catch{return!1}},{message:"Invalid Base64 string"}),Xn=Zn.extend({blob:Ys}),Wn=Mr.extend({uri:c.string(),description:c.optional(c.string()),mimeType:c.optional(c.string()),_meta:c.optional(c.object({}).passthrough())}).merge(Fr),Sd=Mr.extend({uriTemplate:c.string(),description:c.optional(c.string()),mimeType:c.optional(c.string()),_meta:c.optional(c.object({}).passthrough())}).merge(Fr),xd=ns.extend({method:c.literal("resources/list")}),ea=os.extend({resources:c.array(Wn)}),Rd=ns.extend({method:c.literal("resources/templates/list")}),ta=os.extend({resourceTemplates:c.array(Sd)}),Td=Be.extend({method:c.literal("resources/read"),params:Ye.extend({uri:c.string()})}),ra=et.extend({contents:c.array(c.union([Gn,Xn]))}),wd=pt.extend({method:c.literal("notifications/resources/list_changed")}),Od=Be.extend({method:c.literal("resources/subscribe"),params:Ye.extend({uri:c.string()})}),Pd=Be.extend({method:c.literal("resources/unsubscribe"),params:Ye.extend({uri:c.string()})}),Id=pt.extend({method:c.literal("notifications/resources/updated"),params:jr.extend({uri:c.string()})}),Nd=c.object({name:c.string(),description:c.optional(c.string()),required:c.optional(c.boolean())}).passthrough(),Ad=Mr.extend({description:c.optional(c.string()),arguments:c.optional(c.array(Nd)),_meta:c.optional(c.object({}).passthrough())}).merge(Fr),$d=ns.extend({method:c.literal("prompts/list")}),sa=os.extend({prompts:c.array(Ad)}),Dd=Be.extend({method:c.literal("prompts/get"),params:Ye.extend({name:c.string(),arguments:c.optional(c.record(c.string()))})}),aa=c.object({type:c.literal("text"),text:c.string(),_meta:c.optional(c.object({}).passthrough())}).passthrough(),na=c.object({type:c.literal("image"),data:Ys,mimeType:c.string(),_meta:c.optional(c.object({}).passthrough())}).passthrough(),oa=c.object({type:c.literal("audio"),data:Ys,mimeType:c.string(),_meta:c.optional(c.object({}).passthrough())}).passthrough(),Cd=c.object({type:c.literal("resource"),resource:c.union([Gn,Xn]),_meta:c.optional(c.object({}).passthrough())}).passthrough(),kd=Wn.extend({type:c.literal("resource_link")}),Qn=c.union([aa,na,oa,kd,Cd]),Ld=c.object({role:c.enum(["user","assistant"]),content:Qn}).passthrough(),ia=et.extend({description:c.optional(c.string()),messages:c.array(Ld)}),jd=pt.extend({method:c.literal("notifications/prompts/list_changed")}),Fd=c.object({title:c.optional(c.string()),readOnlyHint:c.optional(c.boolean()),destructiveHint:c.optional(c.boolean()),idempotentHint:c.optional(c.boolean()),openWorldHint:c.optional(c.boolean())}).passthrough(),Md=Mr.extend({description:c.optional(c.string()),inputSchema:c.object({type:c.literal("object"),properties:c.optional(c.object({}).passthrough()),required:c.optional(c.array(c.string()))}).passthrough(),outputSchema:c.optional(c.object({type:c.literal("object"),properties:c.optional(c.object({}).passthrough()),required:c.optional(c.array(c.string()))}).passthrough()),annotations:c.optional(Fd),_meta:c.optional(c.object({}).passthrough())}).merge(Fr),ca=ns.extend({method:c.literal("tools/list")}),la=os.extend({tools:c.array(Md)}),is=et.extend({content:c.array(Qn).default([]),structuredContent:c.object({}).passthrough().optional(),isError:c.optional(c.boolean())}),um=is.or(et.extend({toolResult:c.unknown()})),ua=Be.extend({method:c.literal("tools/call"),params:Ye.extend({name:c.string(),arguments:c.optional(c.record(c.unknown()))})}),qd=pt.extend({method:c.literal("notifications/tools/list_changed")}),qr=c.enum(["debug","info","notice","warning","error","critical","alert","emergency"]),da=Be.extend({method:c.literal("logging/setLevel"),params:Ye.extend({level:qr})}),Ud=pt.extend({method:c.literal("notifications/message"),params:jr.extend({level:qr,logger:c.optional(c.string()),data:c.unknown()})}),Bd=c.object({name:c.string().optional()}).passthrough(),Vd=c.object({hints:c.optional(c.array(Bd)),costPriority:c.optional(c.number().min(0).max(1)),speedPriority:c.optional(c.number().min(0).max(1)),intelligencePriority:c.optional(c.number().min(0).max(1))}).passthrough(),Hd=c.object({role:c.enum(["user","assistant"]),content:c.union([aa,na,oa])}).passthrough(),zd=Be.extend({method:c.literal("sampling/createMessage"),params:Ye.extend({messages:c.array(Hd),systemPrompt:c.optional(c.string()),includeContext:c.optional(c.enum(["none","thisServer","allServers"])),temperature:c.optional(c.number()),maxTokens:c.number().int(),stopSequences:c.optional(c.array(c.string())),metadata:c.optional(c.object({}).passthrough()),modelPreferences:c.optional(Vd)})}),pa=et.extend({model:c.string(),stopReason:c.optional(c.enum(["endTurn","stopSequence","maxTokens"]).or(c.string())),role:c.enum(["user","assistant"]),content:c.discriminatedUnion("type",[aa,na,oa])}),Zd=c.object({type:c.literal("boolean"),title:c.optional(c.string()),description:c.optional(c.string()),default:c.optional(c.boolean())}).passthrough(),Gd=c.object({type:c.literal("string"),title:c.optional(c.string()),description:c.optional(c.string()),minLength:c.optional(c.number()),maxLength:c.optional(c.number()),format:c.optional(c.enum(["email","uri","date","date-time"]))}).passthrough(),Xd=c.object({type:c.enum(["number","integer"]),title:c.optional(c.string()),description:c.optional(c.string()),minimum:c.optional(c.number()),maximum:c.optional(c.number())}).passthrough(),Wd=c.object({type:c.literal("string"),title:c.optional(c.string()),description:c.optional(c.string()),enum:c.array(c.string()),enumNames:c.optional(c.array(c.string()))}).passthrough(),Qd=c.union([Zd,Gd,Xd,Wd]),Kd=Be.extend({method:c.literal("elicitation/create"),params:Ye.extend({message:c.string(),requestedSchema:c.object({type:c.literal("object"),properties:c.record(c.string(),Qd),required:c.optional(c.array(c.string()))}).passthrough()})}),fa=et.extend({action:c.enum(["accept","decline","cancel"]),content:c.optional(c.record(c.string(),c.unknown()))}),Jd=c.object({type:c.literal("ref/resource"),uri:c.string()}).passthrough();var Yd=c.object({type:c.literal("ref/prompt"),name:c.string()}).passthrough(),ep=Be.extend({method:c.literal("completion/complete"),params:Ye.extend({ref:c.union([Yd,Jd]),argument:c.object({name:c.string(),value:c.string()}).passthrough(),context:c.optional(c.object({arguments:c.optional(c.record(c.string(),c.string()))}))})}),ha=et.extend({completion:c.object({values:c.array(c.string()).max(100),total:c.optional(c.number().int()),hasMore:c.optional(c.boolean())}).passthrough()}),tp=c.object({uri:c.string().startsWith("file://"),name:c.optional(c.string()),_meta:c.optional(c.object({}).passthrough())}).passthrough(),rp=Be.extend({method:c.literal("roots/list")}),ma=et.extend({roots:c.array(tp)}),sp=pt.extend({method:c.literal("notifications/roots/list_changed")}),dm=c.union([ss,Qs,ep,da,Dd,$d,xd,Rd,Td,Od,Pd,ua,ca]),pm=c.union([rs,as,Js,sp]),fm=c.union([xt,pa,fa,ma]),hm=c.union([ss,zd,Kd,rp]),mm=c.union([rs,as,Ud,Id,wd,qd,jd]),vm=c.union([xt,Ks,ha,ia,sa,ea,ta,ra,is,la]),$e=class extends Error{constructor(e,r,a){super(`MCP error ${e}: ${r}`),this.code=e,this.data=a,this.name="McpError"}};var ap=6e4,Sr=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.setNotificationHandler(rs,r=>{let a=this._requestHandlerAbortControllers.get(r.params.requestId);a?.abort(r.params.reason)}),this.setNotificationHandler(as,r=>{this._onprogress(r)}),this.setRequestHandler(ss,r=>({}))}_setupTimeout(e,r,a,t,n=!1){this._timeoutInfo.set(e,{timeoutId:setTimeout(t,r),startTime:Date.now(),timeout:r,maxTotalTimeout:a,resetTimeoutOnProgress:n,onTimeout:t})}_resetTimeout(e){let r=this._timeoutInfo.get(e);if(!r)return!1;let a=Date.now()-r.startTime;if(r.maxTotalTimeout&&a>=r.maxTotalTimeout)throw this._timeoutInfo.delete(e),new $e(je.RequestTimeout,"Maximum total timeout exceeded",{maxTotalTimeout:r.maxTotalTimeout,totalElapsed:a});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){var r,a,t;this._transport=e;let n=(r=this.transport)===null||r===void 0?void 0:r.onclose;this._transport.onclose=()=>{n?.(),this._onclose()};let i=(a=this.transport)===null||a===void 0?void 0:a.onerror;this._transport.onerror=l=>{i?.(l),this._onerror(l)};let o=(t=this._transport)===null||t===void 0?void 0:t.onmessage;this._transport.onmessage=(l,u)=>{o?.(l,u),Ws(l)||Vn(l)?this._onresponse(l):Fn(l)?this._onrequest(l,u):qn(l)?this._onnotification(l):this._onerror(new Error(`Unknown message type: ${JSON.stringify(l)}`))},await this._transport.start()}_onclose(){var e;let r=this._responseHandlers;this._responseHandlers=new Map,this._progressHandlers.clear(),this._pendingDebouncedNotifications.clear(),this._transport=void 0,(e=this.onclose)===null||e===void 0||e.call(this);let a=new $e(je.ConnectionClosed,"Connection closed");for(let t of r.values())t(a)}_onerror(e){var r;(r=this.onerror)===null||r===void 0||r.call(this,e)}_onnotification(e){var r;let a=(r=this._notificationHandlers.get(e.method))!==null&&r!==void 0?r:this.fallbackNotificationHandler;a!==void 0&&Promise.resolve().then(()=>a(e)).catch(t=>this._onerror(new Error(`Uncaught error in notification handler: ${t}`)))}_onrequest(e,r){var a,t;let n=(a=this._requestHandlers.get(e.method))!==null&&a!==void 0?a:this.fallbackRequestHandler,i=this._transport;if(n===void 0){i?.send({jsonrpc:"2.0",id:e.id,error:{code:je.MethodNotFound,message:"Method not found"}}).catch(u=>this._onerror(new Error(`Failed to send an error response: ${u}`)));return}let o=new AbortController;this._requestHandlerAbortControllers.set(e.id,o);let l={signal:o.signal,sessionId:i?.sessionId,_meta:(t=e.params)===null||t===void 0?void 0:t._meta,sendNotification:u=>this.notification(u,{relatedRequestId:e.id}),sendRequest:(u,d,f)=>this.request(u,d,{...f,relatedRequestId:e.id}),authInfo:r?.authInfo,requestId:e.id,requestInfo:r?.requestInfo};Promise.resolve().then(()=>n(e,l)).then(u=>{if(!o.signal.aborted)return i?.send({result:u,jsonrpc:"2.0",id:e.id})},u=>{var d;if(!o.signal.aborted)return i?.send({jsonrpc:"2.0",id:e.id,error:{code:Number.isSafeInteger(u.code)?u.code:je.InternalError,message:(d=u.message)!==null&&d!==void 0?d:"Internal error"}})}).catch(u=>this._onerror(new Error(`Failed to send response: ${u}`))).finally(()=>{this._requestHandlerAbortControllers.delete(e.id)})}_onprogress(e){let{progressToken:r,...a}=e.params,t=Number(r),n=this._progressHandlers.get(t);if(!n){this._onerror(new Error(`Received a progress notification for an unknown token: ${JSON.stringify(e)}`));return}let i=this._responseHandlers.get(t),o=this._timeoutInfo.get(t);if(o&&i&&o.resetTimeoutOnProgress)try{this._resetTimeout(t)}catch(l){i(l);return}n(a)}_onresponse(e){let r=Number(e.id),a=this._responseHandlers.get(r);if(a===void 0){this._onerror(new Error(`Received a response for an unknown message ID: ${JSON.stringify(e)}`));return}if(this._responseHandlers.delete(r),this._progressHandlers.delete(r),this._cleanupTimeout(r),Ws(e))a(e);else{let t=new $e(e.error.code,e.error.message,e.error.data);a(t)}}get transport(){return this._transport}async close(){var e;await((e=this._transport)===null||e===void 0?void 0:e.close())}request(e,r,a){let{relatedRequestId:t,resumptionToken:n,onresumptiontoken:i}=a??{};return new Promise((o,l)=>{var u,d,f,h,p,g;if(!this._transport){l(new Error("Not connected"));return}((u=this._options)===null||u===void 0?void 0:u.enforceStrictCapabilities)===!0&&this.assertCapabilityForMethod(e.method),(d=a?.signal)===null||d===void 0||d.throwIfAborted();let y=this._requestMessageId++,v={...e,jsonrpc:"2.0",id:y};a?.onprogress&&(this._progressHandlers.set(y,a.onprogress),v.params={...e.params,_meta:{...((f=e.params)===null||f===void 0?void 0:f._meta)||{},progressToken:y}});let x=R=>{var T;this._responseHandlers.delete(y),this._progressHandlers.delete(y),this._cleanupTimeout(y),(T=this._transport)===null||T===void 0||T.send({jsonrpc:"2.0",method:"notifications/cancelled",params:{requestId:y,reason:String(R)}},{relatedRequestId:t,resumptionToken:n,onresumptiontoken:i}).catch(S=>this._onerror(new Error(`Failed to send cancellation: ${S}`))),l(R)};this._responseHandlers.set(y,R=>{var T;if(!(!((T=a?.signal)===null||T===void 0)&&T.aborted)){if(R instanceof Error)return l(R);try{let S=r.parse(R.result);o(S)}catch(S){l(S)}}}),(h=a?.signal)===null||h===void 0||h.addEventListener("abort",()=>{var R;x((R=a?.signal)===null||R===void 0?void 0:R.reason)});let P=(p=a?.timeout)!==null&&p!==void 0?p:ap,E=()=>x(new $e(je.RequestTimeout,"Request timed out",{timeout:P}));this._setupTimeout(y,P,a?.maxTotalTimeout,E,(g=a?.resetTimeoutOnProgress)!==null&&g!==void 0?g:!1),this._transport.send(v,{relatedRequestId:t,resumptionToken:n,onresumptiontoken:i}).catch(R=>{this._cleanupTimeout(y),l(R)})})}async notification(e,r){var a,t;if(!this._transport)throw new Error("Not connected");if(this.assertNotificationCapability(e.method),((t=(a=this._options)===null||a===void 0?void 0:a.debouncedNotificationMethods)!==null&&t!==void 0?t:[]).includes(e.method)&&!e.params&&!r?.relatedRequestId){if(this._pendingDebouncedNotifications.has(e.method))return;this._pendingDebouncedNotifications.add(e.method),Promise.resolve().then(()=>{var l;if(this._pendingDebouncedNotifications.delete(e.method),!this._transport)return;let u={...e,jsonrpc:"2.0"};(l=this._transport)===null||l===void 0||l.send(u,r).catch(d=>this._onerror(d))});return}let o={...e,jsonrpc:"2.0"};await this._transport.send(o,r)}setRequestHandler(e,r){let a=e.shape.method.value;this.assertRequestHandlerCapability(a),this._requestHandlers.set(a,(t,n)=>Promise.resolve(r(e.parse(t),n)))}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){this._notificationHandlers.set(e.shape.method.value,a=>Promise.resolve(r(e.parse(a))))}removeNotificationHandler(e){this._notificationHandlers.delete(e)}};function cs(s,e){return Object.entries(e).reduce((r,[a,t])=>(t&&typeof t=="object"?r[a]=r[a]?{...r[a],...t}:t:r[a]=t,r),{...s})}var Ji=Ut(qa(),1),Os=class extends Sr{constructor(e,r){var a;super(r),this._serverInfo=e,this._loggingLevels=new Map,this.LOG_LEVEL_SEVERITY=new Map(qr.options.map((t,n)=>[t,n])),this.isMessageIgnored=(t,n)=>{let i=this._loggingLevels.get(n);return i?this.LOG_LEVEL_SEVERITY.get(t)this._oninitialize(t)),this.setNotificationHandler(Js,()=>{var t;return(t=this.oninitialized)===null||t===void 0?void 0:t.call(this)}),this._capabilities.logging&&this.setRequestHandler(da,async(t,n)=>{var i;let o=n.sessionId||((i=n.requestInfo)===null||i===void 0?void 0:i.headers["mcp-session-id"])||void 0,{level:l}=t.params,u=qr.safeParse(l);return u.success&&this._loggingLevels.set(o,u.data),{}})}registerCapabilities(e){if(this.transport)throw new Error("Cannot register capabilities after connecting to transport");this._capabilities=cs(this._capabilities,e)}assertCapabilityForMethod(e){var r,a,t;switch(e){case"sampling/createMessage":if(!(!((r=this._clientCapabilities)===null||r===void 0)&&r.sampling))throw new Error(`Client does not support sampling (required for ${e})`);break;case"elicitation/create":if(!(!((a=this._clientCapabilities)===null||a===void 0)&&a.elicitation))throw new Error(`Client does not support elicitation (required for ${e})`);break;case"roots/list":if(!(!((t=this._clientCapabilities)===null||t===void 0)&&t.roots))throw new Error(`Client does not support listing roots (required for ${e})`);break;case"ping":break}}assertNotificationCapability(e){switch(e){case"notifications/message":if(!this._capabilities.logging)throw new Error(`Server does not support logging (required for ${e})`);break;case"notifications/resources/updated":case"notifications/resources/list_changed":if(!this._capabilities.resources)throw new Error(`Server does not support notifying about resources (required for ${e})`);break;case"notifications/tools/list_changed":if(!this._capabilities.tools)throw new Error(`Server does not support notifying of tool list changes (required for ${e})`);break;case"notifications/prompts/list_changed":if(!this._capabilities.prompts)throw new Error(`Server does not support notifying of prompt list changes (required for ${e})`);break;case"notifications/cancelled":break;case"notifications/progress":break}}assertRequestHandlerCapability(e){switch(e){case"sampling/createMessage":if(!this._capabilities.sampling)throw new Error(`Server does not support sampling (required for ${e})`);break;case"logging/setLevel":if(!this._capabilities.logging)throw new Error(`Server does not support logging (required for ${e})`);break;case"prompts/get":case"prompts/list":if(!this._capabilities.prompts)throw new Error(`Server does not support prompts (required for ${e})`);break;case"resources/list":case"resources/templates/list":case"resources/read":if(!this._capabilities.resources)throw new Error(`Server does not support resources (required for ${e})`);break;case"tools/call":case"tools/list":if(!this._capabilities.tools)throw new Error(`Server does not support tools (required for ${e})`);break;case"ping":case"initialize":break}}async _oninitialize(e){let r=e.params.protocolVersion;return this._clientCapabilities=e.params.capabilities,this._clientVersion=e.params.clientInfo,{protocolVersion:Yr.includes(r)?r:Lr,capabilities:this.getCapabilities(),serverInfo:this._serverInfo,...this._instructions&&{instructions:this._instructions}}}getClientCapabilities(){return this._clientCapabilities}getClientVersion(){return this._clientVersion}getCapabilities(){return this._capabilities}async ping(){return this.request({method:"ping"},xt)}async createMessage(e,r){return this.request({method:"sampling/createMessage",params:e},pa,r)}async elicitInput(e,r){let a=await this.request({method:"elicitation/create",params:e},fa,r);if(a.action==="accept"&&a.content)try{let t=new Ji.default,n=t.compile(e.requestedSchema);if(!n(a.content))throw new $e(je.InvalidParams,`Elicitation response content does not match requested schema: ${t.errorsText(n.errors)}`)}catch(t){throw t instanceof $e?t:new $e(je.InternalError,`Error validating elicitation response: ${t}`)}return a}async listRoots(e,r){return this.request({method:"roots/list",params:e},ma,r)}async sendLoggingMessage(e,r){if(this._capabilities.logging&&!this.isMessageIgnored(e.level,r))return this.notification({method:"notifications/message",params:e})}async sendResourceUpdated(e){return this.notification({method:"notifications/resources/updated",params:e})}async sendResourceListChanged(){return this.notification({method:"notifications/resources/list_changed"})}async sendToolListChanged(){return this.notification({method:"notifications/tools/list_changed"})}async sendPromptListChanged(){return this.notification({method:"notifications/prompts/list_changed"})}};var Ua=Ut(require("node:process"),1);var xr=class{append(e){this._buffer=this._buffer?Buffer.concat([this._buffer,e]):e}readMessage(){if(!this._buffer)return null;let e=this._buffer.indexOf(` +`);if(e===-1)return null;let r=this._buffer.toString("utf8",0,e).replace(/\r$/,"");return this._buffer=this._buffer.subarray(e+1),Ff(r)}clear(){this._buffer=void 0}};function Ff(s){return Hn.parse(JSON.parse(s))}function Ps(s){return JSON.stringify(s)+` +`}var Is=class{constructor(e=Ua.default.stdin,r=Ua.default.stdout){this._stdin=e,this._stdout=r,this._readBuffer=new xr,this._started=!1,this._ondata=a=>{this._readBuffer.append(a),this.processReadBuffer()},this._onerror=a=>{var t;(t=this.onerror)===null||t===void 0||t.call(this,a)}}async start(){if(this._started)throw new Error("StdioServerTransport already started! If using Server class, note that connect() calls start() automatically.");this._started=!0,this._stdin.on("data",this._ondata),this._stdin.on("error",this._onerror)}processReadBuffer(){for(var e,r;;)try{let a=this._readBuffer.readMessage();if(a===null)break;(e=this.onmessage)===null||e===void 0||e.call(this,a)}catch(a){(r=this.onerror)===null||r===void 0||r.call(this,a)}}async close(){var e;this._stdin.off("data",this._ondata),this._stdin.off("error",this._onerror),this._stdin.listenerCount("data")===0&&this._stdin.pause(),this._readBuffer.clear(),(e=this.onclose)===null||e===void 0||e.call(this)}send(e){return new Promise(r=>{let a=Ps(e);this._stdout.write(a)?r():this._stdout.once("drain",r)})}};var Yi=Ut(qa(),1),Ns=class extends Sr{constructor(e,r){var a;super(r),this._clientInfo=e,this._cachedToolOutputValidators=new Map,this._capabilities=(a=r?.capabilities)!==null&&a!==void 0?a:{},this._ajv=new Yi.default}registerCapabilities(e){if(this.transport)throw new Error("Cannot register capabilities after connecting to transport");this._capabilities=cs(this._capabilities,e)}assertCapability(e,r){var a;if(!(!((a=this._serverCapabilities)===null||a===void 0)&&a[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 a=await this.request({method:"initialize",params:{protocolVersion:Lr,capabilities:this._capabilities,clientInfo:this._clientInfo}},Ks,r);if(a===void 0)throw new Error(`Server sent invalid initialize result: ${a}`);if(!Yr.includes(a.protocolVersion))throw new Error(`Server's protocol version is not supported: ${a.protocolVersion}`);this._serverCapabilities=a.capabilities,this._serverVersion=a.serverInfo,e.setProtocolVersion&&e.setProtocolVersion(a.protocolVersion),this._instructions=a.instructions,await this.notification({method:"notifications/initialized"})}catch(a){throw this.close(),a}}getServerCapabilities(){return this._serverCapabilities}getServerVersion(){return this._serverVersion}getInstructions(){return this._instructions}assertCapabilityForMethod(e){var r,a,t,n,i;switch(e){case"logging/setLevel":if(!(!((r=this._serverCapabilities)===null||r===void 0)&&r.logging))throw new Error(`Server does not support logging (required for ${e})`);break;case"prompts/get":case"prompts/list":if(!(!((a=this._serverCapabilities)===null||a===void 0)&&a.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(!(!((t=this._serverCapabilities)===null||t===void 0)&&t.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(!(!((n=this._serverCapabilities)===null||n===void 0)&&n.tools))throw new Error(`Server does not support tools (required for ${e})`);break;case"completion/complete":if(!(!((i=this._serverCapabilities)===null||i===void 0)&&i.completions))throw new Error(`Server does not support completions (required for ${e})`);break;case"initialize":break;case"ping":break}}assertNotificationCapability(e){var r;switch(e){case"notifications/roots/list_changed":if(!(!((r=this._capabilities.roots)===null||r===void 0)&&r.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){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"ping":break}}async ping(e){return this.request({method:"ping"},xt,e)}async complete(e,r){return this.request({method:"completion/complete",params:e},ha,r)}async setLoggingLevel(e,r){return this.request({method:"logging/setLevel",params:{level:e}},xt,r)}async getPrompt(e,r){return this.request({method:"prompts/get",params:e},ia,r)}async listPrompts(e,r){return this.request({method:"prompts/list",params:e},sa,r)}async listResources(e,r){return this.request({method:"resources/list",params:e},ea,r)}async listResourceTemplates(e,r){return this.request({method:"resources/templates/list",params:e},ta,r)}async readResource(e,r){return this.request({method:"resources/read",params:e},ra,r)}async subscribeResource(e,r){return this.request({method:"resources/subscribe",params:e},xt,r)}async unsubscribeResource(e,r){return this.request({method:"resources/unsubscribe",params:e},xt,r)}async callTool(e,r=is,a){let t=await this.request({method:"tools/call",params:e},r,a),n=this.getToolOutputValidator(e.name);if(n){if(!t.structuredContent&&!t.isError)throw new $e(je.InvalidRequest,`Tool ${e.name} has an output schema but did not return structured content`);if(t.structuredContent)try{if(!n(t.structuredContent))throw new $e(je.InvalidParams,`Structured content does not match the tool's output schema: ${this._ajv.errorsText(n.errors)}`)}catch(i){throw i instanceof $e?i:new $e(je.InvalidParams,`Failed to validate structured content: ${i instanceof Error?i.message:String(i)}`)}}return t}cacheToolOutputSchemas(e){this._cachedToolOutputValidators.clear();for(let r of e)if(r.outputSchema)try{let a=this._ajv.compile(r.outputSchema);this._cachedToolOutputValidators.set(r.name,a)}catch{}}getToolOutputValidator(e){return this._cachedToolOutputValidators.get(e)}async listTools(e,r){let a=await this.request({method:"tools/list",params:e},la,r);return this.cacheToolOutputSchemas(a.tools),a}async sendRootsListChanged(){return this.notification({method:"notifications/roots/list_changed"})}};var Bc=Ut(Uc(),1),Br=Ut(require("node:process"),1),Vc=require("node:stream");var dh=Br.default.platform==="win32"?["APPDATA","HOMEDRIVE","HOMEPATH","LOCALAPPDATA","PATH","PROCESSOR_ARCHITECTURE","SYSTEMDRIVE","SYSTEMROOT","TEMP","USERNAME","USERPROFILE","PROGRAMFILES"]:["HOME","LOGNAME","PATH","SHELL","TERM","USER"];function ph(){let s={};for(let e of dh){let r=Br.default.env[e];r!==void 0&&(r.startsWith("()")||(s[e]=r))}return s}var $s=class{constructor(e){this._abortController=new AbortController,this._readBuffer=new xr,this._stderrStream=null,this._serverParams=e,(e.stderr==="pipe"||e.stderr==="overlapped")&&(this._stderrStream=new Vc.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)=>{var a,t,n,i,o;this._process=(0,Bc.default)(this._serverParams.command,(a=this._serverParams.args)!==null&&a!==void 0?a:[],{env:{...ph(),...this._serverParams.env},stdio:["pipe","pipe",(t=this._serverParams.stderr)!==null&&t!==void 0?t:"inherit"],shell:!1,signal:this._abortController.signal,windowsHide:Br.default.platform==="win32"&&fh(),cwd:this._serverParams.cwd}),this._process.on("error",l=>{var u,d;if(l.name==="AbortError"){(u=this.onclose)===null||u===void 0||u.call(this);return}r(l),(d=this.onerror)===null||d===void 0||d.call(this,l)}),this._process.on("spawn",()=>{e()}),this._process.on("close",l=>{var u;this._process=void 0,(u=this.onclose)===null||u===void 0||u.call(this)}),(n=this._process.stdin)===null||n===void 0||n.on("error",l=>{var u;(u=this.onerror)===null||u===void 0||u.call(this,l)}),(i=this._process.stdout)===null||i===void 0||i.on("data",l=>{this._readBuffer.append(l),this.processReadBuffer()}),(o=this._process.stdout)===null||o===void 0||o.on("error",l=>{var u;(u=this.onerror)===null||u===void 0||u.call(this,l)}),this._stderrStream&&this._process.stderr&&this._process.stderr.pipe(this._stderrStream)})}get stderr(){var e,r;return this._stderrStream?this._stderrStream:(r=(e=this._process)===null||e===void 0?void 0:e.stderr)!==null&&r!==void 0?r:null}get pid(){var e,r;return(r=(e=this._process)===null||e===void 0?void 0:e.pid)!==null&&r!==void 0?r:null}processReadBuffer(){for(var e,r;;)try{let a=this._readBuffer.readMessage();if(a===null)break;(e=this.onmessage)===null||e===void 0||e.call(this,a)}catch(a){(r=this.onerror)===null||r===void 0||r.call(this,a)}}async close(){this._abortController.abort(),this._process=void 0,this._readBuffer.clear()}send(e){return new Promise(r=>{var a;if(!(!((a=this._process)===null||a===void 0)&&a.stdin))throw new Error("Not connected");let t=Ps(e);this._process.stdin.write(t)?r():this._process.stdin.once("drain",r)})}};function fh(){return"type"in Br.default}var zc=Symbol("Let zodToJsonSchema decide on which parser to use");var Hc={name:void 0,$refStrategy:"root",basePath:["#"],effectStrategy:"input",pipeStrategy:"all",dateStrategy:"format:date-time",mapStrategy:"entries",removeAdditionalStrategy:"passthrough",allowedAdditionalProperties:!0,rejectedAdditionalProperties:!1,definitionPath:"definitions",target:"jsonSchema7",strictUnions:!1,definitions:{},errorMessages:!1,markdownDescription:!1,patternStrategy:"escape",applyRegexFlags:!1,emailStrategy:"format:email",base64Strategy:"contentEncoding:base64",nameStrategy:"ref",openAiAnyTypeName:"OpenAiAnyType"},Zc=s=>typeof s=="string"?{...Hc,name:s}:{...Hc,...s};var Gc=s=>{let e=Zc(s),r=e.name!==void 0?[...e.basePath,e.definitionPath,e.name]:e.basePath;return{...e,flags:{hasReferencedOpenAiAnyType:!1},currentPath:r,propertyPath:void 0,seen:new Map(Object.entries(e.definitions).map(([a,t])=>[t._def,{def:t._def,path:[...e.basePath,e.definitionPath,a],jsonSchema:void 0}]))}};function Ka(s,e,r,a){a?.errorMessages&&r&&(s.errorMessage={...s.errorMessage,[e]:r})}function se(s,e,r,a,t){s[e]=r,Ka(s,e,a,t)}var Ds=(s,e)=>{let r=0;for(;rX(s.innerType._def,e);function Ja(s,e,r){let a=r??e.dateStrategy;if(Array.isArray(a))return{anyOf:a.map((t,n)=>Ja(s,e,t))};switch(a){case"string":case"format:date-time":return{type:"string",format:"date-time"};case"format:date":return{type:"string",format:"date"};case"integer":return hh(s,e)}}var hh=(s,e)=>{let r={type:"integer",format:"unix-time"};if(e.target==="openApi3")return r;for(let a of s.checks)switch(a.kind){case"min":se(r,"minimum",a.value,a.message,e);break;case"max":se(r,"maximum",a.value,a.message,e);break}return r};function Jc(s,e){return{...X(s.innerType._def,e),default:s.defaultValue()}}function Yc(s,e){return e.effectStrategy==="input"?X(s.schema._def,e):me(e)}function el(s){return{type:"string",enum:Array.from(s.values)}}var mh=s=>"type"in s&&s.type==="string"?!1:"allOf"in s;function tl(s,e){let r=[X(s.left._def,{...e,currentPath:[...e.currentPath,"allOf","0"]}),X(s.right._def,{...e,currentPath:[...e.currentPath,"allOf","1"]})].filter(n=>!!n),a=e.target==="jsonSchema2019-09"?{unevaluatedProperties:!1}:void 0,t=[];return r.forEach(n=>{if(mh(n))t.push(...n.allOf),n.unevaluatedProperties===void 0&&(a=void 0);else{let i=n;if("additionalProperties"in n&&n.additionalProperties===!1){let{additionalProperties:o,...l}=n;i=l}else a=void 0;t.push(i)}}),t.length?{allOf:t,...a}:void 0}function rl(s,e){let r=typeof s.value;return r!=="bigint"&&r!=="number"&&r!=="boolean"&&r!=="string"?{type:Array.isArray(s.value)?"array":"object"}:e.target==="openApi3"?{type:r==="bigint"?"integer":r,enum:[s.value]}:{type:r==="bigint"?"integer":r,const:s.value}}var Ya,st={cuid:/^[cC][^\s-]{8,}$/,cuid2:/^[0-9a-z]+$/,ulid:/^[0-9A-HJKMNP-TV-Z]{26}$/,email:/^(?!\.)(?!.*\.\.)([a-zA-Z0-9_'+\-\.]*)[a-zA-Z0-9_+-]@([a-zA-Z0-9][a-zA-Z0-9\-]*\.)+[a-zA-Z]{2,}$/,emoji:()=>(Ya===void 0&&(Ya=RegExp("^(\\p{Extended_Pictographic}|\\p{Emoji_Component})+$","u")),Ya),uuid:/^[0-9a-fA-F]{8}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{12}$/,ipv4:/^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])$/,ipv4Cidr:/^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\/(3[0-2]|[12]?[0-9])$/,ipv6:/^(([a-f0-9]{1,4}:){7}|::([a-f0-9]{1,4}:){0,6}|([a-f0-9]{1,4}:){1}:([a-f0-9]{1,4}:){0,5}|([a-f0-9]{1,4}:){2}:([a-f0-9]{1,4}:){0,4}|([a-f0-9]{1,4}:){3}:([a-f0-9]{1,4}:){0,3}|([a-f0-9]{1,4}:){4}:([a-f0-9]{1,4}:){0,2}|([a-f0-9]{1,4}:){5}:([a-f0-9]{1,4}:){0,1})([a-f0-9]{1,4}|(((25[0-5])|(2[0-4][0-9])|(1[0-9]{2})|([0-9]{1,2}))\.){3}((25[0-5])|(2[0-4][0-9])|(1[0-9]{2})|([0-9]{1,2})))$/,ipv6Cidr:/^(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))\/(12[0-8]|1[01][0-9]|[1-9]?[0-9])$/,base64:/^([0-9a-zA-Z+/]{4})*(([0-9a-zA-Z+/]{2}==)|([0-9a-zA-Z+/]{3}=))?$/,base64url:/^([0-9a-zA-Z-_]{4})*(([0-9a-zA-Z-_]{2}(==)?)|([0-9a-zA-Z-_]{3}(=)?))?$/,nanoid:/^[a-zA-Z0-9_-]{21}$/,jwt:/^[A-Za-z0-9-_]+\.[A-Za-z0-9-_]+\.[A-Za-z0-9-_]*$/};function ks(s,e){let r={type:"string"};if(s.checks)for(let a of s.checks)switch(a.kind){case"min":se(r,"minLength",typeof r.minLength=="number"?Math.max(r.minLength,a.value):a.value,a.message,e);break;case"max":se(r,"maxLength",typeof r.maxLength=="number"?Math.min(r.maxLength,a.value):a.value,a.message,e);break;case"email":switch(e.emailStrategy){case"format:email":at(r,"email",a.message,e);break;case"format:idn-email":at(r,"idn-email",a.message,e);break;case"pattern:zod":Fe(r,st.email,a.message,e);break}break;case"url":at(r,"uri",a.message,e);break;case"uuid":at(r,"uuid",a.message,e);break;case"regex":Fe(r,a.regex,a.message,e);break;case"cuid":Fe(r,st.cuid,a.message,e);break;case"cuid2":Fe(r,st.cuid2,a.message,e);break;case"startsWith":Fe(r,RegExp(`^${en(a.value,e)}`),a.message,e);break;case"endsWith":Fe(r,RegExp(`${en(a.value,e)}$`),a.message,e);break;case"datetime":at(r,"date-time",a.message,e);break;case"date":at(r,"date",a.message,e);break;case"time":at(r,"time",a.message,e);break;case"duration":at(r,"duration",a.message,e);break;case"length":se(r,"minLength",typeof r.minLength=="number"?Math.max(r.minLength,a.value):a.value,a.message,e),se(r,"maxLength",typeof r.maxLength=="number"?Math.min(r.maxLength,a.value):a.value,a.message,e);break;case"includes":{Fe(r,RegExp(en(a.value,e)),a.message,e);break}case"ip":{a.version!=="v6"&&at(r,"ipv4",a.message,e),a.version!=="v4"&&at(r,"ipv6",a.message,e);break}case"base64url":Fe(r,st.base64url,a.message,e);break;case"jwt":Fe(r,st.jwt,a.message,e);break;case"cidr":{a.version!=="v6"&&Fe(r,st.ipv4Cidr,a.message,e),a.version!=="v4"&&Fe(r,st.ipv6Cidr,a.message,e);break}case"emoji":Fe(r,st.emoji(),a.message,e);break;case"ulid":{Fe(r,st.ulid,a.message,e);break}case"base64":{switch(e.base64Strategy){case"format:binary":{at(r,"binary",a.message,e);break}case"contentEncoding:base64":{se(r,"contentEncoding","base64",a.message,e);break}case"pattern:zod":{Fe(r,st.base64,a.message,e);break}}break}case"nanoid":Fe(r,st.nanoid,a.message,e);case"toLowerCase":case"toUpperCase":case"trim":break;default:}return r}function en(s,e){return e.patternStrategy==="escape"?gh(s):s}var vh=new Set("ABCDEFGHIJKLMNOPQRSTUVXYZabcdefghijklmnopqrstuvxyz0123456789");function gh(s){let e="";for(let r=0;rt.format)?(s.anyOf||(s.anyOf=[]),s.format&&(s.anyOf.push({format:s.format,...s.errorMessage&&a.errorMessages&&{errorMessage:{format:s.errorMessage.format}}}),delete s.format,s.errorMessage&&(delete s.errorMessage.format,Object.keys(s.errorMessage).length===0&&delete s.errorMessage)),s.anyOf.push({format:e,...r&&a.errorMessages&&{errorMessage:{format:r}}})):se(s,"format",e,r,a)}function Fe(s,e,r,a){s.pattern||s.allOf?.some(t=>t.pattern)?(s.allOf||(s.allOf=[]),s.pattern&&(s.allOf.push({pattern:s.pattern,...s.errorMessage&&a.errorMessages&&{errorMessage:{pattern:s.errorMessage.pattern}}}),delete s.pattern,s.errorMessage&&(delete s.errorMessage.pattern,Object.keys(s.errorMessage).length===0&&delete s.errorMessage)),s.allOf.push({pattern:sl(e,a),...r&&a.errorMessages&&{errorMessage:{pattern:r}}})):se(s,"pattern",sl(e,a),r,a)}function sl(s,e){if(!e.applyRegexFlags||!s.flags)return s.source;let r={i:s.flags.includes("i"),m:s.flags.includes("m"),s:s.flags.includes("s")},a=r.i?s.source.toLowerCase():s.source,t="",n=!1,i=!1,o=!1;for(let l=0;l({...a,[t]:X(s.valueType._def,{...e,currentPath:[...e.currentPath,"properties",t]})??me(e)}),{}),additionalProperties:e.rejectedAdditionalProperties};let r={type:"object",additionalProperties:X(s.valueType._def,{...e,currentPath:[...e.currentPath,"additionalProperties"]})??e.allowedAdditionalProperties};if(e.target==="openApi3")return r;if(s.keyType?._def.typeName===F.ZodString&&s.keyType._def.checks?.length){let{type:a,...t}=ks(s.keyType._def,e);return{...r,propertyNames:t}}else{if(s.keyType?._def.typeName===F.ZodEnum)return{...r,propertyNames:{enum:s.keyType._def.values}};if(s.keyType?._def.typeName===F.ZodBranded&&s.keyType._def.type._def.typeName===F.ZodString&&s.keyType._def.type._def.checks?.length){let{type:a,...t}=Cs(s.keyType._def,e);return{...r,propertyNames:t}}}return r}function al(s,e){if(e.mapStrategy==="record")return Ls(s,e);let r=X(s.keyType._def,{...e,currentPath:[...e.currentPath,"items","items","0"]})||me(e),a=X(s.valueType._def,{...e,currentPath:[...e.currentPath,"items","items","1"]})||me(e);return{type:"array",maxItems:125,items:{type:"array",items:[r,a],minItems:2,maxItems:2}}}function nl(s){let e=s.values,a=Object.keys(s.values).filter(n=>typeof e[e[n]]!="number").map(n=>e[n]),t=Array.from(new Set(a.map(n=>typeof n)));return{type:t.length===1?t[0]==="string"?"string":"number":["string","number"],enum:a}}function ol(s){return s.target==="openAi"?void 0:{not:me({...s,currentPath:[...s.currentPath,"not"]})}}function il(s){return s.target==="openApi3"?{enum:["null"],nullable:!0}:{type:"null"}}var Vr={ZodString:"string",ZodNumber:"number",ZodBigInt:"integer",ZodBoolean:"boolean",ZodNull:"null"};function ll(s,e){if(e.target==="openApi3")return cl(s,e);let r=s.options instanceof Map?Array.from(s.options.values()):s.options;if(r.every(a=>a._def.typeName in Vr&&(!a._def.checks||!a._def.checks.length))){let a=r.reduce((t,n)=>{let i=Vr[n._def.typeName];return i&&!t.includes(i)?[...t,i]:t},[]);return{type:a.length>1?a:a[0]}}else if(r.every(a=>a._def.typeName==="ZodLiteral"&&!a.description)){let a=r.reduce((t,n)=>{let i=typeof n._def.value;switch(i){case"string":case"number":case"boolean":return[...t,i];case"bigint":return[...t,"integer"];case"object":if(n._def.value===null)return[...t,"null"];case"symbol":case"undefined":case"function":default:return t}},[]);if(a.length===r.length){let t=a.filter((n,i,o)=>o.indexOf(n)===i);return{type:t.length>1?t:t[0],enum:r.reduce((n,i)=>n.includes(i._def.value)?n:[...n,i._def.value],[])}}}else if(r.every(a=>a._def.typeName==="ZodEnum"))return{type:"string",enum:r.reduce((a,t)=>[...a,...t._def.values.filter(n=>!a.includes(n))],[])};return cl(s,e)}var cl=(s,e)=>{let r=(s.options instanceof Map?Array.from(s.options.values()):s.options).map((a,t)=>X(a._def,{...e,currentPath:[...e.currentPath,"anyOf",`${t}`]})).filter(a=>!!a&&(!e.strictUnions||typeof a=="object"&&Object.keys(a).length>0));return r.length?{anyOf:r}:void 0};function ul(s,e){if(["ZodString","ZodNumber","ZodBigInt","ZodBoolean","ZodNull"].includes(s.innerType._def.typeName)&&(!s.innerType._def.checks||!s.innerType._def.checks.length))return e.target==="openApi3"?{type:Vr[s.innerType._def.typeName],nullable:!0}:{type:[Vr[s.innerType._def.typeName],"null"]};if(e.target==="openApi3"){let a=X(s.innerType._def,{...e,currentPath:[...e.currentPath]});return a&&"$ref"in a?{allOf:[a],nullable:!0}:a&&{...a,nullable:!0}}let r=X(s.innerType._def,{...e,currentPath:[...e.currentPath,"anyOf","0"]});return r&&{anyOf:[r,{type:"null"}]}}function dl(s,e){let r={type:"number"};if(!s.checks)return r;for(let a of s.checks)switch(a.kind){case"int":r.type="integer",Ka(r,"type",a.message,e);break;case"min":e.target==="jsonSchema7"?a.inclusive?se(r,"minimum",a.value,a.message,e):se(r,"exclusiveMinimum",a.value,a.message,e):(a.inclusive||(r.exclusiveMinimum=!0),se(r,"minimum",a.value,a.message,e));break;case"max":e.target==="jsonSchema7"?a.inclusive?se(r,"maximum",a.value,a.message,e):se(r,"exclusiveMaximum",a.value,a.message,e):(a.inclusive||(r.exclusiveMaximum=!0),se(r,"maximum",a.value,a.message,e));break;case"multipleOf":se(r,"multipleOf",a.value,a.message,e);break}return r}function pl(s,e){let r=e.target==="openAi",a={type:"object",properties:{}},t=[],n=s.shape();for(let o in n){let l=n[o];if(l===void 0||l._def===void 0)continue;let u=_h(l);u&&r&&(l._def.typeName==="ZodOptional"&&(l=l._def.innerType),l.isNullable()||(l=l.nullable()),u=!1);let d=X(l._def,{...e,currentPath:[...e.currentPath,"properties",o],propertyPath:[...e.currentPath,"properties",o]});d!==void 0&&(a.properties[o]=d,u||t.push(o))}t.length&&(a.required=t);let i=yh(s,e);return i!==void 0&&(a.additionalProperties=i),a}function yh(s,e){if(s.catchall._def.typeName!=="ZodNever")return X(s.catchall._def,{...e,currentPath:[...e.currentPath,"additionalProperties"]});switch(s.unknownKeys){case"passthrough":return e.allowedAdditionalProperties;case"strict":return e.rejectedAdditionalProperties;case"strip":return e.removeAdditionalStrategy==="strict"?e.allowedAdditionalProperties:e.rejectedAdditionalProperties}}function _h(s){try{return s.isOptional()}catch{return!0}}var fl=(s,e)=>{if(e.currentPath.toString()===e.propertyPath?.toString())return X(s.innerType._def,e);let r=X(s.innerType._def,{...e,currentPath:[...e.currentPath,"anyOf","1"]});return r?{anyOf:[{not:me(e)},r]}:me(e)};var hl=(s,e)=>{if(e.pipeStrategy==="input")return X(s.in._def,e);if(e.pipeStrategy==="output")return X(s.out._def,e);let r=X(s.in._def,{...e,currentPath:[...e.currentPath,"allOf","0"]}),a=X(s.out._def,{...e,currentPath:[...e.currentPath,"allOf",r?"1":"0"]});return{allOf:[r,a].filter(t=>t!==void 0)}};function ml(s,e){return X(s.type._def,e)}function vl(s,e){let a={type:"array",uniqueItems:!0,items:X(s.valueType._def,{...e,currentPath:[...e.currentPath,"items"]})};return s.minSize&&se(a,"minItems",s.minSize.value,s.minSize.message,e),s.maxSize&&se(a,"maxItems",s.maxSize.value,s.maxSize.message,e),a}function gl(s,e){return s.rest?{type:"array",minItems:s.items.length,items:s.items.map((r,a)=>X(r._def,{...e,currentPath:[...e.currentPath,"items",`${a}`]})).reduce((r,a)=>a===void 0?r:[...r,a],[]),additionalItems:X(s.rest._def,{...e,currentPath:[...e.currentPath,"additionalItems"]})}:{type:"array",minItems:s.items.length,maxItems:s.items.length,items:s.items.map((r,a)=>X(r._def,{...e,currentPath:[...e.currentPath,"items",`${a}`]})).reduce((r,a)=>a===void 0?r:[...r,a],[])}}function yl(s){return{not:me(s)}}function _l(s){return me(s)}var bl=(s,e)=>X(s.innerType._def,e);var El=(s,e,r)=>{switch(e){case F.ZodString:return ks(s,r);case F.ZodNumber:return dl(s,r);case F.ZodObject:return pl(s,r);case F.ZodBigInt:return Wc(s,r);case F.ZodBoolean:return Qc();case F.ZodDate:return Ja(s,r);case F.ZodUndefined:return yl(r);case F.ZodNull:return il(r);case F.ZodArray:return Xc(s,r);case F.ZodUnion:case F.ZodDiscriminatedUnion:return ll(s,r);case F.ZodIntersection:return tl(s,r);case F.ZodTuple:return gl(s,r);case F.ZodRecord:return Ls(s,r);case F.ZodLiteral:return rl(s,r);case F.ZodEnum:return el(s);case F.ZodNativeEnum:return nl(s);case F.ZodNullable:return ul(s,r);case F.ZodOptional:return fl(s,r);case F.ZodMap:return al(s,r);case F.ZodSet:return vl(s,r);case F.ZodLazy:return()=>s.getter()._def;case F.ZodPromise:return ml(s,r);case F.ZodNaN:case F.ZodNever:return ol(r);case F.ZodEffects:return Yc(s,r);case F.ZodAny:return me(r);case F.ZodUnknown:return _l(r);case F.ZodDefault:return Jc(s,r);case F.ZodBranded:return Cs(s,r);case F.ZodReadonly:return bl(s,r);case F.ZodCatch:return Kc(s,r);case F.ZodPipeline:return hl(s,r);case F.ZodFunction:case F.ZodVoid:case F.ZodSymbol:return;default:return(a=>{})(e)}};function X(s,e,r=!1){let a=e.seen.get(s);if(e.override){let o=e.override?.(s,e,a,r);if(o!==zc)return o}if(a&&!r){let o=bh(a,e);if(o!==void 0)return o}let t={def:s,path:e.currentPath,jsonSchema:void 0};e.seen.set(s,t);let n=El(s,s.typeName,e),i=typeof n=="function"?X(n(),e):n;if(i&&Eh(s,e,i),e.postProcess){let o=e.postProcess(i,s,e);return t.jsonSchema=i,o}return t.jsonSchema=i,i}var bh=(s,e)=>{switch(e.$refStrategy){case"root":return{$ref:s.path.join("/")};case"relative":return{$ref:Ds(e.currentPath,s.path)};case"none":case"seen":return s.path.lengthe.currentPath[a]===r)?(console.warn(`Recursive reference detected at ${e.currentPath.join("/")}! Defaulting to any`),me(e)):e.$refStrategy==="seen"?me(e):void 0}},Eh=(s,e,r)=>(s.description&&(r.description=s.description,e.markdownDescription&&(r.markdownDescription=s.description)),r);var tn=(s,e)=>{let r=Gc(e),a=typeof e=="object"&&e.definitions?Object.entries(e.definitions).reduce((l,[u,d])=>({...l,[u]:X(d._def,{...r,currentPath:[...r.basePath,r.definitionPath,u]},!0)??me(r)}),{}):void 0,t=typeof e=="string"?e:e?.nameStrategy==="title"?void 0:e?.name,n=X(s._def,t===void 0?r:{...r,currentPath:[...r.basePath,r.definitionPath,t]},!1)??me(r),i=typeof e=="object"&&e.name!==void 0&&e.nameStrategy==="title"?e.name:void 0;i!==void 0&&(n.title=i),r.flags.hasReferencedOpenAiAnyType&&(a||(a={}),a[r.openAiAnyTypeName]||(a[r.openAiAnyTypeName]={type:["string","number","integer","boolean","array","null"],items:{$ref:r.$refStrategy==="relative"?"1":[...r.basePath,r.definitionPath,r.openAiAnyTypeName].join("/")}}));let o=t===void 0?a?{...n,[r.definitionPath]:a}:n:{$ref:[...r.$refStrategy==="relative"?[]:r.basePath,r.definitionPath,t].join("/"),[r.definitionPath]:{...a,[t]:n}};return r.target==="jsonSchema7"?o.$schema="http://json-schema.org/draft-07/schema#":(r.target==="jsonSchema2019-09"||r.target==="openAi")&&(o.$schema="https://json-schema.org/draft/2019-09/schema#"),r.target==="openAi"&&("anyOf"in o||"oneOf"in o||"allOf"in o||"type"in o&&Array.isArray(o.type))&&console.warn("Warning: OpenAI may not support schemas with unions as roots! Try wrapping it in an object property."),o};var $l=require("path");var Rl=Ut(require("better-sqlite3"),1);var De=require("path"),rn=require("os"),sn=require("fs");var Sl=require("url"),xh={};function Sh(){return typeof __dirname<"u"?__dirname:(0,De.dirname)((0,Sl.fileURLToPath)(xh.url))}var I_=Sh(),nt=process.env.CLAUDE_MEM_DATA_DIR||(0,De.join)((0,rn.homedir)(),".claude-mem"),an=process.env.CLAUDE_CONFIG_DIR||(0,De.join)((0,rn.homedir)(),".claude"),N_=(0,De.join)(nt,"archives"),A_=(0,De.join)(nt,"logs"),$_=(0,De.join)(nt,"trash"),D_=(0,De.join)(nt,"backups"),C_=(0,De.join)(nt,"settings.json"),js=(0,De.join)(nt,"claude-mem.db"),xl=(0,De.join)(nt,"vector-db"),k_=(0,De.join)(an,"settings.json"),L_=(0,De.join)(an,"commands"),j_=(0,De.join)(an,"CLAUDE.md");function Fs(s){(0,sn.mkdirSync)(s,{recursive:!0})}var Ms=class{db;constructor(e){e||(Fs(nt),e=js),this.db=new Rl.default(e),this.db.pragma("journal_mode = WAL"),this.ensureFTSTables()}ensureFTSTables(){try{if(this.db.prepare("SELECT name FROM sqlite_master WHERE type='table' AND name LIKE '%_fts'").all().some(a=>a.name==="observations_fts"||a.name==="session_summaries_fts"))return;console.error("[SessionSearch] Creating FTS5 tables..."),this.db.exec(` + CREATE VIRTUAL TABLE IF NOT EXISTS observations_fts USING fts5( + title, + subtitle, + narrative, + text, + facts, + concepts, + content='observations', + content_rowid='id' + ); + `),this.db.exec(` + INSERT INTO observations_fts(rowid, title, subtitle, narrative, text, facts, concepts) + SELECT id, title, subtitle, narrative, text, facts, concepts + FROM observations; + `),this.db.exec(` + CREATE TRIGGER IF NOT EXISTS observations_ai AFTER INSERT ON observations BEGIN + INSERT INTO observations_fts(rowid, title, subtitle, narrative, text, facts, concepts) + VALUES (new.id, new.title, new.subtitle, new.narrative, new.text, new.facts, new.concepts); + END; + + CREATE TRIGGER IF NOT EXISTS observations_ad AFTER DELETE ON observations BEGIN + INSERT INTO observations_fts(observations_fts, rowid, title, subtitle, narrative, text, facts, concepts) + VALUES('delete', old.id, old.title, old.subtitle, old.narrative, old.text, old.facts, old.concepts); + END; + + CREATE TRIGGER IF NOT EXISTS observations_au AFTER UPDATE ON observations BEGIN + INSERT INTO observations_fts(observations_fts, rowid, title, subtitle, narrative, text, facts, concepts) + VALUES('delete', old.id, old.title, old.subtitle, old.narrative, old.text, old.facts, old.concepts); + INSERT INTO observations_fts(rowid, title, subtitle, narrative, text, facts, concepts) + VALUES (new.id, new.title, new.subtitle, new.narrative, new.text, new.facts, new.concepts); + END; + `),this.db.exec(` + CREATE VIRTUAL TABLE IF NOT EXISTS session_summaries_fts USING fts5( + request, + investigated, + learned, + completed, + next_steps, + notes, + content='session_summaries', + content_rowid='id' + ); + `),this.db.exec(` + INSERT INTO session_summaries_fts(rowid, request, investigated, learned, completed, next_steps, notes) + SELECT id, request, investigated, learned, completed, next_steps, notes + FROM session_summaries; + `),this.db.exec(` + CREATE TRIGGER IF NOT EXISTS session_summaries_ai AFTER INSERT ON session_summaries BEGIN + INSERT INTO session_summaries_fts(rowid, request, investigated, learned, completed, next_steps, notes) + VALUES (new.id, new.request, new.investigated, new.learned, new.completed, new.next_steps, new.notes); + END; + + CREATE TRIGGER IF NOT EXISTS session_summaries_ad AFTER DELETE ON session_summaries BEGIN + INSERT INTO session_summaries_fts(session_summaries_fts, rowid, request, investigated, learned, completed, next_steps, notes) + VALUES('delete', old.id, old.request, old.investigated, old.learned, old.completed, old.next_steps, old.notes); + END; + + CREATE TRIGGER IF NOT EXISTS session_summaries_au AFTER UPDATE ON session_summaries BEGIN + INSERT INTO session_summaries_fts(session_summaries_fts, rowid, request, investigated, learned, completed, next_steps, notes) + VALUES('delete', old.id, old.request, old.investigated, old.learned, old.completed, old.next_steps, old.notes); + INSERT INTO session_summaries_fts(rowid, request, investigated, learned, completed, next_steps, notes) + VALUES (new.id, new.request, new.investigated, new.learned, new.completed, new.next_steps, new.notes); + END; + `),console.error("[SessionSearch] FTS5 tables created successfully")}catch(e){console.error("[SessionSearch] FTS migration error:",e.message)}}buildFilterClause(e,r,a="o"){let t=[];if(e.project&&(t.push(`${a}.project = ?`),r.push(e.project)),e.type)if(Array.isArray(e.type)){let n=e.type.map(()=>"?").join(",");t.push(`${a}.type IN (${n})`),r.push(...e.type)}else t.push(`${a}.type = ?`),r.push(e.type);if(e.dateRange){let{start:n,end:i}=e.dateRange;if(n){let o=typeof n=="number"?n:new Date(n).getTime();t.push(`${a}.created_at_epoch >= ?`),r.push(o)}if(i){let o=typeof i=="number"?i:new Date(i).getTime();t.push(`${a}.created_at_epoch <= ?`),r.push(o)}}if(e.concepts){let n=Array.isArray(e.concepts)?e.concepts:[e.concepts],i=n.map(()=>`EXISTS (SELECT 1 FROM json_each(${a}.concepts) WHERE value = ?)`);i.length>0&&(t.push(`(${i.join(" OR ")})`),r.push(...n))}if(e.files){let n=Array.isArray(e.files)?e.files:[e.files],i=n.map(()=>`( + EXISTS (SELECT 1 FROM json_each(${a}.files_read) WHERE value LIKE ?) + OR EXISTS (SELECT 1 FROM json_each(${a}.files_modified) WHERE value LIKE ?) + )`);i.length>0&&(t.push(`(${i.join(" OR ")})`),n.forEach(o=>{r.push(`%${o}%`,`%${o}%`)}))}return t.length>0?t.join(" AND "):""}buildOrderClause(e="relevance",r=!0,a="observations_fts"){switch(e){case"relevance":return r?`ORDER BY ${a}.rank ASC`:"ORDER BY o.created_at_epoch DESC";case"date_desc":return"ORDER BY o.created_at_epoch DESC";case"date_asc":return"ORDER BY o.created_at_epoch ASC";default:return"ORDER BY o.created_at_epoch DESC"}}searchObservations(e,r={}){let a=[],{limit:t=50,offset:n=0,orderBy:i="relevance",...o}=r;if(!e){let l=this.buildFilterClause(o,a,"o");if(!l)throw new Error("Either query or filters required for search");let u=this.buildOrderClause(i,!1),d=` + SELECT o.*, o.discovery_tokens + FROM observations o + WHERE ${l} + ${u} + LIMIT ? OFFSET ? + `;return a.push(t,n),this.db.prepare(d).all(...a)}return console.warn("[SessionSearch] Text search not supported - use ChromaDB for vector search"),[]}searchSessions(e,r={}){let a=[],{limit:t=50,offset:n=0,orderBy:i="relevance",...o}=r;if(!e){let l={...o};delete l.type;let u=this.buildFilterClause(l,a,"s");if(!u)throw new Error("Either query or filters required for search");let f=` + SELECT s.*, s.discovery_tokens + FROM session_summaries s + WHERE ${u} + ${i==="date_asc"?"ORDER BY s.created_at_epoch ASC":"ORDER BY s.created_at_epoch DESC"} + LIMIT ? OFFSET ? + `;return a.push(t,n),this.db.prepare(f).all(...a)}return console.warn("[SessionSearch] Text search not supported - use ChromaDB for vector search"),[]}findByConcept(e,r={}){let a=[],{limit:t=50,offset:n=0,orderBy:i="date_desc",...o}=r,l={...o,concepts:e},u=this.buildFilterClause(l,a,"o"),d=this.buildOrderClause(i,!1),f=` + SELECT o.*, o.discovery_tokens + FROM observations o + WHERE ${u} + ${d} + LIMIT ? OFFSET ? + `;return a.push(t,n),this.db.prepare(f).all(...a)}findByFile(e,r={}){let a=[],{limit:t=50,offset:n=0,orderBy:i="date_desc",...o}=r,l={...o,files:e},u=this.buildFilterClause(l,a,"o"),d=this.buildOrderClause(i,!1),f=` + SELECT o.*, o.discovery_tokens + FROM observations o + WHERE ${u} + ${d} + LIMIT ? OFFSET ? + `;a.push(t,n);let h=this.db.prepare(f).all(...a),p=[],g={...o};delete g.type;let y=[];if(g.project&&(y.push("s.project = ?"),p.push(g.project)),g.dateRange){let{start:P,end:E}=g.dateRange;if(P){let R=typeof P=="number"?P:new Date(P).getTime();y.push("s.created_at_epoch >= ?"),p.push(R)}if(E){let R=typeof E=="number"?E:new Date(E).getTime();y.push("s.created_at_epoch <= ?"),p.push(R)}}y.push(`( + EXISTS (SELECT 1 FROM json_each(s.files_read) WHERE value LIKE ?) + OR EXISTS (SELECT 1 FROM json_each(s.files_edited) WHERE value LIKE ?) + )`),p.push(`%${e}%`,`%${e}%`);let v=` + SELECT s.*, s.discovery_tokens + FROM session_summaries s + WHERE ${y.join(" AND ")} + ORDER BY s.created_at_epoch DESC + LIMIT ? OFFSET ? + `;p.push(t,n);let x=this.db.prepare(v).all(...p);return{observations:h,sessions:x}}findByType(e,r={}){let a=[],{limit:t=50,offset:n=0,orderBy:i="date_desc",...o}=r,l={...o,type:e},u=this.buildFilterClause(l,a,"o"),d=this.buildOrderClause(i,!1),f=` + SELECT o.*, o.discovery_tokens + FROM observations o + WHERE ${u} + ${d} + LIMIT ? OFFSET ? + `;return a.push(t,n),this.db.prepare(f).all(...a)}searchUserPrompts(e,r={}){let a=[],{limit:t=20,offset:n=0,orderBy:i="relevance",...o}=r,l=[];if(o.project&&(l.push("s.project = ?"),a.push(o.project)),o.dateRange){let{start:u,end:d}=o.dateRange;if(u){let f=typeof u=="number"?u:new Date(u).getTime();l.push("up.created_at_epoch >= ?"),a.push(f)}if(d){let f=typeof d=="number"?d:new Date(d).getTime();l.push("up.created_at_epoch <= ?"),a.push(f)}}if(!e){if(l.length===0)throw new Error("Either query or filters required for search");let f=` + SELECT up.* + FROM user_prompts up + JOIN sdk_sessions s ON up.claude_session_id = s.claude_session_id + ${`WHERE ${l.join(" AND ")}`} + ${i==="date_asc"?"ORDER BY up.created_at_epoch ASC":"ORDER BY up.created_at_epoch DESC"} + LIMIT ? OFFSET ? + `;return a.push(t,n),this.db.prepare(f).all(...a)}return console.warn("[SessionSearch] Text search not supported - use ChromaDB for vector search"),[]}getUserPromptsBySession(e){return this.db.prepare(` + SELECT + id, + claude_session_id, + prompt_number, + prompt_text, + created_at, + created_at_epoch + FROM user_prompts + WHERE claude_session_id = ? + ORDER BY prompt_number ASC + `).all(e)}close(){this.db.close()}};var wl=Ut(require("better-sqlite3"),1);var nn=(n=>(n[n.DEBUG=0]="DEBUG",n[n.INFO=1]="INFO",n[n.WARN=2]="WARN",n[n.ERROR=3]="ERROR",n[n.SILENT=4]="SILENT",n))(nn||{}),on=class{level;useColor;constructor(){let e=process.env.CLAUDE_MEM_LOG_LEVEL?.toUpperCase()||"INFO";this.level=nn[e]??1,this.useColor=process.stdout.isTTY??!1}correlationId(e,r){return`obs-${e}-${r}`}sessionId(e){return`session-${e}`}formatData(e){if(e==null)return"";if(typeof e=="string")return e;if(typeof e=="number"||typeof e=="boolean")return e.toString();if(typeof e=="object"){if(e instanceof Error)return this.level===0?`${e.message} +${e.stack}`:e.message;if(Array.isArray(e))return`[${e.length} items]`;let r=Object.keys(e);return r.length===0?"{}":r.length<=3?JSON.stringify(e):`{${r.length} keys: ${r.slice(0,3).join(", ")}...}`}return String(e)}formatTool(e,r){if(!r)return e;try{let a=typeof r=="string"?JSON.parse(r):r;if(e==="Bash"&&a.command){let t=a.command.length>50?a.command.substring(0,50)+"...":a.command;return`${e}(${t})`}if(e==="Read"&&a.file_path){let t=a.file_path.split("/").pop()||a.file_path;return`${e}(${t})`}if(e==="Edit"&&a.file_path){let t=a.file_path.split("/").pop()||a.file_path;return`${e}(${t})`}if(e==="Write"&&a.file_path){let t=a.file_path.split("/").pop()||a.file_path;return`${e}(${t})`}return e}catch{return e}}log(e,r,a,t,n){if(e0&&(f=` {${Object.entries(v).map(([P,E])=>`${P}=${E}`).join(", ")}}`)}let h=`[${i}] [${o}] [${l}] ${u}${a}${f}${d}`;e===3?console.error(h):console.log(h)}debug(e,r,a,t){this.log(0,e,r,a,t)}info(e,r,a,t){this.log(1,e,r,a,t)}warn(e,r,a,t){this.log(2,e,r,a,t)}error(e,r,a,t){this.log(3,e,r,a,t)}dataIn(e,r,a,t){this.info(e,`\u2192 ${r}`,a,t)}dataOut(e,r,a,t){this.info(e,`\u2190 ${r}`,a,t)}success(e,r,a,t){this.info(e,`\u2713 ${r}`,a,t)}failure(e,r,a,t){this.error(e,`\u2717 ${r}`,a,t)}timing(e,r,a,t){this.info(e,`\u23F1 ${r}`,t,{duration:`${a}ms`})}},Tl=new on;var qs=class{db;constructor(){Fs(nt),this.db=new wl.default(js),this.db.pragma("journal_mode = WAL"),this.db.pragma("synchronous = NORMAL"),this.db.pragma("foreign_keys = ON"),this.initializeSchema(),this.ensureWorkerPortColumn(),this.ensurePromptTrackingColumns(),this.removeSessionSummariesUniqueConstraint(),this.addObservationHierarchicalFields(),this.makeObservationsTextNullable(),this.createUserPromptsTable(),this.ensureDiscoveryTokensColumn()}initializeSchema(){try{this.db.exec(` + CREATE TABLE IF NOT EXISTS schema_versions ( + id INTEGER PRIMARY KEY, + version INTEGER UNIQUE NOT NULL, + applied_at TEXT NOT NULL + ) + `);let e=this.db.prepare("SELECT version FROM schema_versions ORDER BY version").all();(e.length>0?Math.max(...e.map(a=>a.version)):0)===0&&(console.error("[SessionStore] Initializing fresh database with migration004..."),this.db.exec(` + CREATE TABLE IF NOT EXISTS sdk_sessions ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + claude_session_id TEXT UNIQUE NOT NULL, + sdk_session_id TEXT UNIQUE, + project TEXT NOT NULL, + user_prompt TEXT, + started_at TEXT NOT NULL, + started_at_epoch INTEGER NOT NULL, + completed_at TEXT, + completed_at_epoch INTEGER, + status TEXT CHECK(status IN ('active', 'completed', 'failed')) NOT NULL DEFAULT 'active' + ); + + CREATE INDEX IF NOT EXISTS idx_sdk_sessions_claude_id ON sdk_sessions(claude_session_id); + CREATE INDEX IF NOT EXISTS idx_sdk_sessions_sdk_id ON sdk_sessions(sdk_session_id); + CREATE INDEX IF NOT EXISTS idx_sdk_sessions_project ON sdk_sessions(project); + CREATE INDEX IF NOT EXISTS idx_sdk_sessions_status ON sdk_sessions(status); + CREATE INDEX IF NOT EXISTS idx_sdk_sessions_started ON sdk_sessions(started_at_epoch DESC); + + CREATE TABLE IF NOT EXISTS observations ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + sdk_session_id TEXT NOT NULL, + project TEXT NOT NULL, + text TEXT NOT NULL, + type TEXT NOT NULL CHECK(type IN ('decision', 'bugfix', 'feature', 'refactor', 'discovery')), + created_at TEXT NOT NULL, + created_at_epoch INTEGER NOT NULL, + FOREIGN KEY(sdk_session_id) REFERENCES sdk_sessions(sdk_session_id) ON DELETE CASCADE + ); + + CREATE INDEX IF NOT EXISTS idx_observations_sdk_session ON observations(sdk_session_id); + CREATE INDEX IF NOT EXISTS idx_observations_project ON observations(project); + CREATE INDEX IF NOT EXISTS idx_observations_type ON observations(type); + CREATE INDEX IF NOT EXISTS idx_observations_created ON observations(created_at_epoch DESC); + + CREATE TABLE IF NOT EXISTS session_summaries ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + sdk_session_id TEXT UNIQUE NOT NULL, + project TEXT NOT NULL, + request TEXT, + investigated TEXT, + learned TEXT, + completed TEXT, + next_steps TEXT, + files_read TEXT, + files_edited TEXT, + notes TEXT, + created_at TEXT NOT NULL, + created_at_epoch INTEGER NOT NULL, + FOREIGN KEY(sdk_session_id) REFERENCES sdk_sessions(sdk_session_id) ON DELETE CASCADE + ); + + CREATE INDEX IF NOT EXISTS idx_session_summaries_sdk_session ON session_summaries(sdk_session_id); + CREATE INDEX IF NOT EXISTS idx_session_summaries_project ON session_summaries(project); + CREATE INDEX IF NOT EXISTS idx_session_summaries_created ON session_summaries(created_at_epoch DESC); + `),this.db.prepare("INSERT INTO schema_versions (version, applied_at) VALUES (?, ?)").run(4,new Date().toISOString()),console.error("[SessionStore] Migration004 applied successfully"))}catch(e){throw console.error("[SessionStore] Schema initialization error:",e.message),e}}ensureWorkerPortColumn(){try{if(this.db.prepare("SELECT version FROM schema_versions WHERE version = ?").get(5))return;this.db.pragma("table_info(sdk_sessions)").some(t=>t.name==="worker_port")||(this.db.exec("ALTER TABLE sdk_sessions ADD COLUMN worker_port INTEGER"),console.error("[SessionStore] Added worker_port column to sdk_sessions table")),this.db.prepare("INSERT OR IGNORE INTO schema_versions (version, applied_at) VALUES (?, ?)").run(5,new Date().toISOString())}catch(e){console.error("[SessionStore] Migration error:",e.message)}}ensurePromptTrackingColumns(){try{if(this.db.prepare("SELECT version FROM schema_versions WHERE version = ?").get(6))return;this.db.pragma("table_info(sdk_sessions)").some(l=>l.name==="prompt_counter")||(this.db.exec("ALTER TABLE sdk_sessions ADD COLUMN prompt_counter INTEGER DEFAULT 0"),console.error("[SessionStore] Added prompt_counter column to sdk_sessions table")),this.db.pragma("table_info(observations)").some(l=>l.name==="prompt_number")||(this.db.exec("ALTER TABLE observations ADD COLUMN prompt_number INTEGER"),console.error("[SessionStore] Added prompt_number column to observations table")),this.db.pragma("table_info(session_summaries)").some(l=>l.name==="prompt_number")||(this.db.exec("ALTER TABLE session_summaries ADD COLUMN prompt_number INTEGER"),console.error("[SessionStore] Added prompt_number column to session_summaries table")),this.db.prepare("INSERT OR IGNORE INTO schema_versions (version, applied_at) VALUES (?, ?)").run(6,new Date().toISOString())}catch(e){console.error("[SessionStore] Prompt tracking migration error:",e.message)}}removeSessionSummariesUniqueConstraint(){try{if(this.db.prepare("SELECT version FROM schema_versions WHERE version = ?").get(7))return;if(!this.db.pragma("index_list(session_summaries)").some(t=>t.unique===1)){this.db.prepare("INSERT OR IGNORE INTO schema_versions (version, applied_at) VALUES (?, ?)").run(7,new Date().toISOString());return}console.error("[SessionStore] Removing UNIQUE constraint from session_summaries.sdk_session_id..."),this.db.exec("BEGIN TRANSACTION");try{this.db.exec(` + CREATE TABLE session_summaries_new ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + sdk_session_id TEXT NOT NULL, + project TEXT NOT NULL, + request TEXT, + investigated TEXT, + learned TEXT, + completed TEXT, + next_steps TEXT, + files_read TEXT, + files_edited TEXT, + notes TEXT, + prompt_number INTEGER, + created_at TEXT NOT NULL, + created_at_epoch INTEGER NOT NULL, + FOREIGN KEY(sdk_session_id) REFERENCES sdk_sessions(sdk_session_id) ON DELETE CASCADE + ) + `),this.db.exec(` + INSERT INTO session_summaries_new + SELECT id, sdk_session_id, project, request, investigated, learned, + completed, next_steps, files_read, files_edited, notes, + prompt_number, created_at, created_at_epoch + FROM session_summaries + `),this.db.exec("DROP TABLE session_summaries"),this.db.exec("ALTER TABLE session_summaries_new RENAME TO session_summaries"),this.db.exec(` + CREATE INDEX idx_session_summaries_sdk_session ON session_summaries(sdk_session_id); + CREATE INDEX idx_session_summaries_project ON session_summaries(project); + CREATE INDEX idx_session_summaries_created ON session_summaries(created_at_epoch DESC); + `),this.db.exec("COMMIT"),this.db.prepare("INSERT OR IGNORE INTO schema_versions (version, applied_at) VALUES (?, ?)").run(7,new Date().toISOString()),console.error("[SessionStore] Successfully removed UNIQUE constraint from session_summaries.sdk_session_id")}catch(t){throw this.db.exec("ROLLBACK"),t}}catch(e){console.error("[SessionStore] Migration error (remove UNIQUE constraint):",e.message)}}addObservationHierarchicalFields(){try{if(this.db.prepare("SELECT version FROM schema_versions WHERE version = ?").get(8))return;if(this.db.pragma("table_info(observations)").some(t=>t.name==="title")){this.db.prepare("INSERT OR IGNORE INTO schema_versions (version, applied_at) VALUES (?, ?)").run(8,new Date().toISOString());return}console.error("[SessionStore] Adding hierarchical fields to observations table..."),this.db.exec(` + ALTER TABLE observations ADD COLUMN title TEXT; + ALTER TABLE observations ADD COLUMN subtitle TEXT; + ALTER TABLE observations ADD COLUMN facts TEXT; + ALTER TABLE observations ADD COLUMN narrative TEXT; + ALTER TABLE observations ADD COLUMN concepts TEXT; + ALTER TABLE observations ADD COLUMN files_read TEXT; + ALTER TABLE observations ADD COLUMN files_modified TEXT; + `),this.db.prepare("INSERT OR IGNORE INTO schema_versions (version, applied_at) VALUES (?, ?)").run(8,new Date().toISOString()),console.error("[SessionStore] Successfully added hierarchical fields to observations table")}catch(e){console.error("[SessionStore] Migration error (add hierarchical fields):",e.message)}}makeObservationsTextNullable(){try{if(this.db.prepare("SELECT version FROM schema_versions WHERE version = ?").get(9))return;let a=this.db.pragma("table_info(observations)").find(t=>t.name==="text");if(!a||a.notnull===0){this.db.prepare("INSERT OR IGNORE INTO schema_versions (version, applied_at) VALUES (?, ?)").run(9,new Date().toISOString());return}console.error("[SessionStore] Making observations.text nullable..."),this.db.exec("BEGIN TRANSACTION");try{this.db.exec(` + CREATE TABLE observations_new ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + sdk_session_id TEXT NOT NULL, + project TEXT NOT NULL, + text TEXT, + type TEXT NOT NULL CHECK(type IN ('decision', 'bugfix', 'feature', 'refactor', 'discovery', 'change')), + title TEXT, + subtitle TEXT, + facts TEXT, + narrative TEXT, + concepts TEXT, + files_read TEXT, + files_modified TEXT, + prompt_number INTEGER, + created_at TEXT NOT NULL, + created_at_epoch INTEGER NOT NULL, + FOREIGN KEY(sdk_session_id) REFERENCES sdk_sessions(sdk_session_id) ON DELETE CASCADE + ) + `),this.db.exec(` + INSERT INTO observations_new + SELECT id, sdk_session_id, project, text, type, title, subtitle, facts, + narrative, concepts, files_read, files_modified, prompt_number, + created_at, created_at_epoch + FROM observations + `),this.db.exec("DROP TABLE observations"),this.db.exec("ALTER TABLE observations_new RENAME TO observations"),this.db.exec(` + CREATE INDEX idx_observations_sdk_session ON observations(sdk_session_id); + CREATE INDEX idx_observations_project ON observations(project); + CREATE INDEX idx_observations_type ON observations(type); + CREATE INDEX idx_observations_created ON observations(created_at_epoch DESC); + `),this.db.exec("COMMIT"),this.db.prepare("INSERT OR IGNORE INTO schema_versions (version, applied_at) VALUES (?, ?)").run(9,new Date().toISOString()),console.error("[SessionStore] Successfully made observations.text nullable")}catch(t){throw this.db.exec("ROLLBACK"),t}}catch(e){console.error("[SessionStore] Migration error (make text nullable):",e.message)}}createUserPromptsTable(){try{if(this.db.prepare("SELECT version FROM schema_versions WHERE version = ?").get(10))return;if(this.db.pragma("table_info(user_prompts)").length>0){this.db.prepare("INSERT OR IGNORE INTO schema_versions (version, applied_at) VALUES (?, ?)").run(10,new Date().toISOString());return}console.error("[SessionStore] Creating user_prompts table with FTS5 support..."),this.db.exec("BEGIN TRANSACTION");try{this.db.exec(` + CREATE TABLE user_prompts ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + claude_session_id TEXT NOT NULL, + prompt_number INTEGER NOT NULL, + prompt_text TEXT NOT NULL, + created_at TEXT NOT NULL, + created_at_epoch INTEGER NOT NULL, + FOREIGN KEY(claude_session_id) REFERENCES sdk_sessions(claude_session_id) ON DELETE CASCADE + ); + + CREATE INDEX idx_user_prompts_claude_session ON user_prompts(claude_session_id); + CREATE INDEX idx_user_prompts_created ON user_prompts(created_at_epoch DESC); + CREATE INDEX idx_user_prompts_prompt_number ON user_prompts(prompt_number); + CREATE INDEX idx_user_prompts_lookup ON user_prompts(claude_session_id, prompt_number); + `),this.db.exec(` + CREATE VIRTUAL TABLE user_prompts_fts USING fts5( + prompt_text, + content='user_prompts', + content_rowid='id' + ); + `),this.db.exec(` + CREATE TRIGGER user_prompts_ai AFTER INSERT ON user_prompts BEGIN + INSERT INTO user_prompts_fts(rowid, prompt_text) + VALUES (new.id, new.prompt_text); + END; + + CREATE TRIGGER user_prompts_ad AFTER DELETE ON user_prompts BEGIN + INSERT INTO user_prompts_fts(user_prompts_fts, rowid, prompt_text) + VALUES('delete', old.id, old.prompt_text); + END; + + CREATE TRIGGER user_prompts_au AFTER UPDATE ON user_prompts BEGIN + INSERT INTO user_prompts_fts(user_prompts_fts, rowid, prompt_text) + VALUES('delete', old.id, old.prompt_text); + INSERT INTO user_prompts_fts(rowid, prompt_text) + VALUES (new.id, new.prompt_text); + END; + `),this.db.exec("COMMIT"),this.db.prepare("INSERT OR IGNORE INTO schema_versions (version, applied_at) VALUES (?, ?)").run(10,new Date().toISOString()),console.error("[SessionStore] Successfully created user_prompts table with FTS5 support")}catch(a){throw this.db.exec("ROLLBACK"),a}}catch(e){console.error("[SessionStore] Migration error (create user_prompts table):",e.message)}}ensureDiscoveryTokensColumn(){try{if(this.db.prepare("SELECT version FROM schema_versions WHERE version = ?").get(11))return;this.db.pragma("table_info(observations)").some(i=>i.name==="discovery_tokens")||(this.db.exec("ALTER TABLE observations ADD COLUMN discovery_tokens INTEGER DEFAULT 0"),console.error("[SessionStore] Added discovery_tokens column to observations table")),this.db.pragma("table_info(session_summaries)").some(i=>i.name==="discovery_tokens")||(this.db.exec("ALTER TABLE session_summaries ADD COLUMN discovery_tokens INTEGER DEFAULT 0"),console.error("[SessionStore] Added discovery_tokens column to session_summaries table")),this.db.prepare("INSERT OR IGNORE INTO schema_versions (version, applied_at) VALUES (?, ?)").run(11,new Date().toISOString())}catch(e){throw console.error("[SessionStore] Discovery tokens migration error:",e.message),e}}getRecentSummaries(e,r=10){return this.db.prepare(` + SELECT + request, investigated, learned, completed, next_steps, + files_read, files_edited, notes, prompt_number, created_at + FROM session_summaries + WHERE project = ? + ORDER BY created_at_epoch DESC + LIMIT ? + `).all(e,r)}getRecentSummariesWithSessionInfo(e,r=3){return this.db.prepare(` + SELECT + sdk_session_id, request, learned, completed, next_steps, + prompt_number, created_at + FROM session_summaries + WHERE project = ? + ORDER BY created_at_epoch DESC + LIMIT ? + `).all(e,r)}getRecentObservations(e,r=20){return this.db.prepare(` + SELECT type, text, prompt_number, created_at + FROM observations + WHERE project = ? + ORDER BY created_at_epoch DESC + LIMIT ? + `).all(e,r)}getAllRecentObservations(e=100){return this.db.prepare(` + SELECT id, type, title, subtitle, text, project, prompt_number, created_at, created_at_epoch + FROM observations + ORDER BY created_at_epoch DESC + LIMIT ? + `).all(e)}getAllRecentSummaries(e=50){return this.db.prepare(` + SELECT id, request, investigated, learned, completed, next_steps, + files_read, files_edited, notes, project, prompt_number, + created_at, created_at_epoch + FROM session_summaries + ORDER BY created_at_epoch DESC + LIMIT ? + `).all(e)}getAllRecentUserPrompts(e=100){return this.db.prepare(` + SELECT + up.id, + up.claude_session_id, + s.project, + up.prompt_number, + up.prompt_text, + up.created_at, + up.created_at_epoch + FROM user_prompts up + LEFT JOIN sdk_sessions s ON up.claude_session_id = s.claude_session_id + ORDER BY up.created_at_epoch DESC + LIMIT ? + `).all(e)}getAllProjects(){return this.db.prepare(` + SELECT DISTINCT project + FROM sdk_sessions + WHERE project IS NOT NULL AND project != '' + ORDER BY project ASC + `).all().map(a=>a.project)}getRecentSessionsWithStatus(e,r=3){return this.db.prepare(` + SELECT * FROM ( + SELECT + s.sdk_session_id, + s.status, + s.started_at, + s.started_at_epoch, + s.user_prompt, + CASE WHEN sum.sdk_session_id IS NOT NULL THEN 1 ELSE 0 END as has_summary + FROM sdk_sessions s + LEFT JOIN session_summaries sum ON s.sdk_session_id = sum.sdk_session_id + WHERE s.project = ? AND s.sdk_session_id IS NOT NULL + GROUP BY s.sdk_session_id + ORDER BY s.started_at_epoch DESC + LIMIT ? + ) + ORDER BY started_at_epoch ASC + `).all(e,r)}getObservationsForSession(e){return this.db.prepare(` + SELECT title, subtitle, type, prompt_number + FROM observations + WHERE sdk_session_id = ? + ORDER BY created_at_epoch ASC + `).all(e)}getObservationById(e){return this.db.prepare(` + SELECT * + FROM observations + WHERE id = ? + `).get(e)||null}getObservationsByIds(e,r={}){if(e.length===0)return[];let{orderBy:a="date_desc",limit:t}=r,n=a==="date_asc"?"ASC":"DESC",i=t?`LIMIT ${t}`:"",o=e.map(()=>"?").join(",");return this.db.prepare(` + SELECT * + FROM observations + WHERE id IN (${o}) + ORDER BY created_at_epoch ${n} + ${i} + `).all(...e)}getSummaryForSession(e){return this.db.prepare(` + SELECT + request, investigated, learned, completed, next_steps, + files_read, files_edited, notes, prompt_number, created_at + FROM session_summaries + WHERE sdk_session_id = ? + ORDER BY created_at_epoch DESC + LIMIT 1 + `).get(e)||null}getFilesForSession(e){let a=this.db.prepare(` + SELECT files_read, files_modified + FROM observations + WHERE sdk_session_id = ? + `).all(e),t=new Set,n=new Set;for(let i of a){if(i.files_read)try{let o=JSON.parse(i.files_read);Array.isArray(o)&&o.forEach(l=>t.add(l))}catch{}if(i.files_modified)try{let o=JSON.parse(i.files_modified);Array.isArray(o)&&o.forEach(l=>n.add(l))}catch{}}return{filesRead:Array.from(t),filesModified:Array.from(n)}}getSessionById(e){return this.db.prepare(` + SELECT id, claude_session_id, sdk_session_id, project, user_prompt + FROM sdk_sessions + WHERE id = ? + LIMIT 1 + `).get(e)||null}findActiveSDKSession(e){return this.db.prepare(` + SELECT id, sdk_session_id, project, worker_port + FROM sdk_sessions + WHERE claude_session_id = ? AND status = 'active' + LIMIT 1 + `).get(e)||null}findAnySDKSession(e){return this.db.prepare(` + SELECT id + FROM sdk_sessions + WHERE claude_session_id = ? + LIMIT 1 + `).get(e)||null}reactivateSession(e,r){this.db.prepare(` + UPDATE sdk_sessions + SET status = 'active', user_prompt = ?, worker_port = NULL + WHERE id = ? + `).run(r,e)}incrementPromptCounter(e){return this.db.prepare(` + UPDATE sdk_sessions + SET prompt_counter = COALESCE(prompt_counter, 0) + 1 + WHERE id = ? + `).run(e),this.db.prepare(` + SELECT prompt_counter FROM sdk_sessions WHERE id = ? + `).get(e)?.prompt_counter||1}getPromptCounter(e){return this.db.prepare(` + SELECT prompt_counter FROM sdk_sessions WHERE id = ? + `).get(e)?.prompt_counter||0}createSDKSession(e,r,a){let t=new Date,n=t.getTime(),o=this.db.prepare(` + INSERT OR IGNORE INTO sdk_sessions + (claude_session_id, sdk_session_id, project, user_prompt, started_at, started_at_epoch, status) + VALUES (?, ?, ?, ?, ?, ?, 'active') + `).run(e,e,r,a,t.toISOString(),n);return o.lastInsertRowid===0||o.changes===0?(r&&r.trim()!==""&&this.db.prepare(` + UPDATE sdk_sessions + SET project = ?, user_prompt = ? + WHERE claude_session_id = ? + `).run(r,a,e),this.db.prepare(` + SELECT id FROM sdk_sessions WHERE claude_session_id = ? LIMIT 1 + `).get(e).id):o.lastInsertRowid}updateSDKSessionId(e,r){return this.db.prepare(` + UPDATE sdk_sessions + SET sdk_session_id = ? + WHERE id = ? AND sdk_session_id IS NULL + `).run(r,e).changes===0?(Tl.debug("DB","sdk_session_id already set, skipping update",{sessionId:e,sdkSessionId:r}),!1):!0}setWorkerPort(e,r){this.db.prepare(` + UPDATE sdk_sessions + SET worker_port = ? + WHERE id = ? + `).run(r,e)}getWorkerPort(e){return this.db.prepare(` + SELECT worker_port + FROM sdk_sessions + WHERE id = ? + LIMIT 1 + `).get(e)?.worker_port||null}saveUserPrompt(e,r,a){let t=new Date,n=t.getTime();return this.db.prepare(` + INSERT INTO user_prompts + (claude_session_id, prompt_number, prompt_text, created_at, created_at_epoch) + VALUES (?, ?, ?, ?, ?) + `).run(e,r,a,t.toISOString(),n).lastInsertRowid}getUserPrompt(e,r){return this.db.prepare(` + SELECT prompt_text + FROM user_prompts + WHERE claude_session_id = ? AND prompt_number = ? + LIMIT 1 + `).get(e,r)?.prompt_text??null}storeObservation(e,r,a,t,n=0){let i=new Date,o=i.getTime();this.db.prepare(` + SELECT id FROM sdk_sessions WHERE sdk_session_id = ? + `).get(e)||(this.db.prepare(` + INSERT INTO sdk_sessions + (claude_session_id, sdk_session_id, project, started_at, started_at_epoch, status) + VALUES (?, ?, ?, ?, ?, 'active') + `).run(e,e,r,i.toISOString(),o),console.error(`[SessionStore] Auto-created session record for session_id: ${e}`));let f=this.db.prepare(` + INSERT INTO observations + (sdk_session_id, project, type, title, subtitle, facts, narrative, concepts, + files_read, files_modified, prompt_number, discovery_tokens, created_at, created_at_epoch) + VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?) + `).run(e,r,a.type,a.title,a.subtitle,JSON.stringify(a.facts),a.narrative,JSON.stringify(a.concepts),JSON.stringify(a.files_read),JSON.stringify(a.files_modified),t||null,n,i.toISOString(),o);return{id:Number(f.lastInsertRowid),createdAtEpoch:o}}storeSummary(e,r,a,t,n=0){let i=new Date,o=i.getTime();this.db.prepare(` + SELECT id FROM sdk_sessions WHERE sdk_session_id = ? + `).get(e)||(this.db.prepare(` + INSERT INTO sdk_sessions + (claude_session_id, sdk_session_id, project, started_at, started_at_epoch, status) + VALUES (?, ?, ?, ?, ?, 'active') + `).run(e,e,r,i.toISOString(),o),console.error(`[SessionStore] Auto-created session record for session_id: ${e}`));let f=this.db.prepare(` + INSERT INTO session_summaries + (sdk_session_id, project, request, investigated, learned, completed, + next_steps, notes, prompt_number, discovery_tokens, created_at, created_at_epoch) + VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?) + `).run(e,r,a.request,a.investigated,a.learned,a.completed,a.next_steps,a.notes,t||null,n,i.toISOString(),o);return{id:Number(f.lastInsertRowid),createdAtEpoch:o}}markSessionCompleted(e){let r=new Date,a=r.getTime();this.db.prepare(` + UPDATE sdk_sessions + SET status = 'completed', completed_at = ?, completed_at_epoch = ? + WHERE id = ? + `).run(r.toISOString(),a,e)}markSessionFailed(e){let r=new Date,a=r.getTime();this.db.prepare(` + UPDATE sdk_sessions + SET status = 'failed', completed_at = ?, completed_at_epoch = ? + WHERE id = ? + `).run(r.toISOString(),a,e)}getSessionSummariesByIds(e,r={}){if(e.length===0)return[];let{orderBy:a="date_desc",limit:t}=r,n=a==="date_asc"?"ASC":"DESC",i=t?`LIMIT ${t}`:"",o=e.map(()=>"?").join(",");return this.db.prepare(` + SELECT * FROM session_summaries + WHERE id IN (${o}) + ORDER BY created_at_epoch ${n} + ${i} + `).all(...e)}getUserPromptsByIds(e,r={}){if(e.length===0)return[];let{orderBy:a="date_desc",limit:t}=r,n=a==="date_asc"?"ASC":"DESC",i=t?`LIMIT ${t}`:"",o=e.map(()=>"?").join(",");return this.db.prepare(` + SELECT + up.*, + s.project, + s.sdk_session_id + FROM user_prompts up + JOIN sdk_sessions s ON up.claude_session_id = s.claude_session_id + WHERE up.id IN (${o}) + ORDER BY up.created_at_epoch ${n} + ${i} + `).all(...e)}getTimelineAroundTimestamp(e,r=10,a=10,t){return this.getTimelineAroundObservation(null,e,r,a,t)}getTimelineAroundObservation(e,r,a=10,t=10,n){let i=n?"AND project = ?":"",o=n?[n]:[],l,u;if(e!==null){let p=` + SELECT id, created_at_epoch + FROM observations + WHERE id <= ? ${i} + ORDER BY id DESC + LIMIT ? + `,g=` + SELECT id, created_at_epoch + FROM observations + WHERE id >= ? ${i} + ORDER BY id ASC + LIMIT ? + `;try{let y=this.db.prepare(p).all(e,...o,a+1),v=this.db.prepare(g).all(e,...o,t+1);if(y.length===0&&v.length===0)return{observations:[],sessions:[],prompts:[]};l=y.length>0?y[y.length-1].created_at_epoch:r,u=v.length>0?v[v.length-1].created_at_epoch:r}catch(y){return console.error("[SessionStore] Error getting boundary observations:",y.message),{observations:[],sessions:[],prompts:[]}}}else{let p=` + SELECT created_at_epoch + FROM observations + WHERE created_at_epoch <= ? ${i} + ORDER BY created_at_epoch DESC + LIMIT ? + `,g=` + SELECT created_at_epoch + FROM observations + WHERE created_at_epoch >= ? ${i} + ORDER BY created_at_epoch ASC + LIMIT ? + `;try{let y=this.db.prepare(p).all(r,...o,a),v=this.db.prepare(g).all(r,...o,t+1);if(y.length===0&&v.length===0)return{observations:[],sessions:[],prompts:[]};l=y.length>0?y[y.length-1].created_at_epoch:r,u=v.length>0?v[v.length-1].created_at_epoch:r}catch(y){return console.error("[SessionStore] Error getting boundary timestamps:",y.message),{observations:[],sessions:[],prompts:[]}}}let d=` + SELECT * + FROM observations + WHERE created_at_epoch >= ? AND created_at_epoch <= ? ${i} + ORDER BY created_at_epoch ASC + `,f=` + SELECT * + FROM session_summaries + WHERE created_at_epoch >= ? AND created_at_epoch <= ? ${i} + ORDER BY created_at_epoch ASC + `,h=` + SELECT up.*, s.project, s.sdk_session_id + FROM user_prompts up + JOIN sdk_sessions s ON up.claude_session_id = s.claude_session_id + WHERE up.created_at_epoch >= ? AND up.created_at_epoch <= ? ${i.replace("project","s.project")} + ORDER BY up.created_at_epoch ASC + `;try{let p=this.db.prepare(d).all(l,u,...o),g=this.db.prepare(f).all(l,u,...o),y=this.db.prepare(h).all(l,u,...o);return{observations:p,sessions:g.map(v=>({id:v.id,sdk_session_id:v.sdk_session_id,project:v.project,request:v.request,completed:v.completed,next_steps:v.next_steps,created_at:v.created_at,created_at_epoch:v.created_at_epoch})),prompts:y.map(v=>({id:v.id,claude_session_id:v.claude_session_id,project:v.project,prompt:v.prompt_text,created_at:v.created_at,created_at_epoch:v.created_at_epoch}))}}catch(p){return console.error("[SessionStore] Error querying timeline records:",p.message),{observations:[],sessions:[],prompts:[]}}}close(){this.db.close()}};var Ol=require("fs"),Pl=require("os"),Il=require("path"),Rh=(0,Il.join)((0,Pl.homedir)(),".claude-mem","silent.log");function q(s,e,r=""){let a=new Date().toISOString(),o=((new Error().stack||"").split(` +`)[2]||"").match(/at\s+(?:.*\s+)?\(?([^:]+):(\d+):(\d+)\)?/),l=o?`${o[1].split("/").pop()}:${o[2]}`:"unknown",u=`[${a}] [${l}] ${s}`;if(e!==void 0)try{u+=` ${JSON.stringify(e)}`}catch(d){u+=` [stringify error: ${d}]`}u+=` +`;try{(0,Ol.appendFileSync)(Rh,u)}catch(d){console.error("[silent-debug] Failed to write to log:",d)}return r}var be,oe,Oe=null,Th="cm__claude-mem";try{be=new Ms,oe=new qs}catch(s){q("[search-server] Failed to initialize search:",s.message),process.exit(1)}async function Ze(s,e,r){if(!Oe)throw new Error("Chroma client not initialized");q("queryChroma called",{query:s,limit:e,whereFilter:r});let a=r?JSON.stringify(r):void 0;q("where filter stringified",{whereFilter:r,whereStringified:a});let t={collection_name:Th,query_texts:[s],n_results:e,include:["documents","metadatas","distances"],where:a};q("calling chroma_query_documents",t);let n=await Oe.callTool({name:"chroma_query_documents",arguments:t}),i=n.content[0]?.text||"";q("chroma response received",{hasContent:!!n.content[0]?.text,textLength:i.length,textPreview:i.substring(0,200)});let o;try{o=JSON.parse(i)}catch(h){return q("[search-server] Failed to parse Chroma response as JSON:",h),q("[search-server] Raw Chroma response:",i),{ids:[],distances:[],metadatas:[]}}let l=[],u=o.ids?.[0]||[];for(let h of u){let p=h.match(/obs_(\d+)_/),g=h.match(/summary_(\d+)_/),y=h.match(/prompt_(\d+)/),v=null;p?v=parseInt(p[1],10):g?v=parseInt(g[1],10):y&&(v=parseInt(y[1],10)),v!==null&&!l.includes(v)&&l.push(v)}let d=o.distances?.[0]||[],f=o.metadatas?.[0]||[];return{ids:l,distances:d,metadatas:f}}function or(){return` +--- +\u{1F4A1} Search Strategy: +ALWAYS search with index format FIRST to get an overview and identify relevant results. +This is critical for token efficiency - index format uses ~10x fewer tokens than full format. + +Search workflow: +1. Initial search: Use default (index) format to see titles, dates, and sources +2. Review results: Identify which items are most relevant to your needs +3. Deep dive: Only then use format: "full" on specific items of interest +4. Narrow down: Use filters (type, dateStart/dateEnd, concepts, files) to refine results + +Other tips: +\u2022 To search by concept: Use find_by_concept tool +\u2022 To browse by type: Use find_by_type with ["decision", "feature", etc.] +\u2022 To sort by date: Use orderBy: "date_desc" or "date_asc"`}function cn(s,e,r,a,t){if(s.length===0)return s;let n=-1;if(typeof e=="number")n=s.findIndex(l=>l.type==="observation"&&l.data.id===e);else if(typeof e=="string"&&e.startsWith("S")){let l=parseInt(e.slice(1),10);n=s.findIndex(u=>u.type==="session"&&u.data.id===l)}else n=s.findIndex(l=>l.epoch>=r),n===-1&&(n=s.length-1);if(n===-1)return s;let i=Math.max(0,n-a),o=Math.min(s.length,n+t+1);return s.slice(i,o)}function Dt(s,e){let r=s.title||`Observation #${s.id}`,a=new Date(s.created_at_epoch).toLocaleString(),t=s.type?`[${s.type}]`:"";return`${e+1}. ${t} ${r} + Date: ${a} + Source: claude-mem://observation/${s.id}`}function ln(s,e){let r=s.request||`Session ${s.sdk_session_id?.substring(0,8)||"unknown"}`,a=new Date(s.created_at_epoch).toLocaleString();return`${e+1}. ${r} + Date: ${a} + Source: claude-mem://session/${s.sdk_session_id}`}function Ct(s){let e=s.title||`Observation #${s.id}`,r=[];r.push(`## ${e}`),r.push(`*Source: claude-mem://observation/${s.id}*`),r.push(""),s.subtitle&&(r.push(`**${s.subtitle}**`),r.push("")),s.narrative&&(r.push(s.narrative),r.push("")),s.text&&(r.push(s.text),r.push(""));let a=[];if(a.push(`Type: ${s.type}`),s.facts)try{let n=JSON.parse(s.facts);n.length>0&&a.push(`Facts: ${n.join("; ")}`)}catch{}if(s.concepts)try{let n=JSON.parse(s.concepts);n.length>0&&a.push(`Concepts: ${n.join(", ")}`)}catch{}if(s.files_read||s.files_modified){let n=[];if(s.files_read)try{n.push(...JSON.parse(s.files_read))}catch{}if(s.files_modified)try{n.push(...JSON.parse(s.files_modified))}catch{}n.length>0&&a.push(`Files: ${[...new Set(n)].join(", ")}`)}a.length>0&&(r.push("---"),r.push(a.join(" | ")));let t=new Date(s.created_at_epoch).toLocaleString();return r.push(""),r.push("---"),r.push(`Date: ${t}`),r.join(` +`)}function un(s){let e=s.request||`Session ${s.sdk_session_id?.substring(0,8)||"unknown"}`,r=[];r.push(`## ${e}`),r.push(`*Source: claude-mem://session/${s.sdk_session_id}*`),r.push(""),s.completed&&(r.push(`**Completed:** ${s.completed}`),r.push("")),s.learned&&(r.push(`**Learned:** ${s.learned}`),r.push("")),s.investigated&&(r.push(`**Investigated:** ${s.investigated}`),r.push("")),s.next_steps&&(r.push(`**Next Steps:** ${s.next_steps}`),r.push("")),s.notes&&(r.push(`**Notes:** ${s.notes}`),r.push(""));let a=[];if(s.files_read||s.files_edited){let n=[];if(s.files_read)try{n.push(...JSON.parse(s.files_read))}catch{}if(s.files_edited)try{n.push(...JSON.parse(s.files_edited))}catch{}n.length>0&&a.push(`Files: ${[...new Set(n)].join(", ")}`)}let t=new Date(s.created_at_epoch).toLocaleDateString();return a.push(`Date: ${t}`),a.length>0&&(r.push("---"),r.push(a.join(" | "))),r.join(` +`)}function Nl(s,e){let r=new Date(s.created_at_epoch).toLocaleString();return`${e+1}. "${s.prompt_text}" + Date: ${r} | Prompt #${s.prompt_number} + Source: claude-mem://user-prompt/${s.id}`}function Al(s){let e=[];e.push(`## User Prompt #${s.prompt_number}`),e.push(`*Source: claude-mem://user-prompt/${s.id}*`),e.push(""),e.push(s.prompt_text),e.push(""),e.push("---");let r=new Date(s.created_at_epoch).toLocaleString();return e.push(`Date: ${r}`),e.join(` +`)}function ft(s){let e={...s};return e.concepts&&typeof e.concepts=="string"&&(e.concepts=e.concepts.split(",").map(r=>r.trim()).filter(Boolean)),e.files&&typeof e.files=="string"&&(e.files=e.files.split(",").map(r=>r.trim()).filter(Boolean)),e.obs_type&&typeof e.obs_type=="string"&&(e.obs_type=e.obs_type.split(",").map(r=>r.trim()).filter(Boolean)),e.type&&typeof e.type=="string"&&e.type.includes(",")&&(e.type=e.type.split(",").map(r=>r.trim()).filter(Boolean)),(e.dateStart||e.dateEnd)&&(e.dateRange={start:e.dateStart,end:e.dateEnd},delete e.dateStart,delete e.dateEnd),e}var wh=c.object({project:c.string().optional().describe("Filter by project name"),type:c.union([c.enum(["decision","bugfix","feature","refactor","discovery","change"]),c.array(c.enum(["decision","bugfix","feature","refactor","discovery","change"]))]).optional().describe("Filter by observation type (single value or comma-separated list)"),concepts:c.union([c.string(),c.array(c.string())]).optional().describe("Filter by concept tags (single value or comma-separated list)"),files:c.union([c.string(),c.array(c.string())]).optional().describe("Filter by file paths (single value or comma-separated list for partial match)"),dateStart:c.union([c.string(),c.number()]).optional().describe("Start date (ISO string or epoch)"),dateEnd:c.union([c.string(),c.number()]).optional().describe("End date (ISO string or epoch)"),dateRange:c.object({start:c.union([c.string(),c.number()]).optional().describe("Start date (ISO string or epoch)"),end:c.union([c.string(),c.number()]).optional().describe("End date (ISO string or epoch)")}).optional().describe("Filter by date range (use dateStart/dateEnd instead for simpler URLs)"),limit:c.number().min(1).max(100).default(20).describe("Maximum number of results"),offset:c.number().min(0).default(0).describe("Number of results to skip"),orderBy:c.enum(["relevance","date_desc","date_asc"]).default("date_desc").describe("Sort order")}),Dl=[{name:"search",description:'Unified search across all memory types (observations, sessions, and user prompts) using vector-first semantic search (ChromaDB). Returns combined results from all document types. IMPORTANT: Always use index format first (default) to get an overview with minimal token usage, then use format: "full" only for specific items of interest.',inputSchema:c.object({query:c.string().optional().describe("Natural language search query for semantic ranking via ChromaDB vector search. Optional - omit for date-filtered queries only (Chroma cannot filter by date, requires direct SQLite)."),format:c.enum(["index","full"]).default("index").describe('Output format: "index" for titles/dates only (default, RECOMMENDED for initial search), "full" for complete details (use only after reviewing index results)'),type:c.enum(["observations","sessions","prompts"]).optional().describe("Filter by document type (observations, sessions, or prompts). Omit to search all types."),obs_type:c.string().optional().describe('Filter observations by type (single value or comma-separated list: decision,bugfix,feature,refactor,discovery,change). Only applies when type="observations"'),concepts:c.string().optional().describe('Filter by concept tags (single value or comma-separated list). Only applies when type="observations"'),files:c.string().optional().describe('Filter by file paths (single value or comma-separated list for partial match). Only applies when type="observations"'),project:c.string().optional().describe("Filter by project name"),dateStart:c.union([c.string(),c.number()]).optional().describe("Start date for filtering (ISO string or epoch timestamp)"),dateEnd:c.union([c.string(),c.number()]).optional().describe("End date for filtering (ISO string or epoch timestamp)"),limit:c.number().min(1).max(100).default(20).describe("Maximum number of results"),offset:c.number().min(0).default(0).describe("Number of results to skip"),orderBy:c.enum(["relevance","date_desc","date_asc"]).default("date_desc").describe("Sort order")}),handler:async s=>{try{let e=ft(s),{query:r,format:a="index",type:t,obs_type:n,concepts:i,files:o,...l}=e,u=[],d=[],f=[],h=!t||t==="observations",p=!t||t==="sessions",g=!t||t==="prompts";if(r)if(Oe){let E=!1;try{q(`[search-server] Using ChromaDB semantic search (type filter: ${t||"all"})`);let R;t==="observations"?R={doc_type:"observation"}:t==="sessions"?R={doc_type:"session_summary"}:t==="prompts"&&(R={doc_type:"user_prompt"});let T=await Ze(r,100,R);if(E=!0,q(`[search-server] ChromaDB returned ${T.ids.length} semantic matches`),T.ids.length>0){let S=Date.now()-7776e6,I=T.metadatas.map((C,k)=>({id:T.ids[k],meta:C,isRecent:C&&C.created_at_epoch>S})).filter(C=>C.isRecent);q(`[search-server] ${I.length} results within 90-day window`);let D=[],$=[],L=[];for(let C of I){let k=C.meta?.doc_type;k==="observation"&&h?D.push(C.id):k==="session_summary"&&p?$.push(C.id):k==="user_prompt"&&g&&L.push(C.id)}if(q(`[search-server] Categorized: ${D.length} obs, ${$.length} sessions, ${L.length} prompts`),D.length>0){let C={...l,type:n,concepts:i,files:o};u=oe.getObservationsByIds(D,C)}$.length>0&&(d=oe.getSessionSummariesByIds($,{orderBy:"date_desc",limit:l.limit})),L.length>0&&(f=oe.getUserPromptsByIds(L,{orderBy:"date_desc",limit:l.limit})),q(`[search-server] Hydrated ${u.length} obs, ${d.length} sessions, ${f.length} prompts from SQLite`)}else q("[search-server] ChromaDB found no matches (this is final - NOT falling back to FTS5)")}catch(R){q("[search-server] ChromaDB failed - returning empty results (FTS5 fallback removed):",R.message),q("[search-server] Install UVX/Python to enable vector search: https://docs.astral.sh/uv/getting-started/installation/"),u=[],d=[],f=[]}}else q("[search-server] ChromaDB not initialized - returning empty results (FTS5 fallback removed)"),q("[search-server] Install UVX/Python to enable vector search: https://docs.astral.sh/uv/getting-started/installation/"),u=[],d=[],f=[];else{q("[search-server] Filter-only query (no query text), using direct SQLite filtering (enables date filters)");let E={...l,type:n,concepts:i,files:o};h&&(u=be.searchObservations(void 0,E)),p&&(d=be.searchSessions(void 0,l)),g&&(f=be.searchUserPrompts(void 0,l))}let y=u.length+d.length+f.length;if(y===0)return{content:[{type:"text",text:`No results found matching "${r}"`}]};let v=[...u.map(E=>({type:"observation",data:E,epoch:E.created_at_epoch})),...d.map(E=>({type:"session",data:E,epoch:E.created_at_epoch})),...f.map(E=>({type:"prompt",data:E,epoch:E.created_at_epoch}))];l.orderBy==="date_desc"?v.sort((E,R)=>R.epoch-E.epoch):l.orderBy==="date_asc"&&v.sort((E,R)=>E.epoch-R.epoch);let x=v.slice(0,l.limit||20),P;if(a==="index"){let E=`Found ${y} result(s) matching "${r}" (${u.length} obs, ${d.length} sessions, ${f.length} prompts): + +`,R=x.map((T,S)=>T.type==="observation"?Dt(T.data,S):T.type==="session"?ln(T.data,S):Nl(T.data,S));P=E+R.join(` + +`)+or()}else P=x.map(R=>R.type==="observation"?Ct(R.data):R.type==="session"?un(R.data):Al(R.data)).join(` + +--- + +`);return{content:[{type:"text",text:P}]}}catch(e){return{content:[{type:"text",text:`Search failed: ${e.message}`}],isError:!0}}}},{name:"timeline",description:"Get a unified timeline of context around a specific point in time OR search query. Supports two modes: (1) anchor-based: provide observation ID, session ID, or timestamp to center timeline around; (2) query-based: provide natural language query to find relevant observation and center timeline around it. All record types (observations, sessions, prompts) are interleaved chronologically.",inputSchema:c.object({anchor:c.union([c.number(),c.string()]).optional().describe('Anchor point: observation ID (number), session ID (e.g., "S123"), or ISO timestamp. Use this OR query, not both.'),query:c.string().optional().describe("Natural language search query to find relevant observation as anchor. Use this OR anchor, not both."),depth_before:c.number().min(0).max(50).default(10).describe("Number of records to retrieve before anchor (default: 10)"),depth_after:c.number().min(0).max(50).default(10).describe("Number of records to retrieve after anchor (default: 10)"),project:c.string().optional().describe("Filter by project name")}),handler:async s=>{try{let y=function(S){return new Date(S).toLocaleString("en-US",{month:"short",day:"numeric",year:"numeric"})},v=function(S){return new Date(S).toLocaleString("en-US",{hour:"numeric",minute:"2-digit",hour12:!0})},x=function(S){return new Date(S).toLocaleString("en-US",{month:"short",day:"numeric",hour:"numeric",minute:"2-digit",hour12:!0})},P=function(S){return S?Math.ceil(S.length/4):0};var e=y,r=v,a=x,t=P;let{anchor:n,query:i,depth_before:o=10,depth_after:l=10,project:u}=s;if(!n&&!i)return{content:[{type:"text",text:'Error: Must provide either "anchor" or "query" parameter'}],isError:!0};if(n&&i)return{content:[{type:"text",text:'Error: Cannot provide both "anchor" and "query" parameters. Use one or the other.'}],isError:!0};let d,f,h;if(i){let S=[];if(Oe)try{q("[search-server] Using hybrid semantic search for timeline query");let D=await Ze(i,100);if(q(`[search-server] Chroma returned ${D.ids.length} semantic matches`),D.ids.length>0){let $=Date.now()-7776e6,L=D.ids.filter((C,k)=>{let N=D.metadatas[k];return N&&N.created_at_epoch>$});L.length>0&&(S=oe.getObservationsByIds(L,{orderBy:"date_desc",limit:1}))}}catch(D){q("[search-server] Chroma query failed - no results (FTS5 fallback removed):",D.message)}if(S.length===0)return{content:[{type:"text",text:`No observations found matching "${i}". Try a different search query.`}]};let I=S[0];d=I.id,f=I.created_at_epoch,q(`[search-server] Query mode: Using observation #${I.id} as timeline anchor`),h=oe.getTimelineAroundObservation(I.id,I.created_at_epoch,o,l,u)}else if(typeof n=="number"){let S=oe.getObservationById(n);if(!S)return{content:[{type:"text",text:`Observation #${n} not found`}],isError:!0};d=n,f=S.created_at_epoch,h=oe.getTimelineAroundObservation(n,f,o,l,u)}else if(typeof n=="string")if(n.startsWith("S")||n.startsWith("#S")){let S=n.replace(/^#?S/,""),I=parseInt(S,10),D=oe.getSessionSummariesByIds([I]);if(D.length===0)return{content:[{type:"text",text:`Session #${I} not found`}],isError:!0};f=D[0].created_at_epoch,d=`S${I}`,h=oe.getTimelineAroundTimestamp(f,o,l,u)}else{let S=new Date(n);if(isNaN(S.getTime()))return{content:[{type:"text",text:`Invalid timestamp: ${n}`}],isError:!0};f=S.getTime(),d=n,h=oe.getTimelineAroundTimestamp(f,o,l,u)}else return{content:[{type:"text",text:'Invalid anchor: must be observation ID (number), session ID (e.g., "S123"), or ISO timestamp'}],isError:!0};let p=[...h.observations.map(S=>({type:"observation",data:S,epoch:S.created_at_epoch})),...h.sessions.map(S=>({type:"session",data:S,epoch:S.created_at_epoch})),...h.prompts.map(S=>({type:"prompt",data:S,epoch:S.created_at_epoch}))];p.sort((S,I)=>S.epoch-I.epoch);let g=cn(p,d,f,o,l);if(g.length===0)return{content:[{type:"text",text:i?`Found observation matching "${i}", but no timeline context available (${o} records before, ${l} records after).`:`No context found around anchor (${o} records before, ${l} records after)`}]};let E=[];if(i){let S=g.find(D=>D.type==="observation"&&D.data.id===d),I=S?S.data.title||"Untitled":"Unknown";E.push(`# Timeline for query: "${i}"`),E.push(`**Anchor:** Observation #${d} - ${I}`)}else E.push(`# Timeline around anchor: ${d}`);E.push(`**Window:** ${o} records before \u2192 ${l} records after | **Items:** ${g.length}`),E.push(""),E.push("**Legend:** \u{1F3AF} session-request | \u{1F534} bugfix | \u{1F7E3} feature | \u{1F504} refactor | \u2705 change | \u{1F535} discovery | \u{1F9E0} decision"),E.push("");let R=new Map;for(let S of g){let I=y(S.epoch);R.has(I)||R.set(I,[]),R.get(I).push(S)}let T=Array.from(R.entries()).sort((S,I)=>{let D=new Date(S[0]).getTime(),$=new Date(I[0]).getTime();return D-$});for(let[S,I]of T){E.push(`### ${S}`),E.push("");let D=null,$="",L=!1;for(let C of I){let k=typeof d=="number"&&C.type==="observation"&&C.data.id===d||typeof d=="string"&&d.startsWith("S")&&C.type==="session"&&`S${C.data.id}`===d;if(C.type==="session"){L&&(E.push(""),L=!1,D=null,$="");let N=C.data,A=N.request||"Session summary",M=`claude-mem://session-summary/${N.id}`,W=k?" \u2190 **ANCHOR**":"";E.push(`**\u{1F3AF} #S${N.id}** ${A} (${x(C.epoch)}) [\u2192](${M})${W}`),E.push("")}else if(C.type==="prompt"){L&&(E.push(""),L=!1,D=null,$="");let N=C.data,A=N.prompt.length>100?N.prompt.substring(0,100)+"...":N.prompt;E.push(`**\u{1F4AC} User Prompt #${N.prompt_number}** (${x(C.epoch)})`),E.push(`> ${A}`),E.push("")}else if(C.type==="observation"){let N=C.data,A="General";A!==D&&(L&&E.push(""),E.push(`**${A}**`),E.push("| ID | Time | T | Title | Tokens |"),E.push("|----|------|---|-------|--------|"),D=A,L=!0,$="");let M="\u2022";switch(N.type){case"bugfix":M="\u{1F534}";break;case"feature":M="\u{1F7E3}";break;case"refactor":M="\u{1F504}";break;case"change":M="\u2705";break;case"discovery":M="\u{1F535}";break;case"decision":M="\u{1F9E0}";break}let W=v(C.epoch),Q=N.title||"Untitled",te=P(N.narrative),Z=W!==$?W:"\u2033";$=W;let fe=k?" \u2190 **ANCHOR**":"";E.push(`| #${N.id} | ${Z} | ${M} | ${Q}${fe} | ~${te} |`)}}L&&E.push("")}return{content:[{type:"text",text:E.join(` +`)}]}}catch(n){return{content:[{type:"text",text:`Timeline query failed: ${n.message}`}],isError:!0}}}},{name:"decisions",description:"Semantic shortcut to find decision-type observations. Returns observations where important architectural, technical, or process decisions were made. Supports optional semantic search query to filter decisions by relevance.",inputSchema:c.object({query:c.string().optional().describe("Search query to filter decisions semantically"),format:c.enum(["index","full"]).default("index").describe('Output format: "index" for titles/dates only (default), "full" for complete details'),project:c.string().optional().describe("Filter by project name"),dateStart:c.union([c.string(),c.number()]).optional().describe("Start date for filtering (ISO string or epoch timestamp)"),dateEnd:c.union([c.string(),c.number()]).optional().describe("End date for filtering (ISO string or epoch timestamp)"),limit:c.number().min(1).max(100).default(20).describe("Maximum number of results"),offset:c.number().min(0).default(0).describe("Number of results to skip"),orderBy:c.enum(["relevance","date_desc","date_asc"]).default("date_desc").describe("Sort order")}),handler:async s=>{try{let e=ft(s),{query:r,format:a="index",...t}=e,n=[];if(Oe)try{if(r){q("[search-server] Using Chroma semantic search with type=decision filter");let l=(await Ze(r,Math.min((t.limit||20)*2,100),{type:"decision"})).ids;l.length>0&&(n=oe.getObservationsByIds(l,{...t,type:"decision"}),n.sort((u,d)=>l.indexOf(u.id)-l.indexOf(d.id)))}else{q("[search-server] Using metadata-first + semantic ranking for decisions");let o=be.findByType("decision",t);if(o.length>0){let l=o.map(f=>f.id),u=await Ze("decision",Math.min(l.length,100)),d=[];for(let f of u.ids)l.includes(f)&&!d.includes(f)&&d.push(f);d.length>0&&(n=oe.getObservationsByIds(d,{limit:t.limit||20}),n.sort((f,h)=>d.indexOf(f.id)-d.indexOf(h.id)))}}}catch(o){q("[search-server] Chroma search failed, using SQLite fallback:",o.message)}if(n.length===0&&(n=be.findByType("decision",t)),n.length===0)return{content:[{type:"text",text:"No decision observations found"}]};let i;if(a==="index"){let o=`Found ${n.length} decision(s): + +`,l=n.map((u,d)=>Dt(u,d));i=o+l.join(` + +`)}else i=n.map(l=>Ct(l)).join(` + +--- + +`);return{content:[{type:"text",text:i}]}}catch(e){return{content:[{type:"text",text:`Search failed: ${e.message}`}],isError:!0}}}},{name:"changes",description:'Semantic shortcut to find change-related observations. Returns observations documenting what changed in the codebase, system behavior, or project state. Searches for type="change" OR concept="change" OR concept="what-changed".',inputSchema:c.object({format:c.enum(["index","full"]).default("index").describe('Output format: "index" for titles/dates only (default), "full" for complete details'),project:c.string().optional().describe("Filter by project name"),dateStart:c.union([c.string(),c.number()]).optional().describe("Start date for filtering (ISO string or epoch timestamp)"),dateEnd:c.union([c.string(),c.number()]).optional().describe("End date for filtering (ISO string or epoch timestamp)"),limit:c.number().min(1).max(100).default(20).describe("Maximum number of results"),offset:c.number().min(0).default(0).describe("Number of results to skip"),orderBy:c.enum(["relevance","date_desc","date_asc"]).default("date_desc").describe("Sort order")}),handler:async s=>{try{let e=ft(s),{format:r="index",...a}=e,t=[];if(Oe)try{q("[search-server] Using hybrid search for change-related observations");let i=be.findByType("change",a),o=be.findByConcept("change",a),l=be.findByConcept("what-changed",a),u=new Set;if([...i,...o,...l].forEach(d=>u.add(d.id)),u.size>0){let d=Array.from(u),f=await Ze("what changed",Math.min(d.length,100)),h=[];for(let p of f.ids)d.includes(p)&&!h.includes(p)&&h.push(p);h.length>0&&(t=oe.getObservationsByIds(h,{limit:a.limit||20}),t.sort((p,g)=>h.indexOf(p.id)-h.indexOf(g.id)))}}catch(i){q("[search-server] Chroma ranking failed, using SQLite order:",i.message)}if(t.length===0){let i=be.findByType("change",a),o=be.findByConcept("change",a),l=be.findByConcept("what-changed",a),u=new Set;[...i,...o,...l].forEach(d=>u.add(d.id)),t=Array.from(u).map(d=>i.find(f=>f.id===d)||o.find(f=>f.id===d)||l.find(f=>f.id===d)).filter(Boolean),t.sort((d,f)=>f.created_at_epoch-d.created_at_epoch),t=t.slice(0,a.limit||20)}if(t.length===0)return{content:[{type:"text",text:"No change-related observations found"}]};let n;if(r==="index"){let i=`Found ${t.length} change-related observation(s): + +`,o=t.map((l,u)=>Dt(l,u));n=i+o.join(` + +`)}else n=t.map(o=>Ct(o)).join(` + +--- + +`);return{content:[{type:"text",text:n}]}}catch(e){return{content:[{type:"text",text:`Search failed: ${e.message}`}],isError:!0}}}},{name:"how_it_works",description:'Semantic shortcut to find "how it works" explanations. Returns observations documenting system architecture, component interactions, data flow, and technical mechanisms. Searches for concept="how-it-works".',inputSchema:c.object({format:c.enum(["index","full"]).default("index").describe('Output format: "index" for titles/dates only (default), "full" for complete details'),project:c.string().optional().describe("Filter by project name"),dateStart:c.union([c.string(),c.number()]).optional().describe("Start date for filtering (ISO string or epoch timestamp)"),dateEnd:c.union([c.string(),c.number()]).optional().describe("End date for filtering (ISO string or epoch timestamp)"),limit:c.number().min(1).max(100).default(20).describe("Maximum number of results"),offset:c.number().min(0).default(0).describe("Number of results to skip"),orderBy:c.enum(["relevance","date_desc","date_asc"]).default("date_desc").describe("Sort order")}),handler:async s=>{try{let e=ft(s),{format:r="index",...a}=e,t=[];if(Oe)try{q("[search-server] Using metadata-first + semantic ranking for how-it-works");let i=be.findByConcept("how-it-works",a);if(i.length>0){let o=i.map(d=>d.id),l=await Ze("how it works architecture",Math.min(o.length,100)),u=[];for(let d of l.ids)o.includes(d)&&!u.includes(d)&&u.push(d);u.length>0&&(t=oe.getObservationsByIds(u,{limit:a.limit||20}),t.sort((d,f)=>u.indexOf(d.id)-u.indexOf(f.id)))}}catch(i){q("[search-server] Chroma ranking failed, using SQLite order:",i.message)}if(t.length===0&&(t=be.findByConcept("how-it-works",a)),t.length===0)return{content:[{type:"text",text:'No "how it works" observations found'}]};let n;if(r==="index"){let i=`Found ${t.length} "how it works" observation(s): + +`,o=t.map((l,u)=>Dt(l,u));n=i+o.join(` + +`)}else n=t.map(o=>Ct(o)).join(` + +--- + +`);return{content:[{type:"text",text:n}]}}catch(e){return{content:[{type:"text",text:`Search failed: ${e.message}`}],isError:!0}}}},{name:"search_observations",description:'DEPRECATED: Use the unified "search" tool instead. Search observations using vector-first semantic search (ChromaDB). IMPORTANT: Always use index format first (default) to get an overview with minimal token usage, then use format: "full" only for specific items of interest.',inputSchema:c.object({query:c.string().describe("Natural language search query for semantic ranking via ChromaDB vector search"),format:c.enum(["index","full"]).default("index").describe('Output format: "index" for titles/dates only (default, RECOMMENDED for initial search), "full" for complete details (use only after reviewing index results)'),...wh.shape}),handler:async s=>{try{let e=ft(s),{query:r,format:a="index",...t}=e,n=[];if(Oe)try{q("[search-server] Using hybrid semantic search (Chroma + SQLite)");let o=await Ze(r,100);if(q(`[search-server] Chroma returned ${o.ids.length} semantic matches`),o.ids.length>0){let l=Date.now()-7776e6,u=o.ids.filter((d,f)=>{let h=o.metadatas[f];return h&&h.created_at_epoch>l});if(q(`[search-server] ${u.length} results within 90-day window`),u.length>0){let d=t.limit||20;n=oe.getObservationsByIds(u,{orderBy:"date_desc",limit:d}),q(`[search-server] Hydrated ${n.length} observations from SQLite`)}}}catch(o){q("[search-server] Chroma query failed - no results (FTS5 fallback removed):",o.message)}if(n.length===0)return{content:[{type:"text",text:`No observations found matching "${r}"`}]};let i;if(a==="index"){let o=`Found ${n.length} observation(s) matching "${r}": + +`,l=n.map((u,d)=>Dt(u,d));i=o+l.join(` + +`)+or()}else i=n.map(l=>Ct(l)).join(` + +--- + +`);return{content:[{type:"text",text:i}]}}catch(e){return{content:[{type:"text",text:`Search failed: ${e.message}`}],isError:!0}}}},{name:"search_sessions",description:'DEPRECATED: Use the unified "search" tool instead. Search session summaries using vector-first semantic search (ChromaDB). IMPORTANT: Always use index format first (default) to get an overview with minimal token usage, then use format: "full" only for specific items of interest.',inputSchema:c.object({query:c.string().describe("Natural language search query for semantic ranking via ChromaDB vector search"),format:c.enum(["index","full"]).default("index").describe('Output format: "index" for titles/dates only (default, RECOMMENDED for initial search), "full" for complete details (use only after reviewing index results)'),project:c.string().optional().describe("Filter by project name"),dateStart:c.union([c.string(),c.number()]).optional().describe("Start date for filtering (ISO string or epoch timestamp)"),dateEnd:c.union([c.string(),c.number()]).optional().describe("End date for filtering (ISO string or epoch timestamp)"),limit:c.number().min(1).max(100).default(20).describe("Maximum number of results"),offset:c.number().min(0).default(0).describe("Number of results to skip"),orderBy:c.enum(["relevance","date_desc","date_asc"]).default("date_desc").describe("Sort order")}),handler:async s=>{try{let e=ft(s),{query:r,format:a="index",...t}=e,n=[];if(Oe)try{q("[search-server] Using hybrid semantic search for sessions");let o=await Ze(r,100,{doc_type:"session_summary"});if(q(`[search-server] Chroma returned ${o.ids.length} semantic matches`),o.ids.length>0){let l=Date.now()-7776e6,u=o.ids.filter((d,f)=>{let h=o.metadatas[f];return h&&h.created_at_epoch>l});if(q(`[search-server] ${u.length} results within 90-day window`),u.length>0){let d=t.limit||20;n=oe.getSessionSummariesByIds(u,{orderBy:"date_desc",limit:d}),q(`[search-server] Hydrated ${n.length} sessions from SQLite`)}}}catch(o){q("[search-server] Chroma query failed - no results (FTS5 fallback removed):",o.message)}if(n.length===0)return{content:[{type:"text",text:`No sessions found matching "${r}"`}]};let i;if(a==="index"){let o=`Found ${n.length} session(s) matching "${r}": + +`,l=n.map((u,d)=>ln(u,d));i=o+l.join(` + +`)+or()}else i=n.map(l=>un(l)).join(` + +--- + +`);return{content:[{type:"text",text:i}]}}catch(e){return{content:[{type:"text",text:`Search failed: ${e.message}`}],isError:!0}}}},{name:"find_by_concept",description:'Find observations tagged with a specific concept. Available concepts: "discovery", "problem-solution", "what-changed", "how-it-works", "pattern", "gotcha", "change". IMPORTANT: Always use index format first (default) to get an overview with minimal token usage, then use format: "full" only for specific items of interest.',inputSchema:c.object({concept:c.string().describe("Concept tag to search for. Available: discovery, problem-solution, what-changed, how-it-works, pattern, gotcha, change"),format:c.enum(["index","full"]).default("index").describe('Output format: "index" for titles/dates only (default, RECOMMENDED for initial search), "full" for complete details (use only after reviewing index results)'),project:c.string().optional().describe("Filter by project name"),dateStart:c.union([c.string(),c.number()]).optional().describe("Start date for filtering (ISO string or epoch timestamp)"),dateEnd:c.union([c.string(),c.number()]).optional().describe("End date for filtering (ISO string or epoch timestamp)"),limit:c.number().min(1).max(100).default(20).describe("Maximum results. IMPORTANT: Start with 3-5 to avoid exceeding MCP token limits, even in index mode."),offset:c.number().min(0).default(0).describe("Number of results to skip"),orderBy:c.enum(["relevance","date_desc","date_asc"]).default("date_desc").describe("Sort order")}),handler:async s=>{try{let e=ft(s),{concept:r,format:a="index",...t}=e,n=[];if(Oe)try{q("[search-server] Using metadata-first + semantic ranking for concept search");let o=be.findByConcept(r,t);if(q(`[search-server] Found ${o.length} observations with concept "${r}"`),o.length>0){let l=o.map(f=>f.id),u=await Ze(r,Math.min(l.length,100)),d=[];for(let f of u.ids)l.includes(f)&&!d.includes(f)&&d.push(f);q(`[search-server] Chroma ranked ${d.length} results by semantic relevance`),d.length>0&&(n=oe.getObservationsByIds(d,{limit:t.limit||20}),n.sort((f,h)=>d.indexOf(f.id)-d.indexOf(h.id)))}}catch(o){q("[search-server] Chroma ranking failed, using SQLite order:",o.message)}if(n.length===0&&(q("[search-server] Using SQLite-only concept search"),n=be.findByConcept(r,t)),n.length===0)return{content:[{type:"text",text:`No observations found with concept "${r}"`}]};let i;if(a==="index"){let o=`Found ${n.length} observation(s) with concept "${r}": + +`,l=n.map((u,d)=>Dt(u,d));i=o+l.join(` + +`)+or()}else i=n.map(l=>Ct(l)).join(` + +--- + +`);return{content:[{type:"text",text:i}]}}catch(e){return{content:[{type:"text",text:`Search failed: ${e.message}`}],isError:!0}}}},{name:"find_by_file",description:'Find observations and sessions that reference a specific file path. IMPORTANT: Always use index format first (default) to get an overview with minimal token usage, then use format: "full" only for specific items of interest.',inputSchema:c.object({filePath:c.string().describe("File path to search for (supports partial matching)"),format:c.enum(["index","full"]).default("index").describe('Output format: "index" for titles/dates only (default, RECOMMENDED for initial search), "full" for complete details (use only after reviewing index results)'),project:c.string().optional().describe("Filter by project name"),dateStart:c.union([c.string(),c.number()]).optional().describe("Start date for filtering (ISO string or epoch timestamp)"),dateEnd:c.union([c.string(),c.number()]).optional().describe("End date for filtering (ISO string or epoch timestamp)"),limit:c.number().min(1).max(100).default(20).describe("Maximum results. IMPORTANT: Start with 3-5 to avoid exceeding MCP token limits, even in index mode."),offset:c.number().min(0).default(0).describe("Number of results to skip"),orderBy:c.enum(["relevance","date_desc","date_asc"]).default("date_desc").describe("Sort order")}),handler:async s=>{try{let e=ft(s),{filePath:r,format:a="index",...t}=e,n=[],i=[];if(Oe)try{q("[search-server] Using metadata-first + semantic ranking for file search");let u=be.findByFile(r,t);if(q(`[search-server] Found ${u.observations.length} observations, ${u.sessions.length} sessions for file "${r}"`),i=u.sessions,u.observations.length>0){let d=u.observations.map(p=>p.id),f=await Ze(r,Math.min(d.length,100)),h=[];for(let p of f.ids)d.includes(p)&&!h.includes(p)&&h.push(p);q(`[search-server] Chroma ranked ${h.length} observations by semantic relevance`),h.length>0&&(n=oe.getObservationsByIds(h,{limit:t.limit||20}),n.sort((p,g)=>h.indexOf(p.id)-h.indexOf(g.id)))}}catch(u){q("[search-server] Chroma ranking failed, using SQLite order:",u.message)}if(n.length===0&&i.length===0){q("[search-server] Using SQLite-only file search");let u=be.findByFile(r,t);n=u.observations,i=u.sessions}let o=n.length+i.length;if(o===0)return{content:[{type:"text",text:`No results found for file "${r}"`}]};let l;if(a==="index"){let u=`Found ${o} result(s) for file "${r}": + +`,d=[];n.forEach((f,h)=>{d.push(Dt(f,h))}),i.forEach((f,h)=>{d.push(ln(f,h+n.length))}),l=u+d.join(` + +`)+or()}else{let u=[];n.forEach(d=>{u.push(Ct(d))}),i.forEach(d=>{u.push(un(d))}),l=u.join(` + +--- + +`)}return{content:[{type:"text",text:l}]}}catch(e){return{content:[{type:"text",text:`Search failed: ${e.message}`}],isError:!0}}}},{name:"find_by_type",description:'Find observations of a specific type (decision, bugfix, feature, refactor, discovery, change). IMPORTANT: Always use index format first (default) to get an overview with minimal token usage, then use format: "full" only for specific items of interest.',inputSchema:c.object({type:c.string().describe("Observation type(s) to filter by (single value or comma-separated list: decision,bugfix,feature,refactor,discovery,change)"),format:c.enum(["index","full"]).default("index").describe('Output format: "index" for titles/dates only (default, RECOMMENDED for initial search), "full" for complete details (use only after reviewing index results)'),project:c.string().optional().describe("Filter by project name"),dateStart:c.union([c.string(),c.number()]).optional().describe("Start date for filtering (ISO string or epoch timestamp)"),dateEnd:c.union([c.string(),c.number()]).optional().describe("End date for filtering (ISO string or epoch timestamp)"),limit:c.number().min(1).max(100).default(20).describe("Maximum results. IMPORTANT: Start with 3-5 to avoid exceeding MCP token limits, even in index mode."),offset:c.number().min(0).default(0).describe("Number of results to skip"),orderBy:c.enum(["relevance","date_desc","date_asc"]).default("date_desc").describe("Sort order")}),handler:async s=>{try{let e=ft(s),{type:r,format:a="index",...t}=e,n=Array.isArray(r)?r.join(", "):r,i=[];if(Oe)try{q("[search-server] Using metadata-first + semantic ranking for type search");let l=be.findByType(r,t);if(q(`[search-server] Found ${l.length} observations with type "${n}"`),l.length>0){let u=l.map(h=>h.id),d=await Ze(n,Math.min(u.length,100)),f=[];for(let h of d.ids)u.includes(h)&&!f.includes(h)&&f.push(h);q(`[search-server] Chroma ranked ${f.length} results by semantic relevance`),f.length>0&&(i=oe.getObservationsByIds(f,{limit:t.limit||20}),i.sort((h,p)=>f.indexOf(h.id)-f.indexOf(p.id)))}}catch(l){q("[search-server] Chroma ranking failed, using SQLite order:",l.message)}if(i.length===0&&(q("[search-server] Using SQLite-only type search"),i=be.findByType(r,t)),i.length===0)return{content:[{type:"text",text:`No observations found with type "${n}"`}]};let o;if(a==="index"){let l=`Found ${i.length} observation(s) with type "${n}": + +`,u=i.map((d,f)=>Dt(d,f));o=l+u.join(` + +`)+or()}else o=i.map(u=>Ct(u)).join(` + +--- + +`);return{content:[{type:"text",text:o}]}}catch(e){return{content:[{type:"text",text:`Search failed: ${e.message}`}],isError:!0}}}},{name:"get_recent_context",description:"Get recent session context including summaries and observations for a project",inputSchema:c.object({project:c.string().optional().describe("Project name (defaults to current working directory basename)"),limit:c.number().min(1).max(10).default(3).describe("Number of recent sessions to retrieve")}),handler:async s=>{try{let e=s.project||(0,$l.basename)(process.cwd()),r=s.limit||3,a=oe.getRecentSessionsWithStatus(e,r);if(a.length===0)return{content:[{type:"text",text:`# Recent Session Context + +No previous sessions found for project "${e}".`}]};let t=[];t.push("# Recent Session Context"),t.push(""),t.push(`Showing last ${a.length} session(s) for **${e}**:`),t.push("");for(let n of a)if(n.sdk_session_id){if(t.push("---"),t.push(""),n.has_summary){let i=oe.getSummaryForSession(n.sdk_session_id);if(i){let o=i.prompt_number?` (Prompt #${i.prompt_number})`:"";if(t.push(`**Summary${o}**`),t.push(""),i.request&&t.push(`**Request:** ${i.request}`),i.completed&&t.push(`**Completed:** ${i.completed}`),i.learned&&t.push(`**Learned:** ${i.learned}`),i.next_steps&&t.push(`**Next Steps:** ${i.next_steps}`),i.files_read)try{let u=JSON.parse(i.files_read);Array.isArray(u)&&u.length>0&&t.push(`**Files Read:** ${u.join(", ")}`)}catch{i.files_read.trim()&&t.push(`**Files Read:** ${i.files_read}`)}if(i.files_edited)try{let u=JSON.parse(i.files_edited);Array.isArray(u)&&u.length>0&&t.push(`**Files Edited:** ${u.join(", ")}`)}catch{i.files_edited.trim()&&t.push(`**Files Edited:** ${i.files_edited}`)}let l=new Date(i.created_at).toLocaleString();t.push(`**Date:** ${l}`)}}else if(n.status==="active"){t.push("**In Progress**"),t.push(""),n.user_prompt&&t.push(`**Request:** ${n.user_prompt}`);let i=oe.getObservationsForSession(n.sdk_session_id);if(i.length>0){t.push(""),t.push(`**Observations (${i.length}):**`);for(let l of i)t.push(`- ${l.title}`)}else t.push(""),t.push("*No observations yet*");t.push(""),t.push("**Status:** Active - summary pending");let o=new Date(n.started_at).toLocaleString();t.push(`**Date:** ${o}`)}else{t.push(`**${n.status.charAt(0).toUpperCase()+n.status.slice(1)}**`),t.push(""),n.user_prompt&&t.push(`**Request:** ${n.user_prompt}`),t.push(""),t.push(`**Status:** ${n.status} - no summary available`);let i=new Date(n.started_at).toLocaleString();t.push(`**Date:** ${i}`)}t.push("")}return{content:[{type:"text",text:t.join(` +`)}]}}catch(e){return{content:[{type:"text",text:`Failed to get recent context: ${e.message}`}],isError:!0}}}},{name:"search_user_prompts",description:'DEPRECATED: Use the unified "search" tool instead. Search raw user prompts using vector-first semantic search (ChromaDB). Use this to find what the user actually said/requested across all sessions. IMPORTANT: Always use index format first (default) to get an overview with minimal token usage, then use format: "full" only for specific items of interest.',inputSchema:c.object({query:c.string().describe("Natural language search query for semantic ranking via ChromaDB vector search"),format:c.enum(["index","full"]).default("index").describe('Output format: "index" for truncated prompts/dates (default, RECOMMENDED for initial search), "full" for complete prompt text (use only after reviewing index results)'),project:c.string().optional().describe("Filter by project name"),dateStart:c.union([c.string(),c.number()]).optional().describe("Start date for filtering (ISO string or epoch timestamp)"),dateEnd:c.union([c.string(),c.number()]).optional().describe("End date for filtering (ISO string or epoch timestamp)"),limit:c.number().min(1).max(100).default(20).describe("Maximum number of results"),offset:c.number().min(0).default(0).describe("Number of results to skip"),orderBy:c.enum(["relevance","date_desc","date_asc"]).default("date_desc").describe("Sort order")}),handler:async s=>{try{let e=ft(s),{query:r,format:a="index",...t}=e,n=[];if(Oe)try{q("[search-server] Using hybrid semantic search for user prompts");let o=await Ze(r,100,{doc_type:"user_prompt"});if(q(`[search-server] Chroma returned ${o.ids.length} semantic matches`),o.ids.length>0){let l=Date.now()-7776e6,u=o.ids.filter((d,f)=>{let h=o.metadatas[f];return h&&h.created_at_epoch>l});if(q(`[search-server] ${u.length} results within 90-day window`),u.length>0){let d=t.limit||20;n=oe.getUserPromptsByIds(u,{orderBy:"date_desc",limit:d}),q(`[search-server] Hydrated ${n.length} user prompts from SQLite`)}}}catch(o){q("[search-server] Chroma query failed - no results (FTS5 fallback removed):",o.message)}if(n.length===0)return{content:[{type:"text",text:`No user prompts found matching "${r}"`}]};let i;if(a==="index"){let o=`Found ${n.length} user prompt(s) matching "${r}": + +`,l=n.map((u,d)=>Nl(u,d));i=o+l.join(` + +`)+or()}else i=n.map(l=>Al(l)).join(` + +--- + +`);return{content:[{type:"text",text:i}]}}catch(e){return{content:[{type:"text",text:`Search failed: ${e.message}`}],isError:!0}}}},{name:"get_context_timeline",description:'Get a unified timeline of context (observations, sessions, and prompts) around a specific point in time. All record types are interleaved chronologically. Useful for understanding "what was happening when X occurred". Returns depth_before records before anchor + anchor + depth_after records after (total: depth_before + 1 + depth_after mixed records).',inputSchema:c.object({anchor:c.union([c.number().describe("Observation ID to center timeline around"),c.string().describe("Session ID (format: S123) or ISO timestamp to center timeline around")]).describe('Anchor point: observation ID, session ID (e.g., "S123"), or ISO timestamp'),depth_before:c.number().min(0).max(50).default(10).describe("Number of records to retrieve before anchor, not including anchor (default: 10)"),depth_after:c.number().min(0).max(50).default(10).describe("Number of records to retrieve after anchor, not including anchor (default: 10)"),project:c.string().optional().describe("Filter by project name")}),handler:async s=>{try{let g=function(T){return new Date(T).toLocaleString("en-US",{month:"short",day:"numeric",year:"numeric"})},y=function(T){return new Date(T).toLocaleString("en-US",{hour:"numeric",minute:"2-digit",hour12:!0})},v=function(T){return new Date(T).toLocaleString("en-US",{month:"short",day:"numeric",hour:"numeric",minute:"2-digit",hour12:!0})},x=function(T){return T?Math.ceil(T.length/4):0};var e=g,r=y,a=v,t=x;let{anchor:n,depth_before:i=10,depth_after:o=10,project:l}=s,u,d=n,f;if(typeof n=="number"){let T=oe.getObservationById(n);if(!T)return{content:[{type:"text",text:`Observation #${n} not found`}],isError:!0};u=T.created_at_epoch,f=oe.getTimelineAroundObservation(n,u,i,o,l)}else if(typeof n=="string")if(n.startsWith("S")||n.startsWith("#S")){let T=n.replace(/^#?S/,""),S=parseInt(T,10),I=oe.getSessionSummariesByIds([S]);if(I.length===0)return{content:[{type:"text",text:`Session #${S} not found`}],isError:!0};u=I[0].created_at_epoch,d=`S${S}`,f=oe.getTimelineAroundTimestamp(u,i,o,l)}else{let T=new Date(n);if(isNaN(T.getTime()))return{content:[{type:"text",text:`Invalid timestamp: ${n}`}],isError:!0};u=T.getTime(),f=oe.getTimelineAroundTimestamp(u,i,o,l)}else return{content:[{type:"text",text:'Invalid anchor: must be observation ID (number), session ID (e.g., "S123"), or ISO timestamp'}],isError:!0};let h=[...f.observations.map(T=>({type:"observation",data:T,epoch:T.created_at_epoch})),...f.sessions.map(T=>({type:"session",data:T,epoch:T.created_at_epoch})),...f.prompts.map(T=>({type:"prompt",data:T,epoch:T.created_at_epoch}))];h.sort((T,S)=>T.epoch-S.epoch);let p=cn(h,d,u,i,o);if(p.length===0)return{content:[{type:"text",text:`No context found around ${new Date(u).toLocaleString()} (${i} records before, ${o} records after)`}]};let P=[];P.push(`# Timeline around anchor: ${d}`),P.push(`**Window:** ${i} records before \u2192 ${o} records after | **Items:** ${p.length}`),P.push(""),P.push("**Legend:** \u{1F3AF} session-request | \u{1F534} bugfix | \u{1F7E3} feature | \u{1F504} refactor | \u2705 change | \u{1F535} discovery | \u{1F9E0} decision"),P.push("");let E=new Map;for(let T of p){let S=g(T.epoch);E.has(S)||E.set(S,[]),E.get(S).push(T)}let R=Array.from(E.entries()).sort((T,S)=>{let I=new Date(T[0]).getTime(),D=new Date(S[0]).getTime();return I-D});for(let[T,S]of R){P.push(`### ${T}`),P.push("");let I=null,D="",$=!1;for(let L of S){let C=typeof d=="number"&&L.type==="observation"&&L.data.id===d||typeof d=="string"&&d.startsWith("S")&&L.type==="session"&&`S${L.data.id}`===d;if(L.type==="session"){$&&(P.push(""),$=!1,I=null,D="");let k=L.data,N=k.request||"Session summary",A=`claude-mem://session-summary/${k.id}`,M=C?" \u2190 **ANCHOR**":"";P.push(`**\u{1F3AF} #S${k.id}** ${N} (${v(L.epoch)}) [\u2192](${A})${M}`),P.push("")}else if(L.type==="prompt"){$&&(P.push(""),$=!1,I=null,D="");let k=L.data,N=k.prompt.length>100?k.prompt.substring(0,100)+"...":k.prompt;P.push(`**\u{1F4AC} User Prompt #${k.prompt_number}** (${v(L.epoch)})`),P.push(`> ${N}`),P.push("")}else if(L.type==="observation"){let k=L.data,N="General";N!==I&&($&&P.push(""),P.push(`**${N}**`),P.push("| ID | Time | T | Title | Tokens |"),P.push("|----|------|---|-------|--------|"),I=N,$=!0,D="");let A="\u2022";switch(k.type){case"bugfix":A="\u{1F534}";break;case"feature":A="\u{1F7E3}";break;case"refactor":A="\u{1F504}";break;case"change":A="\u2705";break;case"discovery":A="\u{1F535}";break;case"decision":A="\u{1F9E0}";break}let M=y(L.epoch),W=k.title||"Untitled",Q=x(k.narrative),K=M!==D?M:"\u2033";D=M;let Z=C?" \u2190 **ANCHOR**":"";P.push(`| #${k.id} | ${K} | ${A} | ${W}${Z} | ~${Q} |`)}}$&&P.push("")}return{content:[{type:"text",text:P.join(` +`)}]}}catch(n){return{content:[{type:"text",text:`Timeline query failed: ${n.message}`}],isError:!0}}}},{name:"get_timeline_by_query",description:'Search for observations using natural language and get timeline context around the best match. Two modes: "auto" (default) automatically uses top result as timeline anchor; "interactive" returns top matches for you to choose from. This combines search + timeline into a single operation for faster context discovery.',inputSchema:c.object({query:c.string().describe("Natural language search query to find relevant observations"),mode:c.enum(["auto","interactive"]).default("auto").describe("auto: Automatically use top search result as timeline anchor. interactive: Show top N search results for manual anchor selection."),depth_before:c.number().min(0).max(50).default(10).describe("Number of timeline records before anchor (default: 10)"),depth_after:c.number().min(0).max(50).default(10).describe("Number of timeline records after anchor (default: 10)"),limit:c.number().min(1).max(20).default(5).describe("For interactive mode: number of top search results to display (default: 5)"),project:c.string().optional().describe("Filter by project name")}),handler:async s=>{try{let{query:n,mode:i="auto",depth_before:o=10,depth_after:l=10,limit:u=5,project:d}=s,f=[];if(Oe)try{q("[search-server] Using hybrid semantic search for timeline query");let h=await Ze(n,100);if(q(`[search-server] Chroma returned ${h.ids.length} semantic matches`),h.ids.length>0){let p=Date.now()-7776e6,g=h.ids.filter((y,v)=>{let x=h.metadatas[v];return x&&x.created_at_epoch>p});q(`[search-server] ${g.length} results within 90-day window`),g.length>0&&(f=oe.getObservationsByIds(g,{orderBy:"date_desc",limit:i==="auto"?1:u}),q(`[search-server] Hydrated ${f.length} observations from SQLite`))}}catch(h){q("[search-server] Chroma query failed - no results (FTS5 fallback removed):",h.message)}if(f.length===0)return{content:[{type:"text",text:`No observations found matching "${n}". Try a different search query.`}]};if(i==="interactive"){let h=[];h.push("# Timeline Anchor Search Results"),h.push(""),h.push(`Found ${f.length} observation(s) matching "${n}"`),h.push(""),h.push("To get timeline context around any of these observations, use the `get_context_timeline` tool with the observation ID as the anchor."),h.push(""),h.push(`**Top ${f.length} matches:**`),h.push("");for(let p=0;p({type:"observation",data:I,epoch:I.created_at_epoch})),...p.sessions.map(I=>({type:"session",data:I,epoch:I.created_at_epoch})),...p.prompts.map(I=>({type:"prompt",data:I,epoch:I.created_at_epoch}))];g.sort((I,D)=>I.epoch-D.epoch);let y=cn(g,h.id,0,o,l);if(y.length===0)return{content:[{type:"text",text:`Found observation #${h.id} matching "${n}", but no timeline context available (${o} records before, ${l} records after).`}]};let R=[];R.push(`# Timeline for query: "${n}"`),R.push(`**Anchor:** Observation #${h.id} - ${h.title||"Untitled"}`),R.push(`**Window:** ${o} records before \u2192 ${l} records after | **Items:** ${y.length}`),R.push(""),R.push("**Legend:** \u{1F3AF} session-request | \u{1F534} bugfix | \u{1F7E3} feature | \u{1F504} refactor | \u2705 change | \u{1F535} discovery | \u{1F9E0} decision"),R.push("");let T=new Map;for(let I of y){let D=v(I.epoch);T.has(D)||T.set(D,[]),T.get(D).push(I)}let S=Array.from(T.entries()).sort((I,D)=>{let $=new Date(I[0]).getTime(),L=new Date(D[0]).getTime();return $-L});for(let[I,D]of S){R.push(`### ${I}`),R.push("");let $=null,L="",C=!1;for(let k of D){let N=k.type==="observation"&&k.data.id===h.id;if(k.type==="session"){C&&(R.push(""),C=!1,$=null,L="");let A=k.data,M=A.request||"Session summary",W=`claude-mem://session-summary/${A.id}`;R.push(`**\u{1F3AF} #S${A.id}** ${M} (${P(k.epoch)}) [\u2192](${W})`),R.push("")}else if(k.type==="prompt"){C&&(R.push(""),C=!1,$=null,L="");let A=k.data,M=A.prompt.length>100?A.prompt.substring(0,100)+"...":A.prompt;R.push(`**\u{1F4AC} User Prompt #${A.prompt_number}** (${P(k.epoch)})`),R.push(`> ${M}`),R.push("")}else if(k.type==="observation"){let A=k.data,M="General";M!==$&&(C&&R.push(""),R.push(`**${M}**`),R.push("| ID | Time | T | Title | Tokens |"),R.push("|----|------|---|-------|--------|"),$=M,C=!0,L="");let W="\u2022";switch(A.type){case"bugfix":W="\u{1F534}";break;case"feature":W="\u{1F7E3}";break;case"refactor":W="\u{1F504}";break;case"change":W="\u2705";break;case"discovery":W="\u{1F535}";break;case"decision":W="\u{1F9E0}";break}let Q=x(k.epoch),te=A.title||"Untitled",K=E(A.narrative),fe=Q!==L?Q:"\u2033";L=Q;let Te=N?" \u2190 **ANCHOR**":"";R.push(`| #${A.id} | ${fe} | ${W} | ${te}${Te} | ~${K} |`)}}C&&R.push("")}return{content:[{type:"text",text:R.join(` +`)}]}}}catch(n){return{content:[{type:"text",text:`Timeline query failed: ${n.message}`}],isError:!0}}}}],dn=new Os({name:"claude-mem-search",version:"1.0.0"},{capabilities:{tools:{}}});dn.setRequestHandler(ca,async()=>({tools:Dl.map(s=>({name:s.name,description:s.description,inputSchema:tn(s.inputSchema)}))}));dn.setRequestHandler(ua,async s=>{let e=Dl.find(r=>r.name===s.params.name);if(!e)throw new Error(`Unknown tool: ${s.params.name}`);try{return await e.handler(s.params.arguments||{})}catch(r){return{content:[{type:"text",text:`Tool execution failed: ${r.message}`}],isError:!0}}});async function Cl(){if(q("[search-server] Shutting down..."),Oe)try{await Oe.close(),q("[search-server] Chroma client closed")}catch(s){q("[search-server] Error closing Chroma client:",s.message)}if(be)try{be.close(),q("[search-server] SessionSearch closed")}catch(s){q("[search-server] Error closing SessionSearch:",s.message)}if(oe)try{oe.close(),q("[search-server] SessionStore closed")}catch(s){q("[search-server] Error closing SessionStore:",s.message)}q("[search-server] Shutdown complete"),process.exit(0)}process.on("SIGTERM",Cl);process.on("SIGINT",Cl);async function Oh(){let s=new Is;await dn.connect(s),q("[search-server] Claude-mem search server started"),setTimeout(async()=>{try{q("[search-server] Initializing Chroma client...");let e=new $s({command:"uvx",args:["chroma-mcp","--client-type","persistent","--data-dir",xl],stderr:"ignore"}),r=new Ns({name:"claude-mem-search-chroma-client",version:"1.0.0"},{capabilities:{}});await r.connect(e),Oe=r,q("[search-server] Chroma client connected successfully")}catch(e){q("[search-server] Failed to initialize Chroma client:",e.message),q("[search-server] Vector search unavailable - text queries will return empty results (FTS5 fallback removed)"),q("[search-server] Install UVX/Python to enable vector search: https://docs.astral.sh/uv/getting-started/installation/"),Oe=null}},0)}Oh().catch(s=>{q("[search-server] Fatal error:",s),process.exit(1)}); +/*! Bundled license information: + +uri-js/dist/es5/uri.all.js: + (** @license URI.js v4.4.1 (c) 2011 Gary Court. License: http://github.com/garycourt/uri-js *) +*/ diff --git a/plugin/scripts/worker-service.cjs b/plugin/scripts/worker-service.cjs index 28a27834..dfbf2b9c 100755 --- a/plugin/scripts/worker-service.cjs +++ b/plugin/scripts/worker-service.cjs @@ -926,7 +926,7 @@ MEMORY PROCESSING CONTINUED GROUP BY project ORDER BY MAX(created_at_epoch) DESC `).all().map(n=>n.project);r.json({projects:i})}catch(t){z.failure("WORKER","Get projects failed",{},t),r.status(500).json({error:t.message})}}handleGetProcessingStatus(e,r){let t=this.sessionManager.isAnySessionProcessing(),s=this.sessionManager.getTotalActiveWork();r.json({isProcessing:t,queueDepth:s})}handleSetProcessing(e,r){try{this.workerService.broadcastProcessingStatus();let t=this.sessionManager.isAnySessionProcessing(),s=this.sessionManager.getTotalQueueDepth(),i=this.sessionManager.getActiveSessionCount();z.debug("WORKER","Processing status broadcast",{isProcessing:t,queueDepth:s,activeSessions:i}),r.json({status:"ok",isProcessing:t})}catch(t){z.failure("WORKER","Failed to broadcast processing status",{},t),r.status(500).json({error:t.message})}}parsePaginationParams(e){let r=parseInt(e.query.offset,10)||0,t=Math.min(parseInt(e.query.limit,10)||20,100),s=e.query.project;return{offset:r,limit:t,project:s}}};xt();var Tl=class{constructor(e){this.mcpClient=e}setupRoutes(e){e.get("/api/search",this.handleUnifiedSearch.bind(this)),e.get("/api/timeline",this.handleUnifiedTimeline.bind(this)),e.get("/api/decisions",this.handleDecisions.bind(this)),e.get("/api/changes",this.handleChanges.bind(this)),e.get("/api/how-it-works",this.handleHowItWorks.bind(this)),e.get("/api/search/observations",this.handleSearchObservations.bind(this)),e.get("/api/search/sessions",this.handleSearchSessions.bind(this)),e.get("/api/search/prompts",this.handleSearchPrompts.bind(this)),e.get("/api/search/by-concept",this.handleSearchByConcept.bind(this)),e.get("/api/search/by-file",this.handleSearchByFile.bind(this)),e.get("/api/search/by-type",this.handleSearchByType.bind(this)),e.get("/api/context/recent",this.handleGetRecentContext.bind(this)),e.get("/api/context/timeline",this.handleGetContextTimeline.bind(this)),e.get("/api/context/preview",this.handleContextPreview.bind(this)),e.get("/api/context/inject",this.handleContextInject.bind(this)),e.get("/api/timeline/by-query",this.handleGetTimelineByQuery.bind(this)),e.get("/api/search/help",this.handleSearchHelp.bind(this))}async handleUnifiedSearch(e,r){try{let t=await this.mcpClient.callTool({name:"search",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","Unified search failed",{},t),r.status(500).json({error:t.message})}}async handleUnifiedTimeline(e,r){try{let t=await this.mcpClient.callTool({name:"timeline",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","Unified timeline failed",{},t),r.status(500).json({error:t.message})}}async handleDecisions(e,r){try{let t=await this.mcpClient.callTool({name:"decisions",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","Decisions search failed",{},t),r.status(500).json({error:t.message})}}async handleChanges(e,r){try{let t=await this.mcpClient.callTool({name:"changes",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","Changes search failed",{},t),r.status(500).json({error:t.message})}}async handleHowItWorks(e,r){try{let t=await this.mcpClient.callTool({name:"how_it_works",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","How it works search failed",{},t),r.status(500).json({error:t.message})}}async handleSearchObservations(e,r){try{let t=await this.mcpClient.callTool({name:"search_observations",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","Search failed",{},t),r.status(500).json({error:t.message})}}async handleSearchSessions(e,r){try{let t=await this.mcpClient.callTool({name:"search_sessions",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","Search failed",{},t),r.status(500).json({error:t.message})}}async handleSearchPrompts(e,r){try{let t=await this.mcpClient.callTool({name:"search_user_prompts",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","Search failed",{},t),r.status(500).json({error:t.message})}}async handleSearchByConcept(e,r){try{let t=await this.mcpClient.callTool({name:"find_by_concept",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","Search failed",{},t),r.status(500).json({error:t.message})}}async handleSearchByFile(e,r){try{let t=await this.mcpClient.callTool({name:"find_by_file",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","Search failed",{},t),r.status(500).json({error:t.message})}}async handleSearchByType(e,r){try{let t=await this.mcpClient.callTool({name:"find_by_type",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","Search failed",{},t),r.status(500).json({error:t.message})}}async handleGetRecentContext(e,r){try{let t=await this.mcpClient.callTool({name:"get_recent_context",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","Search failed",{},t),r.status(500).json({error:t.message})}}async handleGetContextTimeline(e,r){try{let t=await this.mcpClient.callTool({name:"get_context_timeline",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","Search failed",{},t),r.status(500).json({error:t.message})}}async handleContextPreview(e,r){try{let t=e.query.project;if(!t){r.status(400).json({error:"Project parameter is required"});return}let{generateContext:s}=await Promise.resolve().then(()=>(vf(),hf)),i=`/preview/${t}`,n=await s({session_id:"preview-"+Date.now(),cwd:i},!0);r.setHeader("Content-Type","text/plain; charset=utf-8"),r.send(n)}catch(t){z.failure("WORKER","Context preview generation failed",{},t),r.status(500).json({error:"Failed to generate context preview",message:t.message})}}async handleContextInject(e,r){try{let t=e.query.project,s=e.query.colors==="true";if(!t){r.status(400).json({error:"Project parameter is required"});return}let{generateContext:i}=await Promise.resolve().then(()=>(vf(),hf)),n=`/context/${t}`,o=await i({session_id:"context-inject-"+Date.now(),cwd:n},s);r.setHeader("Content-Type","text/plain; charset=utf-8"),r.send(o)}catch(t){z.failure("WORKER","Context injection failed",{},t),r.status(500).json({error:"Failed to generate context",message:t.message})}}async handleGetTimelineByQuery(e,r){try{let t=await this.mcpClient.callTool({name:"get_timeline_by_query",arguments:e.query});r.json(t.content)}catch(t){z.failure("WORKER","Search failed",{},t),r.status(500).json({error:t.message})}}handleSearchHelp(e,r){r.json({title:"Claude-Mem Search API",description:"HTTP API for searching persistent memory",endpoints:[{path:"/api/search/observations",method:"GET",description:"Search observations using full-text search",parameters:{query:"Search query (required)",format:'Response format: "index" or "full" (default: "full")',limit:"Number of results (default: 20)",project:"Filter by project name (optional)"}},{path:"/api/search/sessions",method:"GET",description:"Search session summaries using full-text search",parameters:{query:"Search query (required)",format:'Response format: "index" or "full" (default: "full")',limit:"Number of results (default: 20)"}},{path:"/api/search/prompts",method:"GET",description:"Search user prompts using full-text search",parameters:{query:"Search query (required)",format:'Response format: "index" or "full" (default: "full")',limit:"Number of results (default: 20)",project:"Filter by project name (optional)"}},{path:"/api/search/by-concept",method:"GET",description:"Find observations by concept tag",parameters:{concept:"Concept tag (required): discovery, decision, bugfix, feature, refactor",format:'Response format: "index" or "full" (default: "full")',limit:"Number of results (default: 10)",project:"Filter by project name (optional)"}},{path:"/api/search/by-file",method:"GET",description:"Find observations and sessions by file path",parameters:{filePath:"File path or partial path (required)",format:'Response format: "index" or "full" (default: "full")',limit:"Number of results per type (default: 10)",project:"Filter by project name (optional)"}},{path:"/api/search/by-type",method:"GET",description:"Find observations by type",parameters:{type:"Observation type (required): discovery, decision, bugfix, feature, refactor",format:'Response format: "index" or "full" (default: "full")',limit:"Number of results (default: 10)",project:"Filter by project name (optional)"}},{path:"/api/context/recent",method:"GET",description:"Get recent session context including summaries and observations",parameters:{project:"Project name (default: current directory)",limit:"Number of recent sessions (default: 3)"}},{path:"/api/context/timeline",method:"GET",description:"Get unified timeline around a specific point in time",parameters:{anchor:'Anchor point: observation ID, session ID (e.g., "S123"), or ISO timestamp (required)',depth_before:"Number of records before anchor (default: 10)",depth_after:"Number of records after anchor (default: 10)",project:"Filter by project name (optional)"}},{path:"/api/timeline/by-query",method:"GET",description:"Search for best match, then get timeline around it",parameters:{query:"Search query (required)",mode:'Search mode: "auto", "observations", or "sessions" (default: "auto")',depth_before:"Number of records before match (default: 10)",depth_after:"Number of records after match (default: 10)",project:"Filter by project name (optional)"}},{path:"/api/search/help",method:"GET",description:"Get this help documentation"}],examples:['curl "http://localhost:37777/api/search/observations?query=authentication&format=index&limit=5"','curl "http://localhost:37777/api/search/by-type?type=bugfix&limit=10"','curl "http://localhost:37777/api/context/recent?project=claude-mem&limit=3"','curl "http://localhost:37777/api/context/timeline?anchor=123&depth_before=5&depth_after=5"']})}};var Hn=ht(require("path"),1),Vt=require("fs"),yf=require("os");Aa();xt();var gf=require("child_process"),qs=require("fs"),A1=require("os"),Xi=require("path");xt();var Qi=(0,Xi.join)((0,A1.homedir)(),".claude","plugins","marketplaces","thedotmack");function yr(a){return(0,gf.execSync)(`git ${a}`,{cwd:Qi,encoding:"utf-8",timeout:3e4}).trim()}function I1(a,e=6e4){return(0,gf.execSync)(a,{cwd:Qi,encoding:"utf-8",timeout:e}).trim()}function Pl(){let a=(0,Xi.join)(Qi,".git");if(!(0,qs.existsSync)(a))return{branch:null,isBeta:!1,isGitRepo:!1,isDirty:!1,canSwitch:!1,error:"Installed plugin is not a git repository"};try{let e=yr("rev-parse --abbrev-ref HEAD"),t=yr("status --porcelain").length>0,s=e.startsWith("beta");return{branch:e,isBeta:s,isGitRepo:!0,isDirty:t,canSwitch:!0}}catch(e){return z.error("BRANCH","Failed to get branch info",{},e),{branch:null,isBeta:!1,isGitRepo:!0,isDirty:!1,canSwitch:!1,error:e.message}}}async function N1(a){let e=Pl();if(!e.isGitRepo)return{success:!1,error:"Installed plugin is not a git repository. Please reinstall."};if(e.branch===a)return{success:!0,branch:a,message:`Already on branch ${a}`};try{z.info("BRANCH","Starting branch switch",{from:e.branch,to:a}),z.debug("BRANCH","Discarding local changes"),yr("checkout -- ."),yr("clean -fd"),z.debug("BRANCH","Fetching from origin"),yr("fetch origin"),z.debug("BRANCH","Checking out branch",{branch:a});try{yr(`checkout ${a}`)}catch{yr(`checkout -b ${a} origin/${a}`)}z.debug("BRANCH","Pulling latest"),yr(`pull origin ${a}`);let r=(0,Xi.join)(Qi,".install-version");return(0,qs.existsSync)(r)&&(0,qs.unlinkSync)(r),z.debug("BRANCH","Running npm install"),I1("npm install",12e4),z.success("BRANCH","Branch switch complete",{branch:a}),{success:!0,branch:a,message:`Switched to ${a}. Worker will restart automatically.`}}catch(r){z.error("BRANCH","Branch switch failed",{targetBranch:a},r);try{e.branch&&yr(`checkout ${e.branch}`)}catch{}return{success:!1,error:`Branch switch failed: ${r.message}`}}}async function j1(){let a=Pl();if(!a.isGitRepo||!a.branch)return{success:!1,error:"Cannot pull updates: not a git repository"};try{z.info("BRANCH","Pulling updates",{branch:a.branch}),yr("checkout -- ."),yr("fetch origin"),yr(`pull origin ${a.branch}`);let e=(0,Xi.join)(Qi,".install-version");return(0,qs.existsSync)(e)&&(0,qs.unlinkSync)(e),I1("npm install",12e4),z.success("BRANCH","Updates pulled",{branch:a.branch}),{success:!0,branch:a.branch,message:`Updated ${a.branch}. Worker will restart automatically.`}}catch(e){return z.error("BRANCH","Pull failed",{},e),{success:!1,error:`Pull failed: ${e.message}`}}}mf();var Rl=class{constructor(e){this.settingsManager=e}setupRoutes(e){e.get("/api/settings",this.handleGetSettings.bind(this)),e.post("/api/settings",this.handleUpdateSettings.bind(this)),e.get("/api/mcp/status",this.handleGetMcpStatus.bind(this)),e.post("/api/mcp/toggle",this.handleToggleMcp.bind(this)),e.get("/api/branch/status",this.handleGetBranchStatus.bind(this)),e.post("/api/branch/switch",this.handleSwitchBranch.bind(this)),e.post("/api/branch/update",this.handleUpdateBranch.bind(this))}handleGetSettings(e,r){try{let t=Hn.default.join((0,yf.homedir)(),".claude-mem","settings.json");if(!(0,Vt.existsSync)(t)){r.json({CLAUDE_MEM_MODEL:"claude-haiku-4-5",CLAUDE_MEM_CONTEXT_OBSERVATIONS:"50",CLAUDE_MEM_WORKER_PORT:"37777",CLAUDE_MEM_CONTEXT_SHOW_READ_TOKENS:"true",CLAUDE_MEM_CONTEXT_SHOW_WORK_TOKENS:"true",CLAUDE_MEM_CONTEXT_SHOW_SAVINGS_AMOUNT:"true",CLAUDE_MEM_CONTEXT_SHOW_SAVINGS_PERCENT:"true",CLAUDE_MEM_CONTEXT_OBSERVATION_TYPES:Zi,CLAUDE_MEM_CONTEXT_OBSERVATION_CONCEPTS:Ki,CLAUDE_MEM_CONTEXT_FULL_COUNT:"5",CLAUDE_MEM_CONTEXT_FULL_FIELD:"narrative",CLAUDE_MEM_CONTEXT_SESSION_COUNT:"10",CLAUDE_MEM_CONTEXT_SHOW_LAST_SUMMARY:"true",CLAUDE_MEM_CONTEXT_SHOW_LAST_MESSAGE:"false"});return}let s=(0,Vt.readFileSync)(t,"utf-8"),n=JSON.parse(s).env||{};r.json({CLAUDE_MEM_MODEL:n.CLAUDE_MEM_MODEL||"claude-haiku-4-5",CLAUDE_MEM_CONTEXT_OBSERVATIONS:n.CLAUDE_MEM_CONTEXT_OBSERVATIONS||"50",CLAUDE_MEM_WORKER_PORT:n.CLAUDE_MEM_WORKER_PORT||"37777",CLAUDE_MEM_CONTEXT_SHOW_READ_TOKENS:n.CLAUDE_MEM_CONTEXT_SHOW_READ_TOKENS||"true",CLAUDE_MEM_CONTEXT_SHOW_WORK_TOKENS:n.CLAUDE_MEM_CONTEXT_SHOW_WORK_TOKENS||"true",CLAUDE_MEM_CONTEXT_SHOW_SAVINGS_AMOUNT:n.CLAUDE_MEM_CONTEXT_SHOW_SAVINGS_AMOUNT||"true",CLAUDE_MEM_CONTEXT_SHOW_SAVINGS_PERCENT:n.CLAUDE_MEM_CONTEXT_SHOW_SAVINGS_PERCENT||"true",CLAUDE_MEM_CONTEXT_OBSERVATION_TYPES:n.CLAUDE_MEM_CONTEXT_OBSERVATION_TYPES||Zi,CLAUDE_MEM_CONTEXT_OBSERVATION_CONCEPTS:n.CLAUDE_MEM_CONTEXT_OBSERVATION_CONCEPTS||Ki,CLAUDE_MEM_CONTEXT_FULL_COUNT:n.CLAUDE_MEM_CONTEXT_FULL_COUNT||"5",CLAUDE_MEM_CONTEXT_FULL_FIELD:n.CLAUDE_MEM_CONTEXT_FULL_FIELD||"narrative",CLAUDE_MEM_CONTEXT_SESSION_COUNT:n.CLAUDE_MEM_CONTEXT_SESSION_COUNT||"10",CLAUDE_MEM_CONTEXT_SHOW_LAST_SUMMARY:n.CLAUDE_MEM_CONTEXT_SHOW_LAST_SUMMARY||"true",CLAUDE_MEM_CONTEXT_SHOW_LAST_MESSAGE:n.CLAUDE_MEM_CONTEXT_SHOW_LAST_MESSAGE||"false"})}catch(t){z.failure("WORKER","Get settings failed",{},t),r.status(500).json({error:t.message})}}handleUpdateSettings(e,r){try{if(e.body.CLAUDE_MEM_CONTEXT_OBSERVATIONS){let o=parseInt(e.body.CLAUDE_MEM_CONTEXT_OBSERVATIONS,10);if(isNaN(o)||o<1||o>200){r.status(400).json({success:!1,error:"CLAUDE_MEM_CONTEXT_OBSERVATIONS must be between 1 and 200"});return}}if(e.body.CLAUDE_MEM_WORKER_PORT){let o=parseInt(e.body.CLAUDE_MEM_WORKER_PORT,10);if(isNaN(o)||o<1024||o>65535){r.status(400).json({success:!1,error:"CLAUDE_MEM_WORKER_PORT must be between 1024 and 65535"});return}}let t=this.validateContextSettings(e.body);if(!t.valid){r.status(400).json({success:!1,error:t.error});return}let s=Hn.default.join((0,yf.homedir)(),".claude-mem","settings.json"),i={env:{}};if((0,Vt.existsSync)(s)){let o=(0,Vt.readFileSync)(s,"utf-8");i=JSON.parse(o),i.env||(i.env={})}let n=["CLAUDE_MEM_MODEL","CLAUDE_MEM_CONTEXT_OBSERVATIONS","CLAUDE_MEM_WORKER_PORT","CLAUDE_MEM_CONTEXT_SHOW_READ_TOKENS","CLAUDE_MEM_CONTEXT_SHOW_WORK_TOKENS","CLAUDE_MEM_CONTEXT_SHOW_SAVINGS_AMOUNT","CLAUDE_MEM_CONTEXT_SHOW_SAVINGS_PERCENT","CLAUDE_MEM_CONTEXT_OBSERVATION_TYPES","CLAUDE_MEM_CONTEXT_OBSERVATION_CONCEPTS","CLAUDE_MEM_CONTEXT_FULL_COUNT","CLAUDE_MEM_CONTEXT_FULL_FIELD","CLAUDE_MEM_CONTEXT_SESSION_COUNT","CLAUDE_MEM_CONTEXT_SHOW_LAST_SUMMARY","CLAUDE_MEM_CONTEXT_SHOW_LAST_MESSAGE"];for(let o of n)e.body[o]!==void 0&&(i.env[o]=e.body[o]);(0,Vt.writeFileSync)(s,JSON.stringify(i,null,2),"utf-8"),z.info("WORKER","Settings updated"),r.json({success:!0,message:"Settings updated successfully"})}catch(t){z.failure("WORKER","Update settings failed",{},t),r.status(500).json({success:!1,error:String(t)})}}handleGetMcpStatus(e,r){try{let t=this.isMcpEnabled();r.json({enabled:t})}catch(t){z.failure("WORKER","Get MCP status failed",{},t),r.status(500).json({error:t.message})}}handleToggleMcp(e,r){try{let{enabled:t}=e.body;if(typeof t!="boolean"){r.status(400).json({error:"enabled must be a boolean"});return}this.toggleMcp(t),r.json({success:!0,enabled:this.isMcpEnabled()})}catch(t){z.failure("WORKER","Toggle MCP failed",{},t),r.status(500).json({success:!1,error:t.message})}}handleGetBranchStatus(e,r){try{let t=Pl();r.json(t)}catch(t){z.failure("WORKER","Failed to get branch status",{},t),r.status(500).json({error:t.message})}}async handleSwitchBranch(e,r){try{let{branch:t}=e.body;if(!t){r.status(400).json({success:!1,error:"Missing branch parameter"});return}let s=["main","beta/7.0"];if(!s.includes(t)){r.status(400).json({success:!1,error:`Invalid branch. Allowed: ${s.join(", ")}`});return}z.info("WORKER","Branch switch requested",{branch:t});let i=await N1(t);i.success&&setTimeout(()=>{z.info("WORKER","Restarting worker after branch switch"),process.exit(0)},1e3),r.json(i)}catch(t){z.failure("WORKER","Branch switch failed",{},t),r.status(500).json({success:!1,error:t.message})}}async handleUpdateBranch(e,r){try{z.info("WORKER","Branch update requested");let t=await j1();t.success&&setTimeout(()=>{z.info("WORKER","Restarting worker after branch update"),process.exit(0)},1e3),r.json(t)}catch(t){z.failure("WORKER","Branch update failed",{},t),r.status(500).json({success:!1,error:t.message})}}validateContextSettings(e){let r=["CLAUDE_MEM_CONTEXT_SHOW_READ_TOKENS","CLAUDE_MEM_CONTEXT_SHOW_WORK_TOKENS","CLAUDE_MEM_CONTEXT_SHOW_SAVINGS_AMOUNT","CLAUDE_MEM_CONTEXT_SHOW_SAVINGS_PERCENT","CLAUDE_MEM_CONTEXT_SHOW_LAST_SUMMARY","CLAUDE_MEM_CONTEXT_SHOW_LAST_MESSAGE"];for(let t of r)if(e[t]&&!["true","false"].includes(e[t]))return{valid:!1,error:`${t} must be "true" or "false"`};if(e.CLAUDE_MEM_CONTEXT_FULL_COUNT){let t=parseInt(e.CLAUDE_MEM_CONTEXT_FULL_COUNT,10);if(isNaN(t)||t<0||t>20)return{valid:!1,error:"CLAUDE_MEM_CONTEXT_FULL_COUNT must be between 0 and 20"}}if(e.CLAUDE_MEM_CONTEXT_SESSION_COUNT){let t=parseInt(e.CLAUDE_MEM_CONTEXT_SESSION_COUNT,10);if(isNaN(t)||t<1||t>50)return{valid:!1,error:"CLAUDE_MEM_CONTEXT_SESSION_COUNT must be between 1 and 50"}}if(e.CLAUDE_MEM_CONTEXT_FULL_FIELD&&!["narrative","facts"].includes(e.CLAUDE_MEM_CONTEXT_FULL_FIELD))return{valid:!1,error:'CLAUDE_MEM_CONTEXT_FULL_FIELD must be "narrative" or "facts"'};if(e.CLAUDE_MEM_CONTEXT_OBSERVATION_TYPES){let t=e.CLAUDE_MEM_CONTEXT_OBSERVATION_TYPES.split(",").map(s=>s.trim());for(let s of t)if(s&&!zn.includes(s))return{valid:!1,error:`Invalid observation type: ${s}. Valid types: ${zn.join(", ")}`}}if(e.CLAUDE_MEM_CONTEXT_OBSERVATION_CONCEPTS){let t=e.CLAUDE_MEM_CONTEXT_OBSERVATION_CONCEPTS.split(",").map(s=>s.trim());for(let s of t)if(s&&!Bn.includes(s))return{valid:!1,error:`Invalid observation concept: ${s}. Valid concepts: ${Bn.join(", ")}`}}return{valid:!0}}isMcpEnabled(){let e=zr(),r=Hn.default.join(e,"plugin",".mcp.json");return(0,Vt.existsSync)(r)}toggleMcp(e){try{let r=zr(),t=Hn.default.join(r,"plugin",".mcp.json"),s=Hn.default.join(r,"plugin",".mcp.json.disabled");e&&(0,Vt.existsSync)(s)?((0,Vt.renameSync)(s,t),z.info("WORKER","MCP search server enabled")):!e&&(0,Vt.existsSync)(t)?((0,Vt.renameSync)(t,s),z.info("WORKER","MCP search server disabled")):z.debug("WORKER","MCP toggle no-op (already in desired state)",{enabled:e})}catch(r){throw z.failure("WORKER","Failed to toggle MCP",{enabled:e},r),r}}};var Ol=class{app;server=null;startTime=Date.now();mcpClient;dbManager;sessionManager;sseBroadcaster;sdkAgent;paginationHelper;settingsManager;viewerRoutes;sessionRoutes;dataRoutes;searchRoutes;settingsRoutes;constructor(){this.app=(0,D1.default)(),this.dbManager=new Yc,this.sessionManager=new Jc(this.dbManager),this.sseBroadcaster=new el,this.sdkAgent=new vl(this.dbManager,this.sessionManager),this.paginationHelper=new yl(this.dbManager),this.settingsManager=new bl(this.dbManager),this.sessionManager.setOnSessionDeleted(()=>{this.broadcastProcessingStatus()}),this.mcpClient=new wn({name:"worker-search-proxy",version:"1.0.0"},{capabilities:{}}),this.viewerRoutes=new xl(this.sseBroadcaster,this.dbManager,this.sessionManager),this.sessionRoutes=new _l(this.sessionManager,this.dbManager,this.sdkAgent,this.sseBroadcaster,this),this.dataRoutes=new El(this.paginationHelper,this.dbManager,this.sessionManager,this.sseBroadcaster,this,this.startTime),this.searchRoutes=new Tl(this.mcpClient),this.settingsRoutes=new Rl(this.settingsManager),this.setupMiddleware(),this.setupRoutes()}setupMiddleware(){_1(this.summarizeRequestBody.bind(this)).forEach(r=>this.app.use(r))}setupRoutes(){this.app.get("/api/health",(e,r)=>{r.status(200).json({status:"ok"})}),this.viewerRoutes.setupRoutes(this.app),this.sessionRoutes.setupRoutes(this.app),this.dataRoutes.setupRoutes(this.app),this.searchRoutes.setupRoutes(this.app),this.settingsRoutes.setupRoutes(this.app)}async cleanupOrphanedProcesses(){try{let{execSync:e}=await import("child_process");try{let r=e("pgrep -fl uvx",{encoding:"utf-8",stdio:"pipe",windowsHide:!0}).trim();if(r){let t=r.split(` -`).length;z.info("WORKER","Cleaning up orphaned MCP processes",{count:t}),e("pkill -f uvx",{stdio:"pipe",windowsHide:!0}),z.success("WORKER",`Cleaned up ${t} orphaned MCP server processes`)}}catch(r){if(r.status===1)z.debug("WORKER","No orphaned MCP processes to clean up");else throw r}}catch(e){z.warn("WORKER","Failed to cleanup orphaned processes (non-fatal)",{},e)}}async start(){let e=On();this.server=await new Promise((r,t)=>{let s=this.app.listen(e,()=>r(s));s.on("error",t)}),z.info("SYSTEM","Worker started",{port:e,pid:process.pid}),this.initializeBackground().catch(r=>{z.error("SYSTEM","Background initialization failed",{},r)})}async initializeBackground(){await this.cleanupOrphanedProcesses(),await this.dbManager.initialize();let e=$1.default.join(__dirname,"..","..","plugin","scripts","search-server.cjs"),r=new Rn({command:"node",args:[e],env:process.env});await this.mcpClient.connect(r),z.success("WORKER","Connected to MCP search server")}async shutdown(){if(await this.sessionManager.shutdownAll(),this.mcpClient)try{await this.mcpClient.close(),z.info("SYSTEM","MCP client closed")}catch(e){z.error("SYSTEM","Failed to close MCP client",{},e)}this.server&&await new Promise((e,r)=>{this.server.close(t=>t?r(t):e())}),await this.dbManager.close(),z.info("SYSTEM","Worker shutdown complete")}summarizeRequestBody(e,r,t){return E1(e,r,t)}broadcastProcessingStatus(){let e=this.sessionManager.isAnySessionProcessing(),r=this.sessionManager.getTotalActiveWork(),t=this.sessionManager.getActiveSessionCount();z.info("WORKER","Broadcasting processing status",{isProcessing:e,queueDepth:r,activeSessions:t}),this.sseBroadcaster.broadcast({type:"processing_status",isProcessing:e,queueDepth:r})}};if(require.main===module||!module.parent){let a=new Ol;process.on("SIGTERM",async()=>{z.info("SYSTEM","Received SIGTERM, shutting down gracefully"),await a.shutdown(),process.exit(0)}),process.on("SIGINT",async()=>{z.info("SYSTEM","Received SIGINT, shutting down gracefully"),await a.shutdown(),process.exit(0)}),a.start().catch(e=>{z.failure("SYSTEM","Worker failed to start",{},e),process.exit(1)})}0&&(module.exports={WorkerService}); +`).length;z.info("WORKER","Cleaning up orphaned MCP processes",{count:t}),e("pkill -f uvx",{stdio:"pipe",windowsHide:!0}),z.success("WORKER",`Cleaned up ${t} orphaned MCP server processes`)}}catch(r){if(r.status===1)z.debug("WORKER","No orphaned MCP processes to clean up");else throw r}}catch(e){z.warn("WORKER","Failed to cleanup orphaned processes (non-fatal)",{},e)}}async start(){let e=On();this.server=await new Promise((r,t)=>{let s=this.app.listen(e,()=>r(s));s.on("error",t)}),z.info("SYSTEM","Worker started",{port:e,pid:process.pid}),this.initializeBackground().catch(r=>{z.error("SYSTEM","Background initialization failed",{},r)})}async initializeBackground(){await this.cleanupOrphanedProcesses(),await this.dbManager.initialize();let e=$1.default.join(__dirname,"..","..","plugin","scripts","mcp-server.cjs"),r=new Rn({command:"node",args:[e],env:process.env});await this.mcpClient.connect(r),z.success("WORKER","Connected to MCP server")}async shutdown(){if(await this.sessionManager.shutdownAll(),this.mcpClient)try{await this.mcpClient.close(),z.info("SYSTEM","MCP client closed")}catch(e){z.error("SYSTEM","Failed to close MCP client",{},e)}this.server&&await new Promise((e,r)=>{this.server.close(t=>t?r(t):e())}),await this.dbManager.close(),z.info("SYSTEM","Worker shutdown complete")}summarizeRequestBody(e,r,t){return E1(e,r,t)}broadcastProcessingStatus(){let e=this.sessionManager.isAnySessionProcessing(),r=this.sessionManager.getTotalActiveWork(),t=this.sessionManager.getActiveSessionCount();z.info("WORKER","Broadcasting processing status",{isProcessing:e,queueDepth:r,activeSessions:t}),this.sseBroadcaster.broadcast({type:"processing_status",isProcessing:e,queueDepth:r})}};if(require.main===module||!module.parent){let a=new Ol;process.on("SIGTERM",async()=>{z.info("SYSTEM","Received SIGTERM, shutting down gracefully"),await a.shutdown(),process.exit(0)}),process.on("SIGINT",async()=>{z.info("SYSTEM","Received SIGINT, shutting down gracefully"),await a.shutdown(),process.exit(0)}),a.start().catch(e=>{z.failure("SYSTEM","Worker failed to start",{},e),process.exit(1)})}0&&(module.exports={WorkerService}); /*! Bundled license information: depd/index.js: diff --git a/scripts/build-hooks.js b/scripts/build-hooks.js index 7d151e8c..5b49fc26 100644 --- a/scripts/build-hooks.js +++ b/scripts/build-hooks.js @@ -26,9 +26,9 @@ const WORKER_SERVICE = { source: 'src/services/worker-service.ts' }; -const SEARCH_SERVER = { - name: 'search-server', - source: 'src/servers/search-server.ts' +const MCP_SERVER = { + name: 'mcp-server', + source: 'src/servers/mcp-server.ts' }; const CONTEXT_GENERATOR = { @@ -97,15 +97,15 @@ async function buildHooks() { const workerStats = fs.statSync(`${hooksDir}/${WORKER_SERVICE.name}.cjs`); console.log(`✓ worker-service built (${(workerStats.size / 1024).toFixed(2)} KB)`); - // Build search server - console.log(`\n🔧 Building search server...`); + // Build MCP server + console.log(`\n🔧 Building MCP server...`); await build({ - entryPoints: [SEARCH_SERVER.source], + entryPoints: [MCP_SERVER.source], bundle: true, platform: 'node', target: 'node18', format: 'cjs', - outfile: `${hooksDir}/${SEARCH_SERVER.name}.cjs`, + outfile: `${hooksDir}/${MCP_SERVER.name}.cjs`, minify: true, logLevel: 'error', external: ['better-sqlite3'], @@ -117,10 +117,10 @@ async function buildHooks() { } }); - // Make search server executable - fs.chmodSync(`${hooksDir}/${SEARCH_SERVER.name}.cjs`, 0o755); - const searchServerStats = fs.statSync(`${hooksDir}/${SEARCH_SERVER.name}.cjs`); - console.log(`✓ search-server built (${(searchServerStats.size / 1024).toFixed(2)} KB)`); + // Make MCP server executable + fs.chmodSync(`${hooksDir}/${MCP_SERVER.name}.cjs`, 0o755); + const mcpServerStats = fs.statSync(`${hooksDir}/${MCP_SERVER.name}.cjs`); + console.log(`✓ mcp-server built (${(mcpServerStats.size / 1024).toFixed(2)} KB)`); // Build context generator console.log(`\n🔧 Building context generator...`); @@ -174,11 +174,11 @@ async function buildHooks() { console.log(`✓ ${hook.name} built (${sizeInKB} KB)`); } - console.log('\n✅ All hooks, worker service, and search server built successfully!'); + console.log('\n✅ All hooks, worker service, and MCP server built successfully!'); console.log(` Output: ${hooksDir}/`); console.log(` - Hooks: *-hook.js`); console.log(` - Worker: worker-service.cjs`); - console.log(` - Search Server: search-server.cjs`); + console.log(` - MCP Server: mcp-server.cjs`); console.log(` - Skills: plugin/skills/`); console.log('\n💡 Note: Dependencies will be auto-installed on first hook execution'); diff --git a/scripts/extract-search-manager.js b/scripts/extract-search-manager.js new file mode 100644 index 00000000..e61e6cf0 --- /dev/null +++ b/scripts/extract-search-manager.js @@ -0,0 +1,229 @@ +#!/usr/bin/env node + +/** + * One-time script to extract tool handlers from mcp-server.ts into SearchManager.ts + */ + +import { readFileSync, writeFileSync } from 'fs'; +import { fileURLToPath } from 'url'; +import { dirname, join } from 'path'; + +const __filename = fileURLToPath(import.meta.url); +const __dirname = dirname(__filename); +const projectRoot = join(__dirname, '..'); + +const mcpServerPath = join(projectRoot, 'src/servers/mcp-server.ts'); +const outputPath = join(projectRoot, 'src/services/worker/SearchManager.ts'); + +console.log('Reading mcp-server.ts...'); +const content = readFileSync(mcpServerPath, 'utf-8'); + +// Extract just the sections we need by finding line numbers +// This is more reliable than parsing + +// Extract tool handler bodies by finding each "handler: async (args: any) => {" +// and extracting until the matching closing brace + +const extractHandlerBody = (content, startPattern) => { + const lines = content.split('\n'); + const startIdx = lines.findIndex(line => line.includes(startPattern)); + + if (startIdx === -1) return null; + + // Find the "handler: async (args: any) => {" line + let handlerIdx = -1; + for (let i = startIdx; i < Math.min(startIdx + 30, lines.length); i++) { + if (lines[i].includes('handler: async (args: any) => {')) { + handlerIdx = i; + break; + } + } + + if (handlerIdx === -1) return null; + + // Extract the body by counting braces + let braceCount = 0; + let bodyLines = []; + let started = false; + + for (let i = handlerIdx; i < lines.length; i++) { + const line = lines[i]; + + for (const char of line) { + if (char === '{') { + braceCount++; + started = true; + } else if (char === '}') { + braceCount--; + } + } + + if (started) { + bodyLines.push(line); + } + + if (started && braceCount === 0) { + break; + } + } + + // Remove the first line (handler wrapper) and last line (closing brace) + if (bodyLines.length > 2) { + bodyLines = bodyLines.slice(1, -1); + } + + return bodyLines.join('\n'); +}; + +// Tool name to search pattern mapping +const tools = { + 'search': "name: 'search'", + 'timeline': "name: 'timeline'", + 'decisions': "name: 'decisions'", + 'changes': "name: 'changes'", + 'how_it_works': "name: 'how_it_works'", + 'search_observations': "name: 'search_observations'", + 'search_sessions': "name: 'search_sessions'", + 'search_user_prompts': "name: 'search_user_prompts'", + 'find_by_concept': "name: 'find_by_concept'", + 'find_by_file': "name: 'find_by_file'", + 'find_by_type': "name: 'find_by_type'", + 'get_recent_context': "name: 'get_recent_context'", + 'get_context_timeline': "name: 'get_context_timeline'", + 'get_timeline_by_query': "name: 'get_timeline_by_query'" +}; + +console.log('Extracting tool handlers...'); +const handlers = {}; + +for (const [toolName, pattern] of Object.entries(tools)) { + console.log(` Extracting ${toolName}...`); + const body = extractHandlerBody(content, pattern); + if (body) { + handlers[toolName] = body; + console.log(` ✓ ${body.split('\n').length} lines`); + } else { + console.log(` ✗ Not found`); + } +} + +console.log(`\nExtracted ${Object.keys(handlers).length}/${Object.keys(tools).length} handlers`); + +// Now generate SearchManager.ts +console.log('\nGenerating SearchManager.ts...'); + +const methodBodies = Object.entries(handlers).map(([toolName, body]) => { + // Convert tool name to camelCase method name + const methodName = toolName.replace(/_([a-z])/g, (_, letter) => letter.toUpperCase()); + + // Replace standalone function calls with class methods + let processedBody = body + .replace(/formatSearchTips\(\)/g, 'this.formatter.formatSearchTips()') + .replace(/formatObservationIndex\(/g, 'this.formatter.formatObservationIndex(') + .replace(/formatSessionIndex\(/g, 'this.formatter.formatSessionIndex(') + .replace(/formatUserPromptIndex\(/g, 'this.formatter.formatUserPromptIndex(') + .replace(/formatObservationResult\(/g, 'this.formatter.formatObservationResult(') + .replace(/formatSessionResult\(/g, 'this.formatter.formatSessionResult(') + .replace(/formatUserPromptResult\(/g, 'this.formatter.formatUserPromptResult(') + .replace(/filterTimelineByDepth\(/g, 'this.timeline.filterByDepth(') + .replace(/\bsearch\./g, 'this.sessionSearch.') + .replace(/\bstore\./g, 'this.sessionStore.') + .replace(/queryChroma\(/g, 'this.queryChroma(') + .replace(/normalizeParams\(/g, 'this.normalizeParams(') + .replace(/chromaClient/g, 'this.chromaSync'); + + return ` /** + * Tool handler: ${toolName} + */ + async ${methodName}(args: any): Promise { +${processedBody} + }`; +}).join('\n\n'); + +const searchManagerContent = `/** + * SearchManager - Core search orchestration for claude-mem + * Extracted from mcp-server.ts to centralize business logic in Worker services + * + * This class contains all tool handler logic that was previously in the MCP server. + * The MCP server now acts as a thin HTTP wrapper that calls these methods via HTTP. + */ + +import { SessionSearch } from '../sqlite/SessionSearch.js'; +import { SessionStore } from '../sqlite/SessionStore.js'; +import { ChromaSync } from '../sync/ChromaSync.js'; +import { FormattingService } from './FormattingService.js'; +import { TimelineService, TimelineItem } from './TimelineService.js'; +import { ObservationSearchResult, SessionSummarySearchResult, UserPromptSearchResult } from '../sqlite/types.js'; +import { silentDebug } from '../../utils/silent-debug.js'; + +const COLLECTION_NAME = 'cm__claude-mem'; + +export class SearchManager { + constructor( + private sessionSearch: SessionSearch, + private sessionStore: SessionStore, + private chromaSync: ChromaSync, + private formatter: FormattingService, + private timeline: TimelineService + ) {} + + /** + * Query Chroma vector database via ChromaSync + */ + private async queryChroma( + query: string, + limit: number, + whereFilter?: Record + ): Promise<{ ids: number[]; distances: number[]; metadatas: any[] }> { + return await this.chromaSync.queryChroma(query, limit, whereFilter); + } + + /** + * Helper to normalize query parameters from URL-friendly format + * Converts comma-separated strings to arrays and flattens date params + */ + private normalizeParams(args: any): any { + const normalized: any = { ...args }; + + // Parse comma-separated concepts into array + if (normalized.concepts && typeof normalized.concepts === 'string') { + normalized.concepts = normalized.concepts.split(',').map((s: string) => s.trim()).filter(Boolean); + } + + // Parse comma-separated files into array + if (normalized.files && typeof normalized.files === 'string') { + normalized.files = normalized.files.split(',').map((s: string) => s.trim()).filter(Boolean); + } + + // Parse comma-separated obs_type into array + if (normalized.obs_type && typeof normalized.obs_type === 'string') { + normalized.obs_type = normalized.obs_type.split(',').map((s: string) => s.trim()).filter(Boolean); + } + + // Parse comma-separated type (for filterSchema) into array + if (normalized.type && typeof normalized.type === 'string' && normalized.type.includes(',')) { + normalized.type = normalized.type.split(',').map((s: string) => s.trim()).filter(Boolean); + } + + // Flatten dateStart/dateEnd into dateRange object + if (normalized.dateStart || normalized.dateEnd) { + normalized.dateRange = { + start: normalized.dateStart, + end: normalized.dateEnd + }; + delete normalized.dateStart; + delete normalized.dateEnd; + } + + return normalized; + } + +${methodBodies} +} +`; + +writeFileSync(outputPath, searchManagerContent, 'utf-8'); + +console.log(`\n✅ SearchManager.ts generated at ${outputPath}`); +console.log(` Total methods: ${Object.keys(handlers).length + 2} (${Object.keys(handlers).length} tools + queryChroma + normalizeParams)`); +console.log(` File size: ${(searchManagerContent.length / 1024).toFixed(1)} KB`); diff --git a/src/servers/search-server.ts b/src/servers/mcp-server.ts similarity index 100% rename from src/servers/search-server.ts rename to src/servers/mcp-server.ts diff --git a/src/services/sync/ChromaSync.ts b/src/services/sync/ChromaSync.ts index a80dc50d..869d9514 100644 --- a/src/services/sync/ChromaSync.ts +++ b/src/services/sync/ChromaSync.ts @@ -729,6 +729,79 @@ export class ChromaSync { } } + /** + * Query Chroma collection for semantic search + * Used by SearchManager for vector-based search + */ + async queryChroma( + query: string, + limit: number, + whereFilter?: Record + ): Promise<{ ids: number[]; distances: number[]; metadatas: any[] }> { + await this.ensureConnection(); + + if (!this.client) { + throw new Error('Chroma client not initialized'); + } + + const whereStringified = whereFilter ? JSON.stringify(whereFilter) : undefined; + + const arguments_obj = { + collection_name: this.collectionName, + query_texts: [query], + n_results: limit, + include: ['documents', 'metadatas', 'distances'], + where: whereStringified + }; + + const result = await this.client.callTool({ + name: 'chroma_query_documents', + arguments: arguments_obj + }); + + const resultText = result.content[0]?.text || ''; + + // Parse JSON response + let parsed: any; + try { + parsed = JSON.parse(resultText); + } catch (error) { + logger.error('CHROMA_SYNC', 'Failed to parse Chroma response', { project: this.project }, error as Error); + return { ids: [], distances: [], metadatas: [] }; + } + + // Extract unique IDs from document IDs + const ids: number[] = []; + const docIds = parsed.ids?.[0] || []; + for (const docId of docIds) { + // Extract sqlite_id from document ID (supports three formats): + // - obs_{id}_narrative, obs_{id}_fact_0, etc (observations) + // - summary_{id}_request, summary_{id}_learned, etc (session summaries) + // - prompt_{id} (user prompts) + const obsMatch = docId.match(/obs_(\d+)_/); + const summaryMatch = docId.match(/summary_(\d+)_/); + const promptMatch = docId.match(/prompt_(\d+)/); + + let sqliteId: number | null = null; + if (obsMatch) { + sqliteId = parseInt(obsMatch[1], 10); + } else if (summaryMatch) { + sqliteId = parseInt(summaryMatch[1], 10); + } else if (promptMatch) { + sqliteId = parseInt(promptMatch[1], 10); + } + + if (sqliteId !== null && !ids.includes(sqliteId)) { + ids.push(sqliteId); + } + } + + const distances = parsed.distances?.[0] || []; + const metadatas = parsed.metadatas?.[0] || []; + + return { ids, distances, metadatas }; + } + /** * Close the Chroma client connection */ diff --git a/src/services/worker-service.ts b/src/services/worker-service.ts index 69aa50a3..ef76b3ac 100644 --- a/src/services/worker-service.ts +++ b/src/services/worker-service.ts @@ -169,16 +169,16 @@ export class WorkerService { // Initialize database (once, stays open) await this.dbManager.initialize(); - // Connect to MCP search server - const searchServerPath = path.join(__dirname, '..', '..', 'plugin', 'scripts', 'search-server.cjs'); + // Connect to MCP server + const mcpServerPath = path.join(__dirname, '..', '..', 'plugin', 'scripts', 'mcp-server.cjs'); const transport = new StdioClientTransport({ command: 'node', - args: [searchServerPath], + args: [mcpServerPath], env: process.env }); await this.mcpClient.connect(transport); - logger.success('WORKER', 'Connected to MCP search server'); + logger.success('WORKER', 'Connected to MCP server'); } /** @@ -188,7 +188,7 @@ export class WorkerService { // Shutdown all active sessions await this.sessionManager.shutdownAll(); - // Close MCP client connection (terminates search server process) + // Close MCP client connection (terminates MCP server process) if (this.mcpClient) { try { await this.mcpClient.close(); diff --git a/src/services/worker/FormattingService.ts b/src/services/worker/FormattingService.ts new file mode 100644 index 00000000..980543a2 --- /dev/null +++ b/src/services/worker/FormattingService.ts @@ -0,0 +1,233 @@ +/** + * FormattingService - Handles all formatting logic for search results + * Extracted from mcp-server.ts to follow worker service organization pattern + */ + +import { ObservationSearchResult, SessionSummarySearchResult, UserPromptSearchResult } from '../sqlite/types.js'; + +export type FormatType = 'index' | 'full'; + +export class FormattingService { + /** + * Format search tips footer + */ + formatSearchTips(): string { + return `\n--- +💡 Search Strategy: +ALWAYS search with index format FIRST to get an overview and identify relevant results. +This is critical for token efficiency - index format uses ~10x fewer tokens than full format. + +Search workflow: +1. Initial search: Use default (index) format to see titles, dates, and sources +2. Review results: Identify which items are most relevant to your needs +3. Deep dive: Only then use format: "full" on specific items of interest +4. Narrow down: Use filters (type, dateStart/dateEnd, concepts, files) to refine results + +Other tips: +• To search by concept: Use find_by_concept tool +• To browse by type: Use find_by_type with ["decision", "feature", etc.] +• To sort by date: Use orderBy: "date_desc" or "date_asc"`; + } + + /** + * Format observation as index entry (title, date, ID only) + */ + formatObservationIndex(obs: ObservationSearchResult, index: number): string { + const title = obs.title || `Observation #${obs.id}`; + const date = new Date(obs.created_at_epoch).toLocaleString(); + const type = obs.type ? `[${obs.type}]` : ''; + + return `${index + 1}. ${type} ${title} + Date: ${date} + Source: claude-mem://observation/${obs.id}`; + } + + /** + * Format session summary as index entry (title, date, ID only) + */ + formatSessionIndex(session: SessionSummarySearchResult, index: number): string { + const title = session.request || `Session ${session.sdk_session_id?.substring(0, 8) || 'unknown'}`; + const date = new Date(session.created_at_epoch).toLocaleString(); + + return `${index + 1}. ${title} + Date: ${date} + Source: claude-mem://session/${session.sdk_session_id}`; + } + + /** + * Format user prompt as index entry (full text - don't truncate context!) + */ + formatUserPromptIndex(prompt: UserPromptSearchResult, index: number): string { + const date = new Date(prompt.created_at_epoch).toLocaleString(); + + return `${index + 1}. "${prompt.prompt_text}" + Date: ${date} | Prompt #${prompt.prompt_number} + Source: claude-mem://user-prompt/${prompt.id}`; + } + + /** + * Format observation as text content with metadata + */ + formatObservationResult(obs: ObservationSearchResult): string { + const title = obs.title || `Observation #${obs.id}`; + + // Build content from available fields + const contentParts: string[] = []; + contentParts.push(`## ${title}`); + contentParts.push(`*Source: claude-mem://observation/${obs.id}*`); + contentParts.push(''); + + if (obs.subtitle) { + contentParts.push(`**${obs.subtitle}**`); + contentParts.push(''); + } + + if (obs.narrative) { + contentParts.push(obs.narrative); + contentParts.push(''); + } + + if (obs.text) { + contentParts.push(obs.text); + contentParts.push(''); + } + + // Add metadata + const metadata: string[] = []; + metadata.push(`Type: ${obs.type}`); + + if (obs.facts) { + try { + const facts = JSON.parse(obs.facts); + if (facts.length > 0) { + metadata.push(`Facts: ${facts.join('; ')}`); + } + } catch {} + } + + if (obs.concepts) { + try { + const concepts = JSON.parse(obs.concepts); + if (concepts.length > 0) { + metadata.push(`Concepts: ${concepts.join(', ')}`); + } + } catch {} + } + + if (obs.files_read || obs.files_modified) { + const files: string[] = []; + if (obs.files_read) { + try { + files.push(...JSON.parse(obs.files_read)); + } catch {} + } + if (obs.files_modified) { + try { + files.push(...JSON.parse(obs.files_modified)); + } catch {} + } + if (files.length > 0) { + metadata.push(`Files: ${[...new Set(files)].join(', ')}`); + } + } + + if (metadata.length > 0) { + contentParts.push('---'); + contentParts.push(metadata.join(' | ')); + } + + // Add date + const date = new Date(obs.created_at_epoch).toLocaleString(); + contentParts.push(''); + contentParts.push(`---`); + contentParts.push(`Date: ${date}`); + + return contentParts.join('\n'); + } + + /** + * Format session summary as text content with metadata + */ + formatSessionResult(session: SessionSummarySearchResult): string { + const title = session.request || `Session ${session.sdk_session_id?.substring(0, 8) || 'unknown'}`; + + // Build content from available fields + const contentParts: string[] = []; + contentParts.push(`## ${title}`); + contentParts.push(`*Source: claude-mem://session/${session.sdk_session_id}*`); + contentParts.push(''); + + if (session.completed) { + contentParts.push(`**Completed:** ${session.completed}`); + contentParts.push(''); + } + + if (session.learned) { + contentParts.push(`**Learned:** ${session.learned}`); + contentParts.push(''); + } + + if (session.investigated) { + contentParts.push(`**Investigated:** ${session.investigated}`); + contentParts.push(''); + } + + if (session.next_steps) { + contentParts.push(`**Next Steps:** ${session.next_steps}`); + contentParts.push(''); + } + + if (session.notes) { + contentParts.push(`**Notes:** ${session.notes}`); + contentParts.push(''); + } + + // Add metadata + const metadata: string[] = []; + + if (session.files_read || session.files_edited) { + const files: string[] = []; + if (session.files_read) { + try { + files.push(...JSON.parse(session.files_read)); + } catch {} + } + if (session.files_edited) { + try { + files.push(...JSON.parse(session.files_edited)); + } catch {} + } + if (files.length > 0) { + metadata.push(`Files: ${[...new Set(files)].join(', ')}`); + } + } + + const date = new Date(session.created_at_epoch).toLocaleDateString(); + metadata.push(`Date: ${date}`); + + if (metadata.length > 0) { + contentParts.push('---'); + contentParts.push(metadata.join(' | ')); + } + + return contentParts.join('\n'); + } + + /** + * Format user prompt as text content with metadata + */ + formatUserPromptResult(prompt: UserPromptSearchResult): string { + const contentParts: string[] = []; + contentParts.push(`## User Prompt #${prompt.prompt_number}`); + contentParts.push(`*Source: claude-mem://user-prompt/${prompt.id}*`); + contentParts.push(''); + contentParts.push(prompt.prompt_text); + contentParts.push(''); + contentParts.push('---'); + + const date = new Date(prompt.created_at_epoch).toLocaleString(); + contentParts.push(`Date: ${date}`); + + return contentParts.join('\n'); + } +} diff --git a/src/services/worker/SearchManager.ts b/src/services/worker/SearchManager.ts new file mode 100644 index 00000000..ca7ec272 --- /dev/null +++ b/src/services/worker/SearchManager.ts @@ -0,0 +1,2095 @@ +/** + * SearchManager - Core search orchestration for claude-mem + * Extracted from mcp-server.ts to centralize business logic in Worker services + * + * This class contains all tool handler logic that was previously in the MCP server. + * The MCP server now acts as a thin HTTP wrapper that calls these methods via HTTP. + */ + +import { SessionSearch } from '../sqlite/SessionSearch.js'; +import { SessionStore } from '../sqlite/SessionStore.js'; +import { ChromaSync } from '../sync/ChromaSync.js'; +import { FormattingService } from './FormattingService.js'; +import { TimelineService, TimelineItem } from './TimelineService.js'; +import { ObservationSearchResult, SessionSummarySearchResult, UserPromptSearchResult } from '../sqlite/types.js'; +import { silentDebug } from '../../utils/silent-debug.js'; + +const COLLECTION_NAME = 'cm__claude-mem'; + +export class SearchManager { + constructor( + private sessionSearch: SessionSearch, + private sessionStore: SessionStore, + private chromaSync: ChromaSync, + private formatter: FormattingService, + private timeline: TimelineService + ) {} + + /** + * Query Chroma vector database via ChromaSync + */ + private async queryChroma( + query: string, + limit: number, + whereFilter?: Record + ): Promise<{ ids: number[]; distances: number[]; metadatas: any[] }> { + return await this.chromaSync.queryChroma(query, limit, whereFilter); + } + + /** + * Helper to normalize query parameters from URL-friendly format + * Converts comma-separated strings to arrays and flattens date params + */ + private normalizeParams(args: any): any { + const normalized: any = { ...args }; + + // Parse comma-separated concepts into array + if (normalized.concepts && typeof normalized.concepts === 'string') { + normalized.concepts = normalized.concepts.split(',').map((s: string) => s.trim()).filter(Boolean); + } + + // Parse comma-separated files into array + if (normalized.files && typeof normalized.files === 'string') { + normalized.files = normalized.files.split(',').map((s: string) => s.trim()).filter(Boolean); + } + + // Parse comma-separated obs_type into array + if (normalized.obs_type && typeof normalized.obs_type === 'string') { + normalized.obs_type = normalized.obs_type.split(',').map((s: string) => s.trim()).filter(Boolean); + } + + // Parse comma-separated type (for filterSchema) into array + if (normalized.type && typeof normalized.type === 'string' && normalized.type.includes(',')) { + normalized.type = normalized.type.split(',').map((s: string) => s.trim()).filter(Boolean); + } + + // Flatten dateStart/dateEnd into dateRange object + if (normalized.dateStart || normalized.dateEnd) { + normalized.dateRange = { + start: normalized.dateStart, + end: normalized.dateEnd + }; + delete normalized.dateStart; + delete normalized.dateEnd; + } + + return normalized; + } + + /** + * Tool handler: search + */ + async search(args: any): Promise { + try { + // Normalize URL-friendly params to internal format + const normalized = this.normalizeParams(args); + const { query, format = 'index', type, obs_type, concepts, files, ...options } = normalized; + let observations: ObservationSearchResult[] = []; + let sessions: SessionSummarySearchResult[] = []; + let prompts: UserPromptSearchResult[] = []; + + // Determine which types to query based on type filter + const searchObservations = !type || type === 'observations'; + const searchSessions = !type || type === 'sessions'; + const searchPrompts = !type || type === 'prompts'; + + // PATH 1: FILTER-ONLY (no query text) - Skip Chroma/FTS5, use direct SQLite filtering + // This path enables date filtering which Chroma cannot do (requires direct SQLite access) + if (!query) { + silentDebug(`[search-server] Filter-only query (no query text), using direct SQLite filtering (enables date filters)`); + const obsOptions = { ...options, type: obs_type, concepts, files }; + if (searchObservations) { + observations = this.sessionSearch.searchObservations(undefined, obsOptions); + } + if (searchSessions) { + sessions = this.sessionSearch.searchSessions(undefined, options); + } + if (searchPrompts) { + prompts = this.sessionSearch.searchUserPrompts(undefined, options); + } + } + // PATH 2: CHROMA SEMANTIC SEARCH (query text + Chroma available) + else if (this.chromaSync) { + let chromaSucceeded = false; + try { + silentDebug(`[search-server] Using ChromaDB semantic search (type filter: ${type || 'all'})`); + + // Build Chroma where filter for doc_type + let whereFilter: Record | undefined; + if (type === 'observations') { + whereFilter = { doc_type: 'observation' }; + } else if (type === 'sessions') { + whereFilter = { doc_type: 'session_summary' }; + } else if (type === 'prompts') { + whereFilter = { doc_type: 'user_prompt' }; + } + + // Step 1: Chroma semantic search with optional type filter + const chromaResults = await this.queryChroma(query, 100, whereFilter); + chromaSucceeded = true; // Chroma didn't throw error + silentDebug(`[search-server] ChromaDB returned ${chromaResults.ids.length} semantic matches`); + + if (chromaResults.ids.length > 0) { + // Step 2: Filter by recency (90 days) + const ninetyDaysAgo = Date.now() - (90 * 24 * 60 * 60 * 1000); + const recentMetadata = chromaResults.metadatas.map((meta, idx) => ({ + id: chromaResults.ids[idx], + meta, + isRecent: meta && meta.created_at_epoch > ninetyDaysAgo + })).filter(item => item.isRecent); + + silentDebug(`[search-server] ${recentMetadata.length} results within 90-day window`); + + // Step 3: Categorize IDs by document type + const obsIds: number[] = []; + const sessionIds: number[] = []; + const promptIds: number[] = []; + + for (const item of recentMetadata) { + const docType = item.meta?.doc_type; + if (docType === 'observation' && searchObservations) { + obsIds.push(item.id); + } else if (docType === 'session_summary' && searchSessions) { + sessionIds.push(item.id); + } else if (docType === 'user_prompt' && searchPrompts) { + promptIds.push(item.id); + } + } + + silentDebug(`[search-server] Categorized: ${obsIds.length} obs, ${sessionIds.length} sessions, ${promptIds.length} prompts`); + + // Step 4: Hydrate from SQLite with additional filters + if (obsIds.length > 0) { + // Apply obs_type, concepts, files filters if provided + const obsOptions = { ...options, type: obs_type, concepts, files }; + observations = this.sessionStore.getObservationsByIds(obsIds, obsOptions); + } + if (sessionIds.length > 0) { + sessions = this.sessionStore.getSessionSummariesByIds(sessionIds, { orderBy: 'date_desc', limit: options.limit }); + } + if (promptIds.length > 0) { + prompts = this.sessionStore.getUserPromptsByIds(promptIds, { orderBy: 'date_desc', limit: options.limit }); + } + + silentDebug(`[search-server] Hydrated ${observations.length} obs, ${sessions.length} sessions, ${prompts.length} prompts from SQLite`); + } else { + // Chroma returned 0 results - this is the correct answer, don't fall back to FTS5 + silentDebug(`[search-server] ChromaDB found no matches (this is final - NOT falling back to FTS5)`); + } + } catch (chromaError: any) { + silentDebug('[search-server] ChromaDB failed - returning empty results (FTS5 fallback removed):', chromaError.message); + silentDebug('[search-server] Install UVX/Python to enable vector search: https://docs.astral.sh/uv/getting-started/installation/'); + // Return empty results - no fallback + observations = []; + sessions = []; + prompts = []; + } + } + // ChromaDB not initialized - return empty results (no fallback) + else { + silentDebug(`[search-server] ChromaDB not initialized - returning empty results (FTS5 fallback removed)`); + silentDebug(`[search-server] Install UVX/Python to enable vector search: https://docs.astral.sh/uv/getting-started/installation/`); + observations = []; + sessions = []; + prompts = []; + } + + const totalResults = observations.length + sessions.length + prompts.length; + + if (totalResults === 0) { + return { + content: [{ + type: 'text' as const, + text: `No results found matching "${query}"` + }] + }; + } + + // Combine all results with timestamps for unified sorting + interface CombinedResult { + type: 'observation' | 'session' | 'prompt'; + data: any; + epoch: number; + } + + const allResults: CombinedResult[] = [ + ...observations.map(obs => ({ type: 'observation' as const, data: obs, epoch: obs.created_at_epoch })), + ...sessions.map(sess => ({ type: 'session' as const, data: sess, epoch: sess.created_at_epoch })), + ...prompts.map(prompt => ({ type: 'prompt' as const, data: prompt, epoch: prompt.created_at_epoch })) + ]; + + // Sort by date (most recent first) + if (options.orderBy === 'date_desc') { + allResults.sort((a, b) => b.epoch - a.epoch); + } else if (options.orderBy === 'date_asc') { + allResults.sort((a, b) => a.epoch - b.epoch); + } + + // Apply limit across all types + const limitedResults = allResults.slice(0, options.limit || 20); + + // Format based on requested format + let combinedText: string; + if (format === 'index') { + const header = `Found ${totalResults} result(s) matching "${query}" (${observations.length} obs, ${sessions.length} sessions, ${prompts.length} prompts):\n\n`; + const formattedResults = limitedResults.map((item, i) => { + if (item.type === 'observation') { + return this.formatter.formatObservationIndex(item.data, i); + } else if (item.type === 'session') { + return this.formatter.formatSessionIndex(item.data, i); + } else { + return this.formatter.formatUserPromptIndex(item.data, i); + } + }); + combinedText = header + formattedResults.join('\n\n') + this.formatter.formatSearchTips(); + } else { + const formattedResults = limitedResults.map(item => { + if (item.type === 'observation') { + return this.formatter.formatObservationResult(item.data); + } else if (item.type === 'session') { + return this.formatter.formatSessionResult(item.data); + } else { + return this.formatter.formatUserPromptResult(item.data); + } + }); + combinedText = formattedResults.join('\n\n---\n\n'); + } + + return { + content: [{ + type: 'text' as const, + text: combinedText + }] + }; + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Search failed: ${error.message}` + }], + isError: true + }; + } + } + + /** + * Tool handler: timeline + */ + async timeline(args: any): Promise { + try { + const { anchor, query, depth_before = 10, depth_after = 10, project } = args; + + // Validate: must provide either anchor or query, not both + if (!anchor && !query) { + return { + content: [{ + type: 'text' as const, + text: 'Error: Must provide either "anchor" or "query" parameter' + }], + isError: true + }; + } + + if (anchor && query) { + return { + content: [{ + type: 'text' as const, + text: 'Error: Cannot provide both "anchor" and "query" parameters. Use one or the other.' + }], + isError: true + }; + } + + let anchorId: string | number; + let anchorEpoch: number; + let timeline: any; + + // MODE 1: Query-based timeline + if (query) { + // Step 1: Search for observations + let results: ObservationSearchResult[] = []; + + if (this.chromaSync) { + try { + silentDebug('[search-server] Using hybrid semantic search for timeline query'); + const chromaResults = await this.queryChroma(query, 100); + silentDebug(`[search-server] Chroma returned ${chromaResults.ids.length} semantic matches`); + + if (chromaResults.ids.length > 0) { + const ninetyDaysAgo = Date.now() - (90 * 24 * 60 * 60 * 1000); + const recentIds = chromaResults.ids.filter((_id, idx) => { + const meta = chromaResults.metadatas[idx]; + return meta && meta.created_at_epoch > ninetyDaysAgo; + }); + + if (recentIds.length > 0) { + results = this.sessionStore.getObservationsByIds(recentIds, { orderBy: 'date_desc', limit: 1 }); + } + } + } catch (chromaError: any) { + silentDebug('[search-server] Chroma query failed - no results (FTS5 fallback removed):', chromaError.message); + } + } + + if (results.length === 0) { + return { + content: [{ + type: 'text' as const, + text: `No observations found matching "${query}". Try a different search query.` + }] + }; + } + + // Use top result as anchor + const topResult = results[0]; + anchorId = topResult.id; + anchorEpoch = topResult.created_at_epoch; + silentDebug(`[search-server] Query mode: Using observation #${topResult.id} as timeline anchor`); + timeline = this.sessionStore.getTimelineAroundObservation(topResult.id, topResult.created_at_epoch, depth_before, depth_after, project); + } + // MODE 2: Anchor-based timeline + else if (typeof anchor === 'number') { + // Observation ID + const obs = this.sessionStore.getObservationById(anchor); + if (!obs) { + return { + content: [{ + type: 'text' as const, + text: `Observation #${anchor} not found` + }], + isError: true + }; + } + anchorId = anchor; + anchorEpoch = obs.created_at_epoch; + timeline = this.sessionStore.getTimelineAroundObservation(anchor, anchorEpoch, depth_before, depth_after, project); + } else if (typeof anchor === 'string') { + // Session ID or ISO timestamp + if (anchor.startsWith('S') || anchor.startsWith('#S')) { + const sessionId = anchor.replace(/^#?S/, ''); + const sessionNum = parseInt(sessionId, 10); + const sessions = this.sessionStore.getSessionSummariesByIds([sessionNum]); + if (sessions.length === 0) { + return { + content: [{ + type: 'text' as const, + text: `Session #${sessionNum} not found` + }], + isError: true + }; + } + anchorEpoch = sessions[0].created_at_epoch; + anchorId = `S${sessionNum}`; + timeline = this.sessionStore.getTimelineAroundTimestamp(anchorEpoch, depth_before, depth_after, project); + } else { + // ISO timestamp + const date = new Date(anchor); + if (isNaN(date.getTime())) { + return { + content: [{ + type: 'text' as const, + text: `Invalid timestamp: ${anchor}` + }], + isError: true + }; + } + anchorEpoch = date.getTime(); + anchorId = anchor; + timeline = this.sessionStore.getTimelineAroundTimestamp(anchorEpoch, depth_before, depth_after, project); + } + } else { + return { + content: [{ + type: 'text' as const, + text: 'Invalid anchor: must be observation ID (number), session ID (e.g., "S123"), or ISO timestamp' + }], + isError: true + }; + } + + // Combine, sort, and filter timeline items + const items: TimelineItem[] = [ + ...timeline.observations.map((obs: any) => ({ type: 'observation' as const, data: obs, epoch: obs.created_at_epoch })), + ...timeline.sessions.map((sess: any) => ({ type: 'session' as const, data: sess, epoch: sess.created_at_epoch })), + ...timeline.prompts.map((prompt: any) => ({ type: 'prompt' as const, data: prompt, epoch: prompt.created_at_epoch })) + ]; + items.sort((a, b) => a.epoch - b.epoch); + const filteredItems = this.timeline.filterByDepth(items, anchorId, anchorEpoch, depth_before, depth_after); + + if (filteredItems.length === 0) { + return { + content: [{ + type: 'text' as const, + text: query + ? `Found observation matching "${query}", but no timeline context available (${depth_before} records before, ${depth_after} records after).` + : `No context found around anchor (${depth_before} records before, ${depth_after} records after)` + }] + }; + } + + // Format timeline (helper functions) + function formatDate(epochMs: number): string { + const date = new Date(epochMs); + return date.toLocaleString('en-US', { + month: 'short', + day: 'numeric', + year: 'numeric' + }); + } + + function formatTime(epochMs: number): string { + const date = new Date(epochMs); + return date.toLocaleString('en-US', { + hour: 'numeric', + minute: '2-digit', + hour12: true + }); + } + + function formatDateTime(epochMs: number): string { + const date = new Date(epochMs); + return date.toLocaleString('en-US', { + month: 'short', + day: 'numeric', + hour: 'numeric', + minute: '2-digit', + hour12: true + }); + } + + function estimateTokens(text: string | null): number { + if (!text) return 0; + return Math.ceil(text.length / 4); + } + + // Format results + const lines: string[] = []; + + // Header + if (query) { + const anchorObs = filteredItems.find(item => item.type === 'observation' && item.data.id === anchorId); + const anchorTitle = anchorObs ? (anchorObs.data.title || 'Untitled') : 'Unknown'; + lines.push(`# Timeline for query: "${query}"`); + lines.push(`**Anchor:** Observation #${anchorId} - ${anchorTitle}`); + } else { + lines.push(`# Timeline around anchor: ${anchorId}`); + } + + lines.push(`**Window:** ${depth_before} records before → ${depth_after} records after | **Items:** ${filteredItems.length}`); + lines.push(''); + + // Legend + lines.push(`**Legend:** 🎯 session-request | 🔴 bugfix | 🟣 feature | 🔄 refactor | ✅ change | 🔵 discovery | 🧠 decision`); + lines.push(''); + + // Group by day + const dayMap = new Map(); + for (const item of filteredItems) { + const day = formatDate(item.epoch); + if (!dayMap.has(day)) { + dayMap.set(day, []); + } + dayMap.get(day)!.push(item); + } + + // Sort days chronologically + const sortedDays = Array.from(dayMap.entries()).sort((a, b) => { + const aDate = new Date(a[0]).getTime(); + const bDate = new Date(b[0]).getTime(); + return aDate - bDate; + }); + + // Render each day + for (const [day, dayItems] of sortedDays) { + lines.push(`### ${day}`); + lines.push(''); + + let currentFile: string | null = null; + let lastTime = ''; + let tableOpen = false; + + for (const item of dayItems) { + const isAnchor = ( + (typeof anchorId === 'number' && item.type === 'observation' && item.data.id === anchorId) || + (typeof anchorId === 'string' && anchorId.startsWith('S') && item.type === 'session' && `S${item.data.id}` === anchorId) + ); + + if (item.type === 'session') { + if (tableOpen) { + lines.push(''); + tableOpen = false; + currentFile = null; + lastTime = ''; + } + + const sess = item.data; + const title = sess.request || 'Session summary'; + const link = `claude-mem://session-summary/${sess.id}`; + const marker = isAnchor ? ' ← **ANCHOR**' : ''; + + lines.push(`**🎯 #S${sess.id}** ${title} (${formatDateTime(item.epoch)}) [→](${link})${marker}`); + lines.push(''); + } else if (item.type === 'prompt') { + if (tableOpen) { + lines.push(''); + tableOpen = false; + currentFile = null; + lastTime = ''; + } + + const prompt = item.data; + const truncated = prompt.prompt.length > 100 ? prompt.prompt.substring(0, 100) + '...' : prompt.prompt; + + lines.push(`**💬 User Prompt #${prompt.prompt_number}** (${formatDateTime(item.epoch)})`); + lines.push(`> ${truncated}`); + lines.push(''); + } else if (item.type === 'observation') { + const obs = item.data; + const file = 'General'; + + if (file !== currentFile) { + if (tableOpen) { + lines.push(''); + } + + lines.push(`**${file}**`); + lines.push(`| ID | Time | T | Title | Tokens |`); + lines.push(`|----|------|---|-------|--------|`); + + currentFile = file; + tableOpen = true; + lastTime = ''; + } + + let icon = '•'; + switch (obs.type) { + case 'bugfix': icon = '🔴'; break; + case 'feature': icon = '🟣'; break; + case 'refactor': icon = '🔄'; break; + case 'change': icon = '✅'; break; + case 'discovery': icon = '🔵'; break; + case 'decision': icon = '🧠'; break; + } + + const time = formatTime(item.epoch); + const title = obs.title || 'Untitled'; + const tokens = estimateTokens(obs.narrative); + + const showTime = time !== lastTime; + const timeDisplay = showTime ? time : '″'; + lastTime = time; + + const anchorMarker = isAnchor ? ' ← **ANCHOR**' : ''; + lines.push(`| #${obs.id} | ${timeDisplay} | ${icon} | ${title}${anchorMarker} | ~${tokens} |`); + } + } + + if (tableOpen) { + lines.push(''); + } + } + + return { + content: [{ + type: 'text' as const, + text: lines.join('\n') + }] + }; + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Timeline query failed: ${error.message}` + }], + isError: true + }; + } + } + + /** + * Tool handler: decisions + */ + async decisions(args: any): Promise { + try { + const normalized = this.normalizeParams(args); + const { query, format = 'index', ...filters } = normalized; + let results: ObservationSearchResult[] = []; + + // Search for decision-type observations + if (this.chromaSync) { + try { + if (query) { + // Semantic search filtered to decision type + silentDebug('[search-server] Using Chroma semantic search with type=decision filter'); + const chromaResults = await this.queryChroma(query, Math.min((filters.limit || 20) * 2, 100), { type: 'decision' }); + const obsIds = chromaResults.ids; + + if (obsIds.length > 0) { + results = this.sessionStore.getObservationsByIds(obsIds, { ...filters, type: 'decision' }); + // Preserve Chroma ranking order + results.sort((a, b) => obsIds.indexOf(a.id) - obsIds.indexOf(b.id)); + } + } else { + // No query: get all decisions, rank by "decision" keyword + silentDebug('[search-server] Using metadata-first + semantic ranking for decisions'); + const metadataResults = this.sessionSearch.findByType('decision', filters); + + if (metadataResults.length > 0) { + const ids = metadataResults.map(obs => obs.id); + const chromaResults = await this.queryChroma('decision', Math.min(ids.length, 100)); + + const rankedIds: number[] = []; + for (const chromaId of chromaResults.ids) { + if (ids.includes(chromaId) && !rankedIds.includes(chromaId)) { + rankedIds.push(chromaId); + } + } + + if (rankedIds.length > 0) { + results = this.sessionStore.getObservationsByIds(rankedIds, { limit: filters.limit || 20 }); + results.sort((a, b) => rankedIds.indexOf(a.id) - rankedIds.indexOf(b.id)); + } + } + } + } catch (chromaError: any) { + silentDebug('[search-server] Chroma search failed, using SQLite fallback:', chromaError.message); + } + } + + if (results.length === 0) { + results = this.sessionSearch.findByType('decision', filters); + } + + if (results.length === 0) { + return { + content: [{ + type: 'text' as const, + text: 'No decision observations found' + }] + }; + } + + let combinedText: string; + if (format === 'index') { + const header = `Found ${results.length} decision(s):\n\n`; + const formattedResults = results.map((obs, i) => this.formatter.formatObservationIndex(obs, i)); + combinedText = header + formattedResults.join('\n\n'); + } else { + const formattedResults = results.map((obs) => this.formatter.formatObservationResult(obs)); + combinedText = formattedResults.join('\n\n---\n\n'); + } + + return { + content: [{ + type: 'text' as const, + text: combinedText + }] + }; + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Search failed: ${error.message}` + }], + isError: true + }; + } + } + + /** + * Tool handler: changes + */ + async changes(args: any): Promise { + try { + const normalized = this.normalizeParams(args); + const { format = 'index', ...filters } = normalized; + let results: ObservationSearchResult[] = []; + + // Search for change-type observations and change-related concepts + if (this.chromaSync) { + try { + silentDebug('[search-server] Using hybrid search for change-related observations'); + + // Get all observations with type="change" or concepts containing change + const typeResults = this.sessionSearch.findByType('change', filters); + const conceptChangeResults = this.sessionSearch.findByConcept('change', filters); + const conceptWhatChangedResults = this.sessionSearch.findByConcept('what-changed', filters); + + // Combine and deduplicate + const allIds = new Set(); + [...typeResults, ...conceptChangeResults, ...conceptWhatChangedResults].forEach(obs => allIds.add(obs.id)); + + if (allIds.size > 0) { + const idsArray = Array.from(allIds); + const chromaResults = await this.queryChroma('what changed', Math.min(idsArray.length, 100)); + + const rankedIds: number[] = []; + for (const chromaId of chromaResults.ids) { + if (idsArray.includes(chromaId) && !rankedIds.includes(chromaId)) { + rankedIds.push(chromaId); + } + } + + if (rankedIds.length > 0) { + results = this.sessionStore.getObservationsByIds(rankedIds, { limit: filters.limit || 20 }); + results.sort((a, b) => rankedIds.indexOf(a.id) - rankedIds.indexOf(b.id)); + } + } + } catch (chromaError: any) { + silentDebug('[search-server] Chroma ranking failed, using SQLite order:', chromaError.message); + } + } + + if (results.length === 0) { + const typeResults = this.sessionSearch.findByType('change', filters); + const conceptResults = this.sessionSearch.findByConcept('change', filters); + const whatChangedResults = this.sessionSearch.findByConcept('what-changed', filters); + + const allIds = new Set(); + [...typeResults, ...conceptResults, ...whatChangedResults].forEach(obs => allIds.add(obs.id)); + + results = Array.from(allIds).map(id => + typeResults.find(obs => obs.id === id) || + conceptResults.find(obs => obs.id === id) || + whatChangedResults.find(obs => obs.id === id) + ).filter(Boolean) as ObservationSearchResult[]; + + results.sort((a, b) => b.created_at_epoch - a.created_at_epoch); + results = results.slice(0, filters.limit || 20); + } + + if (results.length === 0) { + return { + content: [{ + type: 'text' as const, + text: 'No change-related observations found' + }] + }; + } + + let combinedText: string; + if (format === 'index') { + const header = `Found ${results.length} change-related observation(s):\n\n`; + const formattedResults = results.map((obs, i) => this.formatter.formatObservationIndex(obs, i)); + combinedText = header + formattedResults.join('\n\n'); + } else { + const formattedResults = results.map((obs) => this.formatter.formatObservationResult(obs)); + combinedText = formattedResults.join('\n\n---\n\n'); + } + + return { + content: [{ + type: 'text' as const, + text: combinedText + }] + }; + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Search failed: ${error.message}` + }], + isError: true + }; + } + } + + /** + * Tool handler: how_it_works + */ + async howItWorks(args: any): Promise { + try { + const normalized = this.normalizeParams(args); + const { format = 'index', ...filters } = normalized; + let results: ObservationSearchResult[] = []; + + // Search for how-it-works concept observations + if (this.chromaSync) { + try { + silentDebug('[search-server] Using metadata-first + semantic ranking for how-it-works'); + const metadataResults = this.sessionSearch.findByConcept('how-it-works', filters); + + if (metadataResults.length > 0) { + const ids = metadataResults.map(obs => obs.id); + const chromaResults = await this.queryChroma('how it works architecture', Math.min(ids.length, 100)); + + const rankedIds: number[] = []; + for (const chromaId of chromaResults.ids) { + if (ids.includes(chromaId) && !rankedIds.includes(chromaId)) { + rankedIds.push(chromaId); + } + } + + if (rankedIds.length > 0) { + results = this.sessionStore.getObservationsByIds(rankedIds, { limit: filters.limit || 20 }); + results.sort((a, b) => rankedIds.indexOf(a.id) - rankedIds.indexOf(b.id)); + } + } + } catch (chromaError: any) { + silentDebug('[search-server] Chroma ranking failed, using SQLite order:', chromaError.message); + } + } + + if (results.length === 0) { + results = this.sessionSearch.findByConcept('how-it-works', filters); + } + + if (results.length === 0) { + return { + content: [{ + type: 'text' as const, + text: 'No "how it works" observations found' + }] + }; + } + + let combinedText: string; + if (format === 'index') { + const header = `Found ${results.length} "how it works" observation(s):\n\n`; + const formattedResults = results.map((obs, i) => this.formatter.formatObservationIndex(obs, i)); + combinedText = header + formattedResults.join('\n\n'); + } else { + const formattedResults = results.map((obs) => this.formatter.formatObservationResult(obs)); + combinedText = formattedResults.join('\n\n---\n\n'); + } + + return { + content: [{ + type: 'text' as const, + text: combinedText + }] + }; + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Search failed: ${error.message}` + }], + isError: true + }; + } + } + + /** + * Tool handler: search_observations + */ + async searchObservations(args: any): Promise { + try { + const normalized = this.normalizeParams(args); + const { query, format = 'index', ...options } = normalized; + let results: ObservationSearchResult[] = []; + + // Vector-first search via ChromaDB + if (this.chromaSync) { + try { + silentDebug('[search-server] Using hybrid semantic search (Chroma + SQLite)'); + + // Step 1: Chroma semantic search (top 100) + const chromaResults = await this.queryChroma(query, 100); + silentDebug(`[search-server] Chroma returned ${chromaResults.ids.length} semantic matches`); + + if (chromaResults.ids.length > 0) { + // Step 2: Filter by recency (90 days) + const ninetyDaysAgo = Date.now() - (90 * 24 * 60 * 60 * 1000); + const recentIds = chromaResults.ids.filter((_id, idx) => { + const meta = chromaResults.metadatas[idx]; + return meta && meta.created_at_epoch > ninetyDaysAgo; + }); + + silentDebug(`[search-server] ${recentIds.length} results within 90-day window`); + + // Step 3: Hydrate from SQLite in temporal order + if (recentIds.length > 0) { + const limit = options.limit || 20; + results = this.sessionStore.getObservationsByIds(recentIds, { orderBy: 'date_desc', limit }); + silentDebug(`[search-server] Hydrated ${results.length} observations from SQLite`); + } + } + } catch (chromaError: any) { + silentDebug('[search-server] Chroma query failed - no results (FTS5 fallback removed):', chromaError.message); + } + } + + if (results.length === 0) { + return { + content: [{ + type: 'text' as const, + text: `No observations found matching "${query}"` + }] + }; + } + + // Format based on requested format + let combinedText: string; + if (format === 'index') { + const header = `Found ${results.length} observation(s) matching "${query}":\n\n`; + const formattedResults = results.map((obs, i) => this.formatter.formatObservationIndex(obs, i)); + combinedText = header + formattedResults.join('\n\n') + this.formatter.formatSearchTips(); + } else { + const formattedResults = results.map((obs) => this.formatter.formatObservationResult(obs)); + combinedText = formattedResults.join('\n\n---\n\n'); + } + + return { + content: [{ + type: 'text' as const, + text: combinedText + }] + }; + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Search failed: ${error.message}` + }], + isError: true + }; + } + } + + /** + * Tool handler: search_sessions + */ + async searchSessions(args: any): Promise { + try { + const normalized = this.normalizeParams(args); + const { query, format = 'index', ...options } = normalized; + let results: SessionSummarySearchResult[] = []; + + // Vector-first search via ChromaDB + if (this.chromaSync) { + try { + silentDebug('[search-server] Using hybrid semantic search for sessions'); + + // Step 1: Chroma semantic search (top 100) + const chromaResults = await this.queryChroma(query, 100, { doc_type: 'session_summary' }); + silentDebug(`[search-server] Chroma returned ${chromaResults.ids.length} semantic matches`); + + if (chromaResults.ids.length > 0) { + // Step 2: Filter by recency (90 days) + const ninetyDaysAgo = Date.now() - (90 * 24 * 60 * 60 * 1000); + const recentIds = chromaResults.ids.filter((_id, idx) => { + const meta = chromaResults.metadatas[idx]; + return meta && meta.created_at_epoch > ninetyDaysAgo; + }); + + silentDebug(`[search-server] ${recentIds.length} results within 90-day window`); + + // Step 3: Hydrate from SQLite in temporal order + if (recentIds.length > 0) { + const limit = options.limit || 20; + results = this.sessionStore.getSessionSummariesByIds(recentIds, { orderBy: 'date_desc', limit }); + silentDebug(`[search-server] Hydrated ${results.length} sessions from SQLite`); + } + } + } catch (chromaError: any) { + silentDebug('[search-server] Chroma query failed - no results (FTS5 fallback removed):', chromaError.message); + } + } + + if (results.length === 0) { + return { + content: [{ + type: 'text' as const, + text: `No sessions found matching "${query}"` + }] + }; + } + + // Format based on requested format + let combinedText: string; + if (format === 'index') { + const header = `Found ${results.length} session(s) matching "${query}":\n\n`; + const formattedResults = results.map((session, i) => this.formatter.formatSessionIndex(session, i)); + combinedText = header + formattedResults.join('\n\n') + this.formatter.formatSearchTips(); + } else { + const formattedResults = results.map((session) => this.formatter.formatSessionResult(session)); + combinedText = formattedResults.join('\n\n---\n\n'); + } + + return { + content: [{ + type: 'text' as const, + text: combinedText + }] + }; + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Search failed: ${error.message}` + }], + isError: true + }; + } + } + + /** + * Tool handler: search_user_prompts + */ + async searchUserPrompts(args: any): Promise { + try { + const normalized = this.normalizeParams(args); + const { query, format = 'index', ...options } = normalized; + let results: UserPromptSearchResult[] = []; + + // Vector-first search via ChromaDB + if (this.chromaSync) { + try { + silentDebug('[search-server] Using hybrid semantic search for user prompts'); + + // Step 1: Chroma semantic search (top 100) + const chromaResults = await this.queryChroma(query, 100, { doc_type: 'user_prompt' }); + silentDebug(`[search-server] Chroma returned ${chromaResults.ids.length} semantic matches`); + + if (chromaResults.ids.length > 0) { + // Step 2: Filter by recency (90 days) + const ninetyDaysAgo = Date.now() - (90 * 24 * 60 * 60 * 1000); + const recentIds = chromaResults.ids.filter((_id, idx) => { + const meta = chromaResults.metadatas[idx]; + return meta && meta.created_at_epoch > ninetyDaysAgo; + }); + + silentDebug(`[search-server] ${recentIds.length} results within 90-day window`); + + // Step 3: Hydrate from SQLite in temporal order + if (recentIds.length > 0) { + const limit = options.limit || 20; + results = this.sessionStore.getUserPromptsByIds(recentIds, { orderBy: 'date_desc', limit }); + silentDebug(`[search-server] Hydrated ${results.length} user prompts from SQLite`); + } + } + } catch (chromaError: any) { + silentDebug('[search-server] Chroma query failed - no results (FTS5 fallback removed):', chromaError.message); + } + } + + if (results.length === 0) { + return { + content: [{ + type: 'text' as const, + text: `No user prompts found matching "${query}"` + }] + }; + } + + // Format based on requested format + let combinedText: string; + if (format === 'index') { + const header = `Found ${results.length} user prompt(s) matching "${query}":\n\n`; + const formattedResults = results.map((prompt, i) => this.formatter.formatUserPromptIndex(prompt, i)); + combinedText = header + formattedResults.join('\n\n') + this.formatter.formatSearchTips(); + } else { + const formattedResults = results.map((prompt) => this.formatter.formatUserPromptResult(prompt)); + combinedText = formattedResults.join('\n\n---\n\n'); + } + + return { + content: [{ + type: 'text' as const, + text: combinedText + }] + }; + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Search failed: ${error.message}` + }], + isError: true + }; + } + } + + /** + * Tool handler: find_by_concept + */ + async findByConcept(args: any): Promise { + try { + const normalized = this.normalizeParams(args); + const { concept, format = 'index', ...filters } = normalized; + let results: ObservationSearchResult[] = []; + + // Metadata-first, semantic-enhanced search + if (this.chromaSync) { + try { + silentDebug('[search-server] Using metadata-first + semantic ranking for concept search'); + + // Step 1: SQLite metadata filter (get all IDs with this concept) + const metadataResults = this.sessionSearch.findByConcept(concept, filters); + silentDebug(`[search-server] Found ${metadataResults.length} observations with concept "${concept}"`); + + if (metadataResults.length > 0) { + // Step 2: Chroma semantic ranking (rank by relevance to concept) + const ids = metadataResults.map(obs => obs.id); + const chromaResults = await this.queryChroma(concept, Math.min(ids.length, 100)); + + // Intersect: Keep only IDs that passed metadata filter, in semantic rank order + const rankedIds: number[] = []; + for (const chromaId of chromaResults.ids) { + if (ids.includes(chromaId) && !rankedIds.includes(chromaId)) { + rankedIds.push(chromaId); + } + } + + silentDebug(`[search-server] Chroma ranked ${rankedIds.length} results by semantic relevance`); + + // Step 3: Hydrate in semantic rank order + if (rankedIds.length > 0) { + results = this.sessionStore.getObservationsByIds(rankedIds, { limit: filters.limit || 20 }); + // Restore semantic ranking order + results.sort((a, b) => rankedIds.indexOf(a.id) - rankedIds.indexOf(b.id)); + } + } + } catch (chromaError: any) { + silentDebug('[search-server] Chroma ranking failed, using SQLite order:', chromaError.message); + // Fall through to SQLite fallback + } + } + + // Fall back to SQLite-only if Chroma unavailable or failed + if (results.length === 0) { + silentDebug('[search-server] Using SQLite-only concept search'); + results = this.sessionSearch.findByConcept(concept, filters); + } + + if (results.length === 0) { + return { + content: [{ + type: 'text' as const, + text: `No observations found with concept "${concept}"` + }] + }; + } + + // Format based on requested format + let combinedText: string; + if (format === 'index') { + const header = `Found ${results.length} observation(s) with concept "${concept}":\n\n`; + const formattedResults = results.map((obs, i) => this.formatter.formatObservationIndex(obs, i)); + combinedText = header + formattedResults.join('\n\n') + this.formatter.formatSearchTips(); + } else { + const formattedResults = results.map((obs) => this.formatter.formatObservationResult(obs)); + combinedText = formattedResults.join('\n\n---\n\n'); + } + + return { + content: [{ + type: 'text' as const, + text: combinedText + }] + }; + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Search failed: ${error.message}` + }], + isError: true + }; + } + } + + /** + * Tool handler: find_by_file + */ + async findByFile(args: any): Promise { + try { + const normalized = this.normalizeParams(args); + const { filePath, format = 'index', ...filters } = normalized; + let observations: ObservationSearchResult[] = []; + let sessions: SessionSummarySearchResult[] = []; + + // Metadata-first, semantic-enhanced search for observations + if (this.chromaSync) { + try { + silentDebug('[search-server] Using metadata-first + semantic ranking for file search'); + + // Step 1: SQLite metadata filter (get all results with this file) + const metadataResults = this.sessionSearch.findByFile(filePath, filters); + silentDebug(`[search-server] Found ${metadataResults.observations.length} observations, ${metadataResults.sessions.length} sessions for file "${filePath}"`); + + // Sessions: Keep as-is (already summarized, no semantic ranking needed) + sessions = metadataResults.sessions; + + // Observations: Apply semantic ranking + if (metadataResults.observations.length > 0) { + // Step 2: Chroma semantic ranking (rank by relevance to file path) + const ids = metadataResults.observations.map(obs => obs.id); + const chromaResults = await this.queryChroma(filePath, Math.min(ids.length, 100)); + + // Intersect: Keep only IDs that passed metadata filter, in semantic rank order + const rankedIds: number[] = []; + for (const chromaId of chromaResults.ids) { + if (ids.includes(chromaId) && !rankedIds.includes(chromaId)) { + rankedIds.push(chromaId); + } + } + + silentDebug(`[search-server] Chroma ranked ${rankedIds.length} observations by semantic relevance`); + + // Step 3: Hydrate in semantic rank order + if (rankedIds.length > 0) { + observations = this.sessionStore.getObservationsByIds(rankedIds, { limit: filters.limit || 20 }); + // Restore semantic ranking order + observations.sort((a, b) => rankedIds.indexOf(a.id) - rankedIds.indexOf(b.id)); + } + } + } catch (chromaError: any) { + silentDebug('[search-server] Chroma ranking failed, using SQLite order:', chromaError.message); + // Fall through to SQLite fallback + } + } + + // Fall back to SQLite-only if Chroma unavailable or failed + if (observations.length === 0 && sessions.length === 0) { + silentDebug('[search-server] Using SQLite-only file search'); + const results = this.sessionSearch.findByFile(filePath, filters); + observations = results.observations; + sessions = results.sessions; + } + + const totalResults = observations.length + sessions.length; + + if (totalResults === 0) { + return { + content: [{ + type: 'text' as const, + text: `No results found for file "${filePath}"` + }] + }; + } + + let combinedText: string; + if (format === 'index') { + const header = `Found ${totalResults} result(s) for file "${filePath}":\n\n`; + const formattedResults: string[] = []; + + // Add observations + observations.forEach((obs, i) => { + formattedResults.push(this.formatter.formatObservationIndex(obs, i)); + }); + + // Add sessions + sessions.forEach((session, i) => { + formattedResults.push(this.formatter.formatSessionIndex(session, i + observations.length)); + }); + + combinedText = header + formattedResults.join('\n\n') + this.formatter.formatSearchTips(); + } else { + const formattedResults: string[] = []; + + // Add observations + observations.forEach((obs) => { + formattedResults.push(this.formatter.formatObservationResult(obs)); + }); + + // Add sessions + sessions.forEach((session) => { + formattedResults.push(this.formatter.formatSessionResult(session)); + }); + + combinedText = formattedResults.join('\n\n---\n\n'); + } + + return { + content: [{ + type: 'text' as const, + text: combinedText + }] + }; + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Search failed: ${error.message}` + }], + isError: true + }; + } + } + + /** + * Tool handler: find_by_type + */ + async findByType(args: any): Promise { + try { + const normalized = this.normalizeParams(args); + const { type, format = 'index', ...filters } = normalized; + const typeStr = Array.isArray(type) ? type.join(', ') : type; + let results: ObservationSearchResult[] = []; + + // Metadata-first, semantic-enhanced search + if (this.chromaSync) { + try { + silentDebug('[search-server] Using metadata-first + semantic ranking for type search'); + + // Step 1: SQLite metadata filter (get all IDs with this type) + const metadataResults = this.sessionSearch.findByType(type, filters); + silentDebug(`[search-server] Found ${metadataResults.length} observations with type "${typeStr}"`); + + if (metadataResults.length > 0) { + // Step 2: Chroma semantic ranking (rank by relevance to type) + const ids = metadataResults.map(obs => obs.id); + const chromaResults = await this.queryChroma(typeStr, Math.min(ids.length, 100)); + + // Intersect: Keep only IDs that passed metadata filter, in semantic rank order + const rankedIds: number[] = []; + for (const chromaId of chromaResults.ids) { + if (ids.includes(chromaId) && !rankedIds.includes(chromaId)) { + rankedIds.push(chromaId); + } + } + + silentDebug(`[search-server] Chroma ranked ${rankedIds.length} results by semantic relevance`); + + // Step 3: Hydrate in semantic rank order + if (rankedIds.length > 0) { + results = this.sessionStore.getObservationsByIds(rankedIds, { limit: filters.limit || 20 }); + // Restore semantic ranking order + results.sort((a, b) => rankedIds.indexOf(a.id) - rankedIds.indexOf(b.id)); + } + } + } catch (chromaError: any) { + silentDebug('[search-server] Chroma ranking failed, using SQLite order:', chromaError.message); + // Fall through to SQLite fallback + } + } + + // Fall back to SQLite-only if Chroma unavailable or failed + if (results.length === 0) { + silentDebug('[search-server] Using SQLite-only type search'); + results = this.sessionSearch.findByType(type, filters); + } + + if (results.length === 0) { + return { + content: [{ + type: 'text' as const, + text: `No observations found with type "${typeStr}"` + }] + }; + } + + // Format based on requested format + let combinedText: string; + if (format === 'index') { + const header = `Found ${results.length} observation(s) with type "${typeStr}":\n\n`; + const formattedResults = results.map((obs, i) => this.formatter.formatObservationIndex(obs, i)); + combinedText = header + formattedResults.join('\n\n') + this.formatter.formatSearchTips(); + } else { + const formattedResults = results.map((obs) => this.formatter.formatObservationResult(obs)); + combinedText = formattedResults.join('\n\n---\n\n'); + } + + return { + content: [{ + type: 'text' as const, + text: combinedText + }] + }; + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Search failed: ${error.message}` + }], + isError: true + }; + } + } + + /** + * Tool handler: get_recent_context + */ + async getRecentContext(args: any): Promise { + try { + const project = args.project || basename(process.cwd()); + const limit = args.limit || 3; + + const sessions = this.sessionStore.getRecentSessionsWithStatus(project, limit); + + if (sessions.length === 0) { + return { + content: [{ + type: 'text' as const, + text: `# Recent Session Context\n\nNo previous sessions found for project "${project}".` + }] + }; + } + + const lines: string[] = []; + lines.push('# Recent Session Context'); + lines.push(''); + lines.push(`Showing last ${sessions.length} session(s) for **${project}**:`); + lines.push(''); + + for (const session of sessions) { + if (!session.sdk_session_id) continue; + + lines.push('---'); + lines.push(''); + + if (session.has_summary) { + const summary = this.sessionStore.getSummaryForSession(session.sdk_session_id); + if (summary) { + const promptLabel = summary.prompt_number ? ` (Prompt #${summary.prompt_number})` : ''; + lines.push(`**Summary${promptLabel}**`); + lines.push(''); + + if (summary.request) lines.push(`**Request:** ${summary.request}`); + if (summary.completed) lines.push(`**Completed:** ${summary.completed}`); + if (summary.learned) lines.push(`**Learned:** ${summary.learned}`); + if (summary.next_steps) lines.push(`**Next Steps:** ${summary.next_steps}`); + + // Handle files_read + if (summary.files_read) { + try { + const filesRead = JSON.parse(summary.files_read); + if (Array.isArray(filesRead) && filesRead.length > 0) { + lines.push(`**Files Read:** ${filesRead.join(', ')}`); + } + } catch { + if (summary.files_read.trim()) { + lines.push(`**Files Read:** ${summary.files_read}`); + } + } + } + + // Handle files_edited + if (summary.files_edited) { + try { + const filesEdited = JSON.parse(summary.files_edited); + if (Array.isArray(filesEdited) && filesEdited.length > 0) { + lines.push(`**Files Edited:** ${filesEdited.join(', ')}`); + } + } catch { + if (summary.files_edited.trim()) { + lines.push(`**Files Edited:** ${summary.files_edited}`); + } + } + } + + const date = new Date(summary.created_at).toLocaleString(); + lines.push(`**Date:** ${date}`); + } + } else if (session.status === 'active') { + lines.push('**In Progress**'); + lines.push(''); + + if (session.user_prompt) { + lines.push(`**Request:** ${session.user_prompt}`); + } + + const observations = this.sessionStore.getObservationsForSession(session.sdk_session_id); + if (observations.length > 0) { + lines.push(''); + lines.push(`**Observations (${observations.length}):**`); + for (const obs of observations) { + lines.push(`- ${obs.title}`); + } + } else { + lines.push(''); + lines.push('*No observations yet*'); + } + + lines.push(''); + lines.push('**Status:** Active - summary pending'); + + const date = new Date(session.started_at).toLocaleString(); + lines.push(`**Date:** ${date}`); + } else { + lines.push(`**${session.status.charAt(0).toUpperCase() + session.status.slice(1)}**`); + lines.push(''); + + if (session.user_prompt) { + lines.push(`**Request:** ${session.user_prompt}`); + } + + lines.push(''); + lines.push(`**Status:** ${session.status} - no summary available`); + + const date = new Date(session.started_at).toLocaleString(); + lines.push(`**Date:** ${date}`); + } + + lines.push(''); + } + + return { + content: [{ + type: 'text' as const, + text: lines.join('\n') + }] + }; + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Failed to get recent context: ${error.message}` + }], + isError: true + }; + } + } + + /** + * Tool handler: get_context_timeline + */ + async getContextTimeline(args: any): Promise { + try { + const { anchor, depth_before = 10, depth_after = 10, project } = args; + let anchorEpoch: number; + let anchorId: string | number = anchor; + + // Resolve anchor and get timeline data + let timeline; + if (typeof anchor === 'number') { + // Observation ID - use ID-based boundary detection + const obs = this.sessionStore.getObservationById(anchor); + if (!obs) { + return { + content: [{ + type: 'text' as const, + text: `Observation #${anchor} not found` + }], + isError: true + }; + } + anchorEpoch = obs.created_at_epoch; + timeline = this.sessionStore.getTimelineAroundObservation(anchor, anchorEpoch, depth_before, depth_after, project); + } else if (typeof anchor === 'string') { + // Session ID or ISO timestamp + if (anchor.startsWith('S') || anchor.startsWith('#S')) { + const sessionId = anchor.replace(/^#?S/, ''); + const sessionNum = parseInt(sessionId, 10); + const sessions = this.sessionStore.getSessionSummariesByIds([sessionNum]); + if (sessions.length === 0) { + return { + content: [{ + type: 'text' as const, + text: `Session #${sessionNum} not found` + }], + isError: true + }; + } + anchorEpoch = sessions[0].created_at_epoch; + anchorId = `S${sessionNum}`; + timeline = this.sessionStore.getTimelineAroundTimestamp(anchorEpoch, depth_before, depth_after, project); + } else { + // ISO timestamp + const date = new Date(anchor); + if (isNaN(date.getTime())) { + return { + content: [{ + type: 'text' as const, + text: `Invalid timestamp: ${anchor}` + }], + isError: true + }; + } + anchorEpoch = date.getTime(); // Keep as milliseconds + timeline = this.sessionStore.getTimelineAroundTimestamp(anchorEpoch, depth_before, depth_after, project); + } + } else { + return { + content: [{ + type: 'text' as const, + text: 'Invalid anchor: must be observation ID (number), session ID (e.g., "S123"), or ISO timestamp' + }], + isError: true + }; + } + + // Combine, sort, and filter timeline items + const items: TimelineItem[] = [ + ...timeline.observations.map(obs => ({ type: 'observation' as const, data: obs, epoch: obs.created_at_epoch })), + ...timeline.sessions.map(sess => ({ type: 'session' as const, data: sess, epoch: sess.created_at_epoch })), + ...timeline.prompts.map(prompt => ({ type: 'prompt' as const, data: prompt, epoch: prompt.created_at_epoch })) + ]; + items.sort((a, b) => a.epoch - b.epoch); + const filteredItems = this.timeline.filterByDepth(items, anchorId, anchorEpoch, depth_before, depth_after); + + if (filteredItems.length === 0) { + const anchorDate = new Date(anchorEpoch).toLocaleString(); + return { + content: [{ + type: 'text' as const, + text: `No context found around ${anchorDate} (${depth_before} records before, ${depth_after} records after)` + }] + }; + } + + // Helper functions matching context-hook.ts + function formatDate(epochMs: number): string { + const date = new Date(epochMs); + return date.toLocaleString('en-US', { + month: 'short', + day: 'numeric', + year: 'numeric' + }); + } + + function formatTime(epochMs: number): string { + const date = new Date(epochMs); + return date.toLocaleString('en-US', { + hour: 'numeric', + minute: '2-digit', + hour12: true + }); + } + + function formatDateTime(epochMs: number): string { + const date = new Date(epochMs); + return date.toLocaleString('en-US', { + month: 'short', + day: 'numeric', + hour: 'numeric', + minute: '2-digit', + hour12: true + }); + } + + function estimateTokens(text: string | null): number { + if (!text) return 0; + return Math.ceil(text.length / 4); + } + + // Format results matching context-hook.ts exactly + const lines: string[] = []; + + // Header + lines.push(`# Timeline around anchor: ${anchorId}`); + lines.push(`**Window:** ${depth_before} records before → ${depth_after} records after | **Items:** ${filteredItems.length}`); + lines.push(''); + + // Legend + lines.push(`**Legend:** 🎯 session-request | 🔴 bugfix | 🟣 feature | 🔄 refactor | ✅ change | 🔵 discovery | 🧠 decision`); + lines.push(''); + + // Group by day + const dayMap = new Map(); + for (const item of filteredItems) { + const day = formatDate(item.epoch); + if (!dayMap.has(day)) { + dayMap.set(day, []); + } + dayMap.get(day)!.push(item); + } + + // Sort days chronologically + const sortedDays = Array.from(dayMap.entries()).sort((a, b) => { + const aDate = new Date(a[0]).getTime(); + const bDate = new Date(b[0]).getTime(); + return aDate - bDate; + }); + + // Render each day + for (const [day, dayItems] of sortedDays) { + lines.push(`### ${day}`); + lines.push(''); + + let currentFile: string | null = null; + let lastTime = ''; + let tableOpen = false; + + for (const item of dayItems) { + const isAnchor = ( + (typeof anchorId === 'number' && item.type === 'observation' && item.data.id === anchorId) || + (typeof anchorId === 'string' && anchorId.startsWith('S') && item.type === 'session' && `S${item.data.id}` === anchorId) + ); + + if (item.type === 'session') { + // Close any open table + if (tableOpen) { + lines.push(''); + tableOpen = false; + currentFile = null; + lastTime = ''; + } + + // Render session + const sess = item.data; + const title = sess.request || 'Session summary'; + const link = `claude-mem://session-summary/${sess.id}`; + const marker = isAnchor ? ' ← **ANCHOR**' : ''; + + lines.push(`**🎯 #S${sess.id}** ${title} (${formatDateTime(item.epoch)}) [→](${link})${marker}`); + lines.push(''); + } else if (item.type === 'prompt') { + // Close any open table + if (tableOpen) { + lines.push(''); + tableOpen = false; + currentFile = null; + lastTime = ''; + } + + // Render prompt + const prompt = item.data; + const truncated = prompt.prompt.length > 100 ? prompt.prompt.substring(0, 100) + '...' : prompt.prompt; + + lines.push(`**💬 User Prompt #${prompt.prompt_number}** (${formatDateTime(item.epoch)})`); + lines.push(`> ${truncated}`); + lines.push(''); + } else if (item.type === 'observation') { + // Render observation in table + const obs = item.data; + const file = 'General'; // Simplified for timeline view + + // Check if we need a new file section + if (file !== currentFile) { + // Close previous table + if (tableOpen) { + lines.push(''); + } + + // File header + lines.push(`**${file}**`); + lines.push(`| ID | Time | T | Title | Tokens |`); + lines.push(`|----|------|---|-------|--------|`); + + currentFile = file; + tableOpen = true; + lastTime = ''; + } + + // Map observation type to emoji + let icon = '•'; + switch (obs.type) { + case 'bugfix': icon = '🔴'; break; + case 'feature': icon = '🟣'; break; + case 'refactor': icon = '🔄'; break; + case 'change': icon = '✅'; break; + case 'discovery': icon = '🔵'; break; + case 'decision': icon = '🧠'; break; + } + + const time = formatTime(item.epoch); + const title = obs.title || 'Untitled'; + const tokens = estimateTokens(obs.narrative); + + const showTime = time !== lastTime; + const timeDisplay = showTime ? time : '″'; + lastTime = time; + + const anchorMarker = isAnchor ? ' ← **ANCHOR**' : ''; + lines.push(`| #${obs.id} | ${timeDisplay} | ${icon} | ${title}${anchorMarker} | ~${tokens} |`); + } + } + + // Close final table if open + if (tableOpen) { + lines.push(''); + } + } + + return { + content: [{ + type: 'text' as const, + text: lines.join('\n') + }] + }; + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Timeline query failed: ${error.message}` + }], + isError: true + }; + } + } + + /** + * Tool handler: get_timeline_by_query + */ + async getTimelineByQuery(args: any): Promise { + try { + const { query, mode = 'auto', depth_before = 10, depth_after = 10, limit = 5, project } = args; + + // Step 1: Search for observations + let results: ObservationSearchResult[] = []; + + // Use hybrid search if available + if (this.chromaSync) { + try { + silentDebug('[search-server] Using hybrid semantic search for timeline query'); + const chromaResults = await this.queryChroma(query, 100); + silentDebug(`[search-server] Chroma returned ${chromaResults.ids.length} semantic matches`); + + if (chromaResults.ids.length > 0) { + // Filter by recency (90 days) + const ninetyDaysAgo = Date.now() - (90 * 24 * 60 * 60 * 1000); + const recentIds = chromaResults.ids.filter((_id, idx) => { + const meta = chromaResults.metadatas[idx]; + return meta && meta.created_at_epoch > ninetyDaysAgo; + }); + + silentDebug(`[search-server] ${recentIds.length} results within 90-day window`); + + if (recentIds.length > 0) { + results = this.sessionStore.getObservationsByIds(recentIds, { orderBy: 'date_desc', limit: mode === 'auto' ? 1 : limit }); + silentDebug(`[search-server] Hydrated ${results.length} observations from SQLite`); + } + } + } catch (chromaError: any) { + silentDebug('[search-server] Chroma query failed - no results (FTS5 fallback removed):', chromaError.message); + } + } + + if (results.length === 0) { + return { + content: [{ + type: 'text' as const, + text: `No observations found matching "${query}". Try a different search query.` + }] + }; + } + + // Step 2: Handle based on mode + if (mode === 'interactive') { + // Return formatted index of top results for LLM to choose from + const lines: string[] = []; + lines.push(`# Timeline Anchor Search Results`); + lines.push(''); + lines.push(`Found ${results.length} observation(s) matching "${query}"`); + lines.push(''); + lines.push(`To get timeline context around any of these observations, use the \`get_context_timeline\` tool with the observation ID as the anchor.`); + lines.push(''); + lines.push(`**Top ${results.length} matches:**`); + lines.push(''); + + for (let i = 0; i < results.length; i++) { + const obs = results[i]; + const title = obs.title || `Observation #${obs.id}`; + const date = new Date(obs.created_at_epoch).toLocaleString(); + const type = obs.type ? `[${obs.type}]` : ''; + + lines.push(`${i + 1}. **${type} ${title}**`); + lines.push(` - ID: ${obs.id}`); + lines.push(` - Date: ${date}`); + if (obs.subtitle) { + lines.push(` - ${obs.subtitle}`); + } + lines.push(` - Source: claude-mem://observation/${obs.id}`); + lines.push(''); + } + + return { + content: [{ + type: 'text' as const, + text: lines.join('\n') + }] + }; + } else { + // Auto mode: Use top result as timeline anchor + const topResult = results[0]; + silentDebug(`[search-server] Auto mode: Using observation #${topResult.id} as timeline anchor`); + + // Get timeline around this observation + const timeline = this.sessionStore.getTimelineAroundObservation( + topResult.id, + topResult.created_at_epoch, + depth_before, + depth_after, + project + ); + + // Combine, sort, and filter timeline items + const items: TimelineItem[] = [ + ...timeline.observations.map(obs => ({ type: 'observation' as const, data: obs, epoch: obs.created_at_epoch })), + ...timeline.sessions.map(sess => ({ type: 'session' as const, data: sess, epoch: sess.created_at_epoch })), + ...timeline.prompts.map(prompt => ({ type: 'prompt' as const, data: prompt, epoch: prompt.created_at_epoch })) + ]; + items.sort((a, b) => a.epoch - b.epoch); + const filteredItems = this.timeline.filterByDepth(items, topResult.id, 0, depth_before, depth_after); + + if (filteredItems.length === 0) { + return { + content: [{ + type: 'text' as const, + text: `Found observation #${topResult.id} matching "${query}", but no timeline context available (${depth_before} records before, ${depth_after} records after).` + }] + }; + } + + // Helper functions (reused from get_context_timeline) + function formatDate(epochMs: number): string { + const date = new Date(epochMs); + return date.toLocaleString('en-US', { + month: 'short', + day: 'numeric', + year: 'numeric' + }); + } + + function formatTime(epochMs: number): string { + const date = new Date(epochMs); + return date.toLocaleString('en-US', { + hour: 'numeric', + minute: '2-digit', + hour12: true + }); + } + + function formatDateTime(epochMs: number): string { + const date = new Date(epochMs); + return date.toLocaleString('en-US', { + month: 'short', + day: 'numeric', + hour: 'numeric', + minute: '2-digit', + hour12: true + }); + } + + function estimateTokens(text: string | null): number { + if (!text) return 0; + return Math.ceil(text.length / 4); + } + + // Format timeline (reused from get_context_timeline) + const lines: string[] = []; + + // Header + lines.push(`# Timeline for query: "${query}"`); + lines.push(`**Anchor:** Observation #${topResult.id} - ${topResult.title || 'Untitled'}`); + lines.push(`**Window:** ${depth_before} records before → ${depth_after} records after | **Items:** ${filteredItems.length}`); + lines.push(''); + + // Legend + lines.push(`**Legend:** 🎯 session-request | 🔴 bugfix | 🟣 feature | 🔄 refactor | ✅ change | 🔵 discovery | 🧠 decision`); + lines.push(''); + + // Group by day + const dayMap = new Map(); + for (const item of filteredItems) { + const day = formatDate(item.epoch); + if (!dayMap.has(day)) { + dayMap.set(day, []); + } + dayMap.get(day)!.push(item); + } + + // Sort days chronologically + const sortedDays = Array.from(dayMap.entries()).sort((a, b) => { + const aDate = new Date(a[0]).getTime(); + const bDate = new Date(b[0]).getTime(); + return aDate - bDate; + }); + + // Render each day + for (const [day, dayItems] of sortedDays) { + lines.push(`### ${day}`); + lines.push(''); + + let currentFile: string | null = null; + let lastTime = ''; + let tableOpen = false; + + for (const item of dayItems) { + const isAnchor = (item.type === 'observation' && item.data.id === topResult.id); + + if (item.type === 'session') { + // Close any open table + if (tableOpen) { + lines.push(''); + tableOpen = false; + currentFile = null; + lastTime = ''; + } + + // Render session + const sess = item.data; + const title = sess.request || 'Session summary'; + const link = `claude-mem://session-summary/${sess.id}`; + + lines.push(`**🎯 #S${sess.id}** ${title} (${formatDateTime(item.epoch)}) [→](${link})`); + lines.push(''); + } else if (item.type === 'prompt') { + // Close any open table + if (tableOpen) { + lines.push(''); + tableOpen = false; + currentFile = null; + lastTime = ''; + } + + // Render prompt + const prompt = item.data; + const truncated = prompt.prompt.length > 100 ? prompt.prompt.substring(0, 100) + '...' : prompt.prompt; + + lines.push(`**💬 User Prompt #${prompt.prompt_number}** (${formatDateTime(item.epoch)})`); + lines.push(`> ${truncated}`); + lines.push(''); + } else if (item.type === 'observation') { + // Render observation in table + const obs = item.data; + const file = 'General'; // Simplified for timeline view + + // Check if we need a new file section + if (file !== currentFile) { + // Close previous table + if (tableOpen) { + lines.push(''); + } + + // File header + lines.push(`**${file}**`); + lines.push(`| ID | Time | T | Title | Tokens |`); + lines.push(`|----|------|---|-------|--------|`); + + currentFile = file; + tableOpen = true; + lastTime = ''; + } + + // Map observation type to emoji + let icon = '•'; + switch (obs.type) { + case 'bugfix': icon = '🔴'; break; + case 'feature': icon = '🟣'; break; + case 'refactor': icon = '🔄'; break; + case 'change': icon = '✅'; break; + case 'discovery': icon = '🔵'; break; + case 'decision': icon = '🧠'; break; + } + + const time = formatTime(item.epoch); + const title = obs.title || 'Untitled'; + const tokens = estimateTokens(obs.narrative); + + const showTime = time !== lastTime; + const timeDisplay = showTime ? time : '″'; + lastTime = time; + + const anchorMarker = isAnchor ? ' ← **ANCHOR**' : ''; + lines.push(`| #${obs.id} | ${timeDisplay} | ${icon} | ${title}${anchorMarker} | ~${tokens} |`); + } + } + + // Close final table if open + if (tableOpen) { + lines.push(''); + } + } + + return { + content: [{ + type: 'text' as const, + text: lines.join('\n') + }] + }; + } + } catch (error: any) { + return { + content: [{ + type: 'text' as const, + text: `Timeline query failed: ${error.message}` + }], + isError: true + }; + } + } +} diff --git a/src/services/worker/TimelineService.ts b/src/services/worker/TimelineService.ts new file mode 100644 index 00000000..fe974138 --- /dev/null +++ b/src/services/worker/TimelineService.ts @@ -0,0 +1,270 @@ +/** + * TimelineService - Handles timeline building, filtering, and formatting + * Extracted from mcp-server.ts to follow worker service organization pattern + */ + +import { ObservationSearchResult, SessionSummarySearchResult, UserPromptSearchResult } from '../sqlite/types.js'; + +/** + * Timeline item for unified chronological display + */ +export interface TimelineItem { + type: 'observation' | 'session' | 'prompt'; + data: ObservationSearchResult | SessionSummarySearchResult | UserPromptSearchResult; + epoch: number; +} + +export interface TimelineData { + observations: ObservationSearchResult[]; + sessions: SessionSummarySearchResult[]; + prompts: UserPromptSearchResult[]; +} + +export class TimelineService { + /** + * Build timeline items from observations, sessions, and prompts + */ + buildTimeline(data: TimelineData): TimelineItem[] { + const items: TimelineItem[] = [ + ...data.observations.map(obs => ({ type: 'observation' as const, data: obs, epoch: obs.created_at_epoch })), + ...data.sessions.map(sess => ({ type: 'session' as const, data: sess, epoch: sess.created_at_epoch })), + ...data.prompts.map(prompt => ({ type: 'prompt' as const, data: prompt, epoch: prompt.created_at_epoch })) + ]; + items.sort((a, b) => a.epoch - b.epoch); + return items; + } + + /** + * Filter timeline items to respect depth_before/depth_after window around anchor + */ + filterByDepth( + items: TimelineItem[], + anchorId: number | string, + anchorEpoch: number, + depth_before: number, + depth_after: number + ): TimelineItem[] { + if (items.length === 0) return items; + + let anchorIndex = -1; + if (typeof anchorId === 'number') { + anchorIndex = items.findIndex(item => item.type === 'observation' && (item.data as ObservationSearchResult).id === anchorId); + } else if (typeof anchorId === 'string' && anchorId.startsWith('S')) { + const sessionNum = parseInt(anchorId.slice(1), 10); + anchorIndex = items.findIndex(item => item.type === 'session' && (item.data as SessionSummarySearchResult).id === sessionNum); + } else { + // Timestamp anchor - find closest item + anchorIndex = items.findIndex(item => item.epoch >= anchorEpoch); + if (anchorIndex === -1) anchorIndex = items.length - 1; + } + + if (anchorIndex === -1) return items; + + const startIndex = Math.max(0, anchorIndex - depth_before); + const endIndex = Math.min(items.length, anchorIndex + depth_after + 1); + return items.slice(startIndex, endIndex); + } + + /** + * Format timeline items as markdown with grouped days and tables + */ + formatTimeline( + items: TimelineItem[], + anchorId: number | string | null, + query?: string, + depth_before?: number, + depth_after?: number + ): string { + if (items.length === 0) { + return query + ? `Found observation matching "${query}", but no timeline context available.` + : 'No timeline items found'; + } + + const lines: string[] = []; + + // Header + if (query && anchorId) { + const anchorObs = items.find(item => item.type === 'observation' && (item.data as ObservationSearchResult).id === anchorId); + const anchorTitle = anchorObs ? ((anchorObs.data as ObservationSearchResult).title || 'Untitled') : 'Unknown'; + lines.push(`# Timeline for query: "${query}"`); + lines.push(`**Anchor:** Observation #${anchorId} - ${anchorTitle}`); + } else if (anchorId) { + lines.push(`# Timeline around anchor: ${anchorId}`); + } else { + lines.push(`# Timeline`); + } + + if (depth_before !== undefined && depth_after !== undefined) { + lines.push(`**Window:** ${depth_before} records before → ${depth_after} records after | **Items:** ${items.length}`); + } else { + lines.push(`**Items:** ${items.length}`); + } + lines.push(''); + + // Legend + lines.push(`**Legend:** 🎯 session-request | 🔴 bugfix | 🟣 feature | 🔄 refactor | ✅ change | 🔵 discovery | 🧠 decision`); + lines.push(''); + + // Group by day + const dayMap = new Map(); + for (const item of items) { + const day = this.formatDate(item.epoch); + if (!dayMap.has(day)) { + dayMap.set(day, []); + } + dayMap.get(day)!.push(item); + } + + // Sort days chronologically + const sortedDays = Array.from(dayMap.entries()).sort((a, b) => { + const aDate = new Date(a[0]).getTime(); + const bDate = new Date(b[0]).getTime(); + return aDate - bDate; + }); + + // Render each day + for (const [day, dayItems] of sortedDays) { + lines.push(`### ${day}`); + lines.push(''); + + let currentFile: string | null = null; + let lastTime = ''; + let tableOpen = false; + + for (const item of dayItems) { + const isAnchor = ( + (typeof anchorId === 'number' && item.type === 'observation' && (item.data as ObservationSearchResult).id === anchorId) || + (typeof anchorId === 'string' && anchorId.startsWith('S') && item.type === 'session' && `S${(item.data as SessionSummarySearchResult).id}` === anchorId) + ); + + if (item.type === 'session') { + if (tableOpen) { + lines.push(''); + tableOpen = false; + currentFile = null; + lastTime = ''; + } + + const sess = item.data as SessionSummarySearchResult; + const title = sess.request || 'Session summary'; + const link = `claude-mem://session-summary/${sess.id}`; + const marker = isAnchor ? ' ← **ANCHOR**' : ''; + + lines.push(`**🎯 #S${sess.id}** ${title} (${this.formatDateTime(item.epoch)}) [→](${link})${marker}`); + lines.push(''); + } else if (item.type === 'prompt') { + if (tableOpen) { + lines.push(''); + tableOpen = false; + currentFile = null; + lastTime = ''; + } + + const prompt = item.data as UserPromptSearchResult; + const truncated = prompt.prompt_text.length > 100 ? prompt.prompt_text.substring(0, 100) + '...' : prompt.prompt_text; + + lines.push(`**💬 User Prompt #${prompt.prompt_number}** (${this.formatDateTime(item.epoch)})`); + lines.push(`> ${truncated}`); + lines.push(''); + } else if (item.type === 'observation') { + const obs = item.data as ObservationSearchResult; + const file = 'General'; + + if (file !== currentFile) { + if (tableOpen) { + lines.push(''); + } + + lines.push(`**${file}**`); + lines.push(`| ID | Time | T | Title | Tokens |`); + lines.push(`|----|------|---|-------|--------|`); + + currentFile = file; + tableOpen = true; + lastTime = ''; + } + + const icon = this.getTypeIcon(obs.type); + const time = this.formatTime(item.epoch); + const title = obs.title || 'Untitled'; + const tokens = this.estimateTokens(obs.narrative); + + const showTime = time !== lastTime; + const timeDisplay = showTime ? time : '″'; + lastTime = time; + + const anchorMarker = isAnchor ? ' ← **ANCHOR**' : ''; + lines.push(`| #${obs.id} | ${timeDisplay} | ${icon} | ${title}${anchorMarker} | ~${tokens} |`); + } + } + + if (tableOpen) { + lines.push(''); + } + } + + return lines.join('\n'); + } + + /** + * Get icon for observation type + */ + private getTypeIcon(type: string): string { + switch (type) { + case 'bugfix': return '🔴'; + case 'feature': return '🟣'; + case 'refactor': return '🔄'; + case 'change': return '✅'; + case 'discovery': return '🔵'; + case 'decision': return '🧠'; + default: return '•'; + } + } + + /** + * Format date for grouping (e.g., "Dec 7, 2025") + */ + private formatDate(epochMs: number): string { + const date = new Date(epochMs); + return date.toLocaleString('en-US', { + month: 'short', + day: 'numeric', + year: 'numeric' + }); + } + + /** + * Format time (e.g., "6:30 PM") + */ + private formatTime(epochMs: number): string { + const date = new Date(epochMs); + return date.toLocaleString('en-US', { + hour: 'numeric', + minute: '2-digit', + hour12: true + }); + } + + /** + * Format date and time (e.g., "Dec 7, 6:30 PM") + */ + private formatDateTime(epochMs: number): string { + const date = new Date(epochMs); + return date.toLocaleString('en-US', { + month: 'short', + day: 'numeric', + hour: 'numeric', + minute: '2-digit', + hour12: true + }); + } + + /** + * Estimate tokens from text length (~4 chars per token) + */ + private estimateTokens(text: string | null): number { + if (!text) return 0; + return Math.ceil(text.length / 4); + } +}