@elevasis/sdk 1.20.2 → 1.22.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.
Files changed (164) hide show
  1. package/dist/cli.cjs +4220 -1583
  2. package/dist/index.d.ts +1035 -481
  3. package/dist/index.js +7381 -4187
  4. package/dist/node/index.d.ts +1 -3
  5. package/dist/node/index.js +40 -49
  6. package/dist/test-utils/index.d.ts +699 -123
  7. package/dist/test-utils/index.js +3826 -630
  8. package/dist/worker/index.js +3616 -442
  9. package/package.json +3 -3
  10. package/reference/_navigation.md +9 -7
  11. package/reference/_reference-manifest.json +1 -1
  12. package/reference/claude-config/hooks/post-edit-validate.mjs +98 -98
  13. package/reference/claude-config/hooks/scaffold-registry-reminder.mjs +188 -188
  14. package/reference/claude-config/hooks/tool-failure-recovery.mjs +73 -73
  15. package/reference/claude-config/registries/graph-skills.json +4 -4
  16. package/reference/claude-config/registries/knowledge-flags.json +0 -2
  17. package/reference/claude-config/rules/active-change-index.md +80 -80
  18. package/reference/claude-config/rules/agent-start-here.md +277 -273
  19. package/reference/claude-config/rules/deployment.md +57 -57
  20. package/reference/claude-config/rules/error-handling.md +56 -56
  21. package/reference/claude-config/rules/execution.md +40 -40
  22. package/reference/claude-config/rules/frontend.md +4 -4
  23. package/reference/claude-config/rules/observability.md +31 -31
  24. package/reference/claude-config/rules/operations.md +29 -17
  25. package/reference/claude-config/rules/organization-model.md +108 -40
  26. package/reference/claude-config/rules/organization-os.md +115 -113
  27. package/reference/claude-config/rules/package-taxonomy.md +33 -33
  28. package/reference/claude-config/rules/platform.md +42 -42
  29. package/reference/claude-config/rules/shared-types.md +49 -46
  30. package/reference/claude-config/rules/task-tracking.md +47 -47
  31. package/reference/claude-config/rules/ui.md +200 -200
  32. package/reference/claude-config/rules/vibe.md +235 -231
  33. package/reference/claude-config/scripts/statusline-command.js +18 -18
  34. package/reference/claude-config/settings.json +34 -34
  35. package/reference/claude-config/skills/deploy/{SKILL.md → skill.md} +156 -156
  36. package/reference/claude-config/skills/dsp/SKILL.md +66 -66
  37. package/reference/claude-config/skills/elevasis/SKILL.md +235 -235
  38. package/reference/claude-config/skills/explore/SKILL.md +6 -6
  39. package/reference/claude-config/skills/git-sync/SKILL.md +126 -126
  40. package/reference/claude-config/skills/knowledge/SKILL.md +330 -271
  41. package/reference/claude-config/skills/knowledge/operations/codify-level-a.md +100 -100
  42. package/reference/claude-config/skills/knowledge/operations/codify-level-b.md +159 -158
  43. package/reference/claude-config/skills/knowledge/operations/customers.md +109 -109
  44. package/reference/claude-config/skills/knowledge/operations/features.md +76 -113
  45. package/reference/claude-config/skills/knowledge/operations/goals.md +118 -118
  46. package/reference/claude-config/skills/knowledge/operations/identity.md +93 -93
  47. package/reference/claude-config/skills/knowledge/operations/labels.md +94 -89
  48. package/reference/claude-config/skills/knowledge/operations/offerings.md +109 -109
  49. package/reference/claude-config/skills/knowledge/operations/roles.md +99 -99
  50. package/reference/claude-config/skills/knowledge/operations/techStack.md +30 -30
  51. package/reference/claude-config/skills/project/SKILL.md +1088 -1088
  52. package/reference/claude-config/skills/run-ui/SKILL.md +73 -73
  53. package/reference/claude-config/skills/save/SKILL.md +3 -3
  54. package/reference/claude-config/skills/setup/SKILL.md +275 -275
  55. package/reference/claude-config/skills/status/SKILL.md +59 -59
  56. package/reference/claude-config/skills/submit-request/SKILL.md +180 -180
  57. package/reference/claude-config/skills/sync/SKILL.md +47 -47
  58. package/reference/claude-config/skills/tutorial/SKILL.md +259 -259
  59. package/reference/claude-config/skills/tutorial/progress-template.md +74 -74
  60. package/reference/claude-config/skills/tutorial/technical.md +1303 -1306
  61. package/reference/claude-config/skills/tutorial/vibe-coder.md +890 -890
  62. package/reference/claude-config/sync-notes/2026-04-22-git-sync-and-sync-notes.md +27 -27
  63. package/reference/claude-config/sync-notes/2026-04-22-lead-gen-deliverability-removal.md +30 -30
  64. package/reference/claude-config/sync-notes/2026-04-24-test-utils-and-template-tests.md +73 -73
  65. package/reference/claude-config/sync-notes/2026-04-24-ui-consolidation-and-sdk-cli-train.md +86 -86
  66. package/reference/claude-config/sync-notes/2026-04-25-auth-role-system-and-settings-roles.md +55 -55
  67. package/reference/claude-config/sync-notes/2026-04-27-crm-hitl-action-layer-cutover.md +97 -97
  68. package/reference/claude-config/sync-notes/2026-04-27-lead-gen-substrate-train.md +112 -112
  69. package/reference/claude-config/sync-notes/2026-04-29-crm-state-and-lead-gen-processing-status.md +93 -93
  70. package/reference/claude-config/sync-notes/2026-05-02-crm-ownership-next-action.md +58 -58
  71. package/reference/claude-config/sync-notes/2026-05-02-template-hardcode-workos-config.md +56 -56
  72. package/reference/claude-config/sync-notes/2026-05-04-elevasis-workspace.md +71 -71
  73. package/reference/claude-config/sync-notes/2026-05-04-knowledge-bundle.md +83 -83
  74. package/reference/claude-config/sync-notes/2026-05-04-template-skills-run-ui-and-tutorial.md +59 -59
  75. package/reference/claude-config/sync-notes/2026-05-05-list-builder.md +42 -42
  76. package/reference/claude-config/sync-notes/2026-05-06-crm-spine.md +60 -60
  77. package/reference/claude-config/sync-notes/2026-05-06-sdk-changes-release-train.md +37 -37
  78. package/reference/claude-config/sync-notes/2026-05-07-sdk-changes-release-train.md +34 -34
  79. package/reference/claude-config/sync-notes/2026-05-08-resource-governance-scaffold-guidance.md +38 -38
  80. package/reference/claude-config/sync-notes/2026-05-09-clients-domain.md +32 -32
  81. package/reference/claude-config/sync-notes/2026-05-09-command-system.md +33 -33
  82. package/reference/claude-config/sync-notes/2026-05-09-resource-governance-and-misc.md +69 -69
  83. package/reference/claude-config/sync-notes/2026-05-12-sdk-ready-release-train.md +30 -0
  84. package/reference/claude-config/sync-notes/2026-05-14-organization-model-ontology-refactor.md +42 -0
  85. package/reference/claude-config/sync-notes/README.md +43 -43
  86. package/reference/cli.mdx +808 -668
  87. package/reference/concepts.mdx +146 -146
  88. package/reference/deployment/api.mdx +297 -297
  89. package/reference/deployment/command-center.mdx +209 -209
  90. package/reference/deployment/index.mdx +195 -195
  91. package/reference/deployment/provided-features.mdx +107 -93
  92. package/reference/deployment/ui-execution.mdx +250 -250
  93. package/reference/examples/organization-model.ts +147 -84
  94. package/reference/framework/agent.mdx +156 -156
  95. package/reference/framework/index.mdx +195 -195
  96. package/reference/framework/interaction-guidance.mdx +182 -182
  97. package/reference/framework/memory.mdx +326 -326
  98. package/reference/framework/project-structure.mdx +282 -282
  99. package/reference/framework/tutorial-system.mdx +135 -135
  100. package/reference/getting-started.mdx +142 -142
  101. package/reference/index.mdx +106 -106
  102. package/reference/packages/core/src/README.md +14 -14
  103. package/reference/packages/core/src/business/README.md +2 -2
  104. package/reference/packages/core/src/knowledge/README.md +33 -32
  105. package/reference/packages/core/src/organization-model/README.md +149 -109
  106. package/reference/packages/core/src/test-utils/README.md +37 -37
  107. package/reference/packages/ui/src/api/README.md +18 -18
  108. package/reference/packages/ui/src/app/README.md +24 -24
  109. package/reference/packages/ui/src/auth/README.md +18 -18
  110. package/reference/packages/ui/src/components/README.md +24 -24
  111. package/reference/packages/ui/src/execution/README.md +16 -16
  112. package/reference/packages/ui/src/features/README.md +28 -28
  113. package/reference/packages/ui/src/graph/README.md +16 -16
  114. package/reference/packages/ui/src/hooks/README.md +23 -23
  115. package/reference/packages/ui/src/initialization/README.md +19 -19
  116. package/reference/packages/ui/src/knowledge/README.md +31 -31
  117. package/reference/packages/ui/src/organization/README.md +18 -18
  118. package/reference/packages/ui/src/profile/README.md +19 -19
  119. package/reference/packages/ui/src/provider/README.md +32 -32
  120. package/reference/packages/ui/src/router/README.md +18 -18
  121. package/reference/packages/ui/src/sse/README.md +13 -13
  122. package/reference/packages/ui/src/test-utils/README.md +7 -7
  123. package/reference/packages/ui/src/theme/README.md +23 -23
  124. package/reference/packages/ui/src/theme/presets/README.md +19 -19
  125. package/reference/packages/ui/src/types/README.md +16 -16
  126. package/reference/packages/ui/src/utils/README.md +18 -18
  127. package/reference/packages/ui/src/zustand/README.md +18 -18
  128. package/reference/platform-tools/adapters-integration.mdx +301 -301
  129. package/reference/platform-tools/adapters-platform.mdx +553 -553
  130. package/reference/platform-tools/index.mdx +217 -217
  131. package/reference/platform-tools/type-safety.mdx +82 -82
  132. package/reference/resources/index.mdx +349 -349
  133. package/reference/resources/patterns.mdx +449 -449
  134. package/reference/resources/types.mdx +116 -116
  135. package/reference/roadmap.mdx +165 -165
  136. package/reference/runtime.mdx +173 -173
  137. package/reference/scaffold/core/organization-graph.mdx +110 -89
  138. package/reference/scaffold/core/organization-model.mdx +226 -171
  139. package/reference/scaffold/index.mdx +67 -67
  140. package/reference/scaffold/operations/propagation-pipeline.md +77 -77
  141. package/reference/scaffold/operations/scaffold-maintenance.md +10 -10
  142. package/reference/scaffold/operations/workflow-recipes.md +138 -138
  143. package/reference/scaffold/recipes/add-a-feature.md +310 -88
  144. package/reference/scaffold/recipes/add-a-resource.md +137 -117
  145. package/reference/scaffold/recipes/customize-crm-actions.md +439 -439
  146. package/reference/scaffold/recipes/customize-knowledge-browser.md +384 -0
  147. package/reference/scaffold/recipes/customize-organization-model.md +281 -118
  148. package/reference/scaffold/recipes/extend-a-base-entity.md +8 -8
  149. package/reference/scaffold/recipes/extend-crm.md +40 -39
  150. package/reference/scaffold/recipes/extend-lead-gen.md +400 -401
  151. package/reference/scaffold/recipes/gate-by-feature-or-admin.md +118 -114
  152. package/reference/scaffold/recipes/index.md +47 -46
  153. package/reference/scaffold/recipes/query-the-knowledge-graph.md +227 -0
  154. package/reference/scaffold/reference/contracts.md +2389 -2121
  155. package/reference/scaffold/reference/feature-registry.md +9 -20
  156. package/reference/scaffold/reference/glossary.md +76 -76
  157. package/reference/scaffold/ui/composition-extensibility.mdx +233 -233
  158. package/reference/scaffold/ui/customization.md +243 -243
  159. package/reference/scaffold/ui/feature-flags-and-gating.md +46 -46
  160. package/reference/scaffold/ui/feature-shell.mdx +72 -72
  161. package/reference/scaffold/ui/recipes.md +221 -213
  162. package/reference/spine/spine-primer.md +96 -96
  163. package/reference/templates/index.mdx +47 -47
  164. package/reference/troubleshooting.mdx +223 -223
@@ -1,326 +1,326 @@
1
- ---
2
- title: Memory System
3
- description: Cross-session project knowledge stored in .claude/memory/ -- deployment state, environment, decisions, and error patterns that persist between Claude Code sessions
4
- loadWhen: "Working with agent memory or session state"
5
- ---
6
-
7
- The memory system gives Claude Code a structured knowledge base for your project that survives across sessions. Deployment history, discovered credentials, architectural decisions, and error patterns are all written to `.claude/memory/` as the project evolves -- so the agent never starts from scratch.
8
-
9
- The `memory/` directory is gitignored and personal to each developer. The `profile/` subdirectory is created by `/meta init` during first-run setup. All other topics are created by the agent as the project evolves.
10
-
11
- ## Purpose
12
-
13
- Without project memory, the agent starts every session with only the context of the current conversation. It cannot remember that you already deployed yesterday, that a particular credential is configured, or that you encountered and solved a specific TypeScript error last week.
14
-
15
- With project memory, the agent loads a root index at session start, sees what has been recorded, and can retrieve detail on demand. Error patterns are matched before diagnosis. Deployment state is available before deploying again. The agent can say "I've seen this before -- here's the fix" instead of repeating the same diagnostic process.
16
-
17
- ## Architecture
18
-
19
- Memory is organized as a hierarchical index tree. Every directory has an `index.md` that maps to its children -- either content files or subdirectories with their own indexes.
20
-
21
- **The invariant:** A reader always starts at the root index and drills down. The agent reads `memory/index.md` at session start. It reads individual topic files on demand when the user asks about that topic or the agent is about to perform an action in that domain.
22
-
23
- **The scaling rule:** When a content file outgrows a single document, it graduates into a subdirectory:
24
-
25
- 1. `topic.md` becomes `topic/index.md` + sub-files
26
- 2. The parent index updates its link from `topic.md` to `topic/index.md`
27
- 3. The new sub-index maps to the sub-files
28
-
29
- This pattern is recursive. Subdirectories can split further as needed. The agent applies its own judgment about when a file has grown past usefulness as a single document.
30
-
31
- ### Starting Structure
32
-
33
- After `/meta init` and a first deployment, the structure looks like this:
34
-
35
- ```
36
- .claude/memory/
37
- ├── index.md # Root index -- read at session start
38
- ├── profile/ # Developer profile (created by /meta init)
39
- │ ├── index.md # Profile summary with links to sub-files
40
- │ ├── identity.md # Organization, industry, goals, integrations
41
- │ ├── skills.md # Skill dimensions and Growth Log
42
- │ └── preferences.md # Verbosity, guidance style, interaction patterns
43
- ├── deployment-state.md # Deploy IDs, resource inventory, org info
44
- ├── environment.md # Credentials, API keys, env vars
45
- ├── decisions.md # Architectural decisions and patterns
46
- └── errors/ # Subdirectory -- multiple categories
47
- ├── index.md # Error category summary with counts
48
- ├── deploy.md # Deployment error patterns
49
- ├── runtime.md # Runtime execution error patterns
50
- └── typescript.md # Type and build error patterns
51
- ```
52
-
53
- Profile tracking starts as a subdirectory because it has natural sub-topics from day one (identity, skills, preferences). Error tracking starts as a subdirectory because it naturally spans multiple categories. Other topics start as flat files.
54
-
55
- ### Grown Structure
56
-
57
- As a project matures, other topics may split:
58
-
59
- ```
60
- .claude/memory/
61
- ├── index.md
62
- ├── environment.md
63
- ├── decisions.md
64
- ├── deployment-state/ # Grew large enough to split
65
- │ ├── index.md
66
- │ ├── resources.md
67
- │ └── history.md
68
- └── errors/
69
- ├── index.md
70
- ├── deploy.md
71
- ├── typescript.md
72
- └── runtime/ # Runtime errors grew further
73
- ├── index.md
74
- ├── lead-scorer.md
75
- └── email-sender.md
76
- ```
77
-
78
- ## Memory Topics
79
-
80
- ### Developer Profile
81
-
82
- The `profile/` directory stores the developer's personal context -- organization details, skill levels, goals, and interaction preferences. It is created during `/meta init` guided setup and is the first thing the root index links to.
83
-
84
- ```
85
- .claude/memory/profile/
86
- ├── index.md # Profile summary with links to sub-files
87
- ├── identity.md # Organization, industry, goals, integrations
88
- ├── skills.md # Skill dimensions and Growth Log
89
- └── preferences.md # Verbosity, guidance style, interaction patterns
90
- ```
91
-
92
- **`identity.md`** records the organization name, industry, size, project goals, and known tool integrations. Example:
93
-
94
- ```markdown
95
- # Identity
96
-
97
- | Field | Value |
98
- | --- | --- |
99
- | Organization | Acme Corp |
100
- | Industry | E-commerce |
101
- | Size | 10-50 |
102
-
103
- ## Project Goals
104
-
105
- - Automate lead scoring from Attio CRM
106
- - Send follow-up emails via Resend
107
- - Weekly pipeline reports
108
-
109
- ## Known Integrations
110
-
111
- - Attio (CRM)
112
- - Resend (email)
113
- - Google Sheets (reporting)
114
- ```
115
-
116
- **`skills.md`** stores four skill dimensions as structured values so the Adaptive Guidance rules in [Interaction Guidance](interaction-guidance.mdx) can apply them consistently. It also tracks a Growth Log so the agent can detect when a level upgrade is warranted. Example:
117
-
118
- ```markdown
119
- # Skills
120
-
121
- | Dimension | Level | Since |
122
- | --- | --- | --- |
123
- | platformNavigation | oriented | 2026-02-25 |
124
- | apiIntegration | basic | 2026-02-25 |
125
- | automation | low-code | 2026-02-25 |
126
- | domainExpertise | high | 2026-02-25 |
127
-
128
- ## Growth Log
129
-
130
- | Date | Observation | Dimension | Change |
131
- | --- | --- | --- | --- |
132
- | 2026-03-01 | Navigated to Execution Logs and filtered by resource without direction | platformNavigation | none -> oriented |
133
- ```
134
-
135
- Valid levels per dimension:
136
-
137
- - `platformNavigation`: none / oriented / comfortable
138
- - `apiIntegration`: none / basic / proficient
139
- - `automation`: none / low-code / custom
140
- - `domainExpertise`: high / low
141
-
142
- **`preferences.md`** stores verbosity and proactive guidance settings. Example:
143
-
144
- ```markdown
145
- # Preferences
146
-
147
- | Setting | Value |
148
- | --- | --- |
149
- | Verbosity | detailed |
150
- | Proactive guidance | yes |
151
- ```
152
-
153
- ### Root Index
154
-
155
- `memory/index.md` is the only file read at session start. It lists all topics with their last-updated dates, giving the agent enough context to know what has been recorded without loading any detail.
156
-
157
- ```markdown
158
- # Project Memory
159
-
160
- Agent-maintained cross-session knowledge base. Updated automatically.
161
-
162
- | Entry | Topic | Last Updated |
163
- | --- | --- | --- |
164
- | [profile/](profile/index.md) | Developer profile (skills, identity, preferences) | 2026-02-25 |
165
- | [deployment-state.md](deployment-state.md) | Deploy history, resource inventory, org info | 2026-02-25 |
166
- | [environment.md](environment.md) | Credentials, API keys, env vars | 2026-02-25 |
167
- | [decisions.md](decisions.md) | Architectural decisions and patterns | 2026-02-26 |
168
- | [errors/](errors/index.md) | Error patterns by category | 2026-02-26 |
169
- ```
170
-
171
- Subdirectory entries link to their `index.md` rather than the directory itself.
172
-
173
- ### Deployment State
174
-
175
- `deployment-state.md` tracks the most recent deploy and resource inventory. The agent updates it after every successful deployment.
176
-
177
- ```markdown
178
- # Deployment State
179
-
180
- ## Latest Deploy
181
-
182
- | Field | Value |
183
- | --- | --- |
184
- | Date | 2026-02-26 |
185
- | Deploy ID | dep_abc123 |
186
- | Resource count | 2 |
187
- | Organization | acme-corp |
188
-
189
- ## Resources
190
-
191
- - `echo` (workflow, dev) -- echoes input, starter resource
192
- - `lead-scorer` (workflow, prod) -- scores leads from Attio
193
-
194
- ## Deploy History
195
-
196
- | Date | Deploy ID | Resources | Status |
197
- | --- | --- | --- | --- |
198
- | 2026-02-26 | dep_abc123 | 2 | success |
199
- | 2026-02-25 | dep_xyz789 | 1 | success |
200
- ```
201
-
202
- ### Environment
203
-
204
- `environment.md` records discovered credentials and environment variable status. The agent updates it when credentials are confirmed via the command center or deployment output.
205
-
206
- ### Decisions
207
-
208
- `decisions.md` captures architectural choices as a table: which tools were chosen, what patterns were established, and why. The agent adds a row when the user makes a significant decision during development.
209
-
210
- ## Error Tracking
211
-
212
- Error tracking is the first memory topic to outgrow a flat file. It starts as a subdirectory with one file per error category.
213
-
214
- ### Error Index
215
-
216
- `errors/index.md` provides a high-level summary of known error patterns by category. The agent reads this file (via the root index) at session start.
217
-
218
- ```markdown
219
- # Error Patterns
220
-
221
- Error pattern tracking by category. Updated when errors are diagnosed and resolved.
222
-
223
- | Entry | Category | Patterns | Total Occurrences | Last Seen |
224
- | --- | --- | --- | --- | --- |
225
- | [deploy.md](deploy.md) | Deployment | 2 | 3 | 2026-02-26 |
226
- | [runtime.md](runtime.md) | Runtime | 1 | 1 | 2026-02-26 |
227
- | [typescript.md](typescript.md) | TypeScript | 1 | 2 | 2026-02-25 |
228
- ```
229
-
230
- - **Patterns** -- count of unique error patterns in the category file
231
- - **Total Occurrences** -- sum of all occurrences across patterns
232
- - **Last Seen** -- most recent date any error in this category was seen
233
-
234
- ### Category Files
235
-
236
- Each category file is a table of known error patterns with resolutions:
237
-
238
- ```markdown
239
- # Deploy Errors
240
-
241
- | Last Seen | Error | Resolution | Occurrences |
242
- | --- | --- | --- | --- |
243
- | 2026-02-25 | `ELEVASIS_PLATFORM_KEY not set` | Added key to `.env` | 2 |
244
- | 2026-02-26 | `Schema validation: missing outputSchema` | Added Zod output schema to workflow | 1 |
245
- ```
246
-
247
- Runtime errors include the resource name since the same error in different resources may have different causes:
248
-
249
- ```markdown
250
- # Runtime Errors
251
-
252
- | Last Seen | Resource | Error | Resolution | Occurrences |
253
- | --- | --- | --- | --- | --- |
254
- | 2026-02-26 | lead-scorer | `PlatformToolError: credential not found` | Set credential via `elevasis-sdk env set` | 1 |
255
- ```
256
-
257
- ### Error Resolution Flow
258
-
259
- When the agent encounters an error, it follows this sequence:
260
-
261
- 1. Checks `memory/errors/index.md` (already loaded via root index) for a matching category
262
- 2. If the relevant category has known patterns, reads the category file
263
- 3. If a match exists, applies the known resolution immediately -- "I've seen this before, here's the fix"
264
- 4. If no match exists, diagnoses normally, then logs the new pattern
265
-
266
- When the agent logs a resolved error:
267
-
268
- 1. Reads the relevant category file (e.g., `memory/errors/deploy.md`)
269
- 2. If the pattern already exists, increments `Occurrences` and updates `Last Seen`
270
- 3. If it is a new pattern, adds a new row
271
- 4. Updates the error index: recalculates `Patterns`, `Total Occurrences`, and `Last Seen`
272
- 5. If the category file does not exist yet, creates it and adds a row to the error index
273
-
274
- ## Scaling Rule
275
-
276
- When a file has grown past usefulness as a single document -- too many rows to scan, too many unrelated concerns, or too much context to load for a targeted lookup -- split it into a subdirectory.
277
-
278
- **Before split:**
279
-
280
- ```
281
- memory/
282
- ├── index.md
283
- └── deployment-state.md # entry: deployment-state.md
284
- ```
285
-
286
- **After split:**
287
-
288
- ```
289
- memory/
290
- ├── index.md # entry updated: deployment-state/ -> deployment-state/index.md
291
- └── deployment-state/
292
- ├── index.md
293
- ├── resources.md
294
- └── history.md
295
- ```
296
-
297
- The parent index link changes from `deployment-state.md` to `deployment-state/index.md`. The new sub-index maps to the sub-files. The agent applies this pattern at every depth level.
298
-
299
- ## Maintenance
300
-
301
- ### Pruning
302
-
303
- Keep content useful, not exhaustive:
304
-
305
- - Keep the most recent ~20 entries in tables that grow over time (deploy history, error patterns)
306
- - Drop patterns that have not recurred in 30 or more days unless the resolution was non-obvious
307
- - Summarize if patterns are worth preserving but detail is not
308
-
309
- ### Index Hygiene
310
-
311
- - If a file exists but is not in its parent index, add it
312
- - If an index references a missing file, remove the row
313
-
314
- The agent self-heals on read. Index hygiene is applied as part of normal session operation.
315
-
316
- ### Promotion
317
-
318
- If an error pattern recurs 3 or more times, promote it to a rule in the `CLAUDE.md` Rules section. Rules prevent errors rather than diagnosing them.
319
-
320
- ## Relationship to Claude Code Auto-Memory
321
-
322
- Claude Code's auto-memory (`MEMORY.md`) and project memory (`.claude/memory/`) are complementary -- both should be active. Auto-memory captures organic discoveries; project memory captures structured project state that `CLAUDE.md` explicitly instructs the agent to record.
323
-
324
- ---
325
-
326
- **Last Updated:** 2026-02-25
1
+ ---
2
+ title: Memory System
3
+ description: Cross-session project knowledge stored in .claude/memory/ -- deployment state, environment, decisions, and error patterns that persist between Claude Code sessions
4
+ loadWhen: "Working with agent memory or session state"
5
+ ---
6
+
7
+ The memory system gives Claude Code a structured knowledge base for your project that survives across sessions. Deployment history, discovered credentials, architectural decisions, and error patterns are all written to `.claude/memory/` as the project evolves -- so the agent never starts from scratch.
8
+
9
+ The `memory/` directory is gitignored and personal to each developer. The `profile/` subdirectory is created by `/meta init` during first-run setup. All other topics are created by the agent as the project evolves.
10
+
11
+ ## Purpose
12
+
13
+ Without project memory, the agent starts every session with only the context of the current conversation. It cannot remember that you already deployed yesterday, that a particular credential is configured, or that you encountered and solved a specific TypeScript error last week.
14
+
15
+ With project memory, the agent loads a root index at session start, sees what has been recorded, and can retrieve detail on demand. Error patterns are matched before diagnosis. Deployment state is available before deploying again. The agent can say "I've seen this before -- here's the fix" instead of repeating the same diagnostic process.
16
+
17
+ ## Architecture
18
+
19
+ Memory is organized as a hierarchical index tree. Every directory has an `index.md` that maps to its children -- either content files or subdirectories with their own indexes.
20
+
21
+ **The invariant:** A reader always starts at the root index and drills down. The agent reads `memory/index.md` at session start. It reads individual topic files on demand when the user asks about that topic or the agent is about to perform an action in that domain.
22
+
23
+ **The scaling rule:** When a content file outgrows a single document, it graduates into a subdirectory:
24
+
25
+ 1. `topic.md` becomes `topic/index.md` + sub-files
26
+ 2. The parent index updates its link from `topic.md` to `topic/index.md`
27
+ 3. The new sub-index maps to the sub-files
28
+
29
+ This pattern is recursive. Subdirectories can split further as needed. The agent applies its own judgment about when a file has grown past usefulness as a single document.
30
+
31
+ ### Starting Structure
32
+
33
+ After `/meta init` and a first deployment, the structure looks like this:
34
+
35
+ ```
36
+ .claude/memory/
37
+ ├── index.md # Root index -- read at session start
38
+ ├── profile/ # Developer profile (created by /meta init)
39
+ │ ├── index.md # Profile summary with links to sub-files
40
+ │ ├── identity.md # Organization, industry, goals, integrations
41
+ │ ├── skills.md # Skill dimensions and Growth Log
42
+ │ └── preferences.md # Verbosity, guidance style, interaction patterns
43
+ ├── deployment-state.md # Deploy IDs, resource inventory, org info
44
+ ├── environment.md # Credentials, API keys, env vars
45
+ ├── decisions.md # Architectural decisions and patterns
46
+ └── errors/ # Subdirectory -- multiple categories
47
+ ├── index.md # Error category summary with counts
48
+ ├── deploy.md # Deployment error patterns
49
+ ├── runtime.md # Runtime execution error patterns
50
+ └── typescript.md # Type and build error patterns
51
+ ```
52
+
53
+ Profile tracking starts as a subdirectory because it has natural sub-topics from day one (identity, skills, preferences). Error tracking starts as a subdirectory because it naturally spans multiple categories. Other topics start as flat files.
54
+
55
+ ### Grown Structure
56
+
57
+ As a project matures, other topics may split:
58
+
59
+ ```
60
+ .claude/memory/
61
+ ├── index.md
62
+ ├── environment.md
63
+ ├── decisions.md
64
+ ├── deployment-state/ # Grew large enough to split
65
+ │ ├── index.md
66
+ │ ├── resources.md
67
+ │ └── history.md
68
+ └── errors/
69
+ ├── index.md
70
+ ├── deploy.md
71
+ ├── typescript.md
72
+ └── runtime/ # Runtime errors grew further
73
+ ├── index.md
74
+ ├── lead-scorer.md
75
+ └── email-sender.md
76
+ ```
77
+
78
+ ## Memory Topics
79
+
80
+ ### Developer Profile
81
+
82
+ The `profile/` directory stores the developer's personal context -- organization details, skill levels, goals, and interaction preferences. It is created during `/meta init` guided setup and is the first thing the root index links to.
83
+
84
+ ```
85
+ .claude/memory/profile/
86
+ ├── index.md # Profile summary with links to sub-files
87
+ ├── identity.md # Organization, industry, goals, integrations
88
+ ├── skills.md # Skill dimensions and Growth Log
89
+ └── preferences.md # Verbosity, guidance style, interaction patterns
90
+ ```
91
+
92
+ **`identity.md`** records the organization name, industry, size, project goals, and known tool integrations. Example:
93
+
94
+ ```markdown
95
+ # Identity
96
+
97
+ | Field | Value |
98
+ | --- | --- |
99
+ | Organization | Acme Corp |
100
+ | Industry | E-commerce |
101
+ | Size | 10-50 |
102
+
103
+ ## Project Goals
104
+
105
+ - Automate lead scoring from Attio CRM
106
+ - Send follow-up emails via Resend
107
+ - Weekly pipeline reports
108
+
109
+ ## Known Integrations
110
+
111
+ - Attio (CRM)
112
+ - Resend (email)
113
+ - Google Sheets (reporting)
114
+ ```
115
+
116
+ **`skills.md`** stores four skill dimensions as structured values so the Adaptive Guidance rules in [Interaction Guidance](interaction-guidance.mdx) can apply them consistently. It also tracks a Growth Log so the agent can detect when a level upgrade is warranted. Example:
117
+
118
+ ```markdown
119
+ # Skills
120
+
121
+ | Dimension | Level | Since |
122
+ | --- | --- | --- |
123
+ | platformNavigation | oriented | 2026-02-25 |
124
+ | apiIntegration | basic | 2026-02-25 |
125
+ | automation | low-code | 2026-02-25 |
126
+ | domainExpertise | high | 2026-02-25 |
127
+
128
+ ## Growth Log
129
+
130
+ | Date | Observation | Dimension | Change |
131
+ | --- | --- | --- | --- |
132
+ | 2026-03-01 | Navigated to Execution Logs and filtered by resource without direction | platformNavigation | none -> oriented |
133
+ ```
134
+
135
+ Valid levels per dimension:
136
+
137
+ - `platformNavigation`: none / oriented / comfortable
138
+ - `apiIntegration`: none / basic / proficient
139
+ - `automation`: none / low-code / custom
140
+ - `domainExpertise`: high / low
141
+
142
+ **`preferences.md`** stores verbosity and proactive guidance settings. Example:
143
+
144
+ ```markdown
145
+ # Preferences
146
+
147
+ | Setting | Value |
148
+ | --- | --- |
149
+ | Verbosity | detailed |
150
+ | Proactive guidance | yes |
151
+ ```
152
+
153
+ ### Root Index
154
+
155
+ `memory/index.md` is the only file read at session start. It lists all topics with their last-updated dates, giving the agent enough context to know what has been recorded without loading any detail.
156
+
157
+ ```markdown
158
+ # Project Memory
159
+
160
+ Agent-maintained cross-session knowledge base. Updated automatically.
161
+
162
+ | Entry | Topic | Last Updated |
163
+ | --- | --- | --- |
164
+ | [profile/](profile/index.md) | Developer profile (skills, identity, preferences) | 2026-02-25 |
165
+ | [deployment-state.md](deployment-state.md) | Deploy history, resource inventory, org info | 2026-02-25 |
166
+ | [environment.md](environment.md) | Credentials, API keys, env vars | 2026-02-25 |
167
+ | [decisions.md](decisions.md) | Architectural decisions and patterns | 2026-02-26 |
168
+ | [errors/](errors/index.md) | Error patterns by category | 2026-02-26 |
169
+ ```
170
+
171
+ Subdirectory entries link to their `index.md` rather than the directory itself.
172
+
173
+ ### Deployment State
174
+
175
+ `deployment-state.md` tracks the most recent deploy and resource inventory. The agent updates it after every successful deployment.
176
+
177
+ ```markdown
178
+ # Deployment State
179
+
180
+ ## Latest Deploy
181
+
182
+ | Field | Value |
183
+ | --- | --- |
184
+ | Date | 2026-02-26 |
185
+ | Deploy ID | dep_abc123 |
186
+ | Resource count | 2 |
187
+ | Organization | acme-corp |
188
+
189
+ ## Resources
190
+
191
+ - `echo` (workflow, dev) -- echoes input, starter resource
192
+ - `lead-scorer` (workflow, prod) -- scores leads from Attio
193
+
194
+ ## Deploy History
195
+
196
+ | Date | Deploy ID | Resources | Status |
197
+ | --- | --- | --- | --- |
198
+ | 2026-02-26 | dep_abc123 | 2 | success |
199
+ | 2026-02-25 | dep_xyz789 | 1 | success |
200
+ ```
201
+
202
+ ### Environment
203
+
204
+ `environment.md` records discovered credentials and environment variable status. The agent updates it when credentials are confirmed via the command center or deployment output.
205
+
206
+ ### Decisions
207
+
208
+ `decisions.md` captures architectural choices as a table: which tools were chosen, what patterns were established, and why. The agent adds a row when the user makes a significant decision during development.
209
+
210
+ ## Error Tracking
211
+
212
+ Error tracking is the first memory topic to outgrow a flat file. It starts as a subdirectory with one file per error category.
213
+
214
+ ### Error Index
215
+
216
+ `errors/index.md` provides a high-level summary of known error patterns by category. The agent reads this file (via the root index) at session start.
217
+
218
+ ```markdown
219
+ # Error Patterns
220
+
221
+ Error pattern tracking by category. Updated when errors are diagnosed and resolved.
222
+
223
+ | Entry | Category | Patterns | Total Occurrences | Last Seen |
224
+ | --- | --- | --- | --- | --- |
225
+ | [deploy.md](deploy.md) | Deployment | 2 | 3 | 2026-02-26 |
226
+ | [runtime.md](runtime.md) | Runtime | 1 | 1 | 2026-02-26 |
227
+ | [typescript.md](typescript.md) | TypeScript | 1 | 2 | 2026-02-25 |
228
+ ```
229
+
230
+ - **Patterns** -- count of unique error patterns in the category file
231
+ - **Total Occurrences** -- sum of all occurrences across patterns
232
+ - **Last Seen** -- most recent date any error in this category was seen
233
+
234
+ ### Category Files
235
+
236
+ Each category file is a table of known error patterns with resolutions:
237
+
238
+ ```markdown
239
+ # Deploy Errors
240
+
241
+ | Last Seen | Error | Resolution | Occurrences |
242
+ | --- | --- | --- | --- |
243
+ | 2026-02-25 | `ELEVASIS_PLATFORM_KEY not set` | Added key to `.env` | 2 |
244
+ | 2026-02-26 | `Schema validation: missing outputSchema` | Added Zod output schema to workflow | 1 |
245
+ ```
246
+
247
+ Runtime errors include the resource name since the same error in different resources may have different causes:
248
+
249
+ ```markdown
250
+ # Runtime Errors
251
+
252
+ | Last Seen | Resource | Error | Resolution | Occurrences |
253
+ | --- | --- | --- | --- | --- |
254
+ | 2026-02-26 | lead-scorer | `PlatformToolError: credential not found` | Set credential via `elevasis-sdk env set` | 1 |
255
+ ```
256
+
257
+ ### Error Resolution Flow
258
+
259
+ When the agent encounters an error, it follows this sequence:
260
+
261
+ 1. Checks `memory/errors/index.md` (already loaded via root index) for a matching category
262
+ 2. If the relevant category has known patterns, reads the category file
263
+ 3. If a match exists, applies the known resolution immediately -- "I've seen this before, here's the fix"
264
+ 4. If no match exists, diagnoses normally, then logs the new pattern
265
+
266
+ When the agent logs a resolved error:
267
+
268
+ 1. Reads the relevant category file (e.g., `memory/errors/deploy.md`)
269
+ 2. If the pattern already exists, increments `Occurrences` and updates `Last Seen`
270
+ 3. If it is a new pattern, adds a new row
271
+ 4. Updates the error index: recalculates `Patterns`, `Total Occurrences`, and `Last Seen`
272
+ 5. If the category file does not exist yet, creates it and adds a row to the error index
273
+
274
+ ## Scaling Rule
275
+
276
+ When a file has grown past usefulness as a single document -- too many rows to scan, too many unrelated concerns, or too much context to load for a targeted lookup -- split it into a subdirectory.
277
+
278
+ **Before split:**
279
+
280
+ ```
281
+ memory/
282
+ ├── index.md
283
+ └── deployment-state.md # entry: deployment-state.md
284
+ ```
285
+
286
+ **After split:**
287
+
288
+ ```
289
+ memory/
290
+ ├── index.md # entry updated: deployment-state/ -> deployment-state/index.md
291
+ └── deployment-state/
292
+ ├── index.md
293
+ ├── resources.md
294
+ └── history.md
295
+ ```
296
+
297
+ The parent index link changes from `deployment-state.md` to `deployment-state/index.md`. The new sub-index maps to the sub-files. The agent applies this pattern at every depth level.
298
+
299
+ ## Maintenance
300
+
301
+ ### Pruning
302
+
303
+ Keep content useful, not exhaustive:
304
+
305
+ - Keep the most recent ~20 entries in tables that grow over time (deploy history, error patterns)
306
+ - Drop patterns that have not recurred in 30 or more days unless the resolution was non-obvious
307
+ - Summarize if patterns are worth preserving but detail is not
308
+
309
+ ### Index Hygiene
310
+
311
+ - If a file exists but is not in its parent index, add it
312
+ - If an index references a missing file, remove the row
313
+
314
+ The agent self-heals on read. Index hygiene is applied as part of normal session operation.
315
+
316
+ ### Promotion
317
+
318
+ If an error pattern recurs 3 or more times, promote it to a rule in the `CLAUDE.md` Rules section. Rules prevent errors rather than diagnosing them.
319
+
320
+ ## Relationship to Claude Code Auto-Memory
321
+
322
+ Claude Code's auto-memory (`MEMORY.md`) and project memory (`.claude/memory/`) are complementary -- both should be active. Auto-memory captures organic discoveries; project memory captures structured project state that `CLAUDE.md` explicitly instructs the agent to record.
323
+
324
+ ---
325
+
326
+ **Last Updated:** 2026-02-25