@hasna/mementos 0.1.2 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dashboard/dist/assets/{index-C5oRjtKB.js → index-DqyMbv89.js} +20 -20
- package/dashboard/dist/assets/index-UBCddFo_.css +1 -0
- package/dashboard/dist/index.html +2 -2
- package/dist/cli/index.js +316 -15
- package/dist/db/memories.d.ts +1 -0
- package/dist/db/memories.d.ts.map +1 -1
- package/dist/lib/project-detect.d.ts +18 -0
- package/dist/lib/project-detect.d.ts.map +1 -0
- package/dist/mcp/index.js +237 -17
- package/dist/server/index.d.ts.map +1 -1
- package/dist/server/index.js +36 -0
- package/package.json +1 -1
- package/dashboard/dist/assets/index-C8vbNL_5.css +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
/*! tailwindcss v4.2.1 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-500:oklch(63.7% .237 25.331);--color-orange-500:oklch(70.5% .213 47.604);--color-amber-400:oklch(82.8% .189 84.429);--color-amber-500:oklch(76.9% .188 70.08);--color-amber-600:oklch(66.6% .179 58.318);--color-amber-700:oklch(55.5% .163 48.998);--color-yellow-400:oklch(85.2% .199 91.936);--color-yellow-500:oklch(79.5% .184 86.047);--color-green-400:oklch(79.2% .209 151.711);--color-green-500:oklch(72.3% .219 149.579);--color-teal-400:oklch(77.7% .152 181.912);--color-teal-500:oklch(70.4% .14 182.503);--color-blue-400:oklch(70.7% .165 254.624);--color-blue-500:oklch(62.3% .214 259.815);--color-purple-400:oklch(71.4% .203 305.504);--color-purple-500:oklch(62.7% .265 303.9);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-7xl:80rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}*{border-color:var(--border)}body{background-color:var(--background);color:var(--foreground);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}}@layer components;@layer utilities{.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.relative{position:relative}.end{inset-inline-end:var(--spacing)}.top-2\.5{top:calc(var(--spacing) * 2.5)}.right-2{right:calc(var(--spacing) * 2)}.right-2\.5{right:calc(var(--spacing) * 2.5)}.left-2{left:calc(var(--spacing) * 2)}.left-2\.5{left:calc(var(--spacing) * 2.5)}.z-10{z-index:10}.z-50{z-index:50}.-mx-1{margin-inline:calc(var(--spacing) * -1)}.mx-auto{margin-inline:auto}.my-1{margin-block:calc(var(--spacing) * 1)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mr-2{margin-right:calc(var(--spacing) * 2)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.-ml-2{margin-left:calc(var(--spacing) * -2)}.-ml-3{margin-left:calc(var(--spacing) * -3)}.ml-4{margin-left:calc(var(--spacing) * 4)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.inline-flex{display:inline-flex}.table{display:table}.size-3{width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.size-3\.5{width:calc(var(--spacing) * 3.5);height:calc(var(--spacing) * 3.5)}.size-4{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.size-5{width:calc(var(--spacing) * 5);height:calc(var(--spacing) * 5)}.size-8{width:calc(var(--spacing) * 8);height:calc(var(--spacing) * 8)}.size-10{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.h-2{height:calc(var(--spacing) * 2)}.h-3\.5{height:calc(var(--spacing) * 3.5)}.h-4{height:calc(var(--spacing) * 4)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-24{height:calc(var(--spacing) * 24)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.h-px{height:1px}.max-h-96{max-height:calc(var(--spacing) * 96)}.min-h-screen{min-height:100vh}.w-3\.5{width:calc(var(--spacing) * 3.5)}.w-4{width:calc(var(--spacing) * 4)}.w-7{width:calc(var(--spacing) * 7)}.w-9{width:calc(var(--spacing) * 9)}.w-\[130px\]{width:130px}.w-\[140px\]{width:140px}.w-\[150px\]{width:150px}.w-full{width:100%}.w-max{width:max-content}.max-w-7xl{max-width:var(--container-7xl)}.max-w-\[120px\]{max-width:120px}.max-w-\[200px\]{max-width:200px}.max-w-\[250px\]{max-width:250px}.max-w-\[300px\]{max-width:300px}.max-w-max{max-width:max-content}.max-w-none{max-width:none}.max-w-sm{max-width:var(--container-sm)}.min-w-\[8rem\]{min-width:8rem}.min-w-\[200px\]{min-width:200px}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.flex-1{flex:1}.shrink-0{flex-shrink:0}.caption-bottom{caption-side:bottom}.translate-y-1{--tw-translate-y:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.scale-0{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-100{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y)}.rotate-0{rotate:none}.rotate-90{rotate:90deg}.animate-in{animation:.2s ease-out enter}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.list-none{list-style-type:none}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}:where(.space-y-0>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 0) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 0) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:calc(var(--radius) + 4px)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l-2{border-left-style:var(--tw-border-style);border-left-width:2px}.border-amber-500\/30{border-color:#f99c004d}@supports (color:color-mix(in lab,red,red)){.border-amber-500\/30{border-color:color-mix(in oklab,var(--color-amber-500) 30%,transparent)}}.border-blue-500\/30{border-color:#3080ff4d}@supports (color:color-mix(in lab,red,red)){.border-blue-500\/30{border-color:color-mix(in oklab,var(--color-blue-500) 30%,transparent)}}.border-border{border-color:var(--border)}.border-gray-500\/30{border-color:#6a72824d}@supports (color:color-mix(in lab,red,red)){.border-gray-500\/30{border-color:color-mix(in oklab,var(--color-gray-500) 30%,transparent)}}.border-green-500\/30{border-color:#00c7584d}@supports (color:color-mix(in lab,red,red)){.border-green-500\/30{border-color:color-mix(in oklab,var(--color-green-500) 30%,transparent)}}.border-input{border-color:var(--input)}.border-purple-500\/30{border-color:#ac4bff4d}@supports (color:color-mix(in lab,red,red)){.border-purple-500\/30{border-color:color-mix(in oklab,var(--color-purple-500) 30%,transparent)}}.border-teal-500\/30{border-color:#00baa74d}@supports (color:color-mix(in lab,red,red)){.border-teal-500\/30{border-color:color-mix(in oklab,var(--color-teal-500) 30%,transparent)}}.border-transparent{border-color:#0000}.border-yellow-500\/30{border-color:#edb2004d}@supports (color:color-mix(in lab,red,red)){.border-yellow-500\/30{border-color:color-mix(in oklab,var(--color-yellow-500) 30%,transparent)}}.border-l-amber-500{border-left-color:var(--color-amber-500)}.bg-amber-500\/5{background-color:#f99c000d}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/5{background-color:color-mix(in oklab,var(--color-amber-500) 5%,transparent)}}.bg-amber-500\/10{background-color:#f99c001a}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/10{background-color:color-mix(in oklab,var(--color-amber-500) 10%,transparent)}}.bg-amber-500\/15{background-color:#f99c0026}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/15{background-color:color-mix(in oklab,var(--color-amber-500) 15%,transparent)}}.bg-amber-600{background-color:var(--color-amber-600)}.bg-background{background-color:var(--background)}.bg-blue-500\/10{background-color:#3080ff1a}@supports (color:color-mix(in lab,red,red)){.bg-blue-500\/10{background-color:color-mix(in oklab,var(--color-blue-500) 10%,transparent)}}.bg-blue-500\/15{background-color:#3080ff26}@supports (color:color-mix(in lab,red,red)){.bg-blue-500\/15{background-color:color-mix(in oklab,var(--color-blue-500) 15%,transparent)}}.bg-card{background-color:var(--card)}.bg-destructive{background-color:var(--destructive)}.bg-gray-500\/10{background-color:#6a72821a}@supports (color:color-mix(in lab,red,red)){.bg-gray-500\/10{background-color:color-mix(in oklab,var(--color-gray-500) 10%,transparent)}}.bg-gray-500\/15{background-color:#6a728226}@supports (color:color-mix(in lab,red,red)){.bg-gray-500\/15{background-color:color-mix(in oklab,var(--color-gray-500) 15%,transparent)}}.bg-green-500\/10{background-color:#00c7581a}@supports (color:color-mix(in lab,red,red)){.bg-green-500\/10{background-color:color-mix(in oklab,var(--color-green-500) 10%,transparent)}}.bg-green-500\/15{background-color:#00c75826}@supports (color:color-mix(in lab,red,red)){.bg-green-500\/15{background-color:color-mix(in oklab,var(--color-green-500) 15%,transparent)}}.bg-muted,.bg-muted\/30{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/30{background-color:color-mix(in oklab,var(--muted) 30%,transparent)}}.bg-muted\/50{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/50{background-color:color-mix(in oklab,var(--muted) 50%,transparent)}}.bg-popover{background-color:var(--popover)}.bg-primary{background-color:var(--primary)}.bg-purple-500\/10{background-color:#ac4bff1a}@supports (color:color-mix(in lab,red,red)){.bg-purple-500\/10{background-color:color-mix(in oklab,var(--color-purple-500) 10%,transparent)}}.bg-purple-500\/15{background-color:#ac4bff26}@supports (color:color-mix(in lab,red,red)){.bg-purple-500\/15{background-color:color-mix(in oklab,var(--color-purple-500) 15%,transparent)}}.bg-secondary{background-color:var(--secondary)}.bg-teal-500\/10{background-color:#00baa71a}@supports (color:color-mix(in lab,red,red)){.bg-teal-500\/10{background-color:color-mix(in oklab,var(--color-teal-500) 10%,transparent)}}.bg-teal-500\/15{background-color:#00baa726}@supports (color:color-mix(in lab,red,red)){.bg-teal-500\/15{background-color:color-mix(in oklab,var(--color-teal-500) 15%,transparent)}}.bg-transparent{background-color:#0000}.bg-yellow-500\/10{background-color:#edb2001a}@supports (color:color-mix(in lab,red,red)){.bg-yellow-500\/10{background-color:color-mix(in oklab,var(--color-yellow-500) 10%,transparent)}}.bg-yellow-500\/15{background-color:#edb20026}@supports (color:color-mix(in lab,red,red)){.bg-yellow-500\/15{background-color:color-mix(in oklab,var(--color-yellow-500) 15%,transparent)}}.p-1{padding:calc(var(--spacing) * 1)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-8{padding-inline:calc(var(--spacing) * 8)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-12{padding-block:calc(var(--spacing) * 12)}.pt-0{padding-top:calc(var(--spacing) * 0)}.pr-2{padding-right:calc(var(--spacing) * 2)}.pr-8{padding-right:calc(var(--spacing) * 8)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-3{padding-bottom:calc(var(--spacing) * 3)}.pl-2{padding-left:calc(var(--spacing) * 2)}.pl-8{padding-left:calc(var(--spacing) * 8)}.text-center{text-align:center}.text-left{text-align:left}.align-middle{vertical-align:middle}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-none{--tw-leading:1;line-height:1}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.break-words{overflow-wrap:break-word}.whitespace-nowrap{white-space:nowrap}.text-amber-400{color:var(--color-amber-400)}.text-amber-500{color:var(--color-amber-500)}.text-blue-400{color:var(--color-blue-400)}.text-blue-500{color:var(--color-blue-500)}.text-card-foreground{color:var(--card-foreground)}.text-foreground{color:var(--foreground)}.text-gray-400{color:var(--color-gray-400)}.text-green-400{color:var(--color-green-400)}.text-green-500{color:var(--color-green-500)}.text-muted-foreground,.text-muted-foreground\/50{color:var(--muted-foreground)}@supports (color:color-mix(in lab,red,red)){.text-muted-foreground\/50{color:color-mix(in oklab,var(--muted-foreground) 50%,transparent)}}.text-orange-500{color:var(--color-orange-500)}.text-popover-foreground{color:var(--popover-foreground)}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-purple-400{color:var(--color-purple-400)}.text-purple-500{color:var(--color-purple-500)}.text-red-500{color:var(--color-red-500)}.text-secondary-foreground{color:var(--secondary-foreground)}.text-teal-400{color:var(--color-teal-400)}.text-teal-500{color:var(--color-teal-500)}.text-white{color:var(--color-white)}.text-yellow-400{color:var(--color-yellow-400)}.text-yellow-500{color:var(--color-yellow-500)}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.opacity-50{opacity:.5}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-none{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-offset-background{--tw-ring-offset-color:var(--background)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.file\:text-foreground::file-selector-button{color:var(--foreground)}.placeholder\:text-muted-foreground::placeholder{color:var(--muted-foreground)}@media(hover:hover){.hover\:bg-accent:hover{background-color:var(--accent)}.hover\:bg-amber-700:hover{background-color:var(--color-amber-700)}.hover\:bg-background\/50:hover{background-color:var(--background)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-background\/50:hover{background-color:color-mix(in oklab,var(--background) 50%,transparent)}}.hover\:bg-destructive\/90:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,var(--destructive) 90%,transparent)}}.hover\:bg-muted\/50:hover{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-muted\/50:hover{background-color:color-mix(in oklab,var(--muted) 50%,transparent)}}.hover\:bg-primary\/90:hover{background-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab,var(--primary) 90%,transparent)}}.hover\:bg-secondary\/80:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab,var(--secondary) 80%,transparent)}}.hover\:text-accent-foreground:hover{color:var(--accent-foreground)}.hover\:text-foreground:hover{color:var(--foreground)}.hover\:underline:hover{text-decoration-line:underline}}.focus\:bg-accent:focus{background-color:var(--accent)}.focus\:text-accent-foreground:focus{color:var(--accent-foreground)}.focus\:ring-1:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-ring:focus{--tw-ring-color:var(--ring)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:ring-1:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:var(--ring)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.data-\[active\]\:bg-accent\/50[data-active]{background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.data-\[active\]\:bg-accent\/50[data-active]{background-color:color-mix(in oklab,var(--accent) 50%,transparent)}}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=open\]\:bg-accent\/50[data-state=open]{background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.data-\[state\=open\]\:bg-accent\/50[data-state=open]{background-color:color-mix(in oklab,var(--accent) 50%,transparent)}}.data-\[state\=selected\]\:bg-muted[data-state=selected]{background-color:var(--muted)}@media(min-width:40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}@media(min-width:48rem){.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}}@media(prefers-color-scheme:dark){.dark\:scale-0{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y)}.dark\:scale-100{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y)}.dark\:-rotate-90{rotate:-90deg}.dark\:rotate-0{rotate:none}.dark\:bg-input\/30{background-color:var(--input)}@supports (color:color-mix(in lab,red,red)){.dark\:bg-input\/30{background-color:color-mix(in oklab,var(--input) 30%,transparent)}}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_tr\]\:border-b tr{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.\[\&_tr\:last-child\]\:border-0 tr:last-child{border-style:var(--tw-border-style);border-width:0}.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){padding-right:calc(var(--spacing) * 0)}.\[\&\>\[role\=checkbox\]\]\:translate-y-\[2px\]>[role=checkbox]{--tw-translate-y:2px;translate:var(--tw-translate-x) var(--tw-translate-y)}.\[\&\>span\]\:line-clamp-1>span{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.\[\&\>svg\]\:size-4>svg{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\&\>svg\]\:shrink-0>svg{flex-shrink:0}.\[\&\>tr\]\:last\:border-b-0>tr:last-child{border-bottom-style:var(--tw-border-style);border-bottom-width:0}}@keyframes enter{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes exit{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}:root{--radius:.625rem;--background:oklch(100% 0 0);--foreground:oklch(14.5% 0 0);--card:oklch(100% 0 0);--card-foreground:oklch(14.5% 0 0);--popover:oklch(100% 0 0);--popover-foreground:oklch(14.5% 0 0);--primary:oklch(20.5% 0 0);--primary-foreground:oklch(98.5% 0 0);--secondary:oklch(96.5% 0 0);--secondary-foreground:oklch(20.5% 0 0);--muted:oklch(96.5% 0 0);--muted-foreground:oklch(55.6% 0 0);--accent:oklch(96.5% 0 0);--accent-foreground:oklch(20.5% 0 0);--destructive:oklch(57.7% .245 27.325);--border:oklch(92.1% 0 0);--input:oklch(92.1% 0 0);--ring:oklch(70.8% 0 0)}.dark{--background:oklch(14.5% 0 0);--foreground:oklch(98.5% 0 0);--card:oklch(17.5% 0 0);--card-foreground:oklch(98.5% 0 0);--popover:oklch(17.5% 0 0);--popover-foreground:oklch(98.5% 0 0);--primary:oklch(98.5% 0 0);--primary-foreground:oklch(20.5% 0 0);--secondary:oklch(26.9% 0 0);--secondary-foreground:oklch(98.5% 0 0);--muted:oklch(26.9% 0 0);--muted-foreground:oklch(70.8% 0 0);--accent:oklch(26.9% 0 0);--accent-foreground:oklch(98.5% 0 0);--destructive:oklch(39.6% .141 25.723);--border:oklch(26.9% 0 0);--input:oklch(26.9% 0 0);--ring:oklch(43.9% 0 0)}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}
|
|
@@ -4,8 +4,8 @@
|
|
|
4
4
|
<meta charset="UTF-8" />
|
|
5
5
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
6
6
|
<title>Mementos Dashboard</title>
|
|
7
|
-
<script type="module" crossorigin src="/assets/index-
|
|
8
|
-
<link rel="stylesheet" crossorigin href="/assets/index-
|
|
7
|
+
<script type="module" crossorigin src="/assets/index-DqyMbv89.js"></script>
|
|
8
|
+
<link rel="stylesheet" crossorigin href="/assets/index-UBCddFo_.css">
|
|
9
9
|
</head>
|
|
10
10
|
<body>
|
|
11
11
|
<div id="root"></div>
|
package/dist/cli/index.js
CHANGED
|
@@ -2737,7 +2737,7 @@ var {
|
|
|
2737
2737
|
init_database();
|
|
2738
2738
|
init_memories();
|
|
2739
2739
|
import chalk from "chalk";
|
|
2740
|
-
import { readFileSync as readFileSync2 } from "fs";
|
|
2740
|
+
import { readFileSync as readFileSync2, existsSync as existsSync3, accessSync, constants as fsConstants } from "fs";
|
|
2741
2741
|
import { dirname as dirname3, join as join3, resolve as resolve3 } from "path";
|
|
2742
2742
|
import { fileURLToPath } from "url";
|
|
2743
2743
|
|
|
@@ -3150,6 +3150,94 @@ function runCleanup(config, db) {
|
|
|
3150
3150
|
return { expired, evicted, archived };
|
|
3151
3151
|
}
|
|
3152
3152
|
|
|
3153
|
+
// src/lib/injector.ts
|
|
3154
|
+
init_memories();
|
|
3155
|
+
class MemoryInjector {
|
|
3156
|
+
config;
|
|
3157
|
+
injectedIds = new Set;
|
|
3158
|
+
constructor(config) {
|
|
3159
|
+
this.config = config || loadConfig();
|
|
3160
|
+
}
|
|
3161
|
+
getInjectionContext(options = {}) {
|
|
3162
|
+
const maxTokens = options.max_tokens || this.config.injection.max_tokens;
|
|
3163
|
+
const minImportance = options.min_importance || this.config.injection.min_importance;
|
|
3164
|
+
const categories = options.categories || this.config.injection.categories;
|
|
3165
|
+
const db = options.db;
|
|
3166
|
+
const allMemories = [];
|
|
3167
|
+
const globalMems = listMemories({
|
|
3168
|
+
scope: "global",
|
|
3169
|
+
category: categories,
|
|
3170
|
+
min_importance: minImportance,
|
|
3171
|
+
status: "active",
|
|
3172
|
+
limit: 100
|
|
3173
|
+
}, db);
|
|
3174
|
+
allMemories.push(...globalMems);
|
|
3175
|
+
if (options.project_id) {
|
|
3176
|
+
const sharedMems = listMemories({
|
|
3177
|
+
scope: "shared",
|
|
3178
|
+
category: categories,
|
|
3179
|
+
min_importance: minImportance,
|
|
3180
|
+
status: "active",
|
|
3181
|
+
project_id: options.project_id,
|
|
3182
|
+
limit: 100
|
|
3183
|
+
}, db);
|
|
3184
|
+
allMemories.push(...sharedMems);
|
|
3185
|
+
}
|
|
3186
|
+
if (options.agent_id) {
|
|
3187
|
+
const privateMems = listMemories({
|
|
3188
|
+
scope: "private",
|
|
3189
|
+
category: categories,
|
|
3190
|
+
min_importance: minImportance,
|
|
3191
|
+
status: "active",
|
|
3192
|
+
agent_id: options.agent_id,
|
|
3193
|
+
limit: 100
|
|
3194
|
+
}, db);
|
|
3195
|
+
allMemories.push(...privateMems);
|
|
3196
|
+
}
|
|
3197
|
+
const seen = new Set;
|
|
3198
|
+
const unique = allMemories.filter((m) => {
|
|
3199
|
+
if (seen.has(m.id))
|
|
3200
|
+
return false;
|
|
3201
|
+
seen.add(m.id);
|
|
3202
|
+
return true;
|
|
3203
|
+
});
|
|
3204
|
+
unique.sort((a, b) => {
|
|
3205
|
+
if (a.pinned !== b.pinned)
|
|
3206
|
+
return a.pinned ? -1 : 1;
|
|
3207
|
+
if (b.importance !== a.importance)
|
|
3208
|
+
return b.importance - a.importance;
|
|
3209
|
+
return new Date(b.updated_at).getTime() - new Date(a.updated_at).getTime();
|
|
3210
|
+
});
|
|
3211
|
+
const charBudget = maxTokens * 4;
|
|
3212
|
+
const lines = [];
|
|
3213
|
+
let totalChars = 0;
|
|
3214
|
+
for (const m of unique) {
|
|
3215
|
+
if (this.injectedIds.has(m.id))
|
|
3216
|
+
continue;
|
|
3217
|
+
const line = `- [${m.scope}/${m.category}] ${m.key}: ${m.value}`;
|
|
3218
|
+
if (totalChars + line.length > charBudget)
|
|
3219
|
+
break;
|
|
3220
|
+
lines.push(line);
|
|
3221
|
+
totalChars += line.length;
|
|
3222
|
+
this.injectedIds.add(m.id);
|
|
3223
|
+
touchMemory(m.id, db);
|
|
3224
|
+
}
|
|
3225
|
+
if (lines.length === 0) {
|
|
3226
|
+
return "";
|
|
3227
|
+
}
|
|
3228
|
+
return `<agent-memories>
|
|
3229
|
+
${lines.join(`
|
|
3230
|
+
`)}
|
|
3231
|
+
</agent-memories>`;
|
|
3232
|
+
}
|
|
3233
|
+
resetDedup() {
|
|
3234
|
+
this.injectedIds.clear();
|
|
3235
|
+
}
|
|
3236
|
+
getInjectedCount() {
|
|
3237
|
+
return this.injectedIds.size;
|
|
3238
|
+
}
|
|
3239
|
+
}
|
|
3240
|
+
|
|
3153
3241
|
// src/cli/index.tsx
|
|
3154
3242
|
function getPackageVersion() {
|
|
3155
3243
|
try {
|
|
@@ -3254,16 +3342,53 @@ function resolveMemoryId(partialId) {
|
|
|
3254
3342
|
return id;
|
|
3255
3343
|
}
|
|
3256
3344
|
program2.name("mementos").description("Universal memory system for AI agents").version(getPackageVersion()).option("--project <path>", "Project path for scoping").option("--json", "Output as JSON").option("--agent <name>", "Agent name or ID").option("--session <id>", "Session ID");
|
|
3257
|
-
program2.command("save <key> <value>").description("Save a memory (create or upsert)").option("-c, --category <cat>", "Category: preference, fact, knowledge, history").option("-s, --scope <scope>", "Scope: global, shared, private").option("--importance <n>", "Importance 1-10", parseInt).option("--tags <tags>", "Comma-separated tags").option("--summary <text>", "Brief summary").option("--ttl <ms>", "Time-to-live in milliseconds", parseInt).option("--source <src>", "Source: user, agent, system, auto, imported").action((key, value, opts) => {
|
|
3345
|
+
program2.command("save <key> <value>").description("Save a memory (create or upsert)").option("-c, --category <cat>", "Category: preference, fact, knowledge, history").option("-s, --scope <scope>", "Scope: global, shared, private").option("--importance <n>", "Importance 1-10", parseInt).option("--tags <tags>", "Comma-separated tags").option("--summary <text>", "Brief summary").option("--ttl <ms>", "Time-to-live in milliseconds", parseInt).option("--source <src>", "Source: user, agent, system, auto, imported").option("--template <name>", "Apply a template: correction, preference, decision, learning").action((key, value, opts) => {
|
|
3258
3346
|
try {
|
|
3259
3347
|
const globalOpts = program2.opts();
|
|
3348
|
+
const templates = {
|
|
3349
|
+
correction: {
|
|
3350
|
+
scope: "shared",
|
|
3351
|
+
category: "knowledge",
|
|
3352
|
+
importance: 9,
|
|
3353
|
+
tags: ["correction"]
|
|
3354
|
+
},
|
|
3355
|
+
preference: {
|
|
3356
|
+
scope: "global",
|
|
3357
|
+
category: "preference",
|
|
3358
|
+
importance: 8,
|
|
3359
|
+
tags: []
|
|
3360
|
+
},
|
|
3361
|
+
decision: {
|
|
3362
|
+
scope: "shared",
|
|
3363
|
+
category: "fact",
|
|
3364
|
+
importance: 8,
|
|
3365
|
+
tags: ["decision"]
|
|
3366
|
+
},
|
|
3367
|
+
learning: {
|
|
3368
|
+
scope: "shared",
|
|
3369
|
+
category: "knowledge",
|
|
3370
|
+
importance: 7,
|
|
3371
|
+
tags: ["learning"]
|
|
3372
|
+
}
|
|
3373
|
+
};
|
|
3374
|
+
let templateDefaults;
|
|
3375
|
+
if (opts.template) {
|
|
3376
|
+
const tpl = templates[opts.template];
|
|
3377
|
+
if (!tpl) {
|
|
3378
|
+
console.error(chalk.red(`Unknown template: ${opts.template}. Valid templates: ${Object.keys(templates).join(", ")}`));
|
|
3379
|
+
process.exit(1);
|
|
3380
|
+
}
|
|
3381
|
+
templateDefaults = tpl;
|
|
3382
|
+
}
|
|
3383
|
+
const explicitTags = opts.tags ? opts.tags.split(",").map((t) => t.trim()) : undefined;
|
|
3384
|
+
const mergedTags = explicitTags ? explicitTags : templateDefaults?.tags && templateDefaults.tags.length > 0 ? templateDefaults.tags : undefined;
|
|
3260
3385
|
const input = {
|
|
3261
3386
|
key,
|
|
3262
3387
|
value,
|
|
3263
|
-
category: opts.category,
|
|
3264
|
-
scope: opts.scope,
|
|
3265
|
-
importance: opts.importance,
|
|
3266
|
-
tags:
|
|
3388
|
+
category: opts.category ?? templateDefaults?.category,
|
|
3389
|
+
scope: opts.scope ?? templateDefaults?.scope,
|
|
3390
|
+
importance: opts.importance ?? templateDefaults?.importance,
|
|
3391
|
+
tags: mergedTags,
|
|
3267
3392
|
summary: opts.summary,
|
|
3268
3393
|
ttl_ms: opts.ttl,
|
|
3269
3394
|
source: opts.source,
|
|
@@ -3298,20 +3423,38 @@ program2.command("recall <key>").description("Recall a memory by key").option("-
|
|
|
3298
3423
|
projectId = project.id;
|
|
3299
3424
|
}
|
|
3300
3425
|
const memory = getMemoryByKey(key, opts.scope, agentId, projectId);
|
|
3301
|
-
if (
|
|
3426
|
+
if (memory) {
|
|
3427
|
+
touchMemory(memory.id);
|
|
3302
3428
|
if (globalOpts.json) {
|
|
3303
|
-
outputJson(
|
|
3429
|
+
outputJson(memory);
|
|
3304
3430
|
} else {
|
|
3305
|
-
console.
|
|
3431
|
+
console.log(formatMemoryDetail(memory));
|
|
3306
3432
|
}
|
|
3307
|
-
|
|
3433
|
+
return;
|
|
3434
|
+
}
|
|
3435
|
+
const results = searchMemories(key, {
|
|
3436
|
+
scope: opts.scope,
|
|
3437
|
+
agent_id: agentId,
|
|
3438
|
+
project_id: projectId,
|
|
3439
|
+
limit: 1
|
|
3440
|
+
});
|
|
3441
|
+
if (results.length > 0) {
|
|
3442
|
+
const best = results[0];
|
|
3443
|
+
touchMemory(best.memory.id);
|
|
3444
|
+
if (globalOpts.json) {
|
|
3445
|
+
outputJson({ fuzzy_match: true, score: best.score, match_type: best.match_type, memory: best.memory });
|
|
3446
|
+
} else {
|
|
3447
|
+
console.log(chalk.yellow(`No exact match, showing best result (score: ${best.score.toFixed(2)}, match: ${best.match_type}):`));
|
|
3448
|
+
console.log(formatMemoryDetail(best.memory));
|
|
3449
|
+
}
|
|
3450
|
+
return;
|
|
3308
3451
|
}
|
|
3309
|
-
touchMemory(memory.id);
|
|
3310
3452
|
if (globalOpts.json) {
|
|
3311
|
-
outputJson(memory);
|
|
3453
|
+
outputJson({ error: `No memory found for key: ${key}` });
|
|
3312
3454
|
} else {
|
|
3313
|
-
console.
|
|
3455
|
+
console.error(chalk.yellow(`No memory found for key: ${key}`));
|
|
3314
3456
|
}
|
|
3457
|
+
process.exit(1);
|
|
3315
3458
|
} catch (e) {
|
|
3316
3459
|
handleError(e);
|
|
3317
3460
|
}
|
|
@@ -3542,10 +3685,18 @@ program2.command("export").description("Export memories as JSON").option("-s, --
|
|
|
3542
3685
|
handleError(e);
|
|
3543
3686
|
}
|
|
3544
3687
|
});
|
|
3545
|
-
program2.command("import
|
|
3688
|
+
program2.command("import [file]").description("Import memories from a JSON file or stdin (use '-' or pipe data)").option("--overwrite", "Overwrite existing memories (default: merge)").action(async (file, opts) => {
|
|
3546
3689
|
try {
|
|
3547
3690
|
const globalOpts = program2.opts();
|
|
3548
|
-
|
|
3691
|
+
let raw;
|
|
3692
|
+
if (file === "-" || !file && !process.stdin.isTTY) {
|
|
3693
|
+
raw = await Bun.stdin.text();
|
|
3694
|
+
} else if (file) {
|
|
3695
|
+
raw = readFileSync2(resolve3(file), "utf-8");
|
|
3696
|
+
} else {
|
|
3697
|
+
console.error(chalk.red("No input: provide a file path, use '-' for stdin, or pipe data."));
|
|
3698
|
+
process.exit(1);
|
|
3699
|
+
}
|
|
3549
3700
|
const memories = JSON.parse(raw);
|
|
3550
3701
|
if (!Array.isArray(memories)) {
|
|
3551
3702
|
throw new Error("JSON file must contain an array of memories");
|
|
@@ -3860,6 +4011,156 @@ program2.command("bulk <action> <ids...>").description("Batch operations: forget
|
|
|
3860
4011
|
handleError(e);
|
|
3861
4012
|
}
|
|
3862
4013
|
});
|
|
4014
|
+
program2.command("doctor").description("Run health checks on the mementos database").action(() => {
|
|
4015
|
+
const globalOpts = program2.opts();
|
|
4016
|
+
const checks = [];
|
|
4017
|
+
const dbPath = getDbPath();
|
|
4018
|
+
if (existsSync3(dbPath)) {
|
|
4019
|
+
try {
|
|
4020
|
+
accessSync(dbPath, fsConstants.R_OK | fsConstants.W_OK);
|
|
4021
|
+
checks.push({ name: "Database file", status: "ok", detail: dbPath });
|
|
4022
|
+
} catch {
|
|
4023
|
+
checks.push({ name: "Database file", status: "fail", detail: `Not readable/writable: ${dbPath}` });
|
|
4024
|
+
}
|
|
4025
|
+
} else {
|
|
4026
|
+
checks.push({ name: "Database file", status: "fail", detail: `Not found: ${dbPath}` });
|
|
4027
|
+
}
|
|
4028
|
+
try {
|
|
4029
|
+
const db = getDatabase();
|
|
4030
|
+
const migRow = db.query("SELECT MAX(id) as max_id FROM _migrations").get();
|
|
4031
|
+
const schemaVersion = migRow?.max_id ?? 0;
|
|
4032
|
+
checks.push({ name: "Schema version", status: schemaVersion > 0 ? "ok" : "warn", detail: `v${schemaVersion}` });
|
|
4033
|
+
const memCount = db.query("SELECT COUNT(*) as c FROM memories").get().c;
|
|
4034
|
+
const agentCount = db.query("SELECT COUNT(*) as c FROM agents").get().c;
|
|
4035
|
+
const projectCount = db.query("SELECT COUNT(*) as c FROM projects").get().c;
|
|
4036
|
+
checks.push({ name: "Memories", status: "ok", detail: String(memCount) });
|
|
4037
|
+
checks.push({ name: "Agents", status: "ok", detail: String(agentCount) });
|
|
4038
|
+
checks.push({ name: "Projects", status: "ok", detail: String(projectCount) });
|
|
4039
|
+
const orphanedTags = db.query("SELECT COUNT(*) as c FROM memory_tags WHERE memory_id NOT IN (SELECT id FROM memories)").get().c;
|
|
4040
|
+
checks.push({
|
|
4041
|
+
name: "Orphaned tags",
|
|
4042
|
+
status: orphanedTags > 0 ? "warn" : "ok",
|
|
4043
|
+
detail: orphanedTags > 0 ? `${orphanedTags} orphaned tag(s)` : "None"
|
|
4044
|
+
});
|
|
4045
|
+
const expiredCount = db.query("SELECT COUNT(*) as c FROM memories WHERE status != 'expired' AND expires_at IS NOT NULL AND expires_at < datetime('now')").get().c;
|
|
4046
|
+
checks.push({
|
|
4047
|
+
name: "Expired memories",
|
|
4048
|
+
status: expiredCount > 0 ? "warn" : "ok",
|
|
4049
|
+
detail: expiredCount > 0 ? `${expiredCount} expired but not cleaned up (run 'mementos clean')` : "None pending"
|
|
4050
|
+
});
|
|
4051
|
+
} catch (e) {
|
|
4052
|
+
checks.push({ name: "Database connection", status: "fail", detail: e instanceof Error ? e.message : String(e) });
|
|
4053
|
+
}
|
|
4054
|
+
if (globalOpts.json) {
|
|
4055
|
+
outputJson({ checks, healthy: checks.every((c) => c.status === "ok") });
|
|
4056
|
+
} else {
|
|
4057
|
+
console.log(chalk.bold(`
|
|
4058
|
+
Mementos Health Report
|
|
4059
|
+
`));
|
|
4060
|
+
for (const check of checks) {
|
|
4061
|
+
const icon = check.status === "ok" ? chalk.green("\u2713") : check.status === "warn" ? chalk.yellow("!") : chalk.red("\u2717");
|
|
4062
|
+
console.log(` ${icon} ${chalk.bold(check.name)}: ${check.detail}`);
|
|
4063
|
+
}
|
|
4064
|
+
const healthy = checks.every((c) => c.status === "ok");
|
|
4065
|
+
const warnings = checks.filter((c) => c.status === "warn").length;
|
|
4066
|
+
const failures = checks.filter((c) => c.status === "fail").length;
|
|
4067
|
+
console.log("");
|
|
4068
|
+
if (healthy) {
|
|
4069
|
+
console.log(chalk.green(" All checks passed."));
|
|
4070
|
+
} else {
|
|
4071
|
+
if (failures > 0)
|
|
4072
|
+
console.log(chalk.red(` ${failures} check(s) failed.`));
|
|
4073
|
+
if (warnings > 0)
|
|
4074
|
+
console.log(chalk.yellow(` ${warnings} warning(s).`));
|
|
4075
|
+
}
|
|
4076
|
+
console.log("");
|
|
4077
|
+
}
|
|
4078
|
+
});
|
|
4079
|
+
program2.command("show <id>").description("Show full detail of a memory by ID (supports partial IDs)").action((id) => {
|
|
4080
|
+
try {
|
|
4081
|
+
const globalOpts = program2.opts();
|
|
4082
|
+
const resolvedId = resolveMemoryId(id);
|
|
4083
|
+
const memory = getMemory(resolvedId);
|
|
4084
|
+
if (!memory) {
|
|
4085
|
+
if (globalOpts.json) {
|
|
4086
|
+
outputJson({ error: `Memory not found: ${id}` });
|
|
4087
|
+
} else {
|
|
4088
|
+
console.error(chalk.red(`Memory not found: ${id}`));
|
|
4089
|
+
}
|
|
4090
|
+
process.exit(1);
|
|
4091
|
+
}
|
|
4092
|
+
touchMemory(memory.id);
|
|
4093
|
+
if (globalOpts.json) {
|
|
4094
|
+
outputJson(memory);
|
|
4095
|
+
} else {
|
|
4096
|
+
console.log(formatMemoryDetail(memory));
|
|
4097
|
+
}
|
|
4098
|
+
} catch (e) {
|
|
4099
|
+
handleError(e);
|
|
4100
|
+
}
|
|
4101
|
+
});
|
|
4102
|
+
program2.command("history").description("List memories sorted by most recently accessed").option("--limit <n>", "Max results (default: 20)", parseInt).action((opts) => {
|
|
4103
|
+
try {
|
|
4104
|
+
const globalOpts = program2.opts();
|
|
4105
|
+
const limit = opts.limit || 20;
|
|
4106
|
+
const db = getDatabase();
|
|
4107
|
+
const rows = db.query("SELECT * FROM memories WHERE status = 'active' AND accessed_at IS NOT NULL ORDER BY accessed_at DESC LIMIT ?").all(limit);
|
|
4108
|
+
const memories = rows.map(parseMemoryRow);
|
|
4109
|
+
if (globalOpts.json) {
|
|
4110
|
+
outputJson(memories);
|
|
4111
|
+
return;
|
|
4112
|
+
}
|
|
4113
|
+
if (memories.length === 0) {
|
|
4114
|
+
console.log(chalk.yellow("No recently accessed memories."));
|
|
4115
|
+
return;
|
|
4116
|
+
}
|
|
4117
|
+
console.log(chalk.bold(`${memories.length} recently accessed memor${memories.length === 1 ? "y" : "ies"}:`));
|
|
4118
|
+
for (const m of memories) {
|
|
4119
|
+
const id = chalk.dim(m.id.slice(0, 8));
|
|
4120
|
+
const scope = colorScope(m.scope);
|
|
4121
|
+
const cat = colorCategory(m.category);
|
|
4122
|
+
const value = m.value.length > 60 ? m.value.slice(0, 60) + "..." : m.value;
|
|
4123
|
+
const accessed = m.accessed_at ? chalk.dim(m.accessed_at) : chalk.dim("never");
|
|
4124
|
+
console.log(`${id} [${scope}/${cat}] ${chalk.bold(m.key)} = ${value} ${accessed}`);
|
|
4125
|
+
}
|
|
4126
|
+
} catch (e) {
|
|
4127
|
+
handleError(e);
|
|
4128
|
+
}
|
|
4129
|
+
});
|
|
4130
|
+
program2.command("context").description("Output formatted injection context (for piping into agent prompts)").option("--agent <name>", "Agent ID for private memory scope").option("--project <path>", "Project path for shared memory scope").option("--max-tokens <n>", "Token budget for context", parseInt).option("--categories <cats>", "Comma-separated categories: preference, fact, knowledge, history").action((opts) => {
|
|
4131
|
+
try {
|
|
4132
|
+
const globalOpts = program2.opts();
|
|
4133
|
+
const agentId = opts.agent || globalOpts.agent;
|
|
4134
|
+
const projectPath = opts.project || globalOpts.project;
|
|
4135
|
+
let projectId;
|
|
4136
|
+
if (projectPath) {
|
|
4137
|
+
const project = getProject(resolve3(projectPath));
|
|
4138
|
+
if (project)
|
|
4139
|
+
projectId = project.id;
|
|
4140
|
+
}
|
|
4141
|
+
const categories = opts.categories ? opts.categories.split(",").map((c) => c.trim()) : undefined;
|
|
4142
|
+
const injector = new MemoryInjector;
|
|
4143
|
+
const context = injector.getInjectionContext({
|
|
4144
|
+
agent_id: agentId,
|
|
4145
|
+
project_id: projectId,
|
|
4146
|
+
max_tokens: opts.maxTokens,
|
|
4147
|
+
categories
|
|
4148
|
+
});
|
|
4149
|
+
if (globalOpts.json) {
|
|
4150
|
+
outputJson({
|
|
4151
|
+
context,
|
|
4152
|
+
injected_count: injector.getInjectedCount()
|
|
4153
|
+
});
|
|
4154
|
+
} else if (context) {
|
|
4155
|
+
console.log(context);
|
|
4156
|
+
} else {
|
|
4157
|
+
console.error(chalk.yellow("No memories matched the injection criteria."));
|
|
4158
|
+
process.exit(1);
|
|
4159
|
+
}
|
|
4160
|
+
} catch (e) {
|
|
4161
|
+
handleError(e);
|
|
4162
|
+
}
|
|
4163
|
+
});
|
|
3863
4164
|
program2.command("mcp").description("Install mementos MCP server into Claude Code, Codex, or Gemini").option("--claude", "Install into Claude Code (~/.claude/.mcp.json)").option("--codex", "Install into Codex (~/.codex/config.toml)").option("--gemini", "Install into Gemini (~/.gemini/settings.json)").option("--all", "Install into all supported agents").option("--uninstall", "Remove mementos MCP from config").action((opts) => {
|
|
3864
4165
|
const { readFileSync: readFileSync3, writeFileSync, existsSync: fileExists } = __require("fs");
|
|
3865
4166
|
const { join: pathJoin } = __require("path");
|
package/dist/db/memories.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Database } from "bun:sqlite";
|
|
2
2
|
import type { CreateMemoryInput, DedupeMode, Memory, MemoryFilter, UpdateMemoryInput } from "../types/index.js";
|
|
3
|
+
export declare function parseMemoryRow(row: Record<string, unknown>): Memory;
|
|
3
4
|
export declare function createMemory(input: CreateMemoryInput, dedupeMode?: DedupeMode, db?: Database): Memory;
|
|
4
5
|
export declare function getMemory(id: string, db?: Database): Memory | null;
|
|
5
6
|
export declare function getMemoryByKey(key: string, scope?: string, agentId?: string, projectId?: string, sessionId?: string, db?: Database): Memory | null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"memories.d.ts","sourceRoot":"","sources":["../../src/db/memories.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAyB,MAAM,YAAY,CAAC;AAC7D,OAAO,KAAK,EACV,iBAAiB,EACjB,UAAU,EACV,MAAM,EACN,YAAY,EACZ,iBAAiB,EAClB,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"memories.d.ts","sourceRoot":"","sources":["../../src/db/memories.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAyB,MAAM,YAAY,CAAC;AAC7D,OAAO,KAAK,EACV,iBAAiB,EACjB,UAAU,EACV,MAAM,EACN,YAAY,EACZ,iBAAiB,EAClB,MAAM,mBAAmB,CAAC;AAW3B,wBAAgB,cAAc,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAwBnE;AAMD,wBAAgB,YAAY,CAC1B,KAAK,EAAE,iBAAiB,EACxB,UAAU,GAAE,UAAoB,EAChC,EAAE,CAAC,EAAE,QAAQ,GACZ,MAAM,CAoGR;AAMD,wBAAgB,SAAS,CAAC,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,QAAQ,GAAG,MAAM,GAAG,IAAI,CAOlE;AAED,wBAAgB,cAAc,CAC5B,GAAG,EAAE,MAAM,EACX,KAAK,CAAC,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,MAAM,EAChB,SAAS,CAAC,EAAE,MAAM,EAClB,SAAS,CAAC,EAAE,MAAM,EAClB,EAAE,CAAC,EAAE,QAAQ,GACZ,MAAM,GAAG,IAAI,CA4Bf;AAMD,wBAAgB,YAAY,CAAC,MAAM,CAAC,EAAE,YAAY,EAAE,EAAE,CAAC,EAAE,QAAQ,GAAG,MAAM,EAAE,CA4G3E;AAMD,wBAAgB,YAAY,CAC1B,EAAE,EAAE,MAAM,EACV,KAAK,EAAE,iBAAiB,EACxB,EAAE,CAAC,EAAE,QAAQ,GACZ,MAAM,CAiER;AAMD,wBAAgB,YAAY,CAAC,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,QAAQ,GAAG,OAAO,CAI/D;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,EAAE,QAAQ,GAAG,MAAM,CAUvE;AAMD,wBAAgB,WAAW,CAAC,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,QAAQ,GAAG,IAAI,CAM3D;AAMD,wBAAgB,oBAAoB,CAAC,EAAE,CAAC,EAAE,QAAQ,GAAG,MAAM,CAQ1D"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Database } from "bun:sqlite";
|
|
2
|
+
import type { Project } from "../types/index.js";
|
|
3
|
+
/**
|
|
4
|
+
* Auto-detect the current project from cwd's git root.
|
|
5
|
+
* - Finds the git root directory
|
|
6
|
+
* - Extracts the repo name from the directory basename
|
|
7
|
+
* - Checks if a project is already registered by path
|
|
8
|
+
* - If not, registers it automatically
|
|
9
|
+
* - Returns the Project object, or null if not in a git repo
|
|
10
|
+
*
|
|
11
|
+
* Results are cached for the lifetime of the process.
|
|
12
|
+
*/
|
|
13
|
+
export declare function detectProject(db?: Database): Project | null;
|
|
14
|
+
/**
|
|
15
|
+
* Reset the cached project (useful for tests).
|
|
16
|
+
*/
|
|
17
|
+
export declare function resetProjectCache(): void;
|
|
18
|
+
//# sourceMappingURL=project-detect.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project-detect.d.ts","sourceRoot":"","sources":["../../src/lib/project-detect.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAGtC,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAkBjD;;;;;;;;;GASG;AACH,wBAAgB,aAAa,CAAC,EAAE,CAAC,EAAE,QAAQ,GAAG,OAAO,GAAG,IAAI,CA0B3D;AAED;;GAEG;AACH,wBAAgB,iBAAiB,IAAI,IAAI,CAExC"}
|