claude-flow 3.0.0-alpha.10 → 3.0.0-alpha.12

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 (243) hide show
  1. package/README.md +41 -1151
  2. package/bin/cli.js +30 -8
  3. package/dist/index.d.ts +40 -0
  4. package/dist/index.d.ts.map +1 -0
  5. package/dist/index.js +43 -0
  6. package/dist/index.js.map +1 -0
  7. package/package.json +52 -12
  8. package/dist/src/commands/agent.d.ts +0 -8
  9. package/dist/src/commands/agent.d.ts.map +0 -1
  10. package/dist/src/commands/agent.js +0 -819
  11. package/dist/src/commands/agent.js.map +0 -1
  12. package/dist/src/commands/config.d.ts +0 -8
  13. package/dist/src/commands/config.d.ts.map +0 -1
  14. package/dist/src/commands/config.js +0 -406
  15. package/dist/src/commands/config.js.map +0 -1
  16. package/dist/src/commands/daemon.d.ts +0 -8
  17. package/dist/src/commands/daemon.d.ts.map +0 -1
  18. package/dist/src/commands/daemon.js +0 -545
  19. package/dist/src/commands/daemon.js.map +0 -1
  20. package/dist/src/commands/hive-mind.d.ts +0 -8
  21. package/dist/src/commands/hive-mind.d.ts.map +0 -1
  22. package/dist/src/commands/hive-mind.js +0 -844
  23. package/dist/src/commands/hive-mind.js.map +0 -1
  24. package/dist/src/commands/hooks.d.ts +0 -8
  25. package/dist/src/commands/hooks.d.ts.map +0 -1
  26. package/dist/src/commands/hooks.js +0 -2098
  27. package/dist/src/commands/hooks.js.map +0 -1
  28. package/dist/src/commands/index.d.ts +0 -52
  29. package/dist/src/commands/index.d.ts.map +0 -1
  30. package/dist/src/commands/index.js +0 -108
  31. package/dist/src/commands/index.js.map +0 -1
  32. package/dist/src/commands/init.d.ts +0 -8
  33. package/dist/src/commands/init.d.ts.map +0 -1
  34. package/dist/src/commands/init.js +0 -532
  35. package/dist/src/commands/init.js.map +0 -1
  36. package/dist/src/commands/mcp.d.ts +0 -11
  37. package/dist/src/commands/mcp.d.ts.map +0 -1
  38. package/dist/src/commands/mcp.js +0 -662
  39. package/dist/src/commands/mcp.js.map +0 -1
  40. package/dist/src/commands/memory.d.ts +0 -8
  41. package/dist/src/commands/memory.d.ts.map +0 -1
  42. package/dist/src/commands/memory.js +0 -977
  43. package/dist/src/commands/memory.js.map +0 -1
  44. package/dist/src/commands/migrate.d.ts +0 -8
  45. package/dist/src/commands/migrate.d.ts.map +0 -1
  46. package/dist/src/commands/migrate.js +0 -398
  47. package/dist/src/commands/migrate.js.map +0 -1
  48. package/dist/src/commands/process.d.ts +0 -10
  49. package/dist/src/commands/process.d.ts.map +0 -1
  50. package/dist/src/commands/process.js +0 -641
  51. package/dist/src/commands/process.js.map +0 -1
  52. package/dist/src/commands/session.d.ts +0 -8
  53. package/dist/src/commands/session.d.ts.map +0 -1
  54. package/dist/src/commands/session.js +0 -750
  55. package/dist/src/commands/session.js.map +0 -1
  56. package/dist/src/commands/start.d.ts +0 -8
  57. package/dist/src/commands/start.d.ts.map +0 -1
  58. package/dist/src/commands/start.js +0 -398
  59. package/dist/src/commands/start.js.map +0 -1
  60. package/dist/src/commands/status.d.ts +0 -8
  61. package/dist/src/commands/status.d.ts.map +0 -1
  62. package/dist/src/commands/status.js +0 -584
  63. package/dist/src/commands/status.js.map +0 -1
  64. package/dist/src/commands/swarm.d.ts +0 -8
  65. package/dist/src/commands/swarm.d.ts.map +0 -1
  66. package/dist/src/commands/swarm.js +0 -573
  67. package/dist/src/commands/swarm.js.map +0 -1
  68. package/dist/src/commands/task.d.ts +0 -8
  69. package/dist/src/commands/task.d.ts.map +0 -1
  70. package/dist/src/commands/task.js +0 -671
  71. package/dist/src/commands/task.js.map +0 -1
  72. package/dist/src/commands/workflow.d.ts +0 -8
  73. package/dist/src/commands/workflow.d.ts.map +0 -1
  74. package/dist/src/commands/workflow.js +0 -617
  75. package/dist/src/commands/workflow.js.map +0 -1
  76. package/dist/src/config-adapter.d.ts +0 -15
  77. package/dist/src/config-adapter.d.ts.map +0 -1
  78. package/dist/src/config-adapter.js +0 -185
  79. package/dist/src/config-adapter.js.map +0 -1
  80. package/dist/src/index.d.ts +0 -55
  81. package/dist/src/index.d.ts.map +0 -1
  82. package/dist/src/index.js +0 -353
  83. package/dist/src/index.js.map +0 -1
  84. package/dist/src/infrastructure/in-memory-repositories.d.ts +0 -68
  85. package/dist/src/infrastructure/in-memory-repositories.d.ts.map +0 -1
  86. package/dist/src/infrastructure/in-memory-repositories.js +0 -264
  87. package/dist/src/infrastructure/in-memory-repositories.js.map +0 -1
  88. package/dist/src/init/claudemd-generator.d.ts +0 -15
  89. package/dist/src/init/claudemd-generator.d.ts.map +0 -1
  90. package/dist/src/init/claudemd-generator.js +0 -626
  91. package/dist/src/init/claudemd-generator.js.map +0 -1
  92. package/dist/src/init/executor.d.ts +0 -11
  93. package/dist/src/init/executor.d.ts.map +0 -1
  94. package/dist/src/init/executor.js +0 -652
  95. package/dist/src/init/executor.js.map +0 -1
  96. package/dist/src/init/helpers-generator.d.ts +0 -42
  97. package/dist/src/init/helpers-generator.d.ts.map +0 -1
  98. package/dist/src/init/helpers-generator.js +0 -613
  99. package/dist/src/init/helpers-generator.js.map +0 -1
  100. package/dist/src/init/index.d.ts +0 -12
  101. package/dist/src/init/index.d.ts.map +0 -1
  102. package/dist/src/init/index.js +0 -15
  103. package/dist/src/init/index.js.map +0 -1
  104. package/dist/src/init/mcp-generator.d.ts +0 -18
  105. package/dist/src/init/mcp-generator.d.ts.map +0 -1
  106. package/dist/src/init/mcp-generator.js +0 -71
  107. package/dist/src/init/mcp-generator.js.map +0 -1
  108. package/dist/src/init/settings-generator.d.ts +0 -14
  109. package/dist/src/init/settings-generator.d.ts.map +0 -1
  110. package/dist/src/init/settings-generator.js +0 -267
  111. package/dist/src/init/settings-generator.js.map +0 -1
  112. package/dist/src/init/statusline-generator.d.ts +0 -14
  113. package/dist/src/init/statusline-generator.d.ts.map +0 -1
  114. package/dist/src/init/statusline-generator.js +0 -206
  115. package/dist/src/init/statusline-generator.js.map +0 -1
  116. package/dist/src/init/types.d.ts +0 -240
  117. package/dist/src/init/types.d.ts.map +0 -1
  118. package/dist/src/init/types.js +0 -210
  119. package/dist/src/init/types.js.map +0 -1
  120. package/dist/src/mcp-client.d.ts +0 -92
  121. package/dist/src/mcp-client.d.ts.map +0 -1
  122. package/dist/src/mcp-client.js +0 -203
  123. package/dist/src/mcp-client.js.map +0 -1
  124. package/dist/src/mcp-server.d.ts +0 -153
  125. package/dist/src/mcp-server.d.ts.map +0 -1
  126. package/dist/src/mcp-server.js +0 -453
  127. package/dist/src/mcp-server.js.map +0 -1
  128. package/dist/src/mcp-tools/agent-tools.d.ts +0 -8
  129. package/dist/src/mcp-tools/agent-tools.d.ts.map +0 -1
  130. package/dist/src/mcp-tools/agent-tools.js +0 -426
  131. package/dist/src/mcp-tools/agent-tools.js.map +0 -1
  132. package/dist/src/mcp-tools/config-tools.d.ts +0 -8
  133. package/dist/src/mcp-tools/config-tools.d.ts.map +0 -1
  134. package/dist/src/mcp-tools/config-tools.js +0 -333
  135. package/dist/src/mcp-tools/config-tools.js.map +0 -1
  136. package/dist/src/mcp-tools/hive-mind-tools.d.ts +0 -8
  137. package/dist/src/mcp-tools/hive-mind-tools.d.ts.map +0 -1
  138. package/dist/src/mcp-tools/hive-mind-tools.js +0 -447
  139. package/dist/src/mcp-tools/hive-mind-tools.js.map +0 -1
  140. package/dist/src/mcp-tools/hooks-tools.d.ts +0 -41
  141. package/dist/src/mcp-tools/hooks-tools.d.ts.map +0 -1
  142. package/dist/src/mcp-tools/hooks-tools.js +0 -1711
  143. package/dist/src/mcp-tools/hooks-tools.js.map +0 -1
  144. package/dist/src/mcp-tools/index.d.ts +0 -16
  145. package/dist/src/mcp-tools/index.d.ts.map +0 -1
  146. package/dist/src/mcp-tools/index.js +0 -15
  147. package/dist/src/mcp-tools/index.js.map +0 -1
  148. package/dist/src/mcp-tools/memory-tools.d.ts +0 -8
  149. package/dist/src/mcp-tools/memory-tools.d.ts.map +0 -1
  150. package/dist/src/mcp-tools/memory-tools.js +0 -235
  151. package/dist/src/mcp-tools/memory-tools.js.map +0 -1
  152. package/dist/src/mcp-tools/session-tools.d.ts +0 -8
  153. package/dist/src/mcp-tools/session-tools.d.ts.map +0 -1
  154. package/dist/src/mcp-tools/session-tools.js +0 -315
  155. package/dist/src/mcp-tools/session-tools.js.map +0 -1
  156. package/dist/src/mcp-tools/swarm-tools.d.ts +0 -8
  157. package/dist/src/mcp-tools/swarm-tools.d.ts.map +0 -1
  158. package/dist/src/mcp-tools/swarm-tools.js +0 -102
  159. package/dist/src/mcp-tools/swarm-tools.js.map +0 -1
  160. package/dist/src/mcp-tools/task-tools.d.ts +0 -8
  161. package/dist/src/mcp-tools/task-tools.d.ts.map +0 -1
  162. package/dist/src/mcp-tools/task-tools.js +0 -302
  163. package/dist/src/mcp-tools/task-tools.js.map +0 -1
  164. package/dist/src/mcp-tools/types.d.ts +0 -31
  165. package/dist/src/mcp-tools/types.d.ts.map +0 -1
  166. package/dist/src/mcp-tools/types.js +0 -7
  167. package/dist/src/mcp-tools/types.js.map +0 -1
  168. package/dist/src/mcp-tools/workflow-tools.d.ts +0 -8
  169. package/dist/src/mcp-tools/workflow-tools.d.ts.map +0 -1
  170. package/dist/src/mcp-tools/workflow-tools.js +0 -481
  171. package/dist/src/mcp-tools/workflow-tools.js.map +0 -1
  172. package/dist/src/output.d.ts +0 -133
  173. package/dist/src/output.d.ts.map +0 -1
  174. package/dist/src/output.js +0 -513
  175. package/dist/src/output.js.map +0 -1
  176. package/dist/src/parser.d.ts +0 -41
  177. package/dist/src/parser.d.ts.map +0 -1
  178. package/dist/src/parser.js +0 -353
  179. package/dist/src/parser.js.map +0 -1
  180. package/dist/src/prompt.d.ts +0 -44
  181. package/dist/src/prompt.d.ts.map +0 -1
  182. package/dist/src/prompt.js +0 -501
  183. package/dist/src/prompt.js.map +0 -1
  184. package/dist/src/services/index.d.ts +0 -7
  185. package/dist/src/services/index.d.ts.map +0 -1
  186. package/dist/src/services/index.js +0 -6
  187. package/dist/src/services/index.js.map +0 -1
  188. package/dist/src/services/worker-daemon.d.ts +0 -153
  189. package/dist/src/services/worker-daemon.d.ts.map +0 -1
  190. package/dist/src/services/worker-daemon.js +0 -567
  191. package/dist/src/services/worker-daemon.js.map +0 -1
  192. package/dist/src/types.d.ts +0 -198
  193. package/dist/src/types.d.ts.map +0 -1
  194. package/dist/src/types.js +0 -38
  195. package/dist/src/types.js.map +0 -1
  196. package/dist/tsconfig.tsbuildinfo +0 -1
  197. package/src/commands/agent.ts +0 -955
  198. package/src/commands/config.ts +0 -452
  199. package/src/commands/daemon.ts +0 -621
  200. package/src/commands/hive-mind.ts +0 -928
  201. package/src/commands/hooks.ts +0 -2603
  202. package/src/commands/index.ts +0 -118
  203. package/src/commands/init.ts +0 -597
  204. package/src/commands/mcp.ts +0 -753
  205. package/src/commands/memory.ts +0 -1161
  206. package/src/commands/migrate.ts +0 -447
  207. package/src/commands/process.ts +0 -695
  208. package/src/commands/session.ts +0 -891
  209. package/src/commands/start.ts +0 -457
  210. package/src/commands/status.ts +0 -736
  211. package/src/commands/swarm.ts +0 -648
  212. package/src/commands/task.ts +0 -792
  213. package/src/commands/workflow.ts +0 -742
  214. package/src/config-adapter.ts +0 -210
  215. package/src/index.ts +0 -427
  216. package/src/infrastructure/in-memory-repositories.ts +0 -310
  217. package/src/init/claudemd-generator.ts +0 -631
  218. package/src/init/executor.ts +0 -762
  219. package/src/init/helpers-generator.ts +0 -628
  220. package/src/init/index.ts +0 -60
  221. package/src/init/mcp-generator.ts +0 -83
  222. package/src/init/settings-generator.ts +0 -284
  223. package/src/init/statusline-generator.ts +0 -211
  224. package/src/init/types.ts +0 -447
  225. package/src/mcp-client.ts +0 -241
  226. package/src/mcp-server.ts +0 -577
  227. package/src/mcp-tools/agent-tools.ts +0 -466
  228. package/src/mcp-tools/config-tools.ts +0 -370
  229. package/src/mcp-tools/hive-mind-tools.ts +0 -521
  230. package/src/mcp-tools/hooks-tools.ts +0 -1888
  231. package/src/mcp-tools/index.ts +0 -16
  232. package/src/mcp-tools/memory-tools.ts +0 -270
  233. package/src/mcp-tools/session-tools.ts +0 -359
  234. package/src/mcp-tools/swarm-tools.ts +0 -105
  235. package/src/mcp-tools/task-tools.ts +0 -347
  236. package/src/mcp-tools/types.ts +0 -33
  237. package/src/mcp-tools/workflow-tools.ts +0 -573
  238. package/src/output.ts +0 -639
  239. package/src/parser.ts +0 -417
  240. package/src/prompt.ts +0 -619
  241. package/src/services/index.ts +0 -15
  242. package/src/services/worker-daemon.ts +0 -726
  243. package/src/types.ts +0 -287
@@ -1,977 +0,0 @@
1
- /**
2
- * V3 CLI Memory Command
3
- * Memory operations for AgentDB integration
4
- */
5
- import { output } from '../output.js';
6
- import { select, confirm, input } from '../prompt.js';
7
- import { callMCPTool, MCPClientError } from '../mcp-client.js';
8
- // Memory backends
9
- const BACKENDS = [
10
- { value: 'agentdb', label: 'AgentDB', hint: 'Vector database with HNSW indexing (150x-12,500x faster)' },
11
- { value: 'sqlite', label: 'SQLite', hint: 'Lightweight local storage' },
12
- { value: 'hybrid', label: 'Hybrid', hint: 'SQLite + AgentDB (recommended)' },
13
- { value: 'memory', label: 'In-Memory', hint: 'Fast but non-persistent' }
14
- ];
15
- // Store command
16
- const storeCommand = {
17
- name: 'store',
18
- description: 'Store data in memory',
19
- options: [
20
- {
21
- name: 'key',
22
- short: 'k',
23
- description: 'Storage key/namespace',
24
- type: 'string',
25
- required: true
26
- },
27
- {
28
- name: 'value',
29
- short: 'v',
30
- description: 'Value to store',
31
- type: 'string'
32
- },
33
- {
34
- name: 'namespace',
35
- short: 'n',
36
- description: 'Memory namespace',
37
- type: 'string',
38
- default: 'default'
39
- },
40
- {
41
- name: 'ttl',
42
- description: 'Time to live in seconds',
43
- type: 'number'
44
- },
45
- {
46
- name: 'tags',
47
- description: 'Comma-separated tags',
48
- type: 'string'
49
- },
50
- {
51
- name: 'vector',
52
- description: 'Store as vector embedding',
53
- type: 'boolean',
54
- default: false
55
- }
56
- ],
57
- examples: [
58
- { command: 'claude-flow memory store -k "api/auth" -v "JWT implementation"', description: 'Store text' },
59
- { command: 'claude-flow memory store -k "pattern/singleton" --vector', description: 'Store vector' }
60
- ],
61
- action: async (ctx) => {
62
- const key = ctx.flags.key;
63
- let value = ctx.flags.value || ctx.args[0];
64
- const namespace = ctx.flags.namespace;
65
- const ttl = ctx.flags.ttl;
66
- const tags = ctx.flags.tags ? ctx.flags.tags.split(',') : [];
67
- const asVector = ctx.flags.vector;
68
- if (!key) {
69
- output.printError('Key is required. Use --key or -k');
70
- return { success: false, exitCode: 1 };
71
- }
72
- if (!value && ctx.interactive) {
73
- value = await input({
74
- message: 'Enter value to store:',
75
- validate: (v) => v.length > 0 || 'Value is required'
76
- });
77
- }
78
- if (!value) {
79
- output.printError('Value is required. Use --value or -v');
80
- return { success: false, exitCode: 1 };
81
- }
82
- const storeData = {
83
- key,
84
- namespace,
85
- value,
86
- ttl,
87
- tags,
88
- asVector,
89
- storedAt: new Date().toISOString(),
90
- size: Buffer.byteLength(value, 'utf8')
91
- };
92
- output.printInfo(`Storing in ${namespace}/${key}...`);
93
- if (asVector) {
94
- output.writeln(output.dim(' Generating embedding vector...'));
95
- output.writeln(output.dim(' Indexing with HNSW (M=16, ef=200)...'));
96
- }
97
- // Call MCP memory/store tool for real persistence
98
- try {
99
- const result = await callMCPTool('memory/store', {
100
- key,
101
- value,
102
- metadata: { namespace, tags, ttl, asVector, size: storeData.size }
103
- });
104
- output.writeln();
105
- output.printTable({
106
- columns: [
107
- { key: 'property', header: 'Property', width: 15 },
108
- { key: 'val', header: 'Value', width: 40 }
109
- ],
110
- data: [
111
- { property: 'Key', val: key },
112
- { property: 'Namespace', val: namespace },
113
- { property: 'Size', val: `${storeData.size} bytes` },
114
- { property: 'TTL', val: ttl ? `${ttl}s` : 'None' },
115
- { property: 'Tags', val: tags.length > 0 ? tags.join(', ') : 'None' },
116
- { property: 'Vector', val: asVector ? 'Yes' : 'No' },
117
- { property: 'Total Entries', val: String(result.totalEntries || 1) }
118
- ]
119
- });
120
- output.writeln();
121
- output.printSuccess('Data stored successfully');
122
- return { success: true, data: { ...storeData, ...result } };
123
- }
124
- catch (error) {
125
- output.printError(`Failed to store: ${error instanceof Error ? error.message : 'Unknown error'}`);
126
- return { success: false, exitCode: 1 };
127
- }
128
- }
129
- };
130
- // Retrieve command
131
- const retrieveCommand = {
132
- name: 'retrieve',
133
- aliases: ['get'],
134
- description: 'Retrieve data from memory',
135
- options: [
136
- {
137
- name: 'key',
138
- short: 'k',
139
- description: 'Storage key',
140
- type: 'string'
141
- },
142
- {
143
- name: 'namespace',
144
- short: 'n',
145
- description: 'Memory namespace',
146
- type: 'string',
147
- default: 'default'
148
- }
149
- ],
150
- action: async (ctx) => {
151
- const key = ctx.flags.key || ctx.args[0];
152
- const namespace = ctx.flags.namespace;
153
- if (!key) {
154
- output.printError('Key is required');
155
- return { success: false, exitCode: 1 };
156
- }
157
- // Call MCP memory/retrieve tool for real data
158
- try {
159
- const result = await callMCPTool('memory/retrieve', { key });
160
- if (!result.found) {
161
- output.printWarning(`Key not found: ${key}`);
162
- return { success: false, exitCode: 1, data: { key, found: false } };
163
- }
164
- const data = {
165
- key: result.key,
166
- namespace,
167
- value: result.value,
168
- metadata: {
169
- storedAt: result.storedAt || 'Unknown',
170
- accessCount: result.accessCount || 0,
171
- lastAccessed: new Date().toISOString(),
172
- ...(result.metadata || {})
173
- }
174
- };
175
- if (ctx.flags.format === 'json') {
176
- output.printJson(data);
177
- return { success: true, data };
178
- }
179
- const metaTags = result.metadata?.tags || [];
180
- const metaSize = result.metadata?.size || String(data.value).length;
181
- output.writeln();
182
- output.printBox([
183
- `Namespace: ${namespace}`,
184
- `Key: ${data.key}`,
185
- `Size: ${metaSize} bytes`,
186
- `Access Count: ${data.metadata.accessCount}`,
187
- `Tags: ${metaTags.length > 0 ? metaTags.join(', ') : 'None'}`,
188
- '',
189
- output.bold('Value:'),
190
- typeof data.value === 'string' ? data.value : JSON.stringify(data.value, null, 2)
191
- ].join('\n'), 'Memory Entry');
192
- return { success: true, data };
193
- }
194
- catch (error) {
195
- output.printError(`Failed to retrieve: ${error instanceof Error ? error.message : 'Unknown error'}`);
196
- return { success: false, exitCode: 1 };
197
- }
198
- }
199
- };
200
- // Search command
201
- const searchCommand = {
202
- name: 'search',
203
- description: 'Search memory with semantic/vector search',
204
- options: [
205
- {
206
- name: 'query',
207
- short: 'q',
208
- description: 'Search query',
209
- type: 'string',
210
- required: true
211
- },
212
- {
213
- name: 'namespace',
214
- short: 'n',
215
- description: 'Memory namespace',
216
- type: 'string'
217
- },
218
- {
219
- name: 'limit',
220
- short: 'l',
221
- description: 'Maximum results',
222
- type: 'number',
223
- default: 10
224
- },
225
- {
226
- name: 'threshold',
227
- description: 'Similarity threshold (0-1)',
228
- type: 'number',
229
- default: 0.7
230
- },
231
- {
232
- name: 'type',
233
- short: 't',
234
- description: 'Search type (semantic, keyword, hybrid)',
235
- type: 'string',
236
- default: 'semantic',
237
- choices: ['semantic', 'keyword', 'hybrid']
238
- }
239
- ],
240
- examples: [
241
- { command: 'claude-flow memory search -q "authentication patterns"', description: 'Semantic search' },
242
- { command: 'claude-flow memory search -q "JWT" -t keyword', description: 'Keyword search' }
243
- ],
244
- action: async (ctx) => {
245
- const query = ctx.flags.query || ctx.args[0];
246
- const namespace = ctx.flags.namespace;
247
- const limit = ctx.flags.limit;
248
- const threshold = ctx.flags.threshold;
249
- const searchType = ctx.flags.type;
250
- if (!query) {
251
- output.printError('Query is required. Use --query or -q');
252
- return { success: false, exitCode: 1 };
253
- }
254
- output.printInfo(`Searching: "${query}" (${searchType})`);
255
- output.writeln();
256
- // Call MCP memory/search tool for real results
257
- try {
258
- const searchResult = await callMCPTool('memory/search', { query, limit });
259
- const results = searchResult.results.map(r => ({
260
- key: r.key,
261
- score: r.score,
262
- namespace: namespace || 'default',
263
- preview: typeof r.value === 'string'
264
- ? r.value.substring(0, 40) + (r.value.length > 40 ? '...' : '')
265
- : JSON.stringify(r.value).substring(0, 40)
266
- }));
267
- if (ctx.flags.format === 'json') {
268
- output.printJson({ query, searchType, results, searchTime: searchResult.searchTime });
269
- return { success: true, data: results };
270
- }
271
- // Performance stats
272
- output.writeln(output.dim(` Search time: ${searchResult.searchTime}`));
273
- output.writeln();
274
- if (results.length === 0) {
275
- output.printWarning('No results found');
276
- return { success: true, data: [] };
277
- }
278
- output.printTable({
279
- columns: [
280
- { key: 'key', header: 'Key', width: 20 },
281
- { key: 'score', header: 'Score', width: 8, align: 'right', format: (v) => Number(v).toFixed(2) },
282
- { key: 'namespace', header: 'Namespace', width: 12 },
283
- { key: 'preview', header: 'Preview', width: 35 }
284
- ],
285
- data: results
286
- });
287
- output.writeln();
288
- output.printInfo(`Found ${results.length} results`);
289
- return { success: true, data: results };
290
- }
291
- catch (error) {
292
- output.printError(`Search failed: ${error instanceof Error ? error.message : 'Unknown error'}`);
293
- return { success: false, exitCode: 1 };
294
- }
295
- }
296
- };
297
- // List command
298
- const listCommand = {
299
- name: 'list',
300
- aliases: ['ls'],
301
- description: 'List memory entries',
302
- options: [
303
- {
304
- name: 'namespace',
305
- short: 'n',
306
- description: 'Filter by namespace',
307
- type: 'string'
308
- },
309
- {
310
- name: 'tags',
311
- short: 't',
312
- description: 'Filter by tags (comma-separated)',
313
- type: 'string'
314
- },
315
- {
316
- name: 'limit',
317
- short: 'l',
318
- description: 'Maximum entries',
319
- type: 'number',
320
- default: 20
321
- }
322
- ],
323
- action: async (ctx) => {
324
- const namespace = ctx.flags.namespace;
325
- const limit = ctx.flags.limit;
326
- // Call MCP memory/list tool for real entries
327
- try {
328
- const listResult = await callMCPTool('memory/list', { limit, offset: 0 });
329
- // Format entries for display
330
- const entries = listResult.entries.map(e => ({
331
- key: e.key,
332
- namespace: namespace || 'default',
333
- size: e.preview.length + ' B',
334
- accessCount: e.accessCount,
335
- updated: formatRelativeTime(e.storedAt)
336
- }));
337
- if (ctx.flags.format === 'json') {
338
- output.printJson(entries);
339
- return { success: true, data: entries };
340
- }
341
- output.writeln();
342
- output.writeln(output.bold('Memory Entries'));
343
- output.writeln();
344
- if (entries.length === 0) {
345
- output.printWarning('No entries found');
346
- return { success: true, data: [] };
347
- }
348
- output.printTable({
349
- columns: [
350
- { key: 'key', header: 'Key', width: 25 },
351
- { key: 'namespace', header: 'Namespace', width: 12 },
352
- { key: 'size', header: 'Size', width: 10, align: 'right' },
353
- { key: 'accessCount', header: 'Accessed', width: 10, align: 'right' },
354
- { key: 'updated', header: 'Updated', width: 12 }
355
- ],
356
- data: entries
357
- });
358
- output.writeln();
359
- output.printInfo(`Showing ${entries.length} of ${listResult.total} entries`);
360
- return { success: true, data: entries };
361
- }
362
- catch (error) {
363
- output.printError(`Failed to list: ${error instanceof Error ? error.message : 'Unknown error'}`);
364
- return { success: false, exitCode: 1 };
365
- }
366
- }
367
- };
368
- // Helper function to format relative time
369
- function formatRelativeTime(isoDate) {
370
- const now = Date.now();
371
- const date = new Date(isoDate).getTime();
372
- const diff = now - date;
373
- const seconds = Math.floor(diff / 1000);
374
- const minutes = Math.floor(seconds / 60);
375
- const hours = Math.floor(minutes / 60);
376
- const days = Math.floor(hours / 24);
377
- if (days > 0)
378
- return `${days}d ago`;
379
- if (hours > 0)
380
- return `${hours}h ago`;
381
- if (minutes > 0)
382
- return `${minutes}m ago`;
383
- return 'just now';
384
- }
385
- // Delete command
386
- const deleteCommand = {
387
- name: 'delete',
388
- aliases: ['rm'],
389
- description: 'Delete memory entry',
390
- options: [
391
- {
392
- name: 'force',
393
- short: 'f',
394
- description: 'Skip confirmation',
395
- type: 'boolean',
396
- default: false
397
- }
398
- ],
399
- action: async (ctx) => {
400
- const key = ctx.args[0];
401
- const force = ctx.flags.force;
402
- if (!key) {
403
- output.printError('Key is required');
404
- return { success: false, exitCode: 1 };
405
- }
406
- if (!force && ctx.interactive) {
407
- const confirmed = await confirm({
408
- message: `Delete memory entry "${key}"?`,
409
- default: false
410
- });
411
- if (!confirmed) {
412
- output.printInfo('Operation cancelled');
413
- return { success: true };
414
- }
415
- }
416
- // Call MCP memory/delete tool
417
- try {
418
- const result = await callMCPTool('memory/delete', { key });
419
- if (result.deleted) {
420
- output.printSuccess(`Deleted ${key}`);
421
- output.printInfo(`Remaining entries: ${result.remainingEntries}`);
422
- }
423
- else {
424
- output.printWarning(`Key not found: ${key}`);
425
- }
426
- return { success: result.deleted, data: result };
427
- }
428
- catch (error) {
429
- output.printError(`Failed to delete: ${error instanceof Error ? error.message : 'Unknown error'}`);
430
- return { success: false, exitCode: 1 };
431
- }
432
- }
433
- };
434
- // Stats command
435
- const statsCommand = {
436
- name: 'stats',
437
- description: 'Show memory statistics',
438
- action: async (ctx) => {
439
- // Call MCP memory/stats tool for real statistics
440
- try {
441
- const statsResult = await callMCPTool('memory/stats', {});
442
- const stats = {
443
- backend: statsResult.backend,
444
- entries: {
445
- total: statsResult.totalEntries,
446
- vectors: 0, // Would need vector backend support
447
- text: statsResult.totalEntries
448
- },
449
- storage: {
450
- total: statsResult.totalSize,
451
- location: statsResult.location
452
- },
453
- version: statsResult.version,
454
- oldestEntry: statsResult.oldestEntry,
455
- newestEntry: statsResult.newestEntry
456
- };
457
- if (ctx.flags.format === 'json') {
458
- output.printJson(stats);
459
- return { success: true, data: stats };
460
- }
461
- output.writeln();
462
- output.writeln(output.bold('Memory Statistics'));
463
- output.writeln();
464
- output.writeln(output.bold('Overview'));
465
- output.printTable({
466
- columns: [
467
- { key: 'metric', header: 'Metric', width: 20 },
468
- { key: 'value', header: 'Value', width: 30, align: 'right' }
469
- ],
470
- data: [
471
- { metric: 'Backend', value: stats.backend },
472
- { metric: 'Version', value: stats.version },
473
- { metric: 'Total Entries', value: stats.entries.total.toLocaleString() },
474
- { metric: 'Total Storage', value: stats.storage.total },
475
- { metric: 'Location', value: stats.storage.location }
476
- ]
477
- });
478
- output.writeln();
479
- output.writeln(output.bold('Timeline'));
480
- output.printTable({
481
- columns: [
482
- { key: 'metric', header: 'Metric', width: 20 },
483
- { key: 'value', header: 'Value', width: 30, align: 'right' }
484
- ],
485
- data: [
486
- { metric: 'Oldest Entry', value: stats.oldestEntry || 'N/A' },
487
- { metric: 'Newest Entry', value: stats.newestEntry || 'N/A' }
488
- ]
489
- });
490
- output.writeln();
491
- output.printInfo('V3 Performance: 150x-12,500x faster search with HNSW indexing');
492
- return { success: true, data: stats };
493
- }
494
- catch (error) {
495
- output.printError(`Failed to get stats: ${error instanceof Error ? error.message : 'Unknown error'}`);
496
- return { success: false, exitCode: 1 };
497
- }
498
- }
499
- };
500
- // Configure command
501
- const configureCommand = {
502
- name: 'configure',
503
- aliases: ['config'],
504
- description: 'Configure memory backend',
505
- options: [
506
- {
507
- name: 'backend',
508
- short: 'b',
509
- description: 'Memory backend',
510
- type: 'string',
511
- choices: BACKENDS.map(b => b.value)
512
- },
513
- {
514
- name: 'path',
515
- description: 'Storage path',
516
- type: 'string'
517
- },
518
- {
519
- name: 'cache-size',
520
- description: 'Cache size in MB',
521
- type: 'number'
522
- },
523
- {
524
- name: 'hnsw-m',
525
- description: 'HNSW M parameter',
526
- type: 'number',
527
- default: 16
528
- },
529
- {
530
- name: 'hnsw-ef',
531
- description: 'HNSW ef parameter',
532
- type: 'number',
533
- default: 200
534
- }
535
- ],
536
- action: async (ctx) => {
537
- let backend = ctx.flags.backend;
538
- if (!backend && ctx.interactive) {
539
- backend = await select({
540
- message: 'Select memory backend:',
541
- options: BACKENDS,
542
- default: 'hybrid'
543
- });
544
- }
545
- const config = {
546
- backend: backend || 'hybrid',
547
- path: ctx.flags.path || './data/memory',
548
- cacheSize: ctx.flags.cacheSize || 256,
549
- hnsw: {
550
- m: ctx.flags.hnswM || 16,
551
- ef: ctx.flags.hnswEf || 200
552
- }
553
- };
554
- output.writeln();
555
- output.printInfo('Memory Configuration');
556
- output.writeln();
557
- output.printTable({
558
- columns: [
559
- { key: 'setting', header: 'Setting', width: 20 },
560
- { key: 'value', header: 'Value', width: 25 }
561
- ],
562
- data: [
563
- { setting: 'Backend', value: config.backend },
564
- { setting: 'Storage Path', value: config.path },
565
- { setting: 'Cache Size', value: `${config.cacheSize} MB` },
566
- { setting: 'HNSW M', value: config.hnsw.m },
567
- { setting: 'HNSW ef', value: config.hnsw.ef }
568
- ]
569
- });
570
- output.writeln();
571
- output.printSuccess('Memory configuration updated');
572
- return { success: true, data: config };
573
- }
574
- };
575
- // Cleanup command
576
- const cleanupCommand = {
577
- name: 'cleanup',
578
- description: 'Clean up stale and expired memory entries',
579
- options: [
580
- {
581
- name: 'dry-run',
582
- short: 'd',
583
- description: 'Show what would be deleted',
584
- type: 'boolean',
585
- default: false
586
- },
587
- {
588
- name: 'older-than',
589
- short: 'o',
590
- description: 'Delete entries older than (e.g., "7d", "30d")',
591
- type: 'string'
592
- },
593
- {
594
- name: 'expired-only',
595
- short: 'e',
596
- description: 'Only delete expired TTL entries',
597
- type: 'boolean',
598
- default: false
599
- },
600
- {
601
- name: 'low-quality',
602
- short: 'l',
603
- description: 'Delete low quality patterns (threshold)',
604
- type: 'number'
605
- },
606
- {
607
- name: 'namespace',
608
- short: 'n',
609
- description: 'Clean specific namespace only',
610
- type: 'string'
611
- },
612
- {
613
- name: 'force',
614
- short: 'f',
615
- description: 'Skip confirmation',
616
- type: 'boolean',
617
- default: false
618
- }
619
- ],
620
- examples: [
621
- { command: 'claude-flow memory cleanup --dry-run', description: 'Preview cleanup' },
622
- { command: 'claude-flow memory cleanup --older-than 30d', description: 'Delete entries older than 30 days' },
623
- { command: 'claude-flow memory cleanup --expired-only', description: 'Clean expired entries' }
624
- ],
625
- action: async (ctx) => {
626
- const dryRun = ctx.flags.dryRun;
627
- const force = ctx.flags.force;
628
- if (dryRun) {
629
- output.writeln(output.warning('DRY RUN - No changes will be made'));
630
- }
631
- output.printInfo('Analyzing memory for cleanup...');
632
- try {
633
- const result = await callMCPTool('memory/cleanup', {
634
- dryRun,
635
- olderThan: ctx.flags.olderThan,
636
- expiredOnly: ctx.flags.expiredOnly,
637
- lowQualityThreshold: ctx.flags.lowQuality,
638
- namespace: ctx.flags.namespace,
639
- });
640
- if (ctx.flags.format === 'json') {
641
- output.printJson(result);
642
- return { success: true, data: result };
643
- }
644
- output.writeln();
645
- output.writeln(output.bold('Cleanup Analysis'));
646
- output.printTable({
647
- columns: [
648
- { key: 'category', header: 'Category', width: 20 },
649
- { key: 'count', header: 'Count', width: 15, align: 'right' }
650
- ],
651
- data: [
652
- { category: 'Expired (TTL)', count: result.candidates.expired },
653
- { category: 'Stale (unused)', count: result.candidates.stale },
654
- { category: 'Low Quality', count: result.candidates.lowQuality },
655
- { category: output.bold('Total'), count: output.bold(String(result.candidates.total)) }
656
- ]
657
- });
658
- if (!dryRun && result.candidates.total > 0 && !force) {
659
- const confirmed = await confirm({
660
- message: `Delete ${result.candidates.total} entries (${result.freed.formatted})?`,
661
- default: false
662
- });
663
- if (!confirmed) {
664
- output.printInfo('Cleanup cancelled');
665
- return { success: true, data: result };
666
- }
667
- }
668
- if (!dryRun) {
669
- output.writeln();
670
- output.printSuccess(`Cleaned ${result.deleted.entries} entries`);
671
- output.printList([
672
- `Vectors removed: ${result.deleted.vectors}`,
673
- `Patterns removed: ${result.deleted.patterns}`,
674
- `Space freed: ${result.freed.formatted}`,
675
- `Duration: ${result.duration}ms`
676
- ]);
677
- }
678
- return { success: true, data: result };
679
- }
680
- catch (error) {
681
- if (error instanceof MCPClientError) {
682
- output.printError(`Cleanup error: ${error.message}`);
683
- }
684
- else {
685
- output.printError(`Unexpected error: ${String(error)}`);
686
- }
687
- return { success: false, exitCode: 1 };
688
- }
689
- }
690
- };
691
- // Compress command
692
- const compressCommand = {
693
- name: 'compress',
694
- description: 'Compress and optimize memory storage',
695
- options: [
696
- {
697
- name: 'level',
698
- short: 'l',
699
- description: 'Compression level (fast, balanced, max)',
700
- type: 'string',
701
- choices: ['fast', 'balanced', 'max'],
702
- default: 'balanced'
703
- },
704
- {
705
- name: 'target',
706
- short: 't',
707
- description: 'Target (vectors, text, patterns, all)',
708
- type: 'string',
709
- choices: ['vectors', 'text', 'patterns', 'all'],
710
- default: 'all'
711
- },
712
- {
713
- name: 'quantize',
714
- short: 'q',
715
- description: 'Enable vector quantization (reduces memory 4-32x)',
716
- type: 'boolean',
717
- default: false
718
- },
719
- {
720
- name: 'bits',
721
- description: 'Quantization bits (4, 8, 16)',
722
- type: 'number',
723
- default: 8
724
- },
725
- {
726
- name: 'rebuild-index',
727
- short: 'r',
728
- description: 'Rebuild HNSW index after compression',
729
- type: 'boolean',
730
- default: true
731
- }
732
- ],
733
- examples: [
734
- { command: 'claude-flow memory compress', description: 'Balanced compression' },
735
- { command: 'claude-flow memory compress --quantize --bits 4', description: '4-bit quantization (32x reduction)' },
736
- { command: 'claude-flow memory compress -l max -t vectors', description: 'Max compression on vectors' }
737
- ],
738
- action: async (ctx) => {
739
- const level = ctx.flags.level || 'balanced';
740
- const target = ctx.flags.target || 'all';
741
- const quantize = ctx.flags.quantize;
742
- const bits = ctx.flags.bits || 8;
743
- const rebuildIndex = ctx.flags.rebuildIndex ?? true;
744
- output.writeln();
745
- output.writeln(output.bold('Memory Compression'));
746
- output.writeln(output.dim(`Level: ${level}, Target: ${target}, Quantize: ${quantize ? `${bits}-bit` : 'no'}`));
747
- output.writeln();
748
- const spinner = output.createSpinner({ text: 'Analyzing current storage...', spinner: 'dots' });
749
- spinner.start();
750
- try {
751
- const result = await callMCPTool('memory/compress', {
752
- level,
753
- target,
754
- quantize,
755
- bits,
756
- rebuildIndex,
757
- });
758
- spinner.succeed('Compression complete');
759
- if (ctx.flags.format === 'json') {
760
- output.printJson(result);
761
- return { success: true, data: result };
762
- }
763
- output.writeln();
764
- output.writeln(output.bold('Storage Comparison'));
765
- output.printTable({
766
- columns: [
767
- { key: 'category', header: 'Category', width: 15 },
768
- { key: 'before', header: 'Before', width: 12, align: 'right' },
769
- { key: 'after', header: 'After', width: 12, align: 'right' },
770
- { key: 'saved', header: 'Saved', width: 12, align: 'right' }
771
- ],
772
- data: [
773
- { category: 'Vectors', before: result.before.vectorsSize, after: result.after.vectorsSize, saved: '-' },
774
- { category: 'Text', before: result.before.textSize, after: result.after.textSize, saved: '-' },
775
- { category: 'Patterns', before: result.before.patternsSize, after: result.after.patternsSize, saved: '-' },
776
- { category: 'Index', before: result.before.indexSize, after: result.after.indexSize, saved: '-' },
777
- { category: output.bold('Total'), before: result.before.totalSize, after: result.after.totalSize, saved: output.success(result.compression.formattedSaved) }
778
- ]
779
- });
780
- output.writeln();
781
- output.printBox([
782
- `Compression Ratio: ${result.compression.ratio.toFixed(2)}x`,
783
- `Space Saved: ${result.compression.formattedSaved}`,
784
- `Quantization: ${result.compression.quantizationApplied ? `Yes (${bits}-bit)` : 'No'}`,
785
- `Index Rebuilt: ${result.compression.indexRebuilt ? 'Yes' : 'No'}`,
786
- `Duration: ${(result.duration / 1000).toFixed(1)}s`
787
- ].join('\n'), 'Results');
788
- if (result.performance) {
789
- output.writeln();
790
- output.writeln(output.bold('Performance Impact'));
791
- output.printList([
792
- `Search latency: ${result.performance.searchLatencyBefore.toFixed(2)}ms → ${result.performance.searchLatencyAfter.toFixed(2)}ms`,
793
- `Speedup: ${output.success(result.performance.searchSpeedup)}`
794
- ]);
795
- }
796
- return { success: true, data: result };
797
- }
798
- catch (error) {
799
- spinner.fail('Compression failed');
800
- if (error instanceof MCPClientError) {
801
- output.printError(`Compression error: ${error.message}`);
802
- }
803
- else {
804
- output.printError(`Unexpected error: ${String(error)}`);
805
- }
806
- return { success: false, exitCode: 1 };
807
- }
808
- }
809
- };
810
- // Export command
811
- const exportCommand = {
812
- name: 'export',
813
- description: 'Export memory to file',
814
- options: [
815
- {
816
- name: 'output',
817
- short: 'o',
818
- description: 'Output file path',
819
- type: 'string',
820
- required: true
821
- },
822
- {
823
- name: 'format',
824
- short: 'f',
825
- description: 'Export format (json, csv, binary)',
826
- type: 'string',
827
- choices: ['json', 'csv', 'binary'],
828
- default: 'json'
829
- },
830
- {
831
- name: 'namespace',
832
- short: 'n',
833
- description: 'Export specific namespace',
834
- type: 'string'
835
- },
836
- {
837
- name: 'include-vectors',
838
- description: 'Include vector embeddings',
839
- type: 'boolean',
840
- default: true
841
- }
842
- ],
843
- examples: [
844
- { command: 'claude-flow memory export -o ./backup.json', description: 'Export all to JSON' },
845
- { command: 'claude-flow memory export -o ./data.csv -f csv', description: 'Export to CSV' }
846
- ],
847
- action: async (ctx) => {
848
- const outputPath = ctx.flags.output;
849
- const format = ctx.flags.format || 'json';
850
- if (!outputPath) {
851
- output.printError('Output path is required. Use --output or -o');
852
- return { success: false, exitCode: 1 };
853
- }
854
- output.printInfo(`Exporting memory to ${outputPath}...`);
855
- try {
856
- const result = await callMCPTool('memory/export', {
857
- outputPath,
858
- format,
859
- namespace: ctx.flags.namespace,
860
- includeVectors: ctx.flags.includeVectors ?? true,
861
- });
862
- output.printSuccess(`Exported to ${result.outputPath}`);
863
- output.printList([
864
- `Entries: ${result.exported.entries}`,
865
- `Vectors: ${result.exported.vectors}`,
866
- `Patterns: ${result.exported.patterns}`,
867
- `File size: ${result.fileSize}`
868
- ]);
869
- return { success: true, data: result };
870
- }
871
- catch (error) {
872
- if (error instanceof MCPClientError) {
873
- output.printError(`Export error: ${error.message}`);
874
- }
875
- else {
876
- output.printError(`Unexpected error: ${String(error)}`);
877
- }
878
- return { success: false, exitCode: 1 };
879
- }
880
- }
881
- };
882
- // Import command
883
- const importCommand = {
884
- name: 'import',
885
- description: 'Import memory from file',
886
- options: [
887
- {
888
- name: 'input',
889
- short: 'i',
890
- description: 'Input file path',
891
- type: 'string',
892
- required: true
893
- },
894
- {
895
- name: 'merge',
896
- short: 'm',
897
- description: 'Merge with existing (skip duplicates)',
898
- type: 'boolean',
899
- default: true
900
- },
901
- {
902
- name: 'namespace',
903
- short: 'n',
904
- description: 'Import into specific namespace',
905
- type: 'string'
906
- }
907
- ],
908
- examples: [
909
- { command: 'claude-flow memory import -i ./backup.json', description: 'Import from file' },
910
- { command: 'claude-flow memory import -i ./data.json -n archive', description: 'Import to namespace' }
911
- ],
912
- action: async (ctx) => {
913
- const inputPath = ctx.flags.input || ctx.args[0];
914
- if (!inputPath) {
915
- output.printError('Input path is required. Use --input or -i');
916
- return { success: false, exitCode: 1 };
917
- }
918
- output.printInfo(`Importing memory from ${inputPath}...`);
919
- try {
920
- const result = await callMCPTool('memory/import', {
921
- inputPath,
922
- merge: ctx.flags.merge ?? true,
923
- namespace: ctx.flags.namespace,
924
- });
925
- output.printSuccess(`Imported from ${result.inputPath}`);
926
- output.printList([
927
- `Entries: ${result.imported.entries}`,
928
- `Vectors: ${result.imported.vectors}`,
929
- `Patterns: ${result.imported.patterns}`,
930
- `Skipped (duplicates): ${result.skipped}`,
931
- `Duration: ${result.duration}ms`
932
- ]);
933
- return { success: true, data: result };
934
- }
935
- catch (error) {
936
- if (error instanceof MCPClientError) {
937
- output.printError(`Import error: ${error.message}`);
938
- }
939
- else {
940
- output.printError(`Unexpected error: ${String(error)}`);
941
- }
942
- return { success: false, exitCode: 1 };
943
- }
944
- }
945
- };
946
- // Main memory command
947
- export const memoryCommand = {
948
- name: 'memory',
949
- description: 'Memory management commands',
950
- subcommands: [storeCommand, retrieveCommand, searchCommand, listCommand, deleteCommand, statsCommand, configureCommand, cleanupCommand, compressCommand, exportCommand, importCommand],
951
- options: [],
952
- examples: [
953
- { command: 'claude-flow memory store -k "key" -v "value"', description: 'Store data' },
954
- { command: 'claude-flow memory search -q "auth patterns"', description: 'Search memory' },
955
- { command: 'claude-flow memory stats', description: 'Show statistics' }
956
- ],
957
- action: async (ctx) => {
958
- output.writeln();
959
- output.writeln(output.bold('Memory Management Commands'));
960
- output.writeln();
961
- output.writeln('Usage: claude-flow memory <subcommand> [options]');
962
- output.writeln();
963
- output.writeln('Subcommands:');
964
- output.printList([
965
- `${output.highlight('store')} - Store data in memory`,
966
- `${output.highlight('retrieve')} - Retrieve data from memory`,
967
- `${output.highlight('search')} - Semantic/vector search`,
968
- `${output.highlight('list')} - List memory entries`,
969
- `${output.highlight('delete')} - Delete memory entry`,
970
- `${output.highlight('stats')} - Show statistics`,
971
- `${output.highlight('configure')} - Configure backend`
972
- ]);
973
- return { success: true };
974
- }
975
- };
976
- export default memoryCommand;
977
- //# sourceMappingURL=memory.js.map