keepmind 1.1.3 → 1.1.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.codex-plugin/plugin.json +1 -1
- package/dist/npx-cli/index.js +1 -1
- package/package.json +1 -1
- package/plugin/.claude-plugin/plugin.json +1 -1
- package/plugin/.codex-plugin/plugin.json +1 -1
- package/plugin/package.json +1 -1
- package/plugin/scripts/mcp-server.cjs +1 -1
- package/plugin/scripts/worker-service.cjs +492 -428
package/dist/npx-cli/index.js
CHANGED
|
@@ -1341,7 +1341,7 @@ keepmind installed with some IDE setup failures.`),process.exitCode=1):console.l
|
|
|
1341
1341
|
keepmind installed successfully!`))}async function $h(){let t=Nt(),e=nt(t);K?ir(h.default.bgCyan(h.default.black(" keepmind repair "))):console.log("keepmind repair"),k.info(`Version: ${h.default.cyan(t)}`),await Kn([{title:"Setting up runtime",task:async r=>{r("Checking Bun\u2026");let{version:n}=await Wt();r("Checking uv\u2026");let{version:s}=await Zs();_e(fe(e,"package.json"))||(r("Cache missing \u2014 repopulating from npm package\u2026"),gu(t)),r("Reinstalling plugin dependencies\u2026");let{bunPath:o}=await Wt();return await fn(e,o),Qs(e,t,n,s),`Runtime ready (Bun ${n}, uv ${s}) ${h.default.green("OK")}`}}]),K?Be(h.default.green("keepmind repair complete.")):console.log("keepmind repair complete.")}var h,K,k,Yn=S(()=>{"use strict";vs();h=je(rt(),1);Lt();vt();J();Sa();za();dl();Sl();dn();Ks();Tl();Ae();$t();to();Rl();K=process.stdin.isTTY===!0;k={info:t=>K?H.info(t):console.log(` ${t}`),success:t=>K?H.success(t):console.log(` ${t}`),warn:t=>K?H.warn(t):console.warn(` ${t}`),error:t=>K?H.error(t):console.error(` ${t}`)}});var Su={};Ee(Su,{removeFromClaudeSettings:()=>Eu,runUninstallCommand:()=>lE});import{existsSync as Ot,readFileSync as eE,readdirSync as pi,rmSync as Pr,writeFileSync as tE}from"fs";import{homedir as hu}from"os";import{join as Ue}from"path";function rE(){let t=ie();return Ot(t)?(Pr(t,{recursive:!0,force:!0}),!0):!1}function nE(){let t=Ue(be(),"cache","keepmind","keepmind");return Ot(t)?(Pr(t,{recursive:!0,force:!0}),!0):!1}function sE(){let t=z(xe(),{});t.keepmind&&(delete t.keepmind,ne(xe(),t))}function oE(){let t=z(Le(),{});t.plugins?.["keepmind@keepmind"]&&(delete t.plugins["keepmind@keepmind"],ne(Le(),t))}function iE(){let t=hu(),e=[Ue(t,".bashrc"),Ue(t,".zshrc"),Ue(t,"Documents","PowerShell","Microsoft.PowerShell_profile.ps1")],r=/^\s*alias\s+claude-mem\s*=/;for(let n of e){if(!Ot(n))continue;let s;try{s=eE(n,"utf-8")}catch(a){console.warn(`[uninstall] Could not read ${n}:`,a instanceof Error?a.message:String(a));continue}let o=s.split(`
|
|
1342
1342
|
`),i=o.filter(a=>!r.test(a));if(i.length!==o.length)try{tE(n,i.join(`
|
|
1343
1343
|
`)),console.error(`Removed legacy claude-mem alias from ${n}`)}catch(a){console.warn(`[uninstall] Could not rewrite ${n}:`,a instanceof Error?a.message:String(a))}}}function Eu(){let t=z(Re(),{}),e=!1;t.enabledPlugins?.["keepmind@keepmind"]!==void 0&&(delete t.enabledPlugins["keepmind@keepmind"],e=!0),t.env&&typeof t.env=="object"&&!Array.isArray(t.env)&&Object.prototype.hasOwnProperty.call(t.env,"CLAUDE_CODE_DISABLE_AUTO_MEMORY")&&t.env.CLAUDE_CODE_DISABLE_AUTO_MEMORY==="1"&&(delete t.env.CLAUDE_CODE_DISABLE_AUTO_MEMORY,e=!0,Object.keys(t.env).length===0&&delete t.env),e&&ne(Re(),t)}function aE(){let t=hu(),e=0,r=Ue(t,".npm","_npx");if(Ot(r)){let o=[];try{o=pi(r)}catch(i){console.warn(`[uninstall] Could not read ${r}:`,i instanceof Error?i.message:String(i))}for(let i of o){let a=Ue(r,i,"node_modules","keepmind");if(Ot(a))try{Pr(a,{recursive:!0,force:!0}),e++}catch(l){console.warn(`[uninstall] Could not remove ${a}:`,l instanceof Error?l.message:String(l))}}}let n=Ue(t,".cache","claude-cli-nodejs");if(Ot(n)){let o=[];try{o=pi(n)}catch(i){console.warn(`[uninstall] Could not read ${n}:`,i instanceof Error?i.message:String(i))}for(let i of o){let a=Ue(n,i),l=[];try{l=pi(a)}catch(c){console.warn(`[uninstall] Could not read ${a}:`,c instanceof Error?c.message:String(c));continue}for(let c of l){if(!c.startsWith("mcp-logs-plugin-claude-mem-"))continue;let u=Ue(a,c);try{Pr(u,{recursive:!0,force:!0}),e++}catch(m){console.warn(`[uninstall] Could not remove ${u}:`,m instanceof Error?m.message:String(m))}}}}let s=Ue(t,".claude","plugins","data","keepmind-keepmind");if(Ot(s))try{Pr(s,{recursive:!0,force:!0}),e++}catch(o){console.warn(`[uninstall] Could not remove ${s}:`,o instanceof Error?o.message:String(o))}return e}async function lE(){if(ir(ge.default.bgRed(ge.default.white(" claude-mem uninstall "))),Mt()){if(process.stdin.isTTY){let r=await bt({message:"Are you sure you want to uninstall claude-mem?",initialValue:!1});if(X(r)||!r){we("Uninstall cancelled.");return}}}else if(H.warn("claude-mem does not appear to be installed."),process.stdin.isTTY){let r=await bt({message:"Clean up any remaining registration data anyway?",initialValue:!1});if(X(r)||!r){Be("Nothing to do.");return}}else{Be("Nothing to do.");return}let t=te.get("CLAUDE_MEM_WORKER_PORT");try{(await gn(t,1e4)).workerWasRunning&&H.info("Worker service stopped.")}catch(r){console.warn("[uninstall] Worker shutdown attempt failed:",r instanceof Error?r.message:String(r))}await $r([{title:"Removing marketplace directory",task:async()=>rE()?`Marketplace directory removed ${ge.default.green("OK")}`:`Marketplace directory not found ${ge.default.dim("skipped")}`},{title:"Removing cache directory",task:async()=>nE()?`Cache directory removed ${ge.default.green("OK")}`:`Cache directory not found ${ge.default.dim("skipped")}`},{title:"Removing marketplace registration",task:async()=>(sE(),`Marketplace registration removed ${ge.default.green("OK")}`)},{title:"Removing plugin registration",task:async()=>(oE(),`Plugin registration removed ${ge.default.green("OK")}`)},{title:"Removing from Claude settings",task:async()=>(Eu(),`Claude settings updated ${ge.default.green("OK")}`)},{title:"Removing legacy claude-mem shell alias",task:async()=>(iE(),`Legacy alias check complete ${ge.default.green("OK")}`)},{title:"Removing stray claude-mem caches and logs",task:async()=>{let r=aE();return r>0?`Stray paths removed: ${r} ${ge.default.green("OK")}`:`No stray paths found ${ge.default.dim("skipped")}`}}]);let e=[{label:"Gemini CLI hooks",fn:async()=>{let{uninstallGeminiCliHooks:r}=await Promise.resolve().then(()=>(Eo(),ho));return r()}},{label:"Windsurf hooks",fn:async()=>{let{uninstallWindsurfHooks:r}=await Promise.resolve().then(()=>(_o(),ko));return r()}},{label:"OpenCode plugin",fn:async()=>{let{uninstallOpenCodePlugin:r}=await Promise.resolve().then(()=>(wo(),Co));return r()}},{label:"Codex CLI",fn:async()=>{let{uninstallCodexCli:r}=await Promise.resolve().then(()=>(jo(),Wo));return r()}}];for(let{label:r,fn:n}of e)try{await n()===0&&H.info(`${r}: removed.`)}catch(s){console.warn(`[uninstall] ${r} cleanup failed:`,s instanceof Error?s.message:String(s))}xt([`Your data directory at ${ge.default.cyan("~/.keepmind")} was preserved.`,"To remove it manually: rm -rf ~/.keepmind"].join(`
|
|
1344
|
-
`),"Note"),Be(ge.default.green("claude-mem has been uninstalled."))}var ge,bu=S(()=>{"use strict";vs();ge=je(rt(),1);Ae();$t();vt();to()});var et={};Ee(et,{runAdoptCommand:()=>mE,runCleanupCommand:()=>fE,runRestartCommand:()=>Ei,runSearchCommand:()=>gE,runServerApiKeyCommand:()=>bi,runStartCommand:()=>gi,runStatusCommand:()=>Si,runStopCommand:()=>hi,runTranscriptWatchCommand:()=>hE});import{existsSync as Zt,readdirSync as cE,readFileSync as uE}from"fs";import{dirname as dE,join as Ur}from"path";function qn(){Mt()||(console.error(he.default.red("keepmind is not installed.")),console.error(`Run: ${he.default.bold("npx keepmind install")}`),process.exit(1))}function mi(){let t=un();return t||(console.error(he.default.red("Node.js runtime not found.")),console.error("keepmind requires Node.js >= 22.5 \u2014 install it from https://nodejs.org"),console.error("After installation, restart your terminal."),process.exit(1)),t}function pE(){try{let t=JSON.parse(uE(Ur(ie(),"plugin",".claude-plugin","plugin.json"),"utf-8"));return typeof t?.version=="string"?t.version:null}catch{return null}}function yu(t){let e=pE();if(e){let n=Ur(nt(e),"scripts",t);if(Zt(n))return n}let r=Ur(be(),"cache","keepmind","keepmind");if(Zt(r))for(let n of cE(r)){let s=Ur(r,n,"scripts",t);if(Zt(s))return s}return Ur(ie(),"plugin","scripts",t)}function Tu(){return yu("worker-service.cjs")}function fi(t,e,r="worker"){let n=He(t,e,{stdio:"inherit",cwd:dE(e[0]),env:Rt(process.env)});n.on("error",s=>{console.error(he.default.red(`Failed to start ${r}: ${s.message}`)),process.exit(1)}),n.on("close",s=>{process.exit(s??0)})}function kt(t,e=[]){qn();let r=mi(),n=Tu();Zt(n)||(console.error(he.default.red(`Worker script not found at: ${n}`)),console.error("The installation may be corrupted. Try: npx keepmind install"),process.exit(1)),fi(r,[n,t,...e])}function gi(){kt("start")}function hi(){kt("stop")}function Ei(){kt("restart")}function Si(){kt("status")}function bi(t=[]){kt("server",["api-key",...t])}function mE(t=[]){qn();let e=mi(),r=Tu();Zt(r)||(console.error(he.default.red(`Worker script not found at: ${r}`)),console.error("The installation may be corrupted. Try: npx keepmind install"),process.exit(1));let n=process.cwd();fi(e,[r,"adopt","--cwd",n,...t])}function fE(t=[]){kt("cleanup",t)}async function gE(t){qn();let e=t.join(" ").trim();e||(console.error(he.default.red("Usage: npx keepmind search <query>")),process.exit(1));let n=`http://127.0.0.1:${te.get("CLAUDE_MEM_WORKER_PORT")}/api/search?query=${encodeURIComponent(e)}`,s;try{s=await fetch(n)}catch(i){let a=i instanceof Error?i.message:String(i);((i instanceof Error?i.cause:void 0)?.code==="ECONNREFUSED"||a.includes("ECONNREFUSED"))&&(console.error(he.default.red("Worker is not running.")),console.error(`Start it with: ${he.default.bold("npx keepmind start")}`),process.exit(1)),console.error(he.default.red(`Search failed: ${a}`)),process.exit(1)}s.ok||(s.status===404&&(console.error(he.default.red("Search endpoint not found. Is the worker running?")),console.error(`Try: ${he.default.bold("npx keepmind start")}`),process.exit(1)),console.error(he.default.red(`Search failed: HTTP ${s.status}`)),process.exit(1));let o;try{o=await s.json()}catch(i){let a=i instanceof Error?i.message:String(i);console.error(he.default.red(`Search failed: invalid JSON response (${a})`)),process.exit(1)}console.log(typeof o=="object"&&o!==null?JSON.stringify(o,null,2):o)}function hE(){qn();let t=mi(),e=yu("transcript-watcher.cjs");if(!Zt(e)){kt("transcript",["watch"]);return}fi(t,[e,"watch"],"transcript watcher")}var he,Fe=S(()=>{"use strict";Lt();sn();he=je(rt(),1);gr();Ae();vt()});var Au={};Ee(Au,{checkLastInteraction:()=>ku,checkNodeVersion:()=>Iu,checkProviderReadiness:()=>Ou,runDoctorCommand:()=>AE,summarizeReport:()=>_u});import{existsSync as _t,readFileSync as zn,readdirSync as EE}from"fs";import{join as Qt}from"path";import{spawnSync as vu}from"child_process";function Ru(t){try{let e=j?vu(`${t} --version`,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],shell:!0}):vu(t,["--version"],{encoding:"utf-8",stdio:["pipe","pipe","pipe"]});return e.status===0?e.stdout.trim():null}catch{return null}}function SE(){let t=new Set;try{let e=zn(P.envFile(),"utf-8");for(let r of e.split(/\r?\n/)){let n=r.trim();if(!n||n.startsWith("#"))continue;let s=n.indexOf("=");if(s<=0)continue;let o=n.slice(0,s).trim(),i=n.slice(s+1).trim();(i.startsWith('"')&&i.endsWith('"')||i.startsWith("'")&&i.endsWith("'"))&&(i=i.slice(1,-1)),o&&i&&t.add(o)}}catch{}return t}function bE(){try{let t=P.workerPid();if(_t(t)){let e=JSON.parse(zn(t,"utf-8"));if(typeof e.pid=="number"&&typeof e.port=="number"){let r=!1;try{process.kill(e.pid,0),r=!0}catch(n){n?.code==="EPERM"&&(r=!0)}return{port:String(e.port),pidAlive:r,pidPort:e.port}}}}catch{}return{port:te.get("CLAUDE_MEM_WORKER_PORT"),pidAlive:!1,pidPort:null}}async function yi(t,e){try{let r=await fetch(t,{signal:AbortSignal.timeout(e)});return r.ok?await r.json():null}catch{return null}}async function yE(){let{port:t,pidAlive:e,pidPort:r}=bE(),n=`http://127.0.0.1:${t}`,s=await yi(`${n}/api/health`,3e3);if(!s)return{reachable:!1,port:Number(t),pidAlive:e,pidPort:r};let[o,i]=await Promise.all([yi(`${n}/api/stats`,3e3),yi(`${n}/api/chroma/status?deep=true`,8e3)]);return{reachable:!0,port:Number(t),pidAlive:e,pidPort:r,health:s,stats:o??void 0,chroma:i??void 0}}function Iu(t=process.version){let e=/^v?(\d+)\.(\d+)/.exec(t),r=e?parseInt(e[1],10):0,n=e?parseInt(e[2],10):0,s=r>22||r===22&&n>=5;return{name:"Node.js >= 22.5",status:s?"ok":"fail",detail:s?t:`${t} is too old \u2014 keepmind needs Node >= 22.5 (node:sqlite). Install: https://nodejs.org`,required:!0}}function Ou(t){let e="AI provider";if(!Cu.includes(t.provider))return{name:e,status:"fail",detail:`CLAUDE_MEM_PROVIDER='${t.provider}' is invalid \u2014 must be one of ${Cu.join(", ")}`,required:!0};if(t.provider==="gemini")return t.geminiKey.trim()!==""||t.envKeys.has("GEMINI_API_KEY")?{name:e,status:"ok",detail:"gemini \u2014 API key configured",required:!0}:{name:e,status:"fail",detail:"gemini selected but no API key \u2014 set CLAUDE_MEM_GEMINI_API_KEY in settings.json or GEMINI_API_KEY in ~/.keepmind/.env",required:!0};if(t.provider==="openrouter")return t.openrouterKey.trim()!==""||t.envKeys.has("OPENROUTER_API_KEY")?{name:e,status:"ok",detail:"openrouter \u2014 API key configured",required:!0}:{name:e,status:"fail",detail:"openrouter selected but no API key \u2014 set CLAUDE_MEM_OPENROUTER_API_KEY in settings.json or OPENROUTER_API_KEY in ~/.keepmind/.env",required:!0};if(!wu.includes(t.claudeAuthMethod))return{name:e,status:"fail",detail:`claude auth method '${t.claudeAuthMethod}' is invalid \u2014 must be one of ${wu.join(", ")}`,required:!0};switch(t.claudeAuthMethod){case"api-key":return t.envKeys.has("ANTHROPIC_API_KEY")?{name:e,status:"ok",detail:"claude \u2014 ANTHROPIC_API_KEY configured",required:!0}:{name:e,status:"fail",detail:"claude api-key auth selected but ANTHROPIC_API_KEY missing \u2014 add it to ~/.keepmind/.env",required:!0};case"gateway":return t.envKeys.has("ANTHROPIC_BASE_URL")?{name:e,status:"ok",detail:"claude \u2014 gateway (ANTHROPIC_BASE_URL) configured",required:!0}:{name:e,status:"fail",detail:"claude gateway auth selected but ANTHROPIC_BASE_URL missing \u2014 add it to ~/.keepmind/.env",required:!0};case"subscription":return t.staleMarker?{name:e,status:"warn",detail:"claude subscription \u2014 OAuth token is STALE; re-login by running `claude` interactively once",required:!0}:{name:e,status:"ok",detail:"claude \u2014 subscription (OAuth)",required:!0};default:return{name:e,status:"ok",detail:"claude \u2014 uses Claude Code CLI auth",required:!0}}}function ku(t){let e="Last compression",r=t?.lastInteraction;return!r||typeof r.success!="boolean"?{name:e,status:"skip",detail:"no compression has run yet \u2014 end a session to generate the first observation",required:!1}:r.success?{name:e,status:"ok",detail:"most recent summarizer call succeeded",required:!1}:{name:e,status:"warn",detail:`most recent summarizer call FAILED: ${r.error??"unknown error"}`,required:!1}}function _u(t){let r=t.flatMap(n=>n.checks).filter(n=>n.required&&n.status==="fail").length;return{groups:t,ok:r===0,hardFailures:r}}function TE(t){let e=[];e.push(Iu());let r=Ru("bun");e.push({name:"Bun runtime",status:r?"ok":"fail",detail:r?`v${r.replace(/^v/,"")}`:"not found on PATH \u2014 install: https://bun.sh",required:!0});let n=Mt();e.push({name:"Plugin installed",status:n?"ok":"fail",detail:n?ie():"run `npx keepmind install`",required:!0});let s=(()=>{let c=Qt(be(),"cache","keepmind","keepmind");try{return EE(c,{withFileTypes:!0}).some(u=>u.isDirectory()&&_t(Qt(c,u.name,"node_modules")))}catch{return!1}})(),o=Qt(ie(),"plugin","node_modules"),i=s||_t(o);e.push({name:"Plugin deps",status:n?i?"ok":"fail":"warn",detail:i?"node_modules present":"missing \u2014 run `npx keepmind repair`",required:n});let a=Ru("uv");e.push({name:"uv (optional)",status:"ok",detail:a?`${a} \u2014 present (no longer required; vector search is in-process)`:"not installed \u2014 optional; vector search runs in-process, uv is not needed",required:!1});let l=Qt(t,"last-install-error.json");if(_t(l)){let c=`present at ${l}`;try{let u=JSON.parse(zn(l,"utf-8"));u&&typeof u=="object"&&(c=`${u.categoryId??"error"}: ${u.remediation??c}`)}catch{}e.push({name:"Last install error",status:"warn",detail:c,required:!1})}return{title:"Runtime & Install",checks:e}}function vE(t){let e=[],r=SE();for(let s of["ANTHROPIC_API_KEY","ANTHROPIC_BASE_URL","GEMINI_API_KEY","OPENROUTER_API_KEY"])process.env[s]&&process.env[s].trim()!==""&&r.add(s);let n;try{let s=Qt(lt(),"oauth-stale.marker");_t(s)&&(n=zn(s,"utf-8"))}catch{}return e.push(Ou({provider:te.get("CLAUDE_MEM_PROVIDER"),claudeAuthMethod:te.get("CLAUDE_MEM_CLAUDE_AUTH_METHOD"),geminiKey:te.get("CLAUDE_MEM_GEMINI_API_KEY"),openrouterKey:te.get("CLAUDE_MEM_OPENROUTER_API_KEY"),envKeys:r,staleMarker:n})),t.reachable&&e.push(ku(t.health?.ai)),{title:"AI Provider",checks:e}}function RE(t){let e=[];if(t.reachable){let r=t.health??{},n=[`v${(r.version??"?").replace(/^v/,"")}`,r.initialized===!1?"initializing":"initialized",r.mcpReady?"MCP ready":"MCP pending"],s=r.status!=="degraded"&&r.initialized!==!1;e.push({name:"Worker daemon",status:s?"ok":"warn",detail:`${s?"healthy":"degraded"} at http://127.0.0.1:${t.port} (${n.join(", ")})`,required:!1})}else e.push({name:"Worker daemon",status:"fail",detail:`no response on port ${t.port} \u2014 start with \`npx keepmind start\``,required:!1});return t.pidPort===null?e.push({name:"Worker PID file",status:t.reachable?"warn":"skip",detail:t.reachable?"worker responded but no valid worker.pid on disk":"no worker.pid \u2014 worker has not been started",required:!1}):t.pidAlive?e.push({name:"Worker PID file",status:t.reachable?"ok":"warn",detail:t.reachable?`live (port ${t.pidPort})`:`PID alive but daemon not responding on port ${t.pidPort} \u2014 likely a reused/stale PID; clear with \`npx keepmind restart\``,required:!1}):e.push({name:"Worker PID file",status:"warn",detail:"STALE \u2014 worker.pid points at a dead process; clear with `npx keepmind restart`",required:!1}),{title:"Worker",checks:e}}function CE(){let t=ur();if(!_t(t))return{obs:null,schema:null,error:"no database file yet"};let e=null;try{e=new pe(t,{readonly:!0});let r=e.prepare("SELECT COUNT(*) AS n FROM observations").get(),n=null;try{n=e.prepare("SELECT MAX(version) AS v FROM schema_versions").get()?.v??null}catch{}return{obs:r?.n??0,schema:n}}catch(r){return{obs:null,schema:null,error:r instanceof Error?r.message:String(r)}}finally{e?.close()}}function wE(t){let e=[];if(t.reachable&&t.stats?.database){let n=t.stats.database;e.push({name:"Database",status:"ok",detail:`${n.observations??0} observations, ${n.sessions??0} sessions (${OE(n.size)})`,required:!1})}else{let{obs:n,schema:s,error:o}=CE();o&&n===null?e.push({name:"Database",status:n===null&&o==="no database file yet"?"warn":"fail",detail:o==="no database file yet"?"no database yet \u2014 created on first session":`cannot open database read-only: ${o}`,required:!1}):e.push({name:"Database",status:"ok",detail:`${n??0} observations${s!==null?`, schema v${s}`:""} (read-only probe)`,required:!1})}if(!(te.get("CLAUDE_MEM_CHROMA_ENABLED")!=="false"))e.push({name:"Vector search",status:"warn",detail:"disabled via CLAUDE_MEM_CHROMA_ENABLED=false \u2014 semantic search falls back to SQLite/BM25",required:!1});else if(t.reachable&&t.chroma){let n=t.chroma;if(n.status==="disabled")e.push({name:"Vector search",status:"warn",detail:"worker has vector search OFF (started with CLAUDE_MEM_CHROMA_ENABLED=false in its env) \u2014 restart without that flag to enable",required:!1});else if(n.probe){let s=n.probe;e.push({name:"Vector search",status:s.ok?"ok":"warn",detail:s.ok?`ready (${n.backend??"sqlite-vec"}, embedder ${s.embedderWarm?"warm":"cold"}, ${s.queryLatencyMs??"?"}ms)`:`unhealthy: ${s.error??"probe failed"}`,required:!1})}else e.push({name:"Vector search",status:n.connected?"ok":"warn",detail:`${n.status??"unknown"} (${n.backend??"sqlite-vec"})`,required:!1})}else{let n=_t(Qt(ks,"vectors.db"));e.push({name:"Vector search",status:n?"ok":"skip",detail:n?"enabled; vector store present (start worker for a live readiness probe)":"enabled but no vector store yet \u2014 built on first backfill",required:!1})}return{title:"Memory Store",checks:e}}async function IE(){let t=[],e="ok",r="api.anthropic.com reachable, certificate trusted";try{r=`reachable (HTTP ${(await fetch("https://api.anthropic.com/v1/models",{method:"GET",signal:AbortSignal.timeout(5e3)})).status}), certificate trusted`}catch(n){let s=n?.cause?.code??n?.code??"";["CERT_HAS_EXPIRED","SELF_SIGNED_CERT_IN_CHAIN","UNABLE_TO_VERIFY_LEAF_SIGNATURE","UNABLE_TO_GET_ISSUER_CERT_LOCALLY","DEPTH_ZERO_SELF_SIGNED_CERT","CERT_UNTRUSTED"].includes(s)?(e="fail",r=`certificate rejected (${s}) \u2014 corporate TLS interception. Export your corporate root CA to a .pem and set NODE_EXTRA_CA_CERTS to it. On Windows, Claude Code's bundled runtime currently IGNORES CA env vars (upstream bug #71581); until fixed, workaround: NODE_TLS_REJECT_UNAUTHORIZED=0.`):(e="warn",r=`could not reach api.anthropic.com (${s||"network error"}) \u2014 offline or blocked`)}return t.push({name:"API TLS reachability",status:e,detail:r,required:!1}),{title:"Connectivity",checks:t}}function OE(t){if(!t||t<=0)return"0 B";let e=["B","KB","MB","GB"],r=t,n=0;for(;r>=1024&&n<e.length-1;)r/=1024,n++;return`${r.toFixed(n===0?0:1)} ${e[n]}`}function _E(t){console.log(Me.default.bold(`
|
|
1344
|
+
`),"Note"),Be(ge.default.green("claude-mem has been uninstalled."))}var ge,bu=S(()=>{"use strict";vs();ge=je(rt(),1);Ae();$t();vt();to()});var et={};Ee(et,{runAdoptCommand:()=>mE,runCleanupCommand:()=>fE,runRestartCommand:()=>Ei,runSearchCommand:()=>gE,runServerApiKeyCommand:()=>bi,runStartCommand:()=>gi,runStatusCommand:()=>Si,runStopCommand:()=>hi,runTranscriptWatchCommand:()=>hE});import{existsSync as Zt,readdirSync as cE,readFileSync as uE}from"fs";import{dirname as dE,join as Ur}from"path";function qn(){Mt()||(console.error(he.default.red("keepmind is not installed.")),console.error(`Run: ${he.default.bold("npx keepmind install")}`),process.exit(1))}function mi(){let t=un();return t||(console.error(he.default.red("Node.js runtime not found.")),console.error("keepmind requires Node.js >= 22.5 \u2014 install it from https://nodejs.org"),console.error("After installation, restart your terminal."),process.exit(1)),t}function pE(){try{let t=JSON.parse(uE(Ur(ie(),"plugin",".claude-plugin","plugin.json"),"utf-8"));return typeof t?.version=="string"?t.version:null}catch{return null}}function yu(t){let e=pE();if(e){let n=Ur(nt(e),"scripts",t);if(Zt(n))return n}let r=Ur(be(),"cache","keepmind","keepmind");if(Zt(r))for(let n of cE(r)){let s=Ur(r,n,"scripts",t);if(Zt(s))return s}return Ur(ie(),"plugin","scripts",t)}function Tu(){return yu("worker-service.cjs")}function fi(t,e,r="worker"){let n=He(t,e,{stdio:"inherit",cwd:dE(e[0]),env:Rt(process.env)});n.on("error",s=>{console.error(he.default.red(`Failed to start ${r}: ${s.message}`)),process.exit(1)}),n.on("close",s=>{process.exit(s??0)})}function kt(t,e=[]){qn();let r=mi(),n=Tu();Zt(n)||(console.error(he.default.red(`Worker script not found at: ${n}`)),console.error("The installation may be corrupted. Try: npx keepmind install"),process.exit(1)),fi(r,[n,t,...e])}function gi(){kt("start")}function hi(){kt("stop")}function Ei(){kt("restart")}function Si(){kt("status")}function bi(t=[]){kt("server",["api-key",...t])}function mE(t=[]){qn();let e=mi(),r=Tu();Zt(r)||(console.error(he.default.red(`Worker script not found at: ${r}`)),console.error("The installation may be corrupted. Try: npx keepmind install"),process.exit(1));let n=process.cwd();fi(e,[r,"adopt","--cwd",n,...t])}function fE(t=[]){kt("cleanup",t)}async function gE(t){qn();let e=t.join(" ").trim();e||(console.error(he.default.red("Usage: npx keepmind search <query>")),process.exit(1));let n=`http://127.0.0.1:${te.get("CLAUDE_MEM_WORKER_PORT")}/api/search?query=${encodeURIComponent(e)}`,s;try{s=await fetch(n)}catch(i){let a=i instanceof Error?i.message:String(i);((i instanceof Error?i.cause:void 0)?.code==="ECONNREFUSED"||a.includes("ECONNREFUSED"))&&(console.error(he.default.red("Worker is not running.")),console.error(`Start it with: ${he.default.bold("npx keepmind start")}`),process.exit(1)),console.error(he.default.red(`Search failed: ${a}`)),process.exit(1)}s.ok||(s.status===404&&(console.error(he.default.red("Search endpoint not found. Is the worker running?")),console.error(`Try: ${he.default.bold("npx keepmind start")}`),process.exit(1)),console.error(he.default.red(`Search failed: HTTP ${s.status}`)),process.exit(1));let o;try{o=await s.json()}catch(i){let a=i instanceof Error?i.message:String(i);console.error(he.default.red(`Search failed: invalid JSON response (${a})`)),process.exit(1)}console.log(typeof o=="object"&&o!==null?JSON.stringify(o,null,2):o)}function hE(){qn();let t=mi(),e=yu("transcript-watcher.cjs");if(!Zt(e)){kt("transcript",["watch"]);return}fi(t,[e,"watch"],"transcript watcher")}var he,Fe=S(()=>{"use strict";Lt();sn();he=je(rt(),1);gr();Ae();vt()});var Au={};Ee(Au,{checkLastInteraction:()=>ku,checkNodeVersion:()=>Iu,checkProviderReadiness:()=>Ou,runDoctorCommand:()=>AE,summarizeReport:()=>_u});import{existsSync as _t,readFileSync as zn,readdirSync as EE}from"fs";import{join as Qt}from"path";import{spawnSync as vu}from"child_process";function Ru(t){try{let e=j?vu(`${t} --version`,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],shell:!0}):vu(t,["--version"],{encoding:"utf-8",stdio:["pipe","pipe","pipe"]});return e.status===0?e.stdout.trim():null}catch{return null}}function SE(){let t=new Set;try{let e=zn(P.envFile(),"utf-8");for(let r of e.split(/\r?\n/)){let n=r.trim();if(!n||n.startsWith("#"))continue;let s=n.indexOf("=");if(s<=0)continue;let o=n.slice(0,s).trim(),i=n.slice(s+1).trim();(i.startsWith('"')&&i.endsWith('"')||i.startsWith("'")&&i.endsWith("'"))&&(i=i.slice(1,-1)),o&&i&&t.add(o)}}catch{}return t}function bE(){try{let t=P.workerPid();if(_t(t)){let e=JSON.parse(zn(t,"utf-8"));if(typeof e.pid=="number"&&typeof e.port=="number"){let r=!1;try{process.kill(e.pid,0),r=!0}catch(n){n?.code==="EPERM"&&(r=!0)}return{port:String(e.port),pidAlive:r,pidPort:e.port}}}}catch{}return{port:te.get("CLAUDE_MEM_WORKER_PORT"),pidAlive:!1,pidPort:null}}async function yi(t,e){try{let r=await fetch(t,{signal:AbortSignal.timeout(e)});return r.ok?await r.json():null}catch{return null}}async function yE(){let{port:t,pidAlive:e,pidPort:r}=bE(),n=`http://127.0.0.1:${t}`,s=await yi(`${n}/api/health`,3e3);if(!s)return{reachable:!1,port:Number(t),pidAlive:e,pidPort:r};let[o,i]=await Promise.all([yi(`${n}/api/stats`,3e3),yi(`${n}/api/chroma/status?deep=true`,8e3)]);return{reachable:!0,port:Number(t),pidAlive:e,pidPort:r,health:s,stats:o??void 0,chroma:i??void 0}}function Iu(t=process.version){let e=/^v?(\d+)\.(\d+)/.exec(t),r=e?parseInt(e[1],10):0,n=e?parseInt(e[2],10):0,s=r>22||r===22&&n>=5;return{name:"Node.js >= 22.5",status:s?"ok":"fail",detail:s?t:`${t} is too old \u2014 keepmind needs Node >= 22.5 (node:sqlite). Install: https://nodejs.org`,required:!0}}function Ou(t){let e="AI provider";if(!Cu.includes(t.provider))return{name:e,status:"fail",detail:`CLAUDE_MEM_PROVIDER='${t.provider}' is invalid \u2014 must be one of ${Cu.join(", ")}`,required:!0};if(t.provider==="gemini")return t.geminiKey.trim()!==""||t.envKeys.has("GEMINI_API_KEY")?{name:e,status:"ok",detail:"gemini \u2014 API key configured",required:!0}:{name:e,status:"fail",detail:"gemini selected but no API key \u2014 set CLAUDE_MEM_GEMINI_API_KEY in settings.json or GEMINI_API_KEY in ~/.keepmind/.env",required:!0};if(t.provider==="openrouter")return t.openrouterKey.trim()!==""||t.envKeys.has("OPENROUTER_API_KEY")?{name:e,status:"ok",detail:"openrouter \u2014 API key configured",required:!0}:{name:e,status:"fail",detail:"openrouter selected but no API key \u2014 set CLAUDE_MEM_OPENROUTER_API_KEY in settings.json or OPENROUTER_API_KEY in ~/.keepmind/.env",required:!0};if(!wu.includes(t.claudeAuthMethod))return{name:e,status:"fail",detail:`claude auth method '${t.claudeAuthMethod}' is invalid \u2014 must be one of ${wu.join(", ")}`,required:!0};switch(t.claudeAuthMethod){case"api-key":return t.envKeys.has("ANTHROPIC_API_KEY")?{name:e,status:"ok",detail:"claude \u2014 ANTHROPIC_API_KEY configured",required:!0}:{name:e,status:"fail",detail:"claude api-key auth selected but ANTHROPIC_API_KEY missing \u2014 add it to ~/.keepmind/.env",required:!0};case"gateway":return t.envKeys.has("ANTHROPIC_BASE_URL")?{name:e,status:"ok",detail:"claude \u2014 gateway (ANTHROPIC_BASE_URL) configured",required:!0}:{name:e,status:"fail",detail:"claude gateway auth selected but ANTHROPIC_BASE_URL missing \u2014 add it to ~/.keepmind/.env",required:!0};case"subscription":return t.staleMarker?{name:e,status:"warn",detail:"claude subscription \u2014 OAuth token is STALE; re-login by running `claude` interactively once",required:!0}:{name:e,status:"ok",detail:"claude \u2014 subscription (OAuth)",required:!0};default:return{name:e,status:"ok",detail:"claude \u2014 uses Claude Code CLI auth",required:!0}}}function ku(t){let e="Last compression",r=t?.lastInteraction;return!r||typeof r.success!="boolean"?{name:e,status:"skip",detail:"no compression has run yet \u2014 end a session to generate the first observation",required:!1}:r.success?{name:e,status:"ok",detail:"most recent summarizer call succeeded",required:!1}:{name:e,status:"warn",detail:`most recent summarizer call FAILED: ${r.error??"unknown error"}`,required:!1}}function _u(t){let r=t.flatMap(n=>n.checks).filter(n=>n.required&&n.status==="fail").length;return{groups:t,ok:r===0,hardFailures:r}}function TE(t){let e=[];e.push(Iu());let r=Ru("bun");e.push({name:"Bun runtime",status:r?"ok":"warn",detail:r?`v${r.replace(/^v/,"")}`:"not found \u2014 optional; core memory works without it, but it installs the native deps for semantic vector search. Install: `winget install Oven-sh.Bun` (Windows) or https://bun.sh, then `npx keepmind install`.",required:!1});let n=Mt();e.push({name:"Plugin installed",status:n?"ok":"fail",detail:n?ie():"run `npx keepmind install`",required:!0});let s=(()=>{let c=Qt(be(),"cache","keepmind","keepmind");try{return EE(c,{withFileTypes:!0}).some(u=>u.isDirectory()&&_t(Qt(c,u.name,"node_modules")))}catch{return!1}})(),o=Qt(ie(),"plugin","node_modules"),i=s||_t(o);e.push({name:"Plugin deps",status:n?i?"ok":"fail":"warn",detail:i?"node_modules present":"missing \u2014 run `npx keepmind repair`",required:n});let a=Ru("uv");e.push({name:"uv (optional)",status:"ok",detail:a?`${a} \u2014 present (no longer required; vector search is in-process)`:"not installed \u2014 optional; vector search runs in-process, uv is not needed",required:!1});let l=Qt(t,"last-install-error.json");if(_t(l)){let c=`present at ${l}`;try{let u=JSON.parse(zn(l,"utf-8"));u&&typeof u=="object"&&(c=`${u.categoryId??"error"}: ${u.remediation??c}`)}catch{}e.push({name:"Last install error",status:"warn",detail:c,required:!1})}return{title:"Runtime & Install",checks:e}}function vE(t){let e=[],r=SE();for(let s of["ANTHROPIC_API_KEY","ANTHROPIC_BASE_URL","GEMINI_API_KEY","OPENROUTER_API_KEY"])process.env[s]&&process.env[s].trim()!==""&&r.add(s);let n;try{let s=Qt(lt(),"oauth-stale.marker");_t(s)&&(n=zn(s,"utf-8"))}catch{}return e.push(Ou({provider:te.get("CLAUDE_MEM_PROVIDER"),claudeAuthMethod:te.get("CLAUDE_MEM_CLAUDE_AUTH_METHOD"),geminiKey:te.get("CLAUDE_MEM_GEMINI_API_KEY"),openrouterKey:te.get("CLAUDE_MEM_OPENROUTER_API_KEY"),envKeys:r,staleMarker:n})),t.reachable&&e.push(ku(t.health?.ai)),{title:"AI Provider",checks:e}}function RE(t){let e=[];if(t.reachable){let r=t.health??{},n=[`v${(r.version??"?").replace(/^v/,"")}`,r.initialized===!1?"initializing":"initialized",r.mcpReady?"MCP ready":"MCP pending"],s=r.status!=="degraded"&&r.initialized!==!1;e.push({name:"Worker daemon",status:s?"ok":"warn",detail:`${s?"healthy":"degraded"} at http://127.0.0.1:${t.port} (${n.join(", ")})`,required:!1})}else e.push({name:"Worker daemon",status:"fail",detail:`no response on port ${t.port} \u2014 start with \`npx keepmind start\``,required:!1});return t.pidPort===null?e.push({name:"Worker PID file",status:t.reachable?"warn":"skip",detail:t.reachable?"worker responded but no valid worker.pid on disk":"no worker.pid \u2014 worker has not been started",required:!1}):t.pidAlive?e.push({name:"Worker PID file",status:t.reachable?"ok":"warn",detail:t.reachable?`live (port ${t.pidPort})`:`PID alive but daemon not responding on port ${t.pidPort} \u2014 likely a reused/stale PID; clear with \`npx keepmind restart\``,required:!1}):e.push({name:"Worker PID file",status:"warn",detail:"STALE \u2014 worker.pid points at a dead process; clear with `npx keepmind restart`",required:!1}),{title:"Worker",checks:e}}function CE(){let t=ur();if(!_t(t))return{obs:null,schema:null,error:"no database file yet"};let e=null;try{e=new pe(t,{readonly:!0});let r=e.prepare("SELECT COUNT(*) AS n FROM observations").get(),n=null;try{n=e.prepare("SELECT MAX(version) AS v FROM schema_versions").get()?.v??null}catch{}return{obs:r?.n??0,schema:n}}catch(r){return{obs:null,schema:null,error:r instanceof Error?r.message:String(r)}}finally{e?.close()}}function wE(t){let e=[];if(t.reachable&&t.stats?.database){let n=t.stats.database;e.push({name:"Database",status:"ok",detail:`${n.observations??0} observations, ${n.sessions??0} sessions (${OE(n.size)})`,required:!1})}else{let{obs:n,schema:s,error:o}=CE();o&&n===null?e.push({name:"Database",status:n===null&&o==="no database file yet"?"warn":"fail",detail:o==="no database file yet"?"no database yet \u2014 created on first session":`cannot open database read-only: ${o}`,required:!1}):e.push({name:"Database",status:"ok",detail:`${n??0} observations${s!==null?`, schema v${s}`:""} (read-only probe)`,required:!1})}if(!(te.get("CLAUDE_MEM_CHROMA_ENABLED")!=="false"))e.push({name:"Vector search",status:"warn",detail:"disabled via CLAUDE_MEM_CHROMA_ENABLED=false \u2014 semantic search falls back to SQLite/BM25",required:!1});else if(t.reachable&&t.chroma){let n=t.chroma;if(n.status==="disabled")e.push({name:"Vector search",status:"warn",detail:"worker has vector search OFF (started with CLAUDE_MEM_CHROMA_ENABLED=false in its env) \u2014 restart without that flag to enable",required:!1});else if(n.probe){let s=n.probe;e.push({name:"Vector search",status:s.ok?"ok":"warn",detail:s.ok?`ready (${n.backend??"sqlite-vec"}, embedder ${s.embedderWarm?"warm":"cold"}, ${s.queryLatencyMs??"?"}ms)`:`unhealthy: ${s.error??"probe failed"}`,required:!1})}else e.push({name:"Vector search",status:n.connected?"ok":"warn",detail:`${n.status??"unknown"} (${n.backend??"sqlite-vec"})`,required:!1})}else{let n=_t(Qt(ks,"vectors.db"));e.push({name:"Vector search",status:n?"ok":"skip",detail:n?"enabled; vector store present (start worker for a live readiness probe)":"enabled but no vector store yet \u2014 built on first backfill",required:!1})}return{title:"Memory Store",checks:e}}async function IE(){let t=[],e="ok",r="api.anthropic.com reachable, certificate trusted";try{r=`reachable (HTTP ${(await fetch("https://api.anthropic.com/v1/models",{method:"GET",signal:AbortSignal.timeout(5e3)})).status}), certificate trusted`}catch(n){let s=n?.cause?.code??n?.code??"";["CERT_HAS_EXPIRED","SELF_SIGNED_CERT_IN_CHAIN","UNABLE_TO_VERIFY_LEAF_SIGNATURE","UNABLE_TO_GET_ISSUER_CERT_LOCALLY","DEPTH_ZERO_SELF_SIGNED_CERT","CERT_UNTRUSTED"].includes(s)?(e="fail",r=`certificate rejected (${s}) \u2014 corporate TLS interception. Export your corporate root CA to a .pem and set NODE_EXTRA_CA_CERTS to it. On Windows, Claude Code's bundled runtime currently IGNORES CA env vars (upstream bug #71581); until fixed, workaround: NODE_TLS_REJECT_UNAUTHORIZED=0.`):(e="warn",r=`could not reach api.anthropic.com (${s||"network error"}) \u2014 offline or blocked`)}return t.push({name:"API TLS reachability",status:e,detail:r,required:!1}),{title:"Connectivity",checks:t}}function OE(t){if(!t||t<=0)return"0 B";let e=["B","KB","MB","GB"],r=t,n=0;for(;r>=1024&&n<e.length-1;)r/=1024,n++;return`${r.toFixed(n===0?0:1)} ${e[n]}`}function _E(t){console.log(Me.default.bold(`
|
|
1345
1345
|
keepmind doctor
|
|
1346
1346
|
`));for(let e of t.groups){console.log(Me.default.bold(Me.default.cyan(` ${e.title}`)));for(let r of e.checks)console.log(` ${kE(r.status)} ${r.name.padEnd(22)} ${Me.default.dim(r.detail)}`);console.log("")}t.ok?console.log(Me.default.green("All required checks passed.")):console.log(Me.default.red(`${t.hardFailures} required check(s) failed \u2014 see remediation above.`))}async function AE(t=[]){let e=t.includes("--json"),r=lt(),n=await yE(),s=[TE(r),vE(n),RE(n),wE(n),await IE()],o=_u(s);e?console.log(JSON.stringify(o,null,2)):_E(o),process.exit(o.ok?0:1)}var Me,Cu,wu,kE,Nu=S(()=>{"use strict";Me=je(rt(),1);Ae();vt();J();Dt();Cu=["claude","gemini","openrouter"],wu=["subscription","api-key","gateway","cli"];kE=t=>t==="ok"?Me.default.green("\u2713"):t==="warn"?Me.default.yellow("!"):t==="skip"?Me.default.dim("\xB7"):Me.default.red("\u2717")});var Ti={};Ee(Ti,{runServerCommand:()=>ME,runWorkerAliasCommand:()=>xE});function Mu(){console.error(`Usage: ${Fr.default.bold("npx keepmind server <command>")}`),console.error("Commands: api-key create|list|revoke")}function NE(t){switch(t){case"start":return gi(),!0;case"stop":return hi(),!0;case"restart":return Ei(),!0;case"status":return Si(),!0;default:return!1}}async function ME(t=[]){let e=t[0]?.toLowerCase();if(e||(Mu(),process.exit(1)),e==="api-key"){let r=t[1]?.toLowerCase();if(r==="create"||r==="list"||r==="revoke"){bi(t.slice(1));return}console.error(Fr.default.red(`Unknown server api-key subcommand: ${r??"(none)"}`)),console.error("Usage: npx keepmind server api-key create|list|revoke"),process.exit(1)}console.error(Fr.default.red(`Unknown server command: ${e}`)),Mu(),process.exit(1)}function xE(t=[]){let e=t[0]?.toLowerCase();(!e||!NE(e))&&(console.error(Fr.default.red(`Unknown worker command: ${e??"(none)"}`)),console.error("Usage: npx keepmind worker start|stop|restart|status"),process.exit(1))}var Fr,vi=S(()=>{"use strict";Fr=je(rt(),1);Fe()});var x=je(rt(),1);Ae();var We=process.argv.slice(2),Ri=We[0]?.toLowerCase()??"",LE=new Set(["-h","--help","-v","--version"]),xu=Ri.startsWith("-")&&!LE.has(Ri)?"install":Ri;function DE(){let t=Nt();console.log(`
|
|
1347
1347
|
${x.default.bold("keepmind")} v${t} \u2014 persistent memory for AI coding assistants
|
package/package.json
CHANGED
package/plugin/package.json
CHANGED
|
@@ -220,7 +220,7 @@ ${m}`}let c=i.lineStart;for(let l=i.lineStart-1;l>=0;l--){let d=a[l].trim();if(d
|
|
|
220
220
|
${u}`}var V_=new Set([".js",".jsx",".ts",".tsx",".mjs",".cjs",".py",".pyw",".go",".rs",".rb",".java",".cs",".cpp",".cc",".cxx",".c",".h",".hpp",".hh",".swift",".kt",".kts",".php",".vue",".svelte",".ex",".exs",".lua",".scala",".sc",".sh",".bash",".zsh",".hs",".zig",".css",".scss",".toml",".yml",".yaml",".sql",".md",".mdx"]),KP=new Set(["node_modules",".git","dist","build",".next","__pycache__",".venv","venv","env",".env","target","vendor",".cache",".turbo","coverage",".nyc_output",".claude",".smart-file-read"]),JP=512*1024;async function*G_(t,e,r=20,n){if(r<=0)return;let o;try{o=await(0,qr.readdir)(t,{withFileTypes:!0})}catch(s){y.debug("WORKER",`walkDir: failed to read directory ${t}`,void 0,s instanceof Error?s:void 0);return}for(let s of o){if(s.name.startsWith(".")&&s.name!=="."||KP.has(s.name))continue;let i=(0,ro.join)(t,s.name);if(s.isDirectory())yield*G_(i,e,r-1,n);else if(s.isFile()){let a=s.name.slice(s.name.lastIndexOf("."));(V_.has(a)||n&&n.has(a))&&(yield i)}}}async function BP(t){try{let e=await(0,qr.stat)(t);if(e.size>JP||e.size===0)return null;let r=await(0,qr.readFile)(t,"utf-8");return r.slice(0,1e3).includes("\0")?null:r}catch(e){return y.debug("WORKER",`safeReadFile: failed to read ${t}`,void 0,e instanceof Error?e:void 0),null}}async function K_(t,e,r={}){let n=r.maxResults||20,o=e.toLowerCase(),s=o.split(/[\s_\-./]+/).filter(w=>w.length>0),i=r.projectRoot||t,a=to(i),c=new Set;for(let w of Object.values(a.grammars))for(let v of w.extensions)V_.has(v)||c.add(v);let u=[];for await(let w of G_(t,t,20,c.size>0?c:void 0)){if(r.filePattern&&!(0,ro.relative)(t,w).toLowerCase().includes(r.filePattern.toLowerCase()))continue;let v=await BP(w);v&&u.push({absolutePath:w,relativePath:(0,ro.relative)(t,w),content:v})}let l=F_(u,i),d=[],p=[],f=0;for(let[w,v]of l){f+=YP(v);let x=Ws(w.toLowerCase(),s)>0,be=[],xe=(Zt,ir)=>{for(let ce of Zt){let kt=0,Je="",Zr=Ws(ce.name.toLowerCase(),s);Zr>0&&(kt+=Zr*3,Je="name match"),ce.signature.toLowerCase().includes(o)&&(kt+=2,Je=Je?`${Je} + signature`:"signature match"),ce.jsdoc&&ce.jsdoc.toLowerCase().includes(o)&&(kt+=1,Je=Je?`${Je} + jsdoc`:"jsdoc match"),kt>0&&(x=!0,be.push({filePath:w,symbolName:ir?`${ir}.${ce.name}`:ce.name,kind:ce.kind,signature:ce.signature,jsdoc:ce.jsdoc,lineStart:ce.lineStart,lineEnd:ce.lineEnd,matchReason:Je})),ce.children&&xe(ce.children,ce.name)}};xe(v.symbols),x&&(d.push(v),p.push(...be))}p.sort((w,v)=>{let $=Ws(w.symbolName.toLowerCase(),s);return Ws(v.symbolName.toLowerCase(),s)-$});let m=p.slice(0,n),_=new Set(m.map(w=>w.filePath)),S=d.filter(w=>_.has(w.filePath)).slice(0,n),b=S.reduce((w,v)=>w+v.foldedTokenEstimate,0);return{foldedFiles:S,matchingSymbols:m,totalFilesScanned:u.length,totalSymbolsFound:f,tokenEstimate:b}}function Ws(t,e){let r=0;for(let n of e)if(t===n)r+=10;else if(t.includes(n))r+=5;else{let o=0,s=0;for(let i of n){let a=t.indexOf(i,o);a!==-1&&(s++,o=a+1)}s===n.length&&(r+=1)}return r}function YP(t){let e=t.symbols.length;for(let r of t.symbols)r.children&&(e+=r.children.length);return e}function J_(t,e){let r=[];if(r.push(`\u{1F50D} Smart Search: "${e}"`),r.push(` Scanned ${t.totalFilesScanned} files, found ${t.totalSymbolsFound} symbols`),r.push(` ${t.matchingSymbols.length} matches across ${t.foldedFiles.length} files (~${t.tokenEstimate} tokens for folded view)`),r.push(""),t.matchingSymbols.length===0)return r.push(" No matching symbols found."),r.join(`
|
|
221
221
|
`);r.push("\u2500\u2500 Matching Symbols \u2500\u2500"),r.push("");for(let n of t.matchingSymbols){if(r.push(` ${n.kind} ${n.symbolName} (${n.filePath}:${n.lineStart+1})`),r.push(` ${n.signature}`),n.jsdoc){let o=n.jsdoc.split(`
|
|
222
222
|
`).find(s=>s.replace(/^[\s*/]+/,"").trim().length>0);o&&r.push(` \u{1F4AC} ${o.replace(/^[\s*/]+/,"").trim()}`)}r.push("")}r.push("\u2500\u2500 Folded File Views \u2500\u2500"),r.push("");for(let n of t.foldedFiles)r.push(Ur(n)),r.push("");return r.push("\u2500\u2500 Actions \u2500\u2500"),r.push(" To see full implementation: use smart_unfold with file path and symbol name"),r.join(`
|
|
223
|
-
`)}var Du=require("node:fs/promises"),Ks=require("node:fs"),rt=require("node:path"),oy=require("node:os"),sy=require("node:url");var B_="claude";function XP(t){return t.trim().toLowerCase().replace(/\s+/g,"-")}function Vs(t){if(!t)return B_;let e=XP(t);return e?e==="transcript"||e.includes("codex")?"codex":e.includes("cursor")?"cursor":e.includes("claude")?"claude":e:B_}var QP=wt(ue.API_REQUEST),Ke=class extends Error{kind;status;cause;constructor(e,r,n={}){super(r),this.name="ServerClientError",this.kind=e,this.status=n.status??null,this.cause=n.cause}isFallbackEligible(){return this.kind==="transport"||this.kind==="timeout"||this.kind==="missing_api_key"||this.kind==="http_error"&&(this.status!==null&&this.status>=500||this.status===429)}},Gs=class{baseUrl;apiKey;timeoutMs;constructor(e){this.baseUrl=eT(e.serverBaseUrl),this.apiKey=e.apiKey,this.timeoutMs=e.timeoutMs??QP}async startSession(e){let r=this.buildStartSessionPayload(e);return this.request("POST","/v1/sessions/start",r)}async recordEvent(e){let r=this.buildEventPayload(e),n=e.generate===!1?"/v1/events?generate=false":"/v1/events";return this.request("POST",n,r)}async endSession(e){if(!e.sessionId)throw new Ke("invalid_response","sessionId is required for endSession");return this.request("POST",`/v1/sessions/${encodeURIComponent(e.sessionId)}/end`,{})}async addObservation(e){return this.request("POST","/v1/memories",this.buildAddObservationPayload(e))}async searchObservations(e){return this.request("POST","/v1/search",this.buildSearchPayload(e))}async contextObservations(e){return this.request("POST","/v1/context",this.buildSearchPayload(e))}async getJobStatus(e){if(!e)throw new Ke("invalid_response","jobId is required for getJobStatus");return this.request("GET",`/v1/jobs/${encodeURIComponent(e)}`)}buildAddObservationPayload(e){let r=e.content,n=e.kind??"manual",o=typeof e.metadata?.title=="string"?e.metadata.title:void 0;return{projectId:e.projectId,kind:n,type:n,narrative:r,...o?{title:o}:{},...e.serverSessionId!==void 0?{serverSessionId:e.serverSessionId}:{},...e.metadata!==void 0?{metadata:e.metadata}:{}}}buildSearchPayload(e){return{projectId:e.projectId,query:e.query,...e.limit!==void 0?{limit:e.limit}:{},...e.platformSource!==void 0?{platformSource:Au(e.platformSource)}:{}}}buildStartSessionPayload(e){return{projectId:e.projectId,...e.externalSessionId!==void 0?{externalSessionId:e.externalSessionId}:{},...e.contentSessionId!==void 0?{contentSessionId:e.contentSessionId}:{},...e.agentId!==void 0?{agentId:e.agentId}:{},...e.agentType!==void 0?{agentType:e.agentType}:{},...e.platformSource!==void 0?{platformSource:Au(e.platformSource)}:{},...e.metadata!==void 0?{metadata:e.metadata}:{}}}buildEventPayload(e){return{projectId:e.projectId,sourceType:e.sourceType,eventType:e.eventType,occurredAtEpoch:e.occurredAtEpoch,...e.serverSessionId!==void 0?{serverSessionId:e.serverSessionId}:{},...e.contentSessionId!==void 0?{contentSessionId:e.contentSessionId}:{},...e.memorySessionId!==void 0?{memorySessionId:e.memorySessionId}:{},...e.platformSource!==void 0?{platformSource:Au(e.platformSource)}:{},...e.payload!==void 0?{payload:e.payload}:{}}}async request(e,r,n){if(!this.apiKey||!this.apiKey.trim())throw new Ke("missing_api_key","Server API key is not configured (CLAUDE_MEM_SERVER_API_KEY).");let o=`${this.baseUrl}${r}`,s={method:e,headers:{"Content-Type":"application/json",Authorization:`Bearer ${this.apiKey}`}};n!==void 0&&(s.body=JSON.stringify(n));let i;try{i=await Eu(o,s,this.timeoutMs)}catch(c){let u=c instanceof Error?c.message:String(c),l=/timed out|timeout/i.test(u);throw new Ke(l?"timeout":"transport",`Server ${e} ${r} failed: ${u}`,{cause:c})}if(!i.ok){let c=await i.text().catch(()=>"");throw new Ke("http_error",`Server ${e} ${r} returned ${i.status}: ${tT(c,200)}`,{status:i.status})}let a=await i.text();if(!a||a.length===0)return{};try{return JSON.parse(a)}catch(c){throw new Ke("invalid_response",`Server ${e} ${r} returned non-JSON response`,{cause:c})}}};function Y_(t){return t instanceof Ke}function eT(t){return t.replace(/\/+$/,"")}function Au(t){return typeof t=="string"?Vs(t):null}function tT(t,e){return t.length<=e?t:`${t.slice(0,e)}\u2026`}function Mu(){let e=(Ms().CLAUDE_MEM_RUNTIME??"worker").trim().toLowerCase();return e==="server"||e==="server-beta"?"server":"worker"}function X_(){let t=Ms(),e=(...i)=>{for(let a of i){let c=(a??"").trim();if(c.length>0)return c}return""},r=e(t.CLAUDE_MEM_SERVER_URL,t.CLAUDE_MEM_SERVER_BETA_URL),n=e(t.CLAUDE_MEM_SERVER_API_KEY,t.CLAUDE_MEM_SERVER_BETA_API_KEY),o=e(t.CLAUDE_MEM_SERVER_PROJECT_ID,t.CLAUDE_MEM_SERVER_BETA_PROJECT_ID);if(!r)return y.warn("HOOK","[server-fallback] reason=missing_base_url"),null;if(!n)return y.warn("HOOK","[server-fallback] reason=missing_api_key"),null;if(!o)return y.warn("HOOK","[server-fallback] reason=missing_project_id"),null;let s={serverBaseUrl:r,apiKey:n};return{runtime:"server",client:new Gs(s),projectId:o,serverBaseUrl:r}}var ST={},rT="1.1.3";console.log=(...t)=>{y.error("CONSOLE","Intercepted console output (MCP protocol protection)",void 0,{args:t})};var iy=!1,ay=(()=>{if(typeof __dirname<"u")return __dirname;try{return(0,rt.dirname)((0,sy.fileURLToPath)(ST.url))}catch{return iy=!0,process.cwd()}})(),Nu=T_()??(0,rt.resolve)(ay,"worker-service.cjs");function nT(){iy&&((0,Ks.existsSync)(Nu)||y.error("SYSTEM","mcp-server: dirname resolution failed (both __dirname and import.meta.url are unavailable). Fell back to process.cwd() and the resolved WORKER_SCRIPT_PATH does not exist. This is the actual problem \u2014 the worker bundle is fine, but mcp-server cannot locate it. Worker auto-start will fail until the dirname-resolution path is fixed.",{workerScriptPath:Nu,mcpServerDir:ay}))}var Q_={search:"/api/search",timeline:"/api/timeline"};async function Cu(t,e){y.debug("SYSTEM","\u2192 Worker API",void 0,{endpoint:t,params:e});let r=new URLSearchParams;for(let[o,s]of Object.entries(e))s!=null&&r.append(o,String(s));let n=`${t}?${r}`;try{let o=await Xn(n);if(!o.ok){let i=await o.text();throw new Error(`Worker API error (${o.status}): ${i}`)}let s=await o.json();return y.debug("SYSTEM","\u2190 Worker API success",void 0,{endpoint:t}),s}catch(o){return y.error("SYSTEM","\u2190 Worker API error",{endpoint:t},o instanceof Error?o:new Error(String(o))),{content:[{type:"text",text:`Error calling Worker API: ${o instanceof Error?o.message:String(o)}`}],isError:!0}}}async function oT(t,e){y.debug("SYSTEM","\u2192 Worker API text",void 0,{endpoint:t,params:e});let r=new URLSearchParams;for(let[o,s]of Object.entries(e))s!=null&&r.append(o,String(s));let n=`${t}?${r}`;try{let o=await Xn(n);if(!o.ok){let i=await o.text();throw new Error(`Worker API error (${o.status}): ${i}`)}let s=await o.text();return y.debug("SYSTEM","\u2190 Worker API text success",void 0,{endpoint:t}),{content:[{type:"text",text:s}]}}catch(o){return y.error("SYSTEM","\u2190 Worker API text error",{endpoint:t},o instanceof Error?o:new Error(String(o))),{content:[{type:"text",text:`Error calling Worker API: ${o instanceof Error?o.message:String(o)}`}],isError:!0}}}async function sT(t,e){let r=await Xn(t,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)});if(!r.ok){let o=await r.text();throw new Error(`Worker API error (${r.status}): ${o}`)}let n=await r.json();return y.debug("HTTP","Worker API success (POST)",void 0,{endpoint:t}),{content:[{type:"text",text:JSON.stringify(n,null,2)}]}}async function sr(t,e){y.debug("HTTP","Worker API request (POST)",void 0,{endpoint:t});try{return await sT(t,e)}catch(r){return y.error("HTTP","Worker API error (POST)",{endpoint:t},r instanceof Error?r:new Error(String(r))),{content:[{type:"text",text:`Error calling Worker API: ${r instanceof Error?r.message:String(r)}`}],isError:!0}}}async function iT(){try{return(await Xn("/api/health")).ok}catch(t){return y.debug("SYSTEM","Worker health check failed",{},t instanceof Error?t:new Error(String(t))),!1}}function aT(){if(Mu()!=="server")return null;let e=X_();return e?{...e,available:!0}:{runtime:"server",available:!1,reason:"server runtime is selected but configuration is incomplete (missing url, api key, or project id)"}}function oo(t){return Y_(t)?{content:[{type:"text",text:`Server error (${t.kind}${t.status?` ${t.status}`:""}): ${t.message}`}],isError:!0}:{content:[{type:"text",text:`Tool error: ${t instanceof Error?t.message:String(t)}`}],isError:!0}}function so(t){return{content:[{type:"text",text:JSON.stringify(t,null,2)}]}}function io(t){let e=aT();if(!e)throw new Ke("transport",`${t} requires CLAUDE_MEM_RUNTIME=server. Current runtime is "worker"; use the existing search/timeline/get_observations tools for worker-mode memory access.`);if(!e.available)throw new Ke("missing_api_key",`${t}: ${e.reason}`);return e}async function ey(t){try{let e=io("observation_add");if(typeof t?.content!="string"||t.content.trim().length===0)throw new Error('observation_add: "content" is required');let n={projectId:t.projectId&&t.projectId.trim().length>0?t.projectId:e.projectId,content:t.content,...t.serverSessionId!==void 0?{serverSessionId:t.serverSessionId}:{},...t.kind!==void 0?{kind:t.kind}:{},...t.metadata!==void 0?{metadata:t.metadata}:{}},o=await e.client.addObservation(n);return so(o)}catch(e){return oo(e)}}function Bs(t){return typeof t=="string"?Vs(t):null}async function cT(t){try{let e=io("observation_record_event");if(typeof t?.eventType!="string"||t.eventType.trim().length===0)throw new Error('observation_record_event: "eventType" is required');let n={projectId:t.projectId&&t.projectId.trim().length>0?t.projectId:e.projectId,sourceType:t.sourceType??"api",eventType:t.eventType,occurredAtEpoch:typeof t.occurredAtEpoch=="number"?t.occurredAtEpoch:Date.now(),...t.serverSessionId!==void 0?{serverSessionId:t.serverSessionId}:{},...t.contentSessionId!==void 0?{contentSessionId:t.contentSessionId}:{},...t.memorySessionId!==void 0?{memorySessionId:t.memorySessionId}:{},...t.platformSource!==void 0?{platformSource:Bs(t.platformSource)}:{},...t.payload!==void 0?{payload:t.payload}:{},...t.generate!==void 0?{generate:t.generate}:{}},o=await e.client.recordEvent(n);return so(o)}catch(e){return oo(e)}}async function ty(t){try{let e=io("observation_search");if(typeof t?.query!="string"||t.query.trim().length===0)throw new Error('observation_search: "query" is required');let n={projectId:t.projectId&&t.projectId.trim().length>0?t.projectId:e.projectId,query:t.query,...t.limit!==void 0?{limit:t.limit}:{},...t.platformSource!==void 0?{platformSource:Bs(t.platformSource)}:{}},o=await e.client.searchObservations(n);return so(o)}catch(e){return oo(e)}}async function ry(t){try{let e=io("observation_context");if(typeof t?.query!="string"||t.query.trim().length===0)throw new Error('observation_context: "query" is required');let n={projectId:t.projectId&&t.projectId.trim().length>0?t.projectId:e.projectId,query:t.query,...t.limit!==void 0?{limit:t.limit}:{},...t.platformSource!==void 0?{platformSource:Bs(t.platformSource)}:{}},o=await e.client.contextObservations(n);return so(o)}catch(e){return oo(e)}}function uT(t){return Array.isArray(t.projects)?t.projects.map(e=>typeof e=="string"?e.trim():"").filter(Boolean):typeof t.projects=="string"?t.projects.split(",").map(e=>e.trim()).filter(Boolean):typeof t.project=="string"&&t.project.trim().length>0?[t.project.trim()]:[]}async function lT(t){let e=uT(t);return e.length===0?{content:[{type:"text",text:'session_start_context: "project" or "projects" is required'}],isError:!0}:oT("/api/context/inject",{projects:e.join(","),...t.platformSource!==void 0?{platformSource:Bs(t.platformSource)}:{},...t.full!==void 0?{full:t.full}:{},...t.colors!==void 0?{colors:t.colors}:{}})}async function dT(t){try{let e=io("observation_generation_status"),r=(t?.jobId??t?.job_id??"").trim();if(!r)throw new Error('observation_generation_status: "jobId" is required');let n=await e.client.getJobStatus(r);return so(n)}catch(e){return oo(e)}}async function pT(){if(await iT())return!0;y.warn("SYSTEM","Worker not available, attempting auto-start for MCP client"),nT();try{let t=xu(),e=await R_(t,Nu);return e==="dead"&&y.error("SYSTEM","Worker auto-start failed \u2014 MCP tools that require the worker (search, timeline, get_observations) will fail until the worker is running. Check earlier log lines for the specific failure reason (Bun not found, missing worker bundle, port conflict, etc.)."),e!=="dead"}catch(t){return y.error("SYSTEM","Worker auto-start threw \u2014 MCP tools that require the worker (search, timeline, get_observations) will fail until the worker is running.",void 0,t instanceof Error?t:new Error(String(t))),!1}}var cy=[{name:"__IMPORTANT",description:`3-LAYER WORKFLOW (ALWAYS FOLLOW):
|
|
223
|
+
`)}var Du=require("node:fs/promises"),Ks=require("node:fs"),rt=require("node:path"),oy=require("node:os"),sy=require("node:url");var B_="claude";function XP(t){return t.trim().toLowerCase().replace(/\s+/g,"-")}function Vs(t){if(!t)return B_;let e=XP(t);return e?e==="transcript"||e.includes("codex")?"codex":e.includes("cursor")?"cursor":e.includes("claude")?"claude":e:B_}var QP=wt(ue.API_REQUEST),Ke=class extends Error{kind;status;cause;constructor(e,r,n={}){super(r),this.name="ServerClientError",this.kind=e,this.status=n.status??null,this.cause=n.cause}isFallbackEligible(){return this.kind==="transport"||this.kind==="timeout"||this.kind==="missing_api_key"||this.kind==="http_error"&&(this.status!==null&&this.status>=500||this.status===429)}},Gs=class{baseUrl;apiKey;timeoutMs;constructor(e){this.baseUrl=eT(e.serverBaseUrl),this.apiKey=e.apiKey,this.timeoutMs=e.timeoutMs??QP}async startSession(e){let r=this.buildStartSessionPayload(e);return this.request("POST","/v1/sessions/start",r)}async recordEvent(e){let r=this.buildEventPayload(e),n=e.generate===!1?"/v1/events?generate=false":"/v1/events";return this.request("POST",n,r)}async endSession(e){if(!e.sessionId)throw new Ke("invalid_response","sessionId is required for endSession");return this.request("POST",`/v1/sessions/${encodeURIComponent(e.sessionId)}/end`,{})}async addObservation(e){return this.request("POST","/v1/memories",this.buildAddObservationPayload(e))}async searchObservations(e){return this.request("POST","/v1/search",this.buildSearchPayload(e))}async contextObservations(e){return this.request("POST","/v1/context",this.buildSearchPayload(e))}async getJobStatus(e){if(!e)throw new Ke("invalid_response","jobId is required for getJobStatus");return this.request("GET",`/v1/jobs/${encodeURIComponent(e)}`)}buildAddObservationPayload(e){let r=e.content,n=e.kind??"manual",o=typeof e.metadata?.title=="string"?e.metadata.title:void 0;return{projectId:e.projectId,kind:n,type:n,narrative:r,...o?{title:o}:{},...e.serverSessionId!==void 0?{serverSessionId:e.serverSessionId}:{},...e.metadata!==void 0?{metadata:e.metadata}:{}}}buildSearchPayload(e){return{projectId:e.projectId,query:e.query,...e.limit!==void 0?{limit:e.limit}:{},...e.platformSource!==void 0?{platformSource:Au(e.platformSource)}:{}}}buildStartSessionPayload(e){return{projectId:e.projectId,...e.externalSessionId!==void 0?{externalSessionId:e.externalSessionId}:{},...e.contentSessionId!==void 0?{contentSessionId:e.contentSessionId}:{},...e.agentId!==void 0?{agentId:e.agentId}:{},...e.agentType!==void 0?{agentType:e.agentType}:{},...e.platformSource!==void 0?{platformSource:Au(e.platformSource)}:{},...e.metadata!==void 0?{metadata:e.metadata}:{}}}buildEventPayload(e){return{projectId:e.projectId,sourceType:e.sourceType,eventType:e.eventType,occurredAtEpoch:e.occurredAtEpoch,...e.serverSessionId!==void 0?{serverSessionId:e.serverSessionId}:{},...e.contentSessionId!==void 0?{contentSessionId:e.contentSessionId}:{},...e.memorySessionId!==void 0?{memorySessionId:e.memorySessionId}:{},...e.platformSource!==void 0?{platformSource:Au(e.platformSource)}:{},...e.payload!==void 0?{payload:e.payload}:{}}}async request(e,r,n){if(!this.apiKey||!this.apiKey.trim())throw new Ke("missing_api_key","Server API key is not configured (CLAUDE_MEM_SERVER_API_KEY).");let o=`${this.baseUrl}${r}`,s={method:e,headers:{"Content-Type":"application/json",Authorization:`Bearer ${this.apiKey}`}};n!==void 0&&(s.body=JSON.stringify(n));let i;try{i=await Eu(o,s,this.timeoutMs)}catch(c){let u=c instanceof Error?c.message:String(c),l=/timed out|timeout/i.test(u);throw new Ke(l?"timeout":"transport",`Server ${e} ${r} failed: ${u}`,{cause:c})}if(!i.ok){let c=await i.text().catch(()=>"");throw new Ke("http_error",`Server ${e} ${r} returned ${i.status}: ${tT(c,200)}`,{status:i.status})}let a=await i.text();if(!a||a.length===0)return{};try{return JSON.parse(a)}catch(c){throw new Ke("invalid_response",`Server ${e} ${r} returned non-JSON response`,{cause:c})}}};function Y_(t){return t instanceof Ke}function eT(t){return t.replace(/\/+$/,"")}function Au(t){return typeof t=="string"?Vs(t):null}function tT(t,e){return t.length<=e?t:`${t.slice(0,e)}\u2026`}function Mu(){let e=(Ms().CLAUDE_MEM_RUNTIME??"worker").trim().toLowerCase();return e==="server"||e==="server-beta"?"server":"worker"}function X_(){let t=Ms(),e=(...i)=>{for(let a of i){let c=(a??"").trim();if(c.length>0)return c}return""},r=e(t.CLAUDE_MEM_SERVER_URL,t.CLAUDE_MEM_SERVER_BETA_URL),n=e(t.CLAUDE_MEM_SERVER_API_KEY,t.CLAUDE_MEM_SERVER_BETA_API_KEY),o=e(t.CLAUDE_MEM_SERVER_PROJECT_ID,t.CLAUDE_MEM_SERVER_BETA_PROJECT_ID);if(!r)return y.warn("HOOK","[server-fallback] reason=missing_base_url"),null;if(!n)return y.warn("HOOK","[server-fallback] reason=missing_api_key"),null;if(!o)return y.warn("HOOK","[server-fallback] reason=missing_project_id"),null;let s={serverBaseUrl:r,apiKey:n};return{runtime:"server",client:new Gs(s),projectId:o,serverBaseUrl:r}}var ST={},rT="1.1.5";console.log=(...t)=>{y.error("CONSOLE","Intercepted console output (MCP protocol protection)",void 0,{args:t})};var iy=!1,ay=(()=>{if(typeof __dirname<"u")return __dirname;try{return(0,rt.dirname)((0,sy.fileURLToPath)(ST.url))}catch{return iy=!0,process.cwd()}})(),Nu=T_()??(0,rt.resolve)(ay,"worker-service.cjs");function nT(){iy&&((0,Ks.existsSync)(Nu)||y.error("SYSTEM","mcp-server: dirname resolution failed (both __dirname and import.meta.url are unavailable). Fell back to process.cwd() and the resolved WORKER_SCRIPT_PATH does not exist. This is the actual problem \u2014 the worker bundle is fine, but mcp-server cannot locate it. Worker auto-start will fail until the dirname-resolution path is fixed.",{workerScriptPath:Nu,mcpServerDir:ay}))}var Q_={search:"/api/search",timeline:"/api/timeline"};async function Cu(t,e){y.debug("SYSTEM","\u2192 Worker API",void 0,{endpoint:t,params:e});let r=new URLSearchParams;for(let[o,s]of Object.entries(e))s!=null&&r.append(o,String(s));let n=`${t}?${r}`;try{let o=await Xn(n);if(!o.ok){let i=await o.text();throw new Error(`Worker API error (${o.status}): ${i}`)}let s=await o.json();return y.debug("SYSTEM","\u2190 Worker API success",void 0,{endpoint:t}),s}catch(o){return y.error("SYSTEM","\u2190 Worker API error",{endpoint:t},o instanceof Error?o:new Error(String(o))),{content:[{type:"text",text:`Error calling Worker API: ${o instanceof Error?o.message:String(o)}`}],isError:!0}}}async function oT(t,e){y.debug("SYSTEM","\u2192 Worker API text",void 0,{endpoint:t,params:e});let r=new URLSearchParams;for(let[o,s]of Object.entries(e))s!=null&&r.append(o,String(s));let n=`${t}?${r}`;try{let o=await Xn(n);if(!o.ok){let i=await o.text();throw new Error(`Worker API error (${o.status}): ${i}`)}let s=await o.text();return y.debug("SYSTEM","\u2190 Worker API text success",void 0,{endpoint:t}),{content:[{type:"text",text:s}]}}catch(o){return y.error("SYSTEM","\u2190 Worker API text error",{endpoint:t},o instanceof Error?o:new Error(String(o))),{content:[{type:"text",text:`Error calling Worker API: ${o instanceof Error?o.message:String(o)}`}],isError:!0}}}async function sT(t,e){let r=await Xn(t,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)});if(!r.ok){let o=await r.text();throw new Error(`Worker API error (${r.status}): ${o}`)}let n=await r.json();return y.debug("HTTP","Worker API success (POST)",void 0,{endpoint:t}),{content:[{type:"text",text:JSON.stringify(n,null,2)}]}}async function sr(t,e){y.debug("HTTP","Worker API request (POST)",void 0,{endpoint:t});try{return await sT(t,e)}catch(r){return y.error("HTTP","Worker API error (POST)",{endpoint:t},r instanceof Error?r:new Error(String(r))),{content:[{type:"text",text:`Error calling Worker API: ${r instanceof Error?r.message:String(r)}`}],isError:!0}}}async function iT(){try{return(await Xn("/api/health")).ok}catch(t){return y.debug("SYSTEM","Worker health check failed",{},t instanceof Error?t:new Error(String(t))),!1}}function aT(){if(Mu()!=="server")return null;let e=X_();return e?{...e,available:!0}:{runtime:"server",available:!1,reason:"server runtime is selected but configuration is incomplete (missing url, api key, or project id)"}}function oo(t){return Y_(t)?{content:[{type:"text",text:`Server error (${t.kind}${t.status?` ${t.status}`:""}): ${t.message}`}],isError:!0}:{content:[{type:"text",text:`Tool error: ${t instanceof Error?t.message:String(t)}`}],isError:!0}}function so(t){return{content:[{type:"text",text:JSON.stringify(t,null,2)}]}}function io(t){let e=aT();if(!e)throw new Ke("transport",`${t} requires CLAUDE_MEM_RUNTIME=server. Current runtime is "worker"; use the existing search/timeline/get_observations tools for worker-mode memory access.`);if(!e.available)throw new Ke("missing_api_key",`${t}: ${e.reason}`);return e}async function ey(t){try{let e=io("observation_add");if(typeof t?.content!="string"||t.content.trim().length===0)throw new Error('observation_add: "content" is required');let n={projectId:t.projectId&&t.projectId.trim().length>0?t.projectId:e.projectId,content:t.content,...t.serverSessionId!==void 0?{serverSessionId:t.serverSessionId}:{},...t.kind!==void 0?{kind:t.kind}:{},...t.metadata!==void 0?{metadata:t.metadata}:{}},o=await e.client.addObservation(n);return so(o)}catch(e){return oo(e)}}function Bs(t){return typeof t=="string"?Vs(t):null}async function cT(t){try{let e=io("observation_record_event");if(typeof t?.eventType!="string"||t.eventType.trim().length===0)throw new Error('observation_record_event: "eventType" is required');let n={projectId:t.projectId&&t.projectId.trim().length>0?t.projectId:e.projectId,sourceType:t.sourceType??"api",eventType:t.eventType,occurredAtEpoch:typeof t.occurredAtEpoch=="number"?t.occurredAtEpoch:Date.now(),...t.serverSessionId!==void 0?{serverSessionId:t.serverSessionId}:{},...t.contentSessionId!==void 0?{contentSessionId:t.contentSessionId}:{},...t.memorySessionId!==void 0?{memorySessionId:t.memorySessionId}:{},...t.platformSource!==void 0?{platformSource:Bs(t.platformSource)}:{},...t.payload!==void 0?{payload:t.payload}:{},...t.generate!==void 0?{generate:t.generate}:{}},o=await e.client.recordEvent(n);return so(o)}catch(e){return oo(e)}}async function ty(t){try{let e=io("observation_search");if(typeof t?.query!="string"||t.query.trim().length===0)throw new Error('observation_search: "query" is required');let n={projectId:t.projectId&&t.projectId.trim().length>0?t.projectId:e.projectId,query:t.query,...t.limit!==void 0?{limit:t.limit}:{},...t.platformSource!==void 0?{platformSource:Bs(t.platformSource)}:{}},o=await e.client.searchObservations(n);return so(o)}catch(e){return oo(e)}}async function ry(t){try{let e=io("observation_context");if(typeof t?.query!="string"||t.query.trim().length===0)throw new Error('observation_context: "query" is required');let n={projectId:t.projectId&&t.projectId.trim().length>0?t.projectId:e.projectId,query:t.query,...t.limit!==void 0?{limit:t.limit}:{},...t.platformSource!==void 0?{platformSource:Bs(t.platformSource)}:{}},o=await e.client.contextObservations(n);return so(o)}catch(e){return oo(e)}}function uT(t){return Array.isArray(t.projects)?t.projects.map(e=>typeof e=="string"?e.trim():"").filter(Boolean):typeof t.projects=="string"?t.projects.split(",").map(e=>e.trim()).filter(Boolean):typeof t.project=="string"&&t.project.trim().length>0?[t.project.trim()]:[]}async function lT(t){let e=uT(t);return e.length===0?{content:[{type:"text",text:'session_start_context: "project" or "projects" is required'}],isError:!0}:oT("/api/context/inject",{projects:e.join(","),...t.platformSource!==void 0?{platformSource:Bs(t.platformSource)}:{},...t.full!==void 0?{full:t.full}:{},...t.colors!==void 0?{colors:t.colors}:{}})}async function dT(t){try{let e=io("observation_generation_status"),r=(t?.jobId??t?.job_id??"").trim();if(!r)throw new Error('observation_generation_status: "jobId" is required');let n=await e.client.getJobStatus(r);return so(n)}catch(e){return oo(e)}}async function pT(){if(await iT())return!0;y.warn("SYSTEM","Worker not available, attempting auto-start for MCP client"),nT();try{let t=xu(),e=await R_(t,Nu);return e==="dead"&&y.error("SYSTEM","Worker auto-start failed \u2014 MCP tools that require the worker (search, timeline, get_observations) will fail until the worker is running. Check earlier log lines for the specific failure reason (Bun not found, missing worker bundle, port conflict, etc.)."),e!=="dead"}catch(t){return y.error("SYSTEM","Worker auto-start threw \u2014 MCP tools that require the worker (search, timeline, get_observations) will fail until the worker is running.",void 0,t instanceof Error?t:new Error(String(t))),!1}}var cy=[{name:"__IMPORTANT",description:`3-LAYER WORKFLOW (ALWAYS FOLLOW):
|
|
224
224
|
1. search(query) \u2192 Get index with IDs (~50-100 tokens/result)
|
|
225
225
|
2. timeline(anchor=ID) \u2192 Get context around interesting results
|
|
226
226
|
3. get_observations([IDs]) \u2192 Fetch full details ONLY for filtered IDs
|