diff --git a/README.md b/README.md index abd64ef..d448f6c 100644 --- a/README.md +++ b/README.md @@ -2,110 +2,90 @@ image (6) - - > **✨ Requires [Supermemory Pro or above](https://console.supermemory.ai/billing)** - Unlock the state of the art memory for your Claude code. A Claude Code plugin that gives your AI persistent memory across sessions using [Supermemory](https://supermemory.ai). Your agent remembers what you worked on - across sessions, across projects. - ## Features -- **Context Injection**: On session start, relevant memories are automatically injected into Claude's context -- **Automatic Capture**: Conversation turns are captured and stored for future context -- **Codebase Indexing**: Index your project's architecture, patterns, and conventions +- **Team Memory** — Project knowledge shared across your team, separate from personal memories +- **Auto Capture** — Conversations saved when session ends +- **Project Config** — Per-repo settings, API keys, and container tags ## Installation ```bash -# Add the plugin marketplace /plugin marketplace add supermemoryai/claude-supermemory - -# Or from local directory -/plugin marketplace add /path/to/claude-supermemory - -# Install the plugin /plugin install claude-supermemory - -# Set your API key -export SUPERMEMORY_CC_API_KEY="sm_..." ``` -Get your API key at [console.supermemory.ai](https://console.supermemory.ai). - -## How It Works - -### On Session Start +Set your API key (get one at [console.supermemory.ai](https://console.supermemory.ai)): -The plugin fetches relevant memories from Supermemory and injects them into Claude's context: - -``` - -The following is recalled context about the user... - -## User Profile (Persistent) -- Prefers TypeScript over JavaScript -- Uses Bun as package manager - -## Recent Context -- Working on authentication flow - - +```bash +export SUPERMEMORY_CC_API_KEY="sm_..." ``` -### During Session - -Conversation turns are automatically captured on each stop and stored for future context. - -### Skills +## How It Works -**super-search**: When you ask about past work, previous sessions, or want to recall information, the agent automatically searches your memories. +- **super-search** — Ask about past work or previous sessions, Claude searches your memories +- **super-save** — Ask to save something important, Claude saves it for the team ## Commands -### /claude-supermemory:index - -Index your codebase into Supermemory. Explores project structure, architecture, conventions, and key files. - -``` -/claude-supermemory:index -``` - -### /claude-supermemory:logout - -Log out from Supermemory and clear saved credentials. - -``` -/claude-supermemory:logout -``` +| Command | Description | +| ------------------------------------ | ---------------------------------------- | +| `/claude-supermemory:index` | Index codebase architecture and patterns | +| `/claude-supermemory:project-config` | Configure project-level settings | +| `/claude-supermemory:logout` | Clear saved credentials | ## Configuration -### Environment Variables +**Environment** ```bash -# Required -SUPERMEMORY_CC_API_KEY=sm_... +SUPERMEMORY_CC_API_KEY=sm_... # Required +SUPERMEMORY_DEBUG=true # Optional: enable debug logging +``` + +**Global Settings** — `~/.supermemory-claude/settings.json` -# Optional -SUPERMEMORY_SKIP_TOOLS=Read,Glob,Grep # Tools to not capture -SUPERMEMORY_DEBUG=true # Enable debug logging +```json +{ + "maxProfileItems": 5, + "signalExtraction": true, + "signalKeywords": ["remember", "architecture", "decision", "bug", "fix"], + "signalTurnsBefore": 3, + "includeTools": ["Edit", "Write"] +} ``` -### Settings File +| Option | Description | +| ------------------- | --------------------------------------------- | +| `maxProfileItems` | Max memories in context (default: 5) | +| `signalExtraction` | Only capture important turns (default: false) | +| `signalKeywords` | Keywords that trigger capture | +| `signalTurnsBefore` | Context turns before signal (default: 3) | +| `includeTools` | Tools to explicitly capture | + +**Project Config** — `.claude/.supermemory-claude/config.json` -Create `~/.supermemory-claude/settings.json`: +Per-repo overrides. Run `/claude-supermemory:project-config` or create manually: ```json { - "skipTools": ["Read", "Glob", "Grep", "TodoWrite"], - "captureTools": ["Edit", "Write", "Bash", "Task"], - "maxProfileItems": 5, - "debug": false + "apiKey": "sm_...", + "repoContainerTag": "my-team-project", + "signalExtraction": true } ``` +| Option | Description | +| ---------------------- | --------------------------- | +| `apiKey` | Project-specific API key | +| `personalContainerTag` | Override personal container | +| `repoContainerTag` | Override team container tag | + ## License MIT diff --git a/plugin/scripts/add-memory.cjs b/plugin/scripts/add-memory.cjs index 28fdf04..2560bfa 100755 --- a/plugin/scripts/add-memory.cjs +++ b/plugin/scripts/add-memory.cjs @@ -1,9 +1,9 @@ #!/usr/bin/env node -var Me=Object.defineProperty;var Nr=Object.getOwnPropertyDescriptor;var Lr=Object.getOwnPropertyNames;var Vr=Object.prototype.hasOwnProperty;var Rr=(e,t)=>()=>(e&&(t=e(e=0)),t);var d=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Zr=(e,t)=>{for(var r in t)Me(e,r,{get:t[r],enumerable:!0})},wr=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Lr(t))!Vr.call(e,s)&&s!==r&&Me(e,s,{get:()=>t[s],enumerable:!(n=Nr(t,s))||n.enumerable});return e};var Mr=e=>wr(Me({},"__esModule",{value:!0}),e);var De=d(h=>{"use strict";Object.defineProperty(h,"__esModule",{value:!0});h.__setModuleDefault=h.__createBinding=void 0;h.__classPrivateFieldSet=gr;h.__classPrivateFieldGet=Fr;h.__importStar=Dr;h.__exportStar=Yr;function gr(e,t,r,n,s){if(n==="m")throw new TypeError("Private method is not writable");if(n==="a"&&!s)throw new TypeError("Private accessor was defined without a setter");if(typeof t=="function"?e!==t||!s:!t.has(e))throw new TypeError("Cannot write private member to an object whose class did not declare it");return n==="a"?s.call(e,r):s?s.value=r:t.set(e,r),r}function Fr(e,t,r,n){if(r==="a"&&!n)throw new TypeError("Private accessor was defined without a getter");if(typeof t=="function"?e!==t||!n:!t.has(e))throw new TypeError("Cannot read private member from an object whose class did not declare it");return r==="m"?n:r==="a"?n.call(e):n?n.value:t.get(e)}var Fe=Object.create?function(e,t,r,n){n===void 0&&(n=r);var s=Object.getOwnPropertyDescriptor(t,r);(!s||("get"in s?!t.__esModule:s.writable||s.configurable))&&(s={enumerable:!0,get:function(){return t[r]}}),Object.defineProperty(e,n,s)}:function(e,t,r,n){n===void 0&&(n=r),e[n]=t[r]};h.__createBinding=Fe;var Zt=Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t};h.__setModuleDefault=Zt;var ge=function(e){return ge=Object.getOwnPropertyNames||function(t){var r=[];for(var n in t)Object.prototype.hasOwnProperty.call(t,n)&&(r[r.length]=n);return r},ge(e)};function Dr(e){if(e&&e.__esModule)return e;var t={};if(e!=null)for(var r=ge(e),n=0;n{"use strict";Object.defineProperty(U,"__esModule",{value:!0});U.uuid4=void 0;var Ur=function(){let{crypto:e}=globalThis;if(e?.randomUUID)return U.uuid4=e.randomUUID.bind(e),e.randomUUID();let t=new Uint8Array(1),r=e?()=>e.getRandomValues(t)[0]:()=>Math.random()*255&255;return"10000000-1000-4000-8000-100000000000".replace(/[018]/g,n=>(+n^r()&15>>+n/4).toString(16))};U.uuid4=Ur});var Ye=d(S=>{"use strict";Object.defineProperty(S,"__esModule",{value:!0});S.castToError=void 0;S.isAbortError=Sr;function Sr(e){return typeof e=="object"&&e!==null&&("name"in e&&e.name==="AbortError"||"message"in e&&String(e.message).includes("FetchRequestCanceledException"))}var Gr=e=>{if(e instanceof Error)return e;if(typeof e=="object"&&e!==null){try{if(Object.prototype.toString.call(e)==="[object Error]"){let t=new Error(e.message,e.cause?{cause:e.cause}:{});return e.stack&&(t.stack=e.stack),e.cause&&!t.cause&&(t.cause=e.cause),e.name&&(t.name=e.name),t}}catch{}try{return new Error(JSON.stringify(e))}catch{}}return new Error(e)};S.castToError=Gr});var K=d(P=>{"use strict";Object.defineProperty(P,"__esModule",{value:!0});P.InternalServerError=P.RateLimitError=P.UnprocessableEntityError=P.ConflictError=P.NotFoundError=P.PermissionDeniedError=P.AuthenticationError=P.BadRequestError=P.APIConnectionTimeoutError=P.APIConnectionError=P.APIUserAbortError=P.APIError=P.SupermemoryError=void 0;var Kr=Ye(),ne=class extends Error{};P.SupermemoryError=ne;var O=class e extends ne{constructor(t,r,n,s){super(`${e.makeMessage(t,r,n)}`),this.status=t,this.headers=s,this.error=r}static makeMessage(t,r,n){let s=r?.message?typeof r.message=="string"?r.message:JSON.stringify(r.message):r?JSON.stringify(r):n;return t&&s?`${t} ${s}`:t?`${t} status code (no body)`:s||"(no status code or body)"}static generate(t,r,n,s){if(!t||!s)return new G({message:n,cause:(0,Kr.castToError)(r)});let o=r;return t===400?new se(t,o,n,s):t===401?new oe(t,o,n,s):t===403?new ae(t,o,n,s):t===404?new fe(t,o,n,s):t===409?new ce(t,o,n,s):t===422?new ie(t,o,n,s):t===429?new ue(t,o,n,s):t>=500?new de(t,o,n,s):new e(t,o,n,s)}};P.APIError=O;var Ue=class extends O{constructor({message:t}={}){super(void 0,void 0,t||"Request was aborted.",void 0)}};P.APIUserAbortError=Ue;var G=class extends O{constructor({message:t,cause:r}){super(void 0,void 0,t||"Connection error.",void 0),r&&(this.cause=r)}};P.APIConnectionError=G;var Se=class extends G{constructor({message:t}={}){super({message:t??"Request timed out."})}};P.APIConnectionTimeoutError=Se;var se=class extends O{};P.BadRequestError=se;var oe=class extends O{};P.AuthenticationError=oe;var ae=class extends O{};P.PermissionDeniedError=ae;var fe=class extends O{};P.NotFoundError=fe;var ce=class extends O{};P.ConflictError=ce;var ie=class extends O{};P.UnprocessableEntityError=ie;var ue=class extends O{};P.RateLimitError=ue;var de=class extends O{};P.InternalServerError=de});var E=d(u=>{"use strict";Object.defineProperty(u,"__esModule",{value:!0});u.safeJSON=u.maybeCoerceBoolean=u.maybeCoerceFloat=u.maybeCoerceInteger=u.coerceBoolean=u.coerceFloat=u.coerceInteger=u.validatePositiveInteger=u.ensurePresent=u.isReadonlyArray=u.isArray=u.isAbsoluteURL=void 0;u.maybeObj=Cr;u.isEmptyObj=Jr;u.hasOwn=Br;u.isObj=Ar;var k=K(),kr=/^[a-z][a-z0-9+.-]*:/i,Er=e=>kr.test(e);u.isAbsoluteURL=Er;var Ir=e=>(u.isArray=Array.isArray,(0,u.isArray)(e));u.isArray=Ir;u.isReadonlyArray=u.isArray;function Cr(e){return typeof e!="object"?{}:e??{}}function Jr(e){if(!e)return!0;for(let t in e)return!1;return!0}function Br(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function Ar(e){return e!=null&&typeof e=="object"&&!Array.isArray(e)}var Qr=e=>{if(e==null)throw new k.SupermemoryError(`Expected a value to be given but received ${e} instead.`);return e};u.ensurePresent=Qr;var _r=(e,t)=>{if(typeof t!="number"||!Number.isInteger(t))throw new k.SupermemoryError(`${e} must be an integer`);if(t<0)throw new k.SupermemoryError(`${e} must be a positive integer`);return t};u.validatePositiveInteger=_r;var $r=e=>{if(typeof e=="number")return Math.round(e);if(typeof e=="string")return parseInt(e,10);throw new k.SupermemoryError(`Could not coerce ${e} (type: ${typeof e}) into a number`)};u.coerceInteger=$r;var en=e=>{if(typeof e=="number")return e;if(typeof e=="string")return parseFloat(e);throw new k.SupermemoryError(`Could not coerce ${e} (type: ${typeof e}) into a number`)};u.coerceFloat=en;var tn=e=>typeof e=="boolean"?e:typeof e=="string"?e==="true":!!e;u.coerceBoolean=tn;var rn=e=>{if(e!=null)return(0,u.coerceInteger)(e)};u.maybeCoerceInteger=rn;var nn=e=>{if(e!=null)return(0,u.coerceFloat)(e)};u.maybeCoerceFloat=nn;var sn=e=>{if(e!=null)return(0,u.coerceBoolean)(e)};u.maybeCoerceBoolean=sn;var on=e=>{try{return JSON.parse(e)}catch{return}};u.safeJSON=on});var Mt=d(ve=>{"use strict";Object.defineProperty(ve,"__esModule",{value:!0});ve.sleep=void 0;var an=e=>new Promise(t=>setTimeout(t,e));ve.sleep=an});var Ge=d(le=>{"use strict";Object.defineProperty(le,"__esModule",{value:!0});le.VERSION=void 0;le.VERSION="4.0.0"});var Yt=d(w=>{"use strict";Object.defineProperty(w,"__esModule",{value:!0});w.getPlatformHeaders=w.isRunningInBrowser=void 0;var I=Ge(),fn=()=>typeof window<"u"&&typeof window.document<"u"&&typeof navigator<"u";w.isRunningInBrowser=fn;function cn(){return typeof Deno<"u"&&Deno.build!=null?"deno":typeof EdgeRuntime<"u"?"edge":Object.prototype.toString.call(typeof globalThis.process<"u"?globalThis.process:0)==="[object process]"?"node":"unknown"}var un=()=>{let e=cn();if(e==="deno")return{"X-Stainless-Lang":"js","X-Stainless-Package-Version":I.VERSION,"X-Stainless-OS":Ft(Deno.build.os),"X-Stainless-Arch":gt(Deno.build.arch),"X-Stainless-Runtime":"deno","X-Stainless-Runtime-Version":typeof Deno.version=="string"?Deno.version:Deno.version?.deno??"unknown"};if(typeof EdgeRuntime<"u")return{"X-Stainless-Lang":"js","X-Stainless-Package-Version":I.VERSION,"X-Stainless-OS":"Unknown","X-Stainless-Arch":`other:${EdgeRuntime}`,"X-Stainless-Runtime":"edge","X-Stainless-Runtime-Version":globalThis.process.version};if(e==="node")return{"X-Stainless-Lang":"js","X-Stainless-Package-Version":I.VERSION,"X-Stainless-OS":Ft(globalThis.process.platform??"unknown"),"X-Stainless-Arch":gt(globalThis.process.arch??"unknown"),"X-Stainless-Runtime":"node","X-Stainless-Runtime-Version":globalThis.process.version??"unknown"};let t=dn();return t?{"X-Stainless-Lang":"js","X-Stainless-Package-Version":I.VERSION,"X-Stainless-OS":"Unknown","X-Stainless-Arch":"unknown","X-Stainless-Runtime":`browser:${t.browser}`,"X-Stainless-Runtime-Version":t.version}:{"X-Stainless-Lang":"js","X-Stainless-Package-Version":I.VERSION,"X-Stainless-OS":"Unknown","X-Stainless-Arch":"unknown","X-Stainless-Runtime":"unknown","X-Stainless-Runtime-Version":"unknown"}};function dn(){if(typeof navigator>"u"||!navigator)return null;let e=[{key:"edge",pattern:/Edge(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"ie",pattern:/MSIE(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"ie",pattern:/Trident(?:.*rv\:(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"chrome",pattern:/Chrome(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"firefox",pattern:/Firefox(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"safari",pattern:/(?:Version\W+(\d+)\.(\d+)(?:\.(\d+))?)?(?:\W+Mobile\S*)?\W+Safari/}];for(let{key:t,pattern:r}of e){let n=r.exec(navigator.userAgent);if(n){let s=n[1]||0,o=n[2]||0,a=n[3]||0;return{browser:t,version:`${s}.${o}.${a}`}}}return null}var gt=e=>e==="x32"?"x32":e==="x86_64"||e==="x64"?"x64":e==="arm"?"arm":e==="aarch64"||e==="arm64"?"arm64":e?`other:${e}`:"unknown",Ft=e=>(e=e.toLowerCase(),e.includes("ios")?"iOS":e==="android"?"Android":e==="darwin"?"MacOS":e==="win32"?"Windows":e==="freebsd"?"FreeBSD":e==="openbsd"?"OpenBSD":e==="linux"?"Linux":e?`Other:${e}`:"Unknown"),Dt,vn=()=>Dt??(Dt=un());w.getPlatformHeaders=vn});var Ke=d(V=>{"use strict";Object.defineProperty(V,"__esModule",{value:!0});V.getDefaultFetch=ln;V.makeReadableStream=Ut;V.ReadableStreamFrom=Pn;V.ReadableStreamToAsyncIterable=pn;V.CancelReadableStream=zn;function ln(){if(typeof fetch<"u")return fetch;throw new Error("`fetch` is not defined as a global; Either pass `fetch` to the client, `new Supermemory({ fetch })` or polyfill the global, `globalThis.fetch = fetch`")}function Ut(...e){let t=globalThis.ReadableStream;if(typeof t>"u")throw new Error("`ReadableStream` is not defined as a global; You will need to polyfill it, `globalThis.ReadableStream = ReadableStream`");return new t(...e)}function Pn(e){let t=Symbol.asyncIterator in e?e[Symbol.asyncIterator]():e[Symbol.iterator]();return Ut({start(){},async pull(r){let{done:n,value:s}=await t.next();n?r.close():r.enqueue(s)},async cancel(){await t.return?.()}})}function pn(e){if(e[Symbol.asyncIterator])return e;let t=e.getReader();return{async next(){try{let r=await t.read();return r?.done&&t.releaseLock(),r}catch(r){throw t.releaseLock(),r}},async return(){let r=t.cancel();return t.releaseLock(),await r,{done:!0,value:void 0}},[Symbol.asyncIterator](){return this}}}async function zn(e){if(e===null||typeof e!="object")return;if(e[Symbol.asyncIterator]){await e[Symbol.asyncIterator]().return?.();return}let t=e.getReader(),r=t.cancel();t.releaseLock(),await r}});var St=d(Pe=>{"use strict";Object.defineProperty(Pe,"__esModule",{value:!0});Pe.FallbackEncoder=void 0;var mn=({headers:e,body:t})=>({bodyHeaders:{"content-type":"application/json"},body:JSON.stringify(t)});Pe.FallbackEncoder=mn});var C=d(j=>{"use strict";Object.defineProperty(j,"__esModule",{value:!0});j.createForm=j.multipartFormRequestOptions=j.maybeMultipartFormRequestOptions=j.isAsyncIterable=j.checkFileSupport=void 0;j.makeFile=ke;j.getName=pe;var bn=Ke(),jn=()=>{if(typeof File>"u"){let{process:e}=globalThis,t=typeof e?.versions?.node=="string"&&parseInt(e.versions.node.split("."))<20;throw new Error("`File` is not defined as a global, which is required for file uploads."+(t?" Update to Node 20 LTS or newer, or set `globalThis.File` to `import('node:buffer').File`.":""))}};j.checkFileSupport=jn;function ke(e,t,r){return(0,j.checkFileSupport)(),new File(e,t??"unknown_file",r)}function pe(e){return(typeof e=="object"&&e!==null&&("name"in e&&e.name&&String(e.name)||"url"in e&&e.url&&String(e.url)||"filename"in e&&e.filename&&String(e.filename)||"path"in e&&e.path&&String(e.path))||"").split(/[\\/]/).pop()||void 0}var xn=e=>e!=null&&typeof e=="object"&&typeof e[Symbol.asyncIterator]=="function";j.isAsyncIterable=xn;var Xn=async(e,t)=>Ee(e.body)?{...e,body:await(0,j.createForm)(e.body,t)}:e;j.maybeMultipartFormRequestOptions=Xn;var On=async(e,t)=>({...e,body:await(0,j.createForm)(e.body,t)});j.multipartFormRequestOptions=On;var Gt=new WeakMap;function yn(e){let t=typeof e=="function"?e:e.fetch,r=Gt.get(t);if(r)return r;let n=(async()=>{try{let s="Response"in t?t.Response:(await t("data:,")).constructor,o=new FormData;return o.toString()!==await new s(o).text()}catch{return!0}})();return Gt.set(t,n),n}var Hn=async(e,t)=>{if(!await yn(t))throw new TypeError("The provided fetch function does not support file uploads with the current global FormData class.");let r=new FormData;return await Promise.all(Object.entries(e||{}).map(([n,s])=>Ie(r,n,s))),r};j.createForm=Hn;var Kt=e=>e instanceof Blob&&"name"in e,qn=e=>typeof e=="object"&&e!==null&&(e instanceof Response||(0,j.isAsyncIterable)(e)||Kt(e)),Ee=e=>{if(qn(e))return!0;if(Array.isArray(e))return e.some(Ee);if(e&&typeof e=="object"){for(let t in e)if(Ee(e[t]))return!0}return!1},Ie=async(e,t,r)=>{if(r!==void 0){if(r==null)throw new TypeError(`Received null for "${t}"; to pass null in FormData, you must use the string 'null'`);if(typeof r=="string"||typeof r=="number"||typeof r=="boolean")e.append(t,String(r));else if(r instanceof Response)e.append(t,ke([await r.blob()],pe(r)));else if((0,j.isAsyncIterable)(r))e.append(t,ke([await new Response((0,bn.ReadableStreamFrom)(r)).blob()],pe(r)));else if(Kt(r))e.append(t,r,pe(r));else if(Array.isArray(r))await Promise.all(r.map(n=>Ie(e,t+"[]",n)));else if(typeof r=="object")await Promise.all(Object.entries(r).map(([n,s])=>Ie(e,`${t}[${n}]`,s)));else throw new TypeError(`Invalid value given to form, expected a string, number, boolean, object, Array, File or Blob but got ${r} instead`)}}});var Et=d(Je=>{"use strict";Object.defineProperty(Je,"__esModule",{value:!0});Je.toFile=Nn;var J=C(),hn=C(),kt=e=>e!=null&&typeof e=="object"&&typeof e.size=="number"&&typeof e.type=="string"&&typeof e.text=="function"&&typeof e.slice=="function"&&typeof e.arrayBuffer=="function",Wn=e=>e!=null&&typeof e=="object"&&typeof e.name=="string"&&typeof e.lastModified=="number"&&kt(e),Tn=e=>e!=null&&typeof e=="object"&&typeof e.url=="string"&&typeof e.blob=="function";async function Nn(e,t,r){if((0,hn.checkFileSupport)(),e=await e,Wn(e))return e instanceof File?e:(0,J.makeFile)([await e.arrayBuffer()],e.name);if(Tn(e)){let s=await e.blob();return t||(t=new URL(e.url).pathname.split(/[\\/]/).pop()),(0,J.makeFile)(await Ce(s),t,r)}let n=await Ce(e);if(t||(t=(0,J.getName)(e)),!r?.type){let s=n.find(o=>typeof o=="object"&&"type"in o&&o.type);typeof s=="string"&&(r={...r,type:s})}return(0,J.makeFile)(n,t,r)}async function Ce(e){let t=[];if(typeof e=="string"||ArrayBuffer.isView(e)||e instanceof ArrayBuffer)t.push(e);else if(kt(e))t.push(e instanceof Blob?e:await e.arrayBuffer());else if((0,J.isAsyncIterable)(e))for await(let r of e)t.push(...await Ce(r));else{let r=e?.constructor?.name;throw new Error(`Unexpected data type: ${typeof e}${r?`; constructor: ${r}`:""}${Ln(e)}`)}return t}function Ln(e){return typeof e!="object"||e===null?"":`; props: [${Object.getOwnPropertyNames(e).map(r=>`"${r}"`).join(", ")}]`}});var Be=d(ze=>{"use strict";Object.defineProperty(ze,"__esModule",{value:!0});ze.toFile=void 0;var Vn=Et();Object.defineProperty(ze,"toFile",{enumerable:!0,get:function(){return Vn.toFile}})});var M=d(me=>{"use strict";Object.defineProperty(me,"__esModule",{value:!0});me.APIResource=void 0;var Ae=class{constructor(t){this._client=t}};me.APIResource=Ae});var B=d(g=>{"use strict";Object.defineProperty(g,"__esModule",{value:!0});g.isEmptyHeaders=g.buildHeaders=void 0;var It=E(),Ct=Symbol("brand.privateNullableHeaders");function*Jt(e){if(!e)return;if(Ct in e){let{values:n,nulls:s}=e;yield*n.entries();for(let o of s)yield[o,null];return}let t=!1,r;e instanceof Headers?r=e.entries():(0,It.isReadonlyArray)(e)?r=e:(t=!0,r=Object.entries(e??{}));for(let n of r){let s=n[0];if(typeof s!="string")throw new TypeError("expected header name to be a string");let o=(0,It.isReadonlyArray)(n[1])?n[1]:[n[1]],a=!1;for(let f of o)f!==void 0&&(t&&!a&&(a=!0,yield[s,null]),yield[s,f])}}var Rn=e=>{let t=new Headers,r=new Set;for(let n of e){let s=new Set;for(let[o,a]of Jt(n)){let f=o.toLowerCase();s.has(f)||(t.delete(o),s.add(f)),a===null?(t.delete(o),r.add(f)):(t.append(o,a),r.delete(f))}}return{[Ct]:!0,values:t,nulls:r}};g.buildHeaders=Rn;var Zn=e=>{for(let t of Jt(e))return!1;return!0};g.isEmptyHeaders=Zn});var be=d(N=>{"use strict";Object.defineProperty(N,"__esModule",{value:!0});N.path=N.createPathTagFunction=void 0;N.encodeURIPath=Qe;var wn=K();function Qe(e){return e.replace(/[^A-Za-z0-9\-._~!$&'()*+,;=:@]+/g,encodeURIComponent)}var Bt=Object.freeze(Object.create(null)),Mn=(e=Qe)=>function(r,...n){if(r.length===1)return r[0];let s=!1,o=[],a=r.reduce((v,m,X)=>{/[?#]/.test(m)&&(s=!0);let c=n[X],q=(s?encodeURIComponent:e)(""+c);return X!==n.length&&(c==null||typeof c=="object"&&c.toString===Object.getPrototypeOf(Object.getPrototypeOf(c.hasOwnProperty??Bt)??Bt)?.toString)&&(q=c+"",o.push({start:v.length+m.length,length:q.length,error:`Value of type ${Object.prototype.toString.call(c).slice(8,-1)} is not a valid path parameter`})),v+m+(X===n.length?"":q)},""),f=a.split(/[?#]/,1)[0],z=/(?<=^|\/)(?:\.|%2e){1,2}(?=\/|$)/gi,l;for(;(l=z.exec(f))!==null;)o.push({start:l.index,length:l[0].length,error:`Value "${l[0]}" can't be safely passed as a path parameter`});if(o.sort((v,m)=>v.start-m.start),o.length>0){let v=0,m=o.reduce((X,c)=>{let q=" ".repeat(c.start-v),D="^".repeat(c.length);return v=c.start+c.length,X+q+D},"");throw new wn.SupermemoryError(`Path parameters result in path with invalid segments: +var Me=Object.defineProperty;var Vr=Object.getOwnPropertyDescriptor;var Rr=Object.getOwnPropertyNames;var Zr=Object.prototype.hasOwnProperty;var wr=(e,t)=>()=>(e&&(t=e(e=0)),t);var d=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Mr=(e,t)=>{for(var r in t)Me(e,r,{get:t[r],enumerable:!0})},gr=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Rr(t))!Zr.call(e,s)&&s!==r&&Me(e,s,{get:()=>t[s],enumerable:!(n=Vr(t,s))||n.enumerable});return e};var Fr=e=>gr(Me({},"__esModule",{value:!0}),e);var De=d(h=>{"use strict";Object.defineProperty(h,"__esModule",{value:!0});h.__setModuleDefault=h.__createBinding=void 0;h.__classPrivateFieldSet=Dr;h.__classPrivateFieldGet=Ur;h.__importStar=Yr;h.__exportStar=Sr;function Dr(e,t,r,n,s){if(n==="m")throw new TypeError("Private method is not writable");if(n==="a"&&!s)throw new TypeError("Private accessor was defined without a setter");if(typeof t=="function"?e!==t||!s:!t.has(e))throw new TypeError("Cannot write private member to an object whose class did not declare it");return n==="a"?s.call(e,r):s?s.value=r:t.set(e,r),r}function Ur(e,t,r,n){if(r==="a"&&!n)throw new TypeError("Private accessor was defined without a getter");if(typeof t=="function"?e!==t||!n:!t.has(e))throw new TypeError("Cannot read private member from an object whose class did not declare it");return r==="m"?n:r==="a"?n.call(e):n?n.value:t.get(e)}var Fe=Object.create?function(e,t,r,n){n===void 0&&(n=r);var s=Object.getOwnPropertyDescriptor(t,r);(!s||("get"in s?!t.__esModule:s.writable||s.configurable))&&(s={enumerable:!0,get:function(){return t[r]}}),Object.defineProperty(e,n,s)}:function(e,t,r,n){n===void 0&&(n=r),e[n]=t[r]};h.__createBinding=Fe;var wt=Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t};h.__setModuleDefault=wt;var ge=function(e){return ge=Object.getOwnPropertyNames||function(t){var r=[];for(var n in t)Object.prototype.hasOwnProperty.call(t,n)&&(r[r.length]=n);return r},ge(e)};function Yr(e){if(e&&e.__esModule)return e;var t={};if(e!=null)for(var r=ge(e),n=0;n{"use strict";Object.defineProperty(Y,"__esModule",{value:!0});Y.uuid4=void 0;var Gr=function(){let{crypto:e}=globalThis;if(e?.randomUUID)return Y.uuid4=e.randomUUID.bind(e),e.randomUUID();let t=new Uint8Array(1),r=e?()=>e.getRandomValues(t)[0]:()=>Math.random()*255&255;return"10000000-1000-4000-8000-100000000000".replace(/[018]/g,n=>(+n^r()&15>>+n/4).toString(16))};Y.uuid4=Gr});var Ue=d(S=>{"use strict";Object.defineProperty(S,"__esModule",{value:!0});S.castToError=void 0;S.isAbortError=Kr;function Kr(e){return typeof e=="object"&&e!==null&&("name"in e&&e.name==="AbortError"||"message"in e&&String(e.message).includes("FetchRequestCanceledException"))}var kr=e=>{if(e instanceof Error)return e;if(typeof e=="object"&&e!==null){try{if(Object.prototype.toString.call(e)==="[object Error]"){let t=new Error(e.message,e.cause?{cause:e.cause}:{});return e.stack&&(t.stack=e.stack),e.cause&&!t.cause&&(t.cause=e.cause),e.name&&(t.name=e.name),t}}catch{}try{return new Error(JSON.stringify(e))}catch{}}return new Error(e)};S.castToError=kr});var K=d(P=>{"use strict";Object.defineProperty(P,"__esModule",{value:!0});P.InternalServerError=P.RateLimitError=P.UnprocessableEntityError=P.ConflictError=P.NotFoundError=P.PermissionDeniedError=P.AuthenticationError=P.BadRequestError=P.APIConnectionTimeoutError=P.APIConnectionError=P.APIUserAbortError=P.APIError=P.SupermemoryError=void 0;var Er=Ue(),ne=class extends Error{};P.SupermemoryError=ne;var O=class e extends ne{constructor(t,r,n,s){super(`${e.makeMessage(t,r,n)}`),this.status=t,this.headers=s,this.error=r}static makeMessage(t,r,n){let s=r?.message?typeof r.message=="string"?r.message:JSON.stringify(r.message):r?JSON.stringify(r):n;return t&&s?`${t} ${s}`:t?`${t} status code (no body)`:s||"(no status code or body)"}static generate(t,r,n,s){if(!t||!s)return new G({message:n,cause:(0,Er.castToError)(r)});let o=r;return t===400?new se(t,o,n,s):t===401?new oe(t,o,n,s):t===403?new ae(t,o,n,s):t===404?new fe(t,o,n,s):t===409?new ce(t,o,n,s):t===422?new ie(t,o,n,s):t===429?new ue(t,o,n,s):t>=500?new de(t,o,n,s):new e(t,o,n,s)}};P.APIError=O;var Ye=class extends O{constructor({message:t}={}){super(void 0,void 0,t||"Request was aborted.",void 0)}};P.APIUserAbortError=Ye;var G=class extends O{constructor({message:t,cause:r}){super(void 0,void 0,t||"Connection error.",void 0),r&&(this.cause=r)}};P.APIConnectionError=G;var Se=class extends G{constructor({message:t}={}){super({message:t??"Request timed out."})}};P.APIConnectionTimeoutError=Se;var se=class extends O{};P.BadRequestError=se;var oe=class extends O{};P.AuthenticationError=oe;var ae=class extends O{};P.PermissionDeniedError=ae;var fe=class extends O{};P.NotFoundError=fe;var ce=class extends O{};P.ConflictError=ce;var ie=class extends O{};P.UnprocessableEntityError=ie;var ue=class extends O{};P.RateLimitError=ue;var de=class extends O{};P.InternalServerError=de});var E=d(u=>{"use strict";Object.defineProperty(u,"__esModule",{value:!0});u.safeJSON=u.maybeCoerceBoolean=u.maybeCoerceFloat=u.maybeCoerceInteger=u.coerceBoolean=u.coerceFloat=u.coerceInteger=u.validatePositiveInteger=u.ensurePresent=u.isReadonlyArray=u.isArray=u.isAbsoluteURL=void 0;u.maybeObj=Br;u.isEmptyObj=Ar;u.hasOwn=Qr;u.isObj=_r;var k=K(),Ir=/^[a-z][a-z0-9+.-]*:/i,Cr=e=>Ir.test(e);u.isAbsoluteURL=Cr;var Jr=e=>(u.isArray=Array.isArray,(0,u.isArray)(e));u.isArray=Jr;u.isReadonlyArray=u.isArray;function Br(e){return typeof e!="object"?{}:e??{}}function Ar(e){if(!e)return!0;for(let t in e)return!1;return!0}function Qr(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function _r(e){return e!=null&&typeof e=="object"&&!Array.isArray(e)}var $r=e=>{if(e==null)throw new k.SupermemoryError(`Expected a value to be given but received ${e} instead.`);return e};u.ensurePresent=$r;var en=(e,t)=>{if(typeof t!="number"||!Number.isInteger(t))throw new k.SupermemoryError(`${e} must be an integer`);if(t<0)throw new k.SupermemoryError(`${e} must be a positive integer`);return t};u.validatePositiveInteger=en;var tn=e=>{if(typeof e=="number")return Math.round(e);if(typeof e=="string")return parseInt(e,10);throw new k.SupermemoryError(`Could not coerce ${e} (type: ${typeof e}) into a number`)};u.coerceInteger=tn;var rn=e=>{if(typeof e=="number")return e;if(typeof e=="string")return parseFloat(e);throw new k.SupermemoryError(`Could not coerce ${e} (type: ${typeof e}) into a number`)};u.coerceFloat=rn;var nn=e=>typeof e=="boolean"?e:typeof e=="string"?e==="true":!!e;u.coerceBoolean=nn;var sn=e=>{if(e!=null)return(0,u.coerceInteger)(e)};u.maybeCoerceInteger=sn;var on=e=>{if(e!=null)return(0,u.coerceFloat)(e)};u.maybeCoerceFloat=on;var an=e=>{if(e!=null)return(0,u.coerceBoolean)(e)};u.maybeCoerceBoolean=an;var fn=e=>{try{return JSON.parse(e)}catch{return}};u.safeJSON=fn});var gt=d(ve=>{"use strict";Object.defineProperty(ve,"__esModule",{value:!0});ve.sleep=void 0;var cn=e=>new Promise(t=>setTimeout(t,e));ve.sleep=cn});var Ge=d(le=>{"use strict";Object.defineProperty(le,"__esModule",{value:!0});le.VERSION=void 0;le.VERSION="4.0.0"});var Yt=d(w=>{"use strict";Object.defineProperty(w,"__esModule",{value:!0});w.getPlatformHeaders=w.isRunningInBrowser=void 0;var I=Ge(),un=()=>typeof window<"u"&&typeof window.document<"u"&&typeof navigator<"u";w.isRunningInBrowser=un;function dn(){return typeof Deno<"u"&&Deno.build!=null?"deno":typeof EdgeRuntime<"u"?"edge":Object.prototype.toString.call(typeof globalThis.process<"u"?globalThis.process:0)==="[object process]"?"node":"unknown"}var vn=()=>{let e=dn();if(e==="deno")return{"X-Stainless-Lang":"js","X-Stainless-Package-Version":I.VERSION,"X-Stainless-OS":Dt(Deno.build.os),"X-Stainless-Arch":Ft(Deno.build.arch),"X-Stainless-Runtime":"deno","X-Stainless-Runtime-Version":typeof Deno.version=="string"?Deno.version:Deno.version?.deno??"unknown"};if(typeof EdgeRuntime<"u")return{"X-Stainless-Lang":"js","X-Stainless-Package-Version":I.VERSION,"X-Stainless-OS":"Unknown","X-Stainless-Arch":`other:${EdgeRuntime}`,"X-Stainless-Runtime":"edge","X-Stainless-Runtime-Version":globalThis.process.version};if(e==="node")return{"X-Stainless-Lang":"js","X-Stainless-Package-Version":I.VERSION,"X-Stainless-OS":Dt(globalThis.process.platform??"unknown"),"X-Stainless-Arch":Ft(globalThis.process.arch??"unknown"),"X-Stainless-Runtime":"node","X-Stainless-Runtime-Version":globalThis.process.version??"unknown"};let t=ln();return t?{"X-Stainless-Lang":"js","X-Stainless-Package-Version":I.VERSION,"X-Stainless-OS":"Unknown","X-Stainless-Arch":"unknown","X-Stainless-Runtime":`browser:${t.browser}`,"X-Stainless-Runtime-Version":t.version}:{"X-Stainless-Lang":"js","X-Stainless-Package-Version":I.VERSION,"X-Stainless-OS":"Unknown","X-Stainless-Arch":"unknown","X-Stainless-Runtime":"unknown","X-Stainless-Runtime-Version":"unknown"}};function ln(){if(typeof navigator>"u"||!navigator)return null;let e=[{key:"edge",pattern:/Edge(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"ie",pattern:/MSIE(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"ie",pattern:/Trident(?:.*rv\:(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"chrome",pattern:/Chrome(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"firefox",pattern:/Firefox(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"safari",pattern:/(?:Version\W+(\d+)\.(\d+)(?:\.(\d+))?)?(?:\W+Mobile\S*)?\W+Safari/}];for(let{key:t,pattern:r}of e){let n=r.exec(navigator.userAgent);if(n){let s=n[1]||0,o=n[2]||0,a=n[3]||0;return{browser:t,version:`${s}.${o}.${a}`}}}return null}var Ft=e=>e==="x32"?"x32":e==="x86_64"||e==="x64"?"x64":e==="arm"?"arm":e==="aarch64"||e==="arm64"?"arm64":e?`other:${e}`:"unknown",Dt=e=>(e=e.toLowerCase(),e.includes("ios")?"iOS":e==="android"?"Android":e==="darwin"?"MacOS":e==="win32"?"Windows":e==="freebsd"?"FreeBSD":e==="openbsd"?"OpenBSD":e==="linux"?"Linux":e?`Other:${e}`:"Unknown"),Ut,Pn=()=>Ut??(Ut=vn());w.getPlatformHeaders=Pn});var Ke=d(V=>{"use strict";Object.defineProperty(V,"__esModule",{value:!0});V.getDefaultFetch=pn;V.makeReadableStream=St;V.ReadableStreamFrom=zn;V.ReadableStreamToAsyncIterable=mn;V.CancelReadableStream=bn;function pn(){if(typeof fetch<"u")return fetch;throw new Error("`fetch` is not defined as a global; Either pass `fetch` to the client, `new Supermemory({ fetch })` or polyfill the global, `globalThis.fetch = fetch`")}function St(...e){let t=globalThis.ReadableStream;if(typeof t>"u")throw new Error("`ReadableStream` is not defined as a global; You will need to polyfill it, `globalThis.ReadableStream = ReadableStream`");return new t(...e)}function zn(e){let t=Symbol.asyncIterator in e?e[Symbol.asyncIterator]():e[Symbol.iterator]();return St({start(){},async pull(r){let{done:n,value:s}=await t.next();n?r.close():r.enqueue(s)},async cancel(){await t.return?.()}})}function mn(e){if(e[Symbol.asyncIterator])return e;let t=e.getReader();return{async next(){try{let r=await t.read();return r?.done&&t.releaseLock(),r}catch(r){throw t.releaseLock(),r}},async return(){let r=t.cancel();return t.releaseLock(),await r,{done:!0,value:void 0}},[Symbol.asyncIterator](){return this}}}async function bn(e){if(e===null||typeof e!="object")return;if(e[Symbol.asyncIterator]){await e[Symbol.asyncIterator]().return?.();return}let t=e.getReader(),r=t.cancel();t.releaseLock(),await r}});var Gt=d(Pe=>{"use strict";Object.defineProperty(Pe,"__esModule",{value:!0});Pe.FallbackEncoder=void 0;var jn=({headers:e,body:t})=>({bodyHeaders:{"content-type":"application/json"},body:JSON.stringify(t)});Pe.FallbackEncoder=jn});var C=d(j=>{"use strict";Object.defineProperty(j,"__esModule",{value:!0});j.createForm=j.multipartFormRequestOptions=j.maybeMultipartFormRequestOptions=j.isAsyncIterable=j.checkFileSupport=void 0;j.makeFile=ke;j.getName=pe;var xn=Ke(),Xn=()=>{if(typeof File>"u"){let{process:e}=globalThis,t=typeof e?.versions?.node=="string"&&parseInt(e.versions.node.split("."))<20;throw new Error("`File` is not defined as a global, which is required for file uploads."+(t?" Update to Node 20 LTS or newer, or set `globalThis.File` to `import('node:buffer').File`.":""))}};j.checkFileSupport=Xn;function ke(e,t,r){return(0,j.checkFileSupport)(),new File(e,t??"unknown_file",r)}function pe(e){return(typeof e=="object"&&e!==null&&("name"in e&&e.name&&String(e.name)||"url"in e&&e.url&&String(e.url)||"filename"in e&&e.filename&&String(e.filename)||"path"in e&&e.path&&String(e.path))||"").split(/[\\/]/).pop()||void 0}var On=e=>e!=null&&typeof e=="object"&&typeof e[Symbol.asyncIterator]=="function";j.isAsyncIterable=On;var yn=async(e,t)=>Ee(e.body)?{...e,body:await(0,j.createForm)(e.body,t)}:e;j.maybeMultipartFormRequestOptions=yn;var Hn=async(e,t)=>({...e,body:await(0,j.createForm)(e.body,t)});j.multipartFormRequestOptions=Hn;var Kt=new WeakMap;function qn(e){let t=typeof e=="function"?e:e.fetch,r=Kt.get(t);if(r)return r;let n=(async()=>{try{let s="Response"in t?t.Response:(await t("data:,")).constructor,o=new FormData;return o.toString()!==await new s(o).text()}catch{return!0}})();return Kt.set(t,n),n}var hn=async(e,t)=>{if(!await qn(t))throw new TypeError("The provided fetch function does not support file uploads with the current global FormData class.");let r=new FormData;return await Promise.all(Object.entries(e||{}).map(([n,s])=>Ie(r,n,s))),r};j.createForm=hn;var kt=e=>e instanceof Blob&&"name"in e,Wn=e=>typeof e=="object"&&e!==null&&(e instanceof Response||(0,j.isAsyncIterable)(e)||kt(e)),Ee=e=>{if(Wn(e))return!0;if(Array.isArray(e))return e.some(Ee);if(e&&typeof e=="object"){for(let t in e)if(Ee(e[t]))return!0}return!1},Ie=async(e,t,r)=>{if(r!==void 0){if(r==null)throw new TypeError(`Received null for "${t}"; to pass null in FormData, you must use the string 'null'`);if(typeof r=="string"||typeof r=="number"||typeof r=="boolean")e.append(t,String(r));else if(r instanceof Response)e.append(t,ke([await r.blob()],pe(r)));else if((0,j.isAsyncIterable)(r))e.append(t,ke([await new Response((0,xn.ReadableStreamFrom)(r)).blob()],pe(r)));else if(kt(r))e.append(t,r,pe(r));else if(Array.isArray(r))await Promise.all(r.map(n=>Ie(e,t+"[]",n)));else if(typeof r=="object")await Promise.all(Object.entries(r).map(([n,s])=>Ie(e,`${t}[${n}]`,s)));else throw new TypeError(`Invalid value given to form, expected a string, number, boolean, object, Array, File or Blob but got ${r} instead`)}}});var It=d(Je=>{"use strict";Object.defineProperty(Je,"__esModule",{value:!0});Je.toFile=Vn;var J=C(),Tn=C(),Et=e=>e!=null&&typeof e=="object"&&typeof e.size=="number"&&typeof e.type=="string"&&typeof e.text=="function"&&typeof e.slice=="function"&&typeof e.arrayBuffer=="function",Nn=e=>e!=null&&typeof e=="object"&&typeof e.name=="string"&&typeof e.lastModified=="number"&&Et(e),Ln=e=>e!=null&&typeof e=="object"&&typeof e.url=="string"&&typeof e.blob=="function";async function Vn(e,t,r){if((0,Tn.checkFileSupport)(),e=await e,Nn(e))return e instanceof File?e:(0,J.makeFile)([await e.arrayBuffer()],e.name);if(Ln(e)){let s=await e.blob();return t||(t=new URL(e.url).pathname.split(/[\\/]/).pop()),(0,J.makeFile)(await Ce(s),t,r)}let n=await Ce(e);if(t||(t=(0,J.getName)(e)),!r?.type){let s=n.find(o=>typeof o=="object"&&"type"in o&&o.type);typeof s=="string"&&(r={...r,type:s})}return(0,J.makeFile)(n,t,r)}async function Ce(e){let t=[];if(typeof e=="string"||ArrayBuffer.isView(e)||e instanceof ArrayBuffer)t.push(e);else if(Et(e))t.push(e instanceof Blob?e:await e.arrayBuffer());else if((0,J.isAsyncIterable)(e))for await(let r of e)t.push(...await Ce(r));else{let r=e?.constructor?.name;throw new Error(`Unexpected data type: ${typeof e}${r?`; constructor: ${r}`:""}${Rn(e)}`)}return t}function Rn(e){return typeof e!="object"||e===null?"":`; props: [${Object.getOwnPropertyNames(e).map(r=>`"${r}"`).join(", ")}]`}});var Be=d(ze=>{"use strict";Object.defineProperty(ze,"__esModule",{value:!0});ze.toFile=void 0;var Zn=It();Object.defineProperty(ze,"toFile",{enumerable:!0,get:function(){return Zn.toFile}})});var M=d(me=>{"use strict";Object.defineProperty(me,"__esModule",{value:!0});me.APIResource=void 0;var Ae=class{constructor(t){this._client=t}};me.APIResource=Ae});var B=d(g=>{"use strict";Object.defineProperty(g,"__esModule",{value:!0});g.isEmptyHeaders=g.buildHeaders=void 0;var Ct=E(),Jt=Symbol("brand.privateNullableHeaders");function*Bt(e){if(!e)return;if(Jt in e){let{values:n,nulls:s}=e;yield*n.entries();for(let o of s)yield[o,null];return}let t=!1,r;e instanceof Headers?r=e.entries():(0,Ct.isReadonlyArray)(e)?r=e:(t=!0,r=Object.entries(e??{}));for(let n of r){let s=n[0];if(typeof s!="string")throw new TypeError("expected header name to be a string");let o=(0,Ct.isReadonlyArray)(n[1])?n[1]:[n[1]],a=!1;for(let f of o)f!==void 0&&(t&&!a&&(a=!0,yield[s,null]),yield[s,f])}}var wn=e=>{let t=new Headers,r=new Set;for(let n of e){let s=new Set;for(let[o,a]of Bt(n)){let f=o.toLowerCase();s.has(f)||(t.delete(o),s.add(f)),a===null?(t.delete(o),r.add(f)):(t.append(o,a),r.delete(f))}}return{[Jt]:!0,values:t,nulls:r}};g.buildHeaders=wn;var Mn=e=>{for(let t of Bt(e))return!1;return!0};g.isEmptyHeaders=Mn});var be=d(N=>{"use strict";Object.defineProperty(N,"__esModule",{value:!0});N.path=N.createPathTagFunction=void 0;N.encodeURIPath=Qe;var gn=K();function Qe(e){return e.replace(/[^A-Za-z0-9\-._~!$&'()*+,;=:@]+/g,encodeURIComponent)}var At=Object.freeze(Object.create(null)),Fn=(e=Qe)=>function(r,...n){if(r.length===1)return r[0];let s=!1,o=[],a=r.reduce((v,m,X)=>{/[?#]/.test(m)&&(s=!0);let c=n[X],q=(s?encodeURIComponent:e)(""+c);return X!==n.length&&(c==null||typeof c=="object"&&c.toString===Object.getPrototypeOf(Object.getPrototypeOf(c.hasOwnProperty??At)??At)?.toString)&&(q=c+"",o.push({start:v.length+m.length,length:q.length,error:`Value of type ${Object.prototype.toString.call(c).slice(8,-1)} is not a valid path parameter`})),v+m+(X===n.length?"":q)},""),f=a.split(/[?#]/,1)[0],z=/(?<=^|\/)(?:\.|%2e){1,2}(?=\/|$)/gi,l;for(;(l=z.exec(f))!==null;)o.push({start:l.index,length:l[0].length,error:`Value "${l[0]}" can't be safely passed as a path parameter`});if(o.sort((v,m)=>v.start-m.start),o.length>0){let v=0,m=o.reduce((X,c)=>{let q=" ".repeat(c.start-v),D="^".repeat(c.length);return v=c.start+c.length,X+q+D},"");throw new gn.SupermemoryError(`Path parameters result in path with invalid segments: ${o.map(X=>X.error).join(` `)} ${a} -${m}`)}return a};N.createPathTagFunction=Mn;N.path=(0,N.createPathTagFunction)(Qe)});var $e=d(je=>{"use strict";Object.defineProperty(je,"__esModule",{value:!0});je.Connections=void 0;var gn=M(),Fn=B(),W=be(),_e=class extends gn.APIResource{create(t,r={},n){return this._client.post((0,W.path)`/v3/connections/${t}`,{body:r,...n})}list(t={},r){return this._client.post("/v3/connections/list",{body:t,...r})}configure(t,r,n){return this._client.post((0,W.path)`/v3/connections/${t}/configure`,{body:r,...n})}deleteByID(t,r){return this._client.delete((0,W.path)`/v3/connections/${t}`,r)}deleteByProvider(t,r,n){return this._client.delete((0,W.path)`/v3/connections/${t}`,{body:r,...n})}getByID(t,r){return this._client.get((0,W.path)`/v3/connections/${t}`,r)}getByTag(t,r,n){return this._client.post((0,W.path)`/v3/connections/${t}/connection`,{body:r,...n})}import(t,r={},n){return this._client.post((0,W.path)`/v3/connections/${t}/import`,{body:r,...n,headers:(0,Fn.buildHeaders)([{Accept:"text/plain"},n?.headers])})}listDocuments(t,r={},n){return this._client.post((0,W.path)`/v3/connections/${t}/documents`,{body:r,...n})}resources(t,r={},n){return this._client.get((0,W.path)`/v3/connections/${t}/resources`,{query:r,...n})}};je.Connections=_e});var rt=d(xe=>{"use strict";Object.defineProperty(xe,"__esModule",{value:!0});xe.Documents=void 0;var Dn=M(),Yn=B(),Un=C(),et=be(),tt=class extends Dn.APIResource{update(t,r={},n){return this._client.patch((0,et.path)`/v3/documents/${t}`,{body:r,...n})}list(t={},r){return this._client.post("/v3/documents/list",{body:t,...r})}delete(t,r){return this._client.delete((0,et.path)`/v3/documents/${t}`,{...r,headers:(0,Yn.buildHeaders)([{Accept:"*/*"},r?.headers])})}add(t,r){return this._client.post("/v3/documents",{body:t,...r})}batchAdd(t,r){return this._client.post("/v3/documents/batch",{body:t,...r})}deleteBulk(t={},r){return this._client.delete("/v3/documents/bulk",{body:t,...r})}get(t,r){return this._client.get((0,et.path)`/v3/documents/${t}`,r)}listProcessing(t){return this._client.get("/v3/documents/processing",t)}uploadFile(t,r){return this._client.post("/v3/documents/file",(0,Un.multipartFormRequestOptions)({body:t,...r},this._client))}};xe.Documents=tt});var ot=d(Xe=>{"use strict";Object.defineProperty(Xe,"__esModule",{value:!0});Xe.Memories=void 0;var Sn=M(),Gn=B(),Kn=C(),nt=be(),st=class extends Sn.APIResource{update(t,r={},n){return this._client.patch((0,nt.path)`/v3/documents/${t}`,{body:r,...n})}list(t={},r){return this._client.post("/v3/documents/list",{body:t,...r})}delete(t,r){return this._client.delete((0,nt.path)`/v3/documents/${t}`,{...r,headers:(0,Gn.buildHeaders)([{Accept:"*/*"},r?.headers])})}add(t,r){return this._client.post("/v3/documents",{body:t,...r})}forget(t,r){return this._client.delete("/v4/memories",{body:t,...r})}get(t,r){return this._client.get((0,nt.path)`/v3/documents/${t}`,r)}updateMemory(t,r){return this._client.patch("/v4/memories",{body:t,...r})}uploadFile(t,r){return this._client.post("/v3/documents/file",(0,Kn.multipartFormRequestOptions)({body:t,...r},this._client))}};Xe.Memories=st});var ft=d(Oe=>{"use strict";Object.defineProperty(Oe,"__esModule",{value:!0});Oe.Search=void 0;var kn=M(),at=class extends kn.APIResource{documents(t,r){return this._client.post("/v3/search",{body:t,...r})}execute(t,r){return this._client.post("/v3/search",{body:t,...r})}memories(t,r){return this._client.post("/v4/search",{body:t,...r})}};Oe.Search=at});var it=d(ye=>{"use strict";Object.defineProperty(ye,"__esModule",{value:!0});ye.Settings=void 0;var En=M(),ct=class extends En.APIResource{update(t={},r){return this._client.patch("/v3/settings",{body:t,...r})}get(t){return this._client.get("/v3/settings",t)}};ye.Settings=ct});var At=d(H=>{"use strict";Object.defineProperty(H,"__esModule",{value:!0});H.Settings=H.Search=H.Memories=H.Documents=H.Connections=void 0;var In=$e();Object.defineProperty(H,"Connections",{enumerable:!0,get:function(){return In.Connections}});var Cn=rt();Object.defineProperty(H,"Documents",{enumerable:!0,get:function(){return Cn.Documents}});var Jn=ot();Object.defineProperty(H,"Memories",{enumerable:!0,get:function(){return Jn.Memories}});var Bn=ft();Object.defineProperty(H,"Search",{enumerable:!0,get:function(){return Bn.Search}});var An=it();Object.defineProperty(H,"Settings",{enumerable:!0,get:function(){return An.Settings}})});var ut=d(R=>{"use strict";Object.defineProperty(R,"__esModule",{value:!0});R.formatRequestDetails=R.parseLogLevel=void 0;R.loggerFor=_t;var Qn=E(),qe={off:0,error:200,warn:300,info:400,debug:500},_n=(e,t,r)=>{if(e){if((0,Qn.hasOwn)(qe,e))return e;_t(r).warn(`${t} was set to ${JSON.stringify(e)}, expected one of ${JSON.stringify(Object.keys(qe))}`)}};R.parseLogLevel=_n;function A(){}function He(e,t,r){return!t||qe[e]>qe[r]?A:t[e].bind(t)}var $n={error:A,warn:A,info:A,debug:A},Qt=new WeakMap;function _t(e){let t=e.logger,r=e.logLevel??"off";if(!t)return $n;let n=Qt.get(t);if(n&&n[0]===r)return n[1];let s={error:He("error",t,r),warn:He("warn",t,r),info:He("info",t,r),debug:He("debug",t,r)};return Qt.set(t,[r,s]),s}var es=e=>(e.options&&(e.options={...e.options},delete e.options.headers),e.headers&&(e.headers=Object.fromEntries((e.headers instanceof Headers?[...e.headers]:Object.entries(e.headers)).map(([t,r])=>[t,t.toLowerCase()==="authorization"||t.toLowerCase()==="cookie"||t.toLowerCase()==="set-cookie"?"***":r]))),"retryOfRequestLogID"in e&&(e.retryOfRequestLogID&&(e.retryOf=e.retryOfRequestLogID),delete e.retryOfRequestLogID),e);R.formatRequestDetails=es});var er=d(dt=>{"use strict";Object.defineProperty(dt,"__esModule",{value:!0});dt.defaultParseResponse=ts;var $t=ut();async function ts(e,t){let{response:r,requestLogID:n,retryOfRequestLogID:s,startTime:o}=t,a=await(async()=>{if(r.status===204)return null;if(t.options.__binaryResponse)return r;let z=r.headers.get("content-type")?.split(";")[0]?.trim();return z?.includes("application/json")||z?.endsWith("+json")?await r.json():await r.text()})();return(0,$t.loggerFor)(e).debug(`[${n}] response parsed`,(0,$t.formatRequestDetails)({retryOfRequestLogID:s,url:r.url,status:r.status,body:a,durationMs:Date.now()-o})),a}});var Pt=d(he=>{"use strict";var Q;Object.defineProperty(he,"__esModule",{value:!0});he.APIPromise=void 0;var vt=De(),rs=er(),lt=class e extends Promise{constructor(t,r,n=rs.defaultParseResponse){super(s=>{s(null)}),this.responsePromise=r,this.parseResponse=n,Q.set(this,void 0),vt.__classPrivateFieldSet(this,Q,t,"f")}_thenUnwrap(t){return new e(vt.__classPrivateFieldGet(this,Q,"f"),this.responsePromise,async(r,n)=>t(await this.parseResponse(r,n),n))}asResponse(){return this.responsePromise.then(t=>t.response)}async withResponse(){let[t,r]=await Promise.all([this.parse(),this.asResponse()]);return{data:t,response:r}}parse(){return this.parsedPromise||(this.parsedPromise=this.responsePromise.then(t=>this.parseResponse(vt.__classPrivateFieldGet(this,Q,"f"),t))),this.parsedPromise}then(t,r){return this.parse().then(t,r)}catch(t){return this.parse().catch(t)}finally(t){return this.parse().finally(t)}};he.APIPromise=lt;Q=new WeakMap});var tr=d(We=>{"use strict";Object.defineProperty(We,"__esModule",{value:!0});We.readEnv=void 0;var ns=e=>{if(typeof globalThis.process<"u")return globalThis.process.env?.[e]?.trim()??void 0;if(typeof globalThis.Deno<"u")return globalThis.Deno.env?.get?.(e)?.trim()};We.readEnv=ns});var Ot=d(Ne=>{"use strict";var xt,Xt,Te,rr;Object.defineProperty(Ne,"__esModule",{value:!0});Ne.Supermemory=void 0;var L=De(),ss=wt(),pt=E(),os=Mt(),zt=Ye(),as=Yt(),mt=L.__importStar(Ke()),fs=L.__importStar(St()),cs=Ge(),b=L.__importStar(K()),is=L.__importStar(Be()),_=L.__importStar(At()),us=Pt(),ds=$e(),vs=rt(),ls=ot(),Ps=ft(),ps=it(),bt=B(),jt=tr(),x=ut(),zs=E(),p=class{constructor({baseURL:t=(0,jt.readEnv)("SUPERMEMORY_BASE_URL"),apiKey:r=(0,jt.readEnv)("SUPERMEMORY_API_KEY"),...n}={}){if(xt.add(this),Te.set(this,void 0),this.memories=new _.Memories(this),this.documents=new _.Documents(this),this.search=new _.Search(this),this.settings=new _.Settings(this),this.connections=new _.Connections(this),r===void 0)throw new b.SupermemoryError("The SUPERMEMORY_API_KEY environment variable is missing or empty; either provide it, or instantiate the Supermemory client with an apiKey option, like new Supermemory({ apiKey: 'My API Key' }).");let s={apiKey:r,...n,baseURL:t||"https://api.supermemory.ai"};this.baseURL=s.baseURL,this.timeout=s.timeout??Xt.DEFAULT_TIMEOUT,this.logger=s.logger??console;let o="warn";this.logLevel=o,this.logLevel=(0,x.parseLogLevel)(s.logLevel,"ClientOptions.logLevel",this)??(0,x.parseLogLevel)((0,jt.readEnv)("SUPERMEMORY_LOG"),"process.env['SUPERMEMORY_LOG']",this)??o,this.fetchOptions=s.fetchOptions,this.maxRetries=s.maxRetries??2,this.fetch=s.fetch??mt.getDefaultFetch(),L.__classPrivateFieldSet(this,Te,fs.FallbackEncoder,"f"),this._options=s,this.apiKey=r}withOptions(t){return new this.constructor({...this._options,baseURL:this.baseURL,maxRetries:this.maxRetries,timeout:this.timeout,logger:this.logger,logLevel:this.logLevel,fetch:this.fetch,fetchOptions:this.fetchOptions,apiKey:this.apiKey,...t})}add(t,r){return this.post("/v3/documents",{body:t,...r})}profile(t,r){return this.post("/v4/profile",{body:t,...r})}defaultQuery(){return this._options.defaultQuery}validateHeaders({values:t,nulls:r}){}async authHeaders(t){return(0,bt.buildHeaders)([{Authorization:`Bearer ${this.apiKey}`}])}stringifyQuery(t){return Object.entries(t).filter(([r,n])=>typeof n<"u").map(([r,n])=>{if(typeof n=="string"||typeof n=="number"||typeof n=="boolean")return`${encodeURIComponent(r)}=${encodeURIComponent(n)}`;if(n===null)return`${encodeURIComponent(r)}=`;throw new b.SupermemoryError(`Cannot stringify type ${typeof n}; Expected string, number, boolean, or null. If you need to pass nested query parameters, you can manually encode them, e.g. { query: { 'foo[key1]': value1, 'foo[key2]': value2 } }, and please open a GitHub issue requesting better support for your use case.`)}).join("&")}getUserAgent(){return`${this.constructor.name}/JS ${cs.VERSION}`}defaultIdempotencyKey(){return`stainless-node-retry-${(0,ss.uuid4)()}`}makeStatusError(t,r,n,s){return b.APIError.generate(t,r,n,s)}buildURL(t,r,n){let s=!L.__classPrivateFieldGet(this,xt,"m",rr).call(this)&&n||this.baseURL,o=(0,pt.isAbsoluteURL)(t)?new URL(t):new URL(s+(s.endsWith("/")&&t.startsWith("/")?t.slice(1):t)),a=this.defaultQuery();return(0,zs.isEmptyObj)(a)||(r={...a,...r}),typeof r=="object"&&r&&!Array.isArray(r)&&(o.search=this.stringifyQuery(r)),o.toString()}async prepareOptions(t){}async prepareRequest(t,{url:r,options:n}){}get(t,r){return this.methodRequest("get",t,r)}post(t,r){return this.methodRequest("post",t,r)}patch(t,r){return this.methodRequest("patch",t,r)}put(t,r){return this.methodRequest("put",t,r)}delete(t,r){return this.methodRequest("delete",t,r)}methodRequest(t,r,n){return this.request(Promise.resolve(n).then(s=>({method:t,path:r,...s})))}request(t,r=null){return new us.APIPromise(this,this.makeRequest(t,r,void 0))}async makeRequest(t,r,n){let s=await t,o=s.maxRetries??this.maxRetries;r==null&&(r=o),await this.prepareOptions(s);let{req:a,url:f,timeout:z}=await this.buildRequest(s,{retryCount:o-r});await this.prepareRequest(a,{url:f,options:s});let l="log_"+(Math.random()*(1<<24)|0).toString(16).padStart(6,"0"),v=n===void 0?"":`, retryOf: ${n}`,m=Date.now();if((0,x.loggerFor)(this).debug(`[${l}] sending request`,(0,x.formatRequestDetails)({retryOfRequestLogID:n,method:s.method,url:f,options:s,headers:a.headers})),s.signal?.aborted)throw new b.APIUserAbortError;let X=new AbortController,c=await this.fetchWithTimeout(f,a,z,X).catch(zt.castToError),q=Date.now();if(c instanceof globalThis.Error){let Y=`retrying, ${r} attempts remaining`;if(s.signal?.aborted)throw new b.APIUserAbortError;let T=(0,zt.isAbortError)(c)||/timed? ?out/i.test(String(c)+("cause"in c?String(c.cause):""));if(r)return(0,x.loggerFor)(this).info(`[${l}] connection ${T?"timed out":"failed"} - ${Y}`),(0,x.loggerFor)(this).debug(`[${l}] connection ${T?"timed out":"failed"} (${Y})`,(0,x.formatRequestDetails)({retryOfRequestLogID:n,url:f,durationMs:q-m,message:c.message})),this.retryRequest(s,r,n??l);throw(0,x.loggerFor)(this).info(`[${l}] connection ${T?"timed out":"failed"} - error; no more retries left`),(0,x.loggerFor)(this).debug(`[${l}] connection ${T?"timed out":"failed"} (error; no more retries left)`,(0,x.formatRequestDetails)({retryOfRequestLogID:n,url:f,durationMs:q-m,message:c.message})),T?new b.APIConnectionTimeoutError:new b.APIConnectionError({cause:c})}let D=`[${l}${v}] ${a.method} ${f} ${c.ok?"succeeded":"failed"} with status ${c.status} in ${q-m}ms`;if(!c.ok){let Y=await this.shouldRetry(c);if(r&&Y){let re=`retrying, ${r} attempts remaining`;return await mt.CancelReadableStream(c.body),(0,x.loggerFor)(this).info(`${D} - ${re}`),(0,x.loggerFor)(this).debug(`[${l}] response error (${re})`,(0,x.formatRequestDetails)({retryOfRequestLogID:n,url:c.url,status:c.status,headers:c.headers,durationMs:q-m})),this.retryRequest(s,r,n??l,c.headers)}let T=Y?"error; no more retries left":"error; not retryable";(0,x.loggerFor)(this).info(`${D} - ${T}`);let Lt=await c.text().catch(re=>(0,zt.castToError)(re).message),Vt=(0,pt.safeJSON)(Lt),Rt=Vt?void 0:Lt;throw(0,x.loggerFor)(this).debug(`[${l}] response error (${T})`,(0,x.formatRequestDetails)({retryOfRequestLogID:n,url:c.url,status:c.status,headers:c.headers,message:Rt,durationMs:Date.now()-m})),this.makeStatusError(c.status,Vt,Rt,c.headers)}return(0,x.loggerFor)(this).info(D),(0,x.loggerFor)(this).debug(`[${l}] response start`,(0,x.formatRequestDetails)({retryOfRequestLogID:n,url:c.url,status:c.status,headers:c.headers,durationMs:q-m})),{response:c,options:s,controller:X,requestLogID:l,retryOfRequestLogID:n,startTime:m}}async fetchWithTimeout(t,r,n,s){let{signal:o,method:a,...f}=r||{};o&&o.addEventListener("abort",()=>s.abort());let z=setTimeout(()=>s.abort(),n),l=globalThis.ReadableStream&&f.body instanceof globalThis.ReadableStream||typeof f.body=="object"&&f.body!==null&&Symbol.asyncIterator in f.body,v={signal:s.signal,...l?{duplex:"half"}:{},method:"GET",...f};a&&(v.method=a.toUpperCase());try{return await this.fetch.call(void 0,t,v)}finally{clearTimeout(z)}}async shouldRetry(t){let r=t.headers.get("x-should-retry");return r==="true"?!0:r==="false"?!1:t.status===408||t.status===409||t.status===429||t.status>=500}async retryRequest(t,r,n,s){let o,a=s?.get("retry-after-ms");if(a){let z=parseFloat(a);Number.isNaN(z)||(o=z)}let f=s?.get("retry-after");if(f&&!o){let z=parseFloat(f);Number.isNaN(z)?o=Date.parse(f)-Date.now():o=z*1e3}if(!(o&&0<=o&&o<60*1e3)){let z=t.maxRetries??this.maxRetries;o=this.calculateDefaultRetryTimeoutMillis(r,z)}return await(0,os.sleep)(o),this.makeRequest(t,r-1,n)}calculateDefaultRetryTimeoutMillis(t,r){let o=r-t,a=Math.min(.5*Math.pow(2,o),8),f=1-Math.random()*.25;return a*f*1e3}async buildRequest(t,{retryCount:r=0}={}){let n={...t},{method:s,path:o,query:a,defaultBaseURL:f}=n,z=this.buildURL(o,a,f);"timeout"in n&&(0,pt.validatePositiveInteger)("timeout",n.timeout),n.timeout=n.timeout??this.timeout;let{bodyHeaders:l,body:v}=this.buildBody({options:n}),m=await this.buildHeaders({options:t,method:s,bodyHeaders:l,retryCount:r});return{req:{method:s,headers:m,...n.signal&&{signal:n.signal},...globalThis.ReadableStream&&v instanceof globalThis.ReadableStream&&{duplex:"half"},...v&&{body:v},...this.fetchOptions??{},...n.fetchOptions??{}},url:z,timeout:n.timeout}}async buildHeaders({options:t,method:r,bodyHeaders:n,retryCount:s}){let o={};this.idempotencyHeader&&r!=="get"&&(t.idempotencyKey||(t.idempotencyKey=this.defaultIdempotencyKey()),o[this.idempotencyHeader]=t.idempotencyKey);let a=(0,bt.buildHeaders)([o,{Accept:"application/json","User-Agent":this.getUserAgent(),"X-Stainless-Retry-Count":String(s),...t.timeout?{"X-Stainless-Timeout":String(Math.trunc(t.timeout/1e3))}:{},...(0,as.getPlatformHeaders)()},await this.authHeaders(t),this._options.defaultHeaders,n,t.headers]);return this.validateHeaders(a),a.values}buildBody({options:{body:t,headers:r}}){if(!t)return{bodyHeaders:void 0,body:void 0};let n=(0,bt.buildHeaders)([r]);return ArrayBuffer.isView(t)||t instanceof ArrayBuffer||t instanceof DataView||typeof t=="string"&&n.values.has("content-type")||globalThis.Blob&&t instanceof globalThis.Blob||t instanceof FormData||t instanceof URLSearchParams||globalThis.ReadableStream&&t instanceof globalThis.ReadableStream?{bodyHeaders:void 0,body:t}:typeof t=="object"&&(Symbol.asyncIterator in t||Symbol.iterator in t&&"next"in t&&typeof t.next=="function")?{bodyHeaders:void 0,body:mt.ReadableStreamFrom(t)}:L.__classPrivateFieldGet(this,Te,"f").call(this,{body:t,headers:n})}};Ne.Supermemory=p;Xt=p,Te=new WeakMap,xt=new WeakSet,rr=function(){return this.baseURL!=="https://api.supermemory.ai"};p.Supermemory=Xt;p.DEFAULT_TIMEOUT=6e4;p.SupermemoryError=b.SupermemoryError;p.APIError=b.APIError;p.APIConnectionError=b.APIConnectionError;p.APIConnectionTimeoutError=b.APIConnectionTimeoutError;p.APIUserAbortError=b.APIUserAbortError;p.NotFoundError=b.NotFoundError;p.ConflictError=b.ConflictError;p.RateLimitError=b.RateLimitError;p.BadRequestError=b.BadRequestError;p.AuthenticationError=b.AuthenticationError;p.InternalServerError=b.InternalServerError;p.PermissionDeniedError=b.PermissionDeniedError;p.UnprocessableEntityError=b.UnprocessableEntityError;p.toFile=is.toFile;p.Memories=ls.Memories;p.Documents=vs.Documents;p.Search=Ps.Search;p.Settings=ps.Settings;p.Connections=ds.Connections});var sr=d((i,nr)=>{"use strict";i=nr.exports=function(...e){return new i.default(...e)};Object.defineProperty(i,"__esModule",{value:!0});i.UnprocessableEntityError=i.PermissionDeniedError=i.InternalServerError=i.AuthenticationError=i.BadRequestError=i.RateLimitError=i.ConflictError=i.NotFoundError=i.APIUserAbortError=i.APIConnectionTimeoutError=i.APIConnectionError=i.APIError=i.SupermemoryError=i.Supermemory=i.APIPromise=i.toFile=i.default=void 0;var ms=Ot();Object.defineProperty(i,"default",{enumerable:!0,get:function(){return ms.Supermemory}});var bs=Be();Object.defineProperty(i,"toFile",{enumerable:!0,get:function(){return bs.toFile}});var js=Pt();Object.defineProperty(i,"APIPromise",{enumerable:!0,get:function(){return js.APIPromise}});var xs=Ot();Object.defineProperty(i,"Supermemory",{enumerable:!0,get:function(){return xs.Supermemory}});var y=K();Object.defineProperty(i,"SupermemoryError",{enumerable:!0,get:function(){return y.SupermemoryError}});Object.defineProperty(i,"APIError",{enumerable:!0,get:function(){return y.APIError}});Object.defineProperty(i,"APIConnectionError",{enumerable:!0,get:function(){return y.APIConnectionError}});Object.defineProperty(i,"APIConnectionTimeoutError",{enumerable:!0,get:function(){return y.APIConnectionTimeoutError}});Object.defineProperty(i,"APIUserAbortError",{enumerable:!0,get:function(){return y.APIUserAbortError}});Object.defineProperty(i,"NotFoundError",{enumerable:!0,get:function(){return y.NotFoundError}});Object.defineProperty(i,"ConflictError",{enumerable:!0,get:function(){return y.ConflictError}});Object.defineProperty(i,"RateLimitError",{enumerable:!0,get:function(){return y.RateLimitError}});Object.defineProperty(i,"BadRequestError",{enumerable:!0,get:function(){return y.BadRequestError}});Object.defineProperty(i,"AuthenticationError",{enumerable:!0,get:function(){return y.AuthenticationError}});Object.defineProperty(i,"InternalServerError",{enumerable:!0,get:function(){return y.InternalServerError}});Object.defineProperty(i,"PermissionDeniedError",{enumerable:!0,get:function(){return y.PermissionDeniedError}});Object.defineProperty(i,"UnprocessableEntityError",{enumerable:!0,get:function(){return y.UnprocessableEntityError}})});var ar={};Zr(ar,{getRequestIntegrity:()=>Zs,sanitizeContent:()=>Hs,sanitizeMetadata:()=>Ns,validateApiKeyFormat:()=>Xs,validateContainerTag:()=>Os,validateContentLength:()=>qs,validateRecallConfig:()=>Ls});function Xs(e){return!e||typeof e!="string"?{valid:!1,reason:"key is empty or not a string"}:e.startsWith("sm_")?e.length<20?{valid:!1,reason:"key is too short"}:/\s/.test(e)?{valid:!1,reason:"key contains whitespace"}:{valid:!0}:{valid:!1,reason:"key must start with sm_ prefix"}}function Os(e){return!e||typeof e!="string"?{valid:!1,reason:"tag is empty"}:e.length>100?{valid:!1,reason:"tag exceeds 100 characters"}:/^[a-zA-Z0-9_-]+$/.test(e)?/^[-_]|[-_]$/.test(e)?{valid:!1,reason:"tag must not start or end with - or _"}:{valid:!0}:{valid:!1,reason:"tag contains invalid characters (only alphanumeric, underscore, hyphen allowed)"}}function Hs(e,t=1e5){if(!e||typeof e!="string")return"";let r=e;for(let n of ys)r=r.replace(n,"");return r.length>t&&(r=r.slice(0,t)),r}function qs(e,t=1,r=1e5){return e.lengthr?{valid:!1,reason:`content exceeds maximum length (${r})`}:{valid:!0}}function Ns(e){let t={},r=0;for(let[n,s]of Object.entries(e)){if(r>=hs)break;n.length>Ws||/[^\w.-]/.test(n)||(typeof s=="string"?(t[n]=s.slice(0,Ts),r++):(typeof s=="number"&&Number.isFinite(s)||typeof s=="boolean")&&(t[n]=s,r++))}return t}function Ls(e,t){let r=[];return(!Number.isInteger(e)||e<1||e>20)&&r.push("maxRecallResults must be an integer between 1 and 20"),(!Number.isInteger(t)||t<1||t>500)&&r.push("profileFrequency must be an integer between 1 and 500"),r}function yt(e){return(0,Le.createHash)("sha256").update(e).digest("hex")}function Rs(e,t){let r=[yt(e),yt(t),or].join(":");return(0,Le.createHmac)("sha256",Vs).update(r).digest("base64url")}function Zs(e,t){let r=yt(t),n=Rs(e,t);return{"X-Content-Hash":r,"X-Request-Integrity":[`v${or}`,n].join(".")}}var Le,ys,hs,Ws,Ts,or,Vs,fr=Rr(()=>{Le=require("node:crypto");ys=[/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F]/g,/\uFEFF/g,/[\uFFF0-\uFFFF]/g];hs=50,Ws=128,Ts=1024;or=1,Vs="7f2a9c4b8e1d6f3a5c0b9d8e7f6a5b4c3d2e1f0a9b8c7d6e5f4a3b2c1d0e9f8a"});var ir=d((na,cr)=>{var ws=sr().default,{getRequestIntegrity:Ms,validateApiKeyFormat:gs,validateContainerTag:Fs}=(fr(),Mr(ar)),Ds="claudecode_default",Ys=process.env.SUPERMEMORY_API_URL||"https://api.supermemory.ai";function Us(e,t=r=>r){let r=new Set;return e.filter(n=>{let s=String(t(n)).toLowerCase().trim();return!s||r.has(s)?!1:(r.add(s),!0)})}var Ss=`Developer coding session transcript. Focus on USER message and intent. +${m}`)}return a};N.createPathTagFunction=Fn;N.path=(0,N.createPathTagFunction)(Qe)});var $e=d(je=>{"use strict";Object.defineProperty(je,"__esModule",{value:!0});je.Connections=void 0;var Dn=M(),Un=B(),W=be(),_e=class extends Dn.APIResource{create(t,r={},n){return this._client.post((0,W.path)`/v3/connections/${t}`,{body:r,...n})}list(t={},r){return this._client.post("/v3/connections/list",{body:t,...r})}configure(t,r,n){return this._client.post((0,W.path)`/v3/connections/${t}/configure`,{body:r,...n})}deleteByID(t,r){return this._client.delete((0,W.path)`/v3/connections/${t}`,r)}deleteByProvider(t,r,n){return this._client.delete((0,W.path)`/v3/connections/${t}`,{body:r,...n})}getByID(t,r){return this._client.get((0,W.path)`/v3/connections/${t}`,r)}getByTag(t,r,n){return this._client.post((0,W.path)`/v3/connections/${t}/connection`,{body:r,...n})}import(t,r={},n){return this._client.post((0,W.path)`/v3/connections/${t}/import`,{body:r,...n,headers:(0,Un.buildHeaders)([{Accept:"text/plain"},n?.headers])})}listDocuments(t,r={},n){return this._client.post((0,W.path)`/v3/connections/${t}/documents`,{body:r,...n})}resources(t,r={},n){return this._client.get((0,W.path)`/v3/connections/${t}/resources`,{query:r,...n})}};je.Connections=_e});var rt=d(xe=>{"use strict";Object.defineProperty(xe,"__esModule",{value:!0});xe.Documents=void 0;var Yn=M(),Sn=B(),Gn=C(),et=be(),tt=class extends Yn.APIResource{update(t,r={},n){return this._client.patch((0,et.path)`/v3/documents/${t}`,{body:r,...n})}list(t={},r){return this._client.post("/v3/documents/list",{body:t,...r})}delete(t,r){return this._client.delete((0,et.path)`/v3/documents/${t}`,{...r,headers:(0,Sn.buildHeaders)([{Accept:"*/*"},r?.headers])})}add(t,r){return this._client.post("/v3/documents",{body:t,...r})}batchAdd(t,r){return this._client.post("/v3/documents/batch",{body:t,...r})}deleteBulk(t={},r){return this._client.delete("/v3/documents/bulk",{body:t,...r})}get(t,r){return this._client.get((0,et.path)`/v3/documents/${t}`,r)}listProcessing(t){return this._client.get("/v3/documents/processing",t)}uploadFile(t,r){return this._client.post("/v3/documents/file",(0,Gn.multipartFormRequestOptions)({body:t,...r},this._client))}};xe.Documents=tt});var ot=d(Xe=>{"use strict";Object.defineProperty(Xe,"__esModule",{value:!0});Xe.Memories=void 0;var Kn=M(),kn=B(),En=C(),nt=be(),st=class extends Kn.APIResource{update(t,r={},n){return this._client.patch((0,nt.path)`/v3/documents/${t}`,{body:r,...n})}list(t={},r){return this._client.post("/v3/documents/list",{body:t,...r})}delete(t,r){return this._client.delete((0,nt.path)`/v3/documents/${t}`,{...r,headers:(0,kn.buildHeaders)([{Accept:"*/*"},r?.headers])})}add(t,r){return this._client.post("/v3/documents",{body:t,...r})}forget(t,r){return this._client.delete("/v4/memories",{body:t,...r})}get(t,r){return this._client.get((0,nt.path)`/v3/documents/${t}`,r)}updateMemory(t,r){return this._client.patch("/v4/memories",{body:t,...r})}uploadFile(t,r){return this._client.post("/v3/documents/file",(0,En.multipartFormRequestOptions)({body:t,...r},this._client))}};Xe.Memories=st});var ft=d(Oe=>{"use strict";Object.defineProperty(Oe,"__esModule",{value:!0});Oe.Search=void 0;var In=M(),at=class extends In.APIResource{documents(t,r){return this._client.post("/v3/search",{body:t,...r})}execute(t,r){return this._client.post("/v3/search",{body:t,...r})}memories(t,r){return this._client.post("/v4/search",{body:t,...r})}};Oe.Search=at});var it=d(ye=>{"use strict";Object.defineProperty(ye,"__esModule",{value:!0});ye.Settings=void 0;var Cn=M(),ct=class extends Cn.APIResource{update(t={},r){return this._client.patch("/v3/settings",{body:t,...r})}get(t){return this._client.get("/v3/settings",t)}};ye.Settings=ct});var Qt=d(H=>{"use strict";Object.defineProperty(H,"__esModule",{value:!0});H.Settings=H.Search=H.Memories=H.Documents=H.Connections=void 0;var Jn=$e();Object.defineProperty(H,"Connections",{enumerable:!0,get:function(){return Jn.Connections}});var Bn=rt();Object.defineProperty(H,"Documents",{enumerable:!0,get:function(){return Bn.Documents}});var An=ot();Object.defineProperty(H,"Memories",{enumerable:!0,get:function(){return An.Memories}});var Qn=ft();Object.defineProperty(H,"Search",{enumerable:!0,get:function(){return Qn.Search}});var _n=it();Object.defineProperty(H,"Settings",{enumerable:!0,get:function(){return _n.Settings}})});var ut=d(R=>{"use strict";Object.defineProperty(R,"__esModule",{value:!0});R.formatRequestDetails=R.parseLogLevel=void 0;R.loggerFor=$t;var $n=E(),qe={off:0,error:200,warn:300,info:400,debug:500},es=(e,t,r)=>{if(e){if((0,$n.hasOwn)(qe,e))return e;$t(r).warn(`${t} was set to ${JSON.stringify(e)}, expected one of ${JSON.stringify(Object.keys(qe))}`)}};R.parseLogLevel=es;function A(){}function He(e,t,r){return!t||qe[e]>qe[r]?A:t[e].bind(t)}var ts={error:A,warn:A,info:A,debug:A},_t=new WeakMap;function $t(e){let t=e.logger,r=e.logLevel??"off";if(!t)return ts;let n=_t.get(t);if(n&&n[0]===r)return n[1];let s={error:He("error",t,r),warn:He("warn",t,r),info:He("info",t,r),debug:He("debug",t,r)};return _t.set(t,[r,s]),s}var rs=e=>(e.options&&(e.options={...e.options},delete e.options.headers),e.headers&&(e.headers=Object.fromEntries((e.headers instanceof Headers?[...e.headers]:Object.entries(e.headers)).map(([t,r])=>[t,t.toLowerCase()==="authorization"||t.toLowerCase()==="cookie"||t.toLowerCase()==="set-cookie"?"***":r]))),"retryOfRequestLogID"in e&&(e.retryOfRequestLogID&&(e.retryOf=e.retryOfRequestLogID),delete e.retryOfRequestLogID),e);R.formatRequestDetails=rs});var tr=d(dt=>{"use strict";Object.defineProperty(dt,"__esModule",{value:!0});dt.defaultParseResponse=ns;var er=ut();async function ns(e,t){let{response:r,requestLogID:n,retryOfRequestLogID:s,startTime:o}=t,a=await(async()=>{if(r.status===204)return null;if(t.options.__binaryResponse)return r;let z=r.headers.get("content-type")?.split(";")[0]?.trim();return z?.includes("application/json")||z?.endsWith("+json")?await r.json():await r.text()})();return(0,er.loggerFor)(e).debug(`[${n}] response parsed`,(0,er.formatRequestDetails)({retryOfRequestLogID:s,url:r.url,status:r.status,body:a,durationMs:Date.now()-o})),a}});var Pt=d(he=>{"use strict";var Q;Object.defineProperty(he,"__esModule",{value:!0});he.APIPromise=void 0;var vt=De(),ss=tr(),lt=class e extends Promise{constructor(t,r,n=ss.defaultParseResponse){super(s=>{s(null)}),this.responsePromise=r,this.parseResponse=n,Q.set(this,void 0),vt.__classPrivateFieldSet(this,Q,t,"f")}_thenUnwrap(t){return new e(vt.__classPrivateFieldGet(this,Q,"f"),this.responsePromise,async(r,n)=>t(await this.parseResponse(r,n),n))}asResponse(){return this.responsePromise.then(t=>t.response)}async withResponse(){let[t,r]=await Promise.all([this.parse(),this.asResponse()]);return{data:t,response:r}}parse(){return this.parsedPromise||(this.parsedPromise=this.responsePromise.then(t=>this.parseResponse(vt.__classPrivateFieldGet(this,Q,"f"),t))),this.parsedPromise}then(t,r){return this.parse().then(t,r)}catch(t){return this.parse().catch(t)}finally(t){return this.parse().finally(t)}};he.APIPromise=lt;Q=new WeakMap});var rr=d(We=>{"use strict";Object.defineProperty(We,"__esModule",{value:!0});We.readEnv=void 0;var os=e=>{if(typeof globalThis.process<"u")return globalThis.process.env?.[e]?.trim()??void 0;if(typeof globalThis.Deno<"u")return globalThis.Deno.env?.get?.(e)?.trim()};We.readEnv=os});var Ot=d(Ne=>{"use strict";var xt,Xt,Te,nr;Object.defineProperty(Ne,"__esModule",{value:!0});Ne.Supermemory=void 0;var L=De(),as=Mt(),pt=E(),fs=gt(),zt=Ue(),cs=Yt(),mt=L.__importStar(Ke()),is=L.__importStar(Gt()),us=Ge(),b=L.__importStar(K()),ds=L.__importStar(Be()),_=L.__importStar(Qt()),vs=Pt(),ls=$e(),Ps=rt(),ps=ot(),zs=ft(),ms=it(),bt=B(),jt=rr(),x=ut(),bs=E(),p=class{constructor({baseURL:t=(0,jt.readEnv)("SUPERMEMORY_BASE_URL"),apiKey:r=(0,jt.readEnv)("SUPERMEMORY_API_KEY"),...n}={}){if(xt.add(this),Te.set(this,void 0),this.memories=new _.Memories(this),this.documents=new _.Documents(this),this.search=new _.Search(this),this.settings=new _.Settings(this),this.connections=new _.Connections(this),r===void 0)throw new b.SupermemoryError("The SUPERMEMORY_API_KEY environment variable is missing or empty; either provide it, or instantiate the Supermemory client with an apiKey option, like new Supermemory({ apiKey: 'My API Key' }).");let s={apiKey:r,...n,baseURL:t||"https://api.supermemory.ai"};this.baseURL=s.baseURL,this.timeout=s.timeout??Xt.DEFAULT_TIMEOUT,this.logger=s.logger??console;let o="warn";this.logLevel=o,this.logLevel=(0,x.parseLogLevel)(s.logLevel,"ClientOptions.logLevel",this)??(0,x.parseLogLevel)((0,jt.readEnv)("SUPERMEMORY_LOG"),"process.env['SUPERMEMORY_LOG']",this)??o,this.fetchOptions=s.fetchOptions,this.maxRetries=s.maxRetries??2,this.fetch=s.fetch??mt.getDefaultFetch(),L.__classPrivateFieldSet(this,Te,is.FallbackEncoder,"f"),this._options=s,this.apiKey=r}withOptions(t){return new this.constructor({...this._options,baseURL:this.baseURL,maxRetries:this.maxRetries,timeout:this.timeout,logger:this.logger,logLevel:this.logLevel,fetch:this.fetch,fetchOptions:this.fetchOptions,apiKey:this.apiKey,...t})}add(t,r){return this.post("/v3/documents",{body:t,...r})}profile(t,r){return this.post("/v4/profile",{body:t,...r})}defaultQuery(){return this._options.defaultQuery}validateHeaders({values:t,nulls:r}){}async authHeaders(t){return(0,bt.buildHeaders)([{Authorization:`Bearer ${this.apiKey}`}])}stringifyQuery(t){return Object.entries(t).filter(([r,n])=>typeof n<"u").map(([r,n])=>{if(typeof n=="string"||typeof n=="number"||typeof n=="boolean")return`${encodeURIComponent(r)}=${encodeURIComponent(n)}`;if(n===null)return`${encodeURIComponent(r)}=`;throw new b.SupermemoryError(`Cannot stringify type ${typeof n}; Expected string, number, boolean, or null. If you need to pass nested query parameters, you can manually encode them, e.g. { query: { 'foo[key1]': value1, 'foo[key2]': value2 } }, and please open a GitHub issue requesting better support for your use case.`)}).join("&")}getUserAgent(){return`${this.constructor.name}/JS ${us.VERSION}`}defaultIdempotencyKey(){return`stainless-node-retry-${(0,as.uuid4)()}`}makeStatusError(t,r,n,s){return b.APIError.generate(t,r,n,s)}buildURL(t,r,n){let s=!L.__classPrivateFieldGet(this,xt,"m",nr).call(this)&&n||this.baseURL,o=(0,pt.isAbsoluteURL)(t)?new URL(t):new URL(s+(s.endsWith("/")&&t.startsWith("/")?t.slice(1):t)),a=this.defaultQuery();return(0,bs.isEmptyObj)(a)||(r={...a,...r}),typeof r=="object"&&r&&!Array.isArray(r)&&(o.search=this.stringifyQuery(r)),o.toString()}async prepareOptions(t){}async prepareRequest(t,{url:r,options:n}){}get(t,r){return this.methodRequest("get",t,r)}post(t,r){return this.methodRequest("post",t,r)}patch(t,r){return this.methodRequest("patch",t,r)}put(t,r){return this.methodRequest("put",t,r)}delete(t,r){return this.methodRequest("delete",t,r)}methodRequest(t,r,n){return this.request(Promise.resolve(n).then(s=>({method:t,path:r,...s})))}request(t,r=null){return new vs.APIPromise(this,this.makeRequest(t,r,void 0))}async makeRequest(t,r,n){let s=await t,o=s.maxRetries??this.maxRetries;r==null&&(r=o),await this.prepareOptions(s);let{req:a,url:f,timeout:z}=await this.buildRequest(s,{retryCount:o-r});await this.prepareRequest(a,{url:f,options:s});let l="log_"+(Math.random()*(1<<24)|0).toString(16).padStart(6,"0"),v=n===void 0?"":`, retryOf: ${n}`,m=Date.now();if((0,x.loggerFor)(this).debug(`[${l}] sending request`,(0,x.formatRequestDetails)({retryOfRequestLogID:n,method:s.method,url:f,options:s,headers:a.headers})),s.signal?.aborted)throw new b.APIUserAbortError;let X=new AbortController,c=await this.fetchWithTimeout(f,a,z,X).catch(zt.castToError),q=Date.now();if(c instanceof globalThis.Error){let U=`retrying, ${r} attempts remaining`;if(s.signal?.aborted)throw new b.APIUserAbortError;let T=(0,zt.isAbortError)(c)||/timed? ?out/i.test(String(c)+("cause"in c?String(c.cause):""));if(r)return(0,x.loggerFor)(this).info(`[${l}] connection ${T?"timed out":"failed"} - ${U}`),(0,x.loggerFor)(this).debug(`[${l}] connection ${T?"timed out":"failed"} (${U})`,(0,x.formatRequestDetails)({retryOfRequestLogID:n,url:f,durationMs:q-m,message:c.message})),this.retryRequest(s,r,n??l);throw(0,x.loggerFor)(this).info(`[${l}] connection ${T?"timed out":"failed"} - error; no more retries left`),(0,x.loggerFor)(this).debug(`[${l}] connection ${T?"timed out":"failed"} (error; no more retries left)`,(0,x.formatRequestDetails)({retryOfRequestLogID:n,url:f,durationMs:q-m,message:c.message})),T?new b.APIConnectionTimeoutError:new b.APIConnectionError({cause:c})}let D=`[${l}${v}] ${a.method} ${f} ${c.ok?"succeeded":"failed"} with status ${c.status} in ${q-m}ms`;if(!c.ok){let U=await this.shouldRetry(c);if(r&&U){let re=`retrying, ${r} attempts remaining`;return await mt.CancelReadableStream(c.body),(0,x.loggerFor)(this).info(`${D} - ${re}`),(0,x.loggerFor)(this).debug(`[${l}] response error (${re})`,(0,x.formatRequestDetails)({retryOfRequestLogID:n,url:c.url,status:c.status,headers:c.headers,durationMs:q-m})),this.retryRequest(s,r,n??l,c.headers)}let T=U?"error; no more retries left":"error; not retryable";(0,x.loggerFor)(this).info(`${D} - ${T}`);let Vt=await c.text().catch(re=>(0,zt.castToError)(re).message),Rt=(0,pt.safeJSON)(Vt),Zt=Rt?void 0:Vt;throw(0,x.loggerFor)(this).debug(`[${l}] response error (${T})`,(0,x.formatRequestDetails)({retryOfRequestLogID:n,url:c.url,status:c.status,headers:c.headers,message:Zt,durationMs:Date.now()-m})),this.makeStatusError(c.status,Rt,Zt,c.headers)}return(0,x.loggerFor)(this).info(D),(0,x.loggerFor)(this).debug(`[${l}] response start`,(0,x.formatRequestDetails)({retryOfRequestLogID:n,url:c.url,status:c.status,headers:c.headers,durationMs:q-m})),{response:c,options:s,controller:X,requestLogID:l,retryOfRequestLogID:n,startTime:m}}async fetchWithTimeout(t,r,n,s){let{signal:o,method:a,...f}=r||{};o&&o.addEventListener("abort",()=>s.abort());let z=setTimeout(()=>s.abort(),n),l=globalThis.ReadableStream&&f.body instanceof globalThis.ReadableStream||typeof f.body=="object"&&f.body!==null&&Symbol.asyncIterator in f.body,v={signal:s.signal,...l?{duplex:"half"}:{},method:"GET",...f};a&&(v.method=a.toUpperCase());try{return await this.fetch.call(void 0,t,v)}finally{clearTimeout(z)}}async shouldRetry(t){let r=t.headers.get("x-should-retry");return r==="true"?!0:r==="false"?!1:t.status===408||t.status===409||t.status===429||t.status>=500}async retryRequest(t,r,n,s){let o,a=s?.get("retry-after-ms");if(a){let z=parseFloat(a);Number.isNaN(z)||(o=z)}let f=s?.get("retry-after");if(f&&!o){let z=parseFloat(f);Number.isNaN(z)?o=Date.parse(f)-Date.now():o=z*1e3}if(!(o&&0<=o&&o<60*1e3)){let z=t.maxRetries??this.maxRetries;o=this.calculateDefaultRetryTimeoutMillis(r,z)}return await(0,fs.sleep)(o),this.makeRequest(t,r-1,n)}calculateDefaultRetryTimeoutMillis(t,r){let o=r-t,a=Math.min(.5*Math.pow(2,o),8),f=1-Math.random()*.25;return a*f*1e3}async buildRequest(t,{retryCount:r=0}={}){let n={...t},{method:s,path:o,query:a,defaultBaseURL:f}=n,z=this.buildURL(o,a,f);"timeout"in n&&(0,pt.validatePositiveInteger)("timeout",n.timeout),n.timeout=n.timeout??this.timeout;let{bodyHeaders:l,body:v}=this.buildBody({options:n}),m=await this.buildHeaders({options:t,method:s,bodyHeaders:l,retryCount:r});return{req:{method:s,headers:m,...n.signal&&{signal:n.signal},...globalThis.ReadableStream&&v instanceof globalThis.ReadableStream&&{duplex:"half"},...v&&{body:v},...this.fetchOptions??{},...n.fetchOptions??{}},url:z,timeout:n.timeout}}async buildHeaders({options:t,method:r,bodyHeaders:n,retryCount:s}){let o={};this.idempotencyHeader&&r!=="get"&&(t.idempotencyKey||(t.idempotencyKey=this.defaultIdempotencyKey()),o[this.idempotencyHeader]=t.idempotencyKey);let a=(0,bt.buildHeaders)([o,{Accept:"application/json","User-Agent":this.getUserAgent(),"X-Stainless-Retry-Count":String(s),...t.timeout?{"X-Stainless-Timeout":String(Math.trunc(t.timeout/1e3))}:{},...(0,cs.getPlatformHeaders)()},await this.authHeaders(t),this._options.defaultHeaders,n,t.headers]);return this.validateHeaders(a),a.values}buildBody({options:{body:t,headers:r}}){if(!t)return{bodyHeaders:void 0,body:void 0};let n=(0,bt.buildHeaders)([r]);return ArrayBuffer.isView(t)||t instanceof ArrayBuffer||t instanceof DataView||typeof t=="string"&&n.values.has("content-type")||globalThis.Blob&&t instanceof globalThis.Blob||t instanceof FormData||t instanceof URLSearchParams||globalThis.ReadableStream&&t instanceof globalThis.ReadableStream?{bodyHeaders:void 0,body:t}:typeof t=="object"&&(Symbol.asyncIterator in t||Symbol.iterator in t&&"next"in t&&typeof t.next=="function")?{bodyHeaders:void 0,body:mt.ReadableStreamFrom(t)}:L.__classPrivateFieldGet(this,Te,"f").call(this,{body:t,headers:n})}};Ne.Supermemory=p;Xt=p,Te=new WeakMap,xt=new WeakSet,nr=function(){return this.baseURL!=="https://api.supermemory.ai"};p.Supermemory=Xt;p.DEFAULT_TIMEOUT=6e4;p.SupermemoryError=b.SupermemoryError;p.APIError=b.APIError;p.APIConnectionError=b.APIConnectionError;p.APIConnectionTimeoutError=b.APIConnectionTimeoutError;p.APIUserAbortError=b.APIUserAbortError;p.NotFoundError=b.NotFoundError;p.ConflictError=b.ConflictError;p.RateLimitError=b.RateLimitError;p.BadRequestError=b.BadRequestError;p.AuthenticationError=b.AuthenticationError;p.InternalServerError=b.InternalServerError;p.PermissionDeniedError=b.PermissionDeniedError;p.UnprocessableEntityError=b.UnprocessableEntityError;p.toFile=ds.toFile;p.Memories=ps.Memories;p.Documents=Ps.Documents;p.Search=zs.Search;p.Settings=ms.Settings;p.Connections=ls.Connections});var or=d((i,sr)=>{"use strict";i=sr.exports=function(...e){return new i.default(...e)};Object.defineProperty(i,"__esModule",{value:!0});i.UnprocessableEntityError=i.PermissionDeniedError=i.InternalServerError=i.AuthenticationError=i.BadRequestError=i.RateLimitError=i.ConflictError=i.NotFoundError=i.APIUserAbortError=i.APIConnectionTimeoutError=i.APIConnectionError=i.APIError=i.SupermemoryError=i.Supermemory=i.APIPromise=i.toFile=i.default=void 0;var js=Ot();Object.defineProperty(i,"default",{enumerable:!0,get:function(){return js.Supermemory}});var xs=Be();Object.defineProperty(i,"toFile",{enumerable:!0,get:function(){return xs.toFile}});var Xs=Pt();Object.defineProperty(i,"APIPromise",{enumerable:!0,get:function(){return Xs.APIPromise}});var Os=Ot();Object.defineProperty(i,"Supermemory",{enumerable:!0,get:function(){return Os.Supermemory}});var y=K();Object.defineProperty(i,"SupermemoryError",{enumerable:!0,get:function(){return y.SupermemoryError}});Object.defineProperty(i,"APIError",{enumerable:!0,get:function(){return y.APIError}});Object.defineProperty(i,"APIConnectionError",{enumerable:!0,get:function(){return y.APIConnectionError}});Object.defineProperty(i,"APIConnectionTimeoutError",{enumerable:!0,get:function(){return y.APIConnectionTimeoutError}});Object.defineProperty(i,"APIUserAbortError",{enumerable:!0,get:function(){return y.APIUserAbortError}});Object.defineProperty(i,"NotFoundError",{enumerable:!0,get:function(){return y.NotFoundError}});Object.defineProperty(i,"ConflictError",{enumerable:!0,get:function(){return y.ConflictError}});Object.defineProperty(i,"RateLimitError",{enumerable:!0,get:function(){return y.RateLimitError}});Object.defineProperty(i,"BadRequestError",{enumerable:!0,get:function(){return y.BadRequestError}});Object.defineProperty(i,"AuthenticationError",{enumerable:!0,get:function(){return y.AuthenticationError}});Object.defineProperty(i,"InternalServerError",{enumerable:!0,get:function(){return y.InternalServerError}});Object.defineProperty(i,"PermissionDeniedError",{enumerable:!0,get:function(){return y.PermissionDeniedError}});Object.defineProperty(i,"UnprocessableEntityError",{enumerable:!0,get:function(){return y.UnprocessableEntityError}})});var fr={};Mr(fr,{getRequestIntegrity:()=>Ms,sanitizeContent:()=>hs,sanitizeMetadata:()=>Vs,validateApiKeyFormat:()=>ys,validateContainerTag:()=>Hs,validateContentLength:()=>Ws,validateRecallConfig:()=>Rs});function ys(e){return!e||typeof e!="string"?{valid:!1,reason:"key is empty or not a string"}:e.startsWith("sm_")?e.length<20?{valid:!1,reason:"key is too short"}:/\s/.test(e)?{valid:!1,reason:"key contains whitespace"}:{valid:!0}:{valid:!1,reason:"key must start with sm_ prefix"}}function Hs(e){return!e||typeof e!="string"?{valid:!1,reason:"tag is empty"}:e.length>100?{valid:!1,reason:"tag exceeds 100 characters"}:/^[a-zA-Z0-9_-]+$/.test(e)?/^[-_]|[-_]$/.test(e)?{valid:!1,reason:"tag must not start or end with - or _"}:{valid:!0}:{valid:!1,reason:"tag contains invalid characters (only alphanumeric, underscore, hyphen allowed)"}}function hs(e,t=1e5){if(!e||typeof e!="string")return"";let r=e;for(let n of qs)r=r.replace(n,"");return r.length>t&&(r=r.slice(0,t)),r}function Ws(e,t=1,r=1e5){return e.lengthr?{valid:!1,reason:`content exceeds maximum length (${r})`}:{valid:!0}}function Vs(e){let t={},r=0;for(let[n,s]of Object.entries(e)){if(r>=Ts)break;n.length>Ns||/[^\w.-]/.test(n)||(typeof s=="string"?(t[n]=s.slice(0,Ls),r++):(typeof s=="number"&&Number.isFinite(s)||typeof s=="boolean")&&(t[n]=s,r++))}return t}function Rs(e,t){let r=[];return(!Number.isInteger(e)||e<1||e>20)&&r.push("maxRecallResults must be an integer between 1 and 20"),(!Number.isInteger(t)||t<1||t>500)&&r.push("profileFrequency must be an integer between 1 and 500"),r}function yt(e){return(0,Le.createHash)("sha256").update(e).digest("hex")}function ws(e,t){let r=[yt(e),yt(t),ar].join(":");return(0,Le.createHmac)("sha256",Zs).update(r).digest("base64url")}function Ms(e,t){let r=yt(t),n=ws(e,t);return{"X-Content-Hash":r,"X-Request-Integrity":[`v${ar}`,n].join(".")}}var Le,qs,Ts,Ns,Ls,ar,Zs,cr=wr(()=>{Le=require("node:crypto");qs=[/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F]/g,/\uFEFF/g,/[\uFFF0-\uFFFF]/g];Ts=50,Ns=128,Ls=1024;ar=1,Zs="7f2a9c4b8e1d6f3a5c0b9d8e7f6a5b4c3d2e1f0a9b8c7d6e5f4a3b2c1d0e9f8a"});var ur=d((sa,ir)=>{var gs=or().default,{getRequestIntegrity:Fs,validateApiKeyFormat:Ds,validateContainerTag:Us}=(cr(),Fr(fr)),Ys="claudecode_default",Ss=process.env.SUPERMEMORY_API_URL||"https://api.supermemory.ai";function Gs(e,t=r=>r){let r=new Set;return e.filter(n=>{let s=String(t(n)).toLowerCase().trim();return!s||r.has(s)?!1:(r.add(s),!0)})}var Ks=`Developer coding session transcript. Focus on USER message and intent. RULES: - Extract USER's action/intent, not every detail assistant provides matter @@ -30,7 +30,7 @@ EXAMPLES: SKIP: - Every fact assistant mentions (condense to user's action) -- Generic assistant explanations user didn't confirm/use`,Gs=`Project/codebase knowledge for team sharing. +- Generic assistant explanations user didn't confirm/use`,ks=`Project/codebase knowledge for team sharing. EXTRACT: - Architecture: "uses monorepo with turborepo", "API in /apps/api" @@ -43,7 +43,7 @@ EXAMPLES: | Input | Memory | | "The auth flow works by..." | "Auth flow: [description]" | | "We structure components like..." | "Component structure convention: [pattern]" | -| "To add a new API route..." | "Adding API routes: [steps]" |`,Ht=class{constructor(t,r){if(!t)throw new Error("SUPERMEMORY_CC_API_KEY is required");let n=gs(t);if(!n.valid)throw new Error(`Invalid API key: ${n.reason}`);let s=r||Ds,o=Fs(s);o.valid||console.warn(`Container tag warning: ${o.reason}`);let a=Ms(t,s);this.client=new ws({apiKey:t,baseURL:Ys,defaultHeaders:a}),this.containerTag=s}async addMemory(t,r,n={},s={}){let o={content:t,containerTag:r||this.containerTag,metadata:{sm_source:"claude-code-plugin",...n}};s.customId&&(o.customId=s.customId),s.entityContext&&(o.entityContext=s.entityContext);let a=await this.client.add(o);return{id:a.id,status:a.status,containerTag:r||this.containerTag}}async search(t,r,n={}){let s=await this.client.search.memories({q:t,containerTag:r||this.containerTag,limit:n.limit||10,searchMode:n.searchMode||"hybrid"}),o=s.results.map(a=>({memory:a.content||a.memory||a.context||"",chunk:a.chunk,metadata:a.metadata,updatedAt:a.updatedAt,similarity:a.similarity}));return{results:Us(o,a=>a.memory),total:s.total,timing:s.timing}}async getProfile(t,r){let n=await this.client.profile({containerTag:t||this.containerTag,q:r}),s=new Set,o=(l,v=m=>m)=>l.filter(m=>{let X=String(v(m)).toLowerCase().trim();return!X||s.has(X)?!1:(s.add(X),!0)}),a=o(n.profile?.static||[]),f=o(n.profile?.dynamic||[]),z;if(n.searchResults){let l=n.searchResults.results.map(v=>({id:v.id,memory:v.content||v.context||"",similarity:v.similarity,title:v.title,updatedAt:v.updatedAt}));z={results:o(l,v=>v.memory),total:n.searchResults.total,timing:n.searchResults.timing}}return{profile:{static:a,dynamic:f},searchResults:z}}};cr.exports={SupermemoryClient:Ht,PERSONAL_ENTITY_CONTEXT:Ss,REPO_ENTITY_CONTEXT:Gs}});var qt=d((sa,pr)=>{var $=require("node:fs"),Ve=require("node:path"),{execSync:Ks}=require("node:child_process"),ur=Ve.join(".claude",".supermemory-claude"),dr="config.json";function vr(e){try{return Ks("git rev-parse --show-toplevel",{cwd:e,encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()||null}catch{return null}}function lr(e){let r=vr(e)||e;return Ve.join(r,ur,dr)}function Pr(e){try{let t=lr(e);if($.existsSync(t))return JSON.parse($.readFileSync(t,"utf-8"))}catch{}return null}function ks(e,t){let n=vr(e)||e,s=Ve.join(n,ur),o=Ve.join(s,dr);$.existsSync(s)||$.mkdirSync(s,{recursive:!0});let f={...Pr(e)||{},...t};return $.writeFileSync(o,JSON.stringify(f,null,2)),o}pr.exports={getConfigPath:lr,loadProjectConfig:Pr,saveProjectConfig:ks}});var jr=d((oa,br)=>{var{execSync:Es}=require("node:child_process"),Is=require("node:crypto"),{loadProjectConfig:zr}=qt();function mr(e){return Is.createHash("sha256").update(e).digest("hex").slice(0,16)}function Re(e){try{return Es("git rev-parse --show-toplevel",{cwd:e,encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()||null}catch{return null}}function Cs(e){let t=zr(e);if(t?.personalContainerTag)return t.personalContainerTag;let n=Re(e)||e;return`claudecode_project_${mr(n)}`}function Js(e){return e.toLowerCase().replace(/[^a-z0-9]/g,"_").replace(/_+/g,"_").replace(/^_|_$/g,"")}function Bs(e){let t=zr(e);if(t?.repoContainerTag)return t.repoContainerTag;let s=(Re(e)||e).split("/").pop()||"unknown";return`repo_${Js(s)}`}function As(e){return(Re(e)||e).split("/").pop()||"unknown"}br.exports={sha256:mr,getGitRoot:Re,getContainerTag:Cs,getRepoContainerTag:Bs,getProjectName:As}});var xr=d((aa,Qs)=>{Qs.exports=` +| "To add a new API route..." | "Adding API routes: [steps]" |`,Ht=class{constructor(t,r){if(!t)throw new Error("SUPERMEMORY_CC_API_KEY is required");let n=Ds(t);if(!n.valid)throw new Error(`Invalid API key: ${n.reason}`);let s=r||Ys,o=Us(s);o.valid||console.warn(`Container tag warning: ${o.reason}`);let a=Fs(t,s);this.client=new gs({apiKey:t,baseURL:Ss,defaultHeaders:a}),this.containerTag=s}async addMemory(t,r,n={},s={}){let o={content:t,containerTag:r||this.containerTag,metadata:{sm_source:"claude-code-plugin",...n}};s.customId&&(o.customId=s.customId),s.entityContext&&(o.entityContext=s.entityContext);let a=await this.client.add(o);return{id:a.id,status:a.status,containerTag:r||this.containerTag}}async search(t,r,n={}){let s=await this.client.search.memories({q:t,containerTag:r||this.containerTag,limit:n.limit||10,searchMode:n.searchMode||"hybrid"}),o=s.results.map(a=>({memory:a.content||a.memory||a.context||"",chunk:a.chunk,metadata:a.metadata,updatedAt:a.updatedAt,similarity:a.similarity}));return{results:Gs(o,a=>a.memory),total:s.total,timing:s.timing}}async getProfile(t,r){let n=await this.client.profile({containerTag:t||this.containerTag,q:r}),s=new Set,o=(l,v=m=>m)=>l.filter(m=>{let X=String(v(m)).toLowerCase().trim();return!X||s.has(X)?!1:(s.add(X),!0)}),a=o(n.profile?.static||[]),f=o(n.profile?.dynamic||[]),z;if(n.searchResults){let l=n.searchResults.results.map(v=>({id:v.id,memory:v.content||v.context||"",similarity:v.similarity,title:v.title,updatedAt:v.updatedAt}));z={results:o(l,v=>v.memory),total:n.searchResults.total,timing:n.searchResults.timing}}return{profile:{static:a,dynamic:f},searchResults:z}}};ir.exports={SupermemoryClient:Ht,PERSONAL_ENTITY_CONTEXT:Ks,REPO_ENTITY_CONTEXT:ks}});var qt=d((oa,zr)=>{var $=require("node:fs"),Ve=require("node:path"),{execSync:Es}=require("node:child_process"),dr=Ve.join(".claude",".supermemory-claude"),vr="config.json";function lr(e){try{return Es("git rev-parse --show-toplevel",{cwd:e,encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()||null}catch{return null}}function Pr(e){let r=lr(e)||e;return Ve.join(r,dr,vr)}function pr(e){try{let t=Pr(e);if($.existsSync(t))return JSON.parse($.readFileSync(t,"utf-8"))}catch{}return null}function Is(e,t){let n=lr(e)||e,s=Ve.join(n,dr),o=Ve.join(s,vr);$.existsSync(s)||$.mkdirSync(s,{recursive:!0});let f={...pr(e)||{},...t};return $.writeFileSync(o,JSON.stringify(f,null,2)),o}zr.exports={getConfigPath:Pr,loadProjectConfig:pr,saveProjectConfig:Is}});var Xr=d((aa,xr)=>{var{execSync:mr}=require("node:child_process"),Cs=require("node:crypto"),{loadProjectConfig:br}=qt();function jr(e){return Cs.createHash("sha256").update(e).digest("hex").slice(0,16)}function Re(e){try{return mr("git rev-parse --show-toplevel",{cwd:e,encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()||null}catch{return null}}function ht(e){try{let r=mr("git remote get-url origin",{cwd:e,encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim().match(/[/:]([^/]+?)(?:\.git)?$/);return r?r[1]:null}catch{return null}}function Js(e){let t=br(e);if(t?.personalContainerTag)return t.personalContainerTag;let n=Re(e)||e;return`claudecode_project_${jr(n)}`}function Bs(e){return e.toLowerCase().replace(/[^a-z0-9]/g,"_").replace(/_+/g,"_").replace(/^_|_$/g,"")}function As(e){let t=br(e);if(t?.repoContainerTag)return t.repoContainerTag;let n=Re(e)||e,o=ht(n)||n.split("/").pop()||"unknown";return`repo_${Bs(o)}`}function Qs(e){let r=Re(e)||e;return ht(r)||r.split("/").pop()||"unknown"}xr.exports={sha256:jr,getGitRoot:Re,getGitRepoName:ht,getContainerTag:Js,getRepoContainerTag:As,getProjectName:Qs}});var Or=d((fa,_s)=>{_s.exports=` Connected - Supermemory