@sylphx/flow 1.0.1 → 1.0.3

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 (229) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/package.json +10 -9
  3. package/src/commands/codebase-command.ts +168 -0
  4. package/src/commands/flow-command.ts +1137 -0
  5. package/src/commands/flow-orchestrator.ts +296 -0
  6. package/src/commands/hook-command.ts +444 -0
  7. package/src/commands/init-command.ts +92 -0
  8. package/src/commands/init-core.ts +322 -0
  9. package/src/commands/knowledge-command.ts +161 -0
  10. package/src/commands/run-command.ts +120 -0
  11. package/src/components/benchmark-monitor.tsx +331 -0
  12. package/src/components/reindex-progress.tsx +261 -0
  13. package/src/composables/functional/index.ts +14 -0
  14. package/src/composables/functional/useEnvironment.ts +171 -0
  15. package/src/composables/functional/useFileSystem.ts +139 -0
  16. package/src/composables/index.ts +5 -0
  17. package/src/composables/useEnv.ts +13 -0
  18. package/src/composables/useRuntimeConfig.ts +27 -0
  19. package/src/composables/useTargetConfig.ts +45 -0
  20. package/src/config/ai-config.ts +376 -0
  21. package/src/config/constants.ts +35 -0
  22. package/src/config/index.ts +27 -0
  23. package/src/config/rules.ts +43 -0
  24. package/src/config/servers.ts +371 -0
  25. package/src/config/targets.ts +126 -0
  26. package/src/core/agent-loader.ts +141 -0
  27. package/src/core/agent-manager.ts +174 -0
  28. package/src/core/ai-sdk.ts +603 -0
  29. package/src/core/app-factory.ts +381 -0
  30. package/src/core/builtin-agents.ts +9 -0
  31. package/src/core/command-system.ts +550 -0
  32. package/src/core/config-system.ts +550 -0
  33. package/src/core/connection-pool.ts +390 -0
  34. package/src/core/di-container.ts +155 -0
  35. package/src/core/error-handling.ts +519 -0
  36. package/src/core/formatting/bytes.test.ts +115 -0
  37. package/src/core/formatting/bytes.ts +64 -0
  38. package/src/core/functional/async.ts +313 -0
  39. package/src/core/functional/either.ts +109 -0
  40. package/src/core/functional/error-handler.ts +135 -0
  41. package/src/core/functional/error-types.ts +311 -0
  42. package/src/core/functional/index.ts +19 -0
  43. package/src/core/functional/option.ts +142 -0
  44. package/src/core/functional/pipe.ts +189 -0
  45. package/src/core/functional/result.ts +204 -0
  46. package/src/core/functional/validation.ts +138 -0
  47. package/src/core/headless-display.ts +96 -0
  48. package/src/core/index.ts +6 -0
  49. package/src/core/installers/file-installer.ts +303 -0
  50. package/src/core/installers/mcp-installer.ts +213 -0
  51. package/src/core/interfaces/index.ts +22 -0
  52. package/src/core/interfaces/repository.interface.ts +91 -0
  53. package/src/core/interfaces/service.interface.ts +133 -0
  54. package/src/core/interfaces.ts +129 -0
  55. package/src/core/loop-controller.ts +200 -0
  56. package/src/core/result.ts +351 -0
  57. package/src/core/rule-loader.ts +147 -0
  58. package/src/core/rule-manager.ts +240 -0
  59. package/src/core/service-config.ts +252 -0
  60. package/src/core/session-service.ts +121 -0
  61. package/src/core/state-detector.ts +389 -0
  62. package/src/core/storage-factory.ts +115 -0
  63. package/src/core/stream-handler.ts +288 -0
  64. package/src/core/target-manager.ts +161 -0
  65. package/src/core/type-utils.ts +427 -0
  66. package/src/core/unified-storage.ts +456 -0
  67. package/src/core/upgrade-manager.ts +300 -0
  68. package/src/core/validation/limit.test.ts +155 -0
  69. package/src/core/validation/limit.ts +46 -0
  70. package/src/core/validation/query.test.ts +44 -0
  71. package/src/core/validation/query.ts +20 -0
  72. package/src/db/auto-migrate.ts +322 -0
  73. package/src/db/base-database-client.ts +144 -0
  74. package/src/db/cache-db.ts +218 -0
  75. package/src/db/cache-schema.ts +75 -0
  76. package/src/db/database.ts +70 -0
  77. package/src/db/index.ts +252 -0
  78. package/src/db/memory-db.ts +153 -0
  79. package/src/db/memory-schema.ts +29 -0
  80. package/src/db/schema.ts +289 -0
  81. package/src/db/session-repository.ts +733 -0
  82. package/src/domains/codebase/index.ts +5 -0
  83. package/src/domains/codebase/tools.ts +139 -0
  84. package/src/domains/index.ts +8 -0
  85. package/src/domains/knowledge/index.ts +10 -0
  86. package/src/domains/knowledge/resources.ts +537 -0
  87. package/src/domains/knowledge/tools.ts +174 -0
  88. package/src/domains/utilities/index.ts +6 -0
  89. package/src/domains/utilities/time/index.ts +5 -0
  90. package/src/domains/utilities/time/tools.ts +291 -0
  91. package/src/index.ts +211 -0
  92. package/src/services/agent-service.ts +273 -0
  93. package/src/services/claude-config-service.ts +252 -0
  94. package/src/services/config-service.ts +258 -0
  95. package/src/services/evaluation-service.ts +271 -0
  96. package/src/services/functional/evaluation-logic.ts +296 -0
  97. package/src/services/functional/file-processor.ts +273 -0
  98. package/src/services/functional/index.ts +12 -0
  99. package/src/services/index.ts +13 -0
  100. package/src/services/mcp-service.ts +432 -0
  101. package/src/services/memory.service.ts +476 -0
  102. package/src/services/search/base-indexer.ts +156 -0
  103. package/src/services/search/codebase-indexer-types.ts +38 -0
  104. package/src/services/search/codebase-indexer.ts +647 -0
  105. package/src/services/search/embeddings-provider.ts +455 -0
  106. package/src/services/search/embeddings.ts +316 -0
  107. package/src/services/search/functional-indexer.ts +323 -0
  108. package/src/services/search/index.ts +27 -0
  109. package/src/services/search/indexer.ts +380 -0
  110. package/src/services/search/knowledge-indexer.ts +422 -0
  111. package/src/services/search/semantic-search.ts +244 -0
  112. package/src/services/search/tfidf.ts +559 -0
  113. package/src/services/search/unified-search-service.ts +888 -0
  114. package/src/services/smart-config-service.ts +385 -0
  115. package/src/services/storage/cache-storage.ts +487 -0
  116. package/src/services/storage/drizzle-storage.ts +581 -0
  117. package/src/services/storage/index.ts +15 -0
  118. package/src/services/storage/lancedb-vector-storage.ts +494 -0
  119. package/src/services/storage/memory-storage.ts +268 -0
  120. package/src/services/storage/separated-storage.ts +467 -0
  121. package/src/services/storage/vector-storage.ts +13 -0
  122. package/src/shared/agents/index.ts +63 -0
  123. package/src/shared/files/index.ts +99 -0
  124. package/src/shared/index.ts +32 -0
  125. package/src/shared/logging/index.ts +24 -0
  126. package/src/shared/processing/index.ts +153 -0
  127. package/src/shared/types/index.ts +25 -0
  128. package/src/targets/claude-code.ts +574 -0
  129. package/src/targets/functional/claude-code-logic.ts +185 -0
  130. package/src/targets/functional/index.ts +6 -0
  131. package/src/targets/opencode.ts +529 -0
  132. package/src/types/agent.types.ts +32 -0
  133. package/src/types/api/batch.ts +108 -0
  134. package/src/types/api/errors.ts +118 -0
  135. package/src/types/api/index.ts +55 -0
  136. package/src/types/api/requests.ts +76 -0
  137. package/src/types/api/responses.ts +180 -0
  138. package/src/types/api/websockets.ts +85 -0
  139. package/src/types/api.types.ts +9 -0
  140. package/src/types/benchmark.ts +49 -0
  141. package/src/types/cli.types.ts +87 -0
  142. package/src/types/common.types.ts +35 -0
  143. package/src/types/database.types.ts +510 -0
  144. package/src/types/mcp-config.types.ts +448 -0
  145. package/src/types/mcp.types.ts +69 -0
  146. package/src/types/memory-types.ts +63 -0
  147. package/src/types/provider.types.ts +28 -0
  148. package/src/types/rule.types.ts +24 -0
  149. package/src/types/session.types.ts +214 -0
  150. package/src/types/target-config.types.ts +295 -0
  151. package/src/types/target.types.ts +140 -0
  152. package/src/types/todo.types.ts +25 -0
  153. package/src/types.ts +40 -0
  154. package/src/utils/advanced-tokenizer.ts +191 -0
  155. package/src/utils/agent-enhancer.ts +114 -0
  156. package/src/utils/ai-model-fetcher.ts +19 -0
  157. package/src/utils/async-file-operations.ts +516 -0
  158. package/src/utils/audio-player.ts +345 -0
  159. package/src/utils/cli-output.ts +266 -0
  160. package/src/utils/codebase-helpers.ts +211 -0
  161. package/src/utils/console-ui.ts +79 -0
  162. package/src/utils/database-errors.ts +140 -0
  163. package/src/utils/debug-logger.ts +49 -0
  164. package/src/utils/error-handler.ts +53 -0
  165. package/src/utils/file-operations.ts +310 -0
  166. package/src/utils/file-scanner.ts +259 -0
  167. package/src/utils/functional/array.ts +355 -0
  168. package/src/utils/functional/index.ts +15 -0
  169. package/src/utils/functional/object.ts +279 -0
  170. package/src/utils/functional/string.ts +281 -0
  171. package/src/utils/functional.ts +543 -0
  172. package/src/utils/help.ts +20 -0
  173. package/src/utils/immutable-cache.ts +106 -0
  174. package/src/utils/index.ts +78 -0
  175. package/src/utils/jsonc.ts +158 -0
  176. package/src/utils/logger.ts +396 -0
  177. package/src/utils/mcp-config.ts +249 -0
  178. package/src/utils/memory-tui.ts +414 -0
  179. package/src/utils/models-dev.ts +91 -0
  180. package/src/utils/notifications.ts +169 -0
  181. package/src/utils/object-utils.ts +51 -0
  182. package/src/utils/parallel-operations.ts +487 -0
  183. package/src/utils/paths.ts +143 -0
  184. package/src/utils/process-manager.ts +155 -0
  185. package/src/utils/prompts.ts +120 -0
  186. package/src/utils/search-tool-builder.ts +214 -0
  187. package/src/utils/secret-utils.ts +179 -0
  188. package/src/utils/security.ts +537 -0
  189. package/src/utils/session-manager.ts +168 -0
  190. package/src/utils/session-title.ts +87 -0
  191. package/src/utils/settings.ts +182 -0
  192. package/src/utils/simplified-errors.ts +410 -0
  193. package/src/utils/sync-utils.ts +159 -0
  194. package/src/utils/target-config.ts +570 -0
  195. package/src/utils/target-utils.ts +394 -0
  196. package/src/utils/template-engine.ts +94 -0
  197. package/src/utils/test-audio.ts +71 -0
  198. package/src/utils/todo-context.ts +46 -0
  199. package/src/utils/token-counter.ts +288 -0
  200. package/dist/index.d.ts +0 -10
  201. package/dist/index.js +0 -59554
  202. package/dist/lancedb.linux-x64-gnu-b7f0jgsz.node +0 -0
  203. package/dist/lancedb.linux-x64-musl-tgcv22rx.node +0 -0
  204. package/dist/shared/chunk-25dwp0dp.js +0 -89
  205. package/dist/shared/chunk-3pjb6063.js +0 -208
  206. package/dist/shared/chunk-4d6ydpw7.js +0 -2854
  207. package/dist/shared/chunk-4wjcadjk.js +0 -225
  208. package/dist/shared/chunk-5j4w74t6.js +0 -30
  209. package/dist/shared/chunk-5j8m3dh3.js +0 -58
  210. package/dist/shared/chunk-5thh3qem.js +0 -91
  211. package/dist/shared/chunk-6g9xy73m.js +0 -252
  212. package/dist/shared/chunk-7eq34c42.js +0 -23
  213. package/dist/shared/chunk-c2gwgx3r.js +0 -115
  214. package/dist/shared/chunk-cjd3mk4c.js +0 -1320
  215. package/dist/shared/chunk-g5cv6703.js +0 -368
  216. package/dist/shared/chunk-hpkhykhq.js +0 -574
  217. package/dist/shared/chunk-m2322pdk.js +0 -122
  218. package/dist/shared/chunk-nd5fdvaq.js +0 -26
  219. package/dist/shared/chunk-pgd3m6zf.js +0 -108
  220. package/dist/shared/chunk-qk8n91hw.js +0 -494
  221. package/dist/shared/chunk-rkkn8szp.js +0 -16855
  222. package/dist/shared/chunk-t16rfxh0.js +0 -61
  223. package/dist/shared/chunk-t4fbfa5v.js +0 -19
  224. package/dist/shared/chunk-t77h86w6.js +0 -276
  225. package/dist/shared/chunk-v0ez4aef.js +0 -71
  226. package/dist/shared/chunk-v29j2r3s.js +0 -32051
  227. package/dist/shared/chunk-vfbc6ew5.js +0 -765
  228. package/dist/shared/chunk-vmeqwm1c.js +0 -204
  229. package/dist/shared/chunk-x66eh37x.js +0 -137
@@ -0,0 +1,510 @@
1
+ import { z } from 'zod';
2
+
3
+ // ============================================================================
4
+ // DATABASE ENTITIES AND OPERATIONS
5
+ // ============================================================================
6
+
7
+ /**
8
+ * Base database entity interface
9
+ */
10
+ export interface BaseEntity {
11
+ /** Unique identifier */
12
+ id: string;
13
+ /** Creation timestamp */
14
+ createdAt: string;
15
+ /** Last updated timestamp */
16
+ updatedAt: string;
17
+ /** Entity version for optimistic locking */
18
+ version?: number;
19
+ /** Soft delete flag */
20
+ deletedAt?: string;
21
+ /** Entity metadata */
22
+ metadata?: Record<string, unknown>;
23
+ }
24
+
25
+ /**
26
+ * Memory storage entry
27
+ */
28
+ export interface MemoryStorageEntry extends BaseEntity {
29
+ /** Storage namespace */
30
+ namespace: string;
31
+ /** Entry key */
32
+ key: string;
33
+ /** Entry value */
34
+ value: unknown;
35
+ /** Value type for serialization */
36
+ valueType: 'string' | 'number' | 'boolean' | 'object' | 'array' | 'null';
37
+ /** Entry size in bytes */
38
+ size?: number;
39
+ /** Expiration timestamp */
40
+ expiresAt?: string;
41
+ /** Access count */
42
+ accessCount?: number;
43
+ /** Last accessed timestamp */
44
+ lastAccessedAt?: string;
45
+ }
46
+
47
+ /**
48
+ * Vector database entry
49
+ */
50
+ export interface VectorStorageEntry extends BaseEntity {
51
+ /** Entry content/text */
52
+ content: string;
53
+ /** Vector embedding */
54
+ embedding: number[];
55
+ /** Vector dimensions */
56
+ dimensions: number;
57
+ /** Source file path */
58
+ sourcePath?: string;
59
+ /** Content hash for deduplication */
60
+ contentHash?: string;
61
+ /** Entry type */
62
+ type: 'document' | 'code' | 'markdown' | 'text';
63
+ /** Language or format */
64
+ language?: string;
65
+ /** Token count */
66
+ tokenCount?: number;
67
+ /** Additional metadata */
68
+ metadata?: {
69
+ title?: string;
70
+ description?: string;
71
+ tags?: string[];
72
+ author?: string;
73
+ project?: string;
74
+ [key: string]: unknown;
75
+ };
76
+ }
77
+
78
+ /**
79
+ * Search index entry
80
+ */
81
+ export interface SearchIndexEntry extends BaseEntity {
82
+ /** Document ID */
83
+ documentId: string;
84
+ /** Term or token */
85
+ term: string;
86
+ /** Term frequency in document */
87
+ frequency: number;
88
+ /** Term position(s) in document */
89
+ positions?: number[];
90
+ /** Document field where term appears */
91
+ field?: 'title' | 'content' | 'metadata' | 'all';
92
+ /** TF-IDF score */
93
+ tfidfScore?: number;
94
+ /** Additional indexing metadata */
95
+ indexMetadata?: Record<string, unknown>;
96
+ }
97
+
98
+ /**
99
+ * Database health check result
100
+ */
101
+ export interface DatabaseHealthCheckResult {
102
+ /** Overall health status */
103
+ healthy: boolean;
104
+ /** Health check timestamp */
105
+ timestamp: string;
106
+ /** Error message if unhealthy */
107
+ error?: string;
108
+ /** Detailed health information */
109
+ details?: {
110
+ /** Connection status */
111
+ connection?: 'connected' | 'disconnected' | 'error';
112
+ /** Response time in milliseconds */
113
+ responseTime?: number;
114
+ /** Database size information */
115
+ size?: {
116
+ totalRecords: number;
117
+ totalSize: number;
118
+ indexes: number;
119
+ };
120
+ /** Memory usage */
121
+ memory?: {
122
+ used: number;
123
+ available: number;
124
+ percentage: number;
125
+ };
126
+ /** Additional metrics */
127
+ metrics?: Record<string, number | string>;
128
+ };
129
+ }
130
+
131
+ /**
132
+ * Database query options
133
+ */
134
+ export interface DatabaseQueryOptions {
135
+ /** Limit number of results */
136
+ limit?: number;
137
+ /** Offset for pagination */
138
+ offset?: number;
139
+ /** Sort order */
140
+ orderBy?: {
141
+ field: string;
142
+ direction: 'asc' | 'desc';
143
+ };
144
+ /** Filter conditions */
145
+ where?: Record<string, unknown>;
146
+ /** Fields to include/exclude */
147
+ select?: string[];
148
+ /** Include soft-deleted records */
149
+ includeDeleted?: boolean;
150
+ /** Query timeout in milliseconds */
151
+ timeout?: number;
152
+ }
153
+
154
+ /**
155
+ * Database transaction options
156
+ */
157
+ export interface DatabaseTransactionOptions {
158
+ /** Transaction isolation level */
159
+ isolation?: 'read-uncommitted' | 'read-committed' | 'repeatable-read' | 'serializable';
160
+ /** Transaction timeout in milliseconds */
161
+ timeout?: number;
162
+ /** Whether transaction is read-only */
163
+ readOnly?: boolean;
164
+ /** Transaction metadata */
165
+ metadata?: Record<string, unknown>;
166
+ }
167
+
168
+ /**
169
+ * Batch operation result
170
+ */
171
+ export interface BatchOperationResult<T = unknown> {
172
+ /** Number of successful operations */
173
+ successCount: number;
174
+ /** Number of failed operations */
175
+ failureCount: number;
176
+ /** Total operations attempted */
177
+ total: number;
178
+ /** Successful results */
179
+ successes: Array<{
180
+ index: number;
181
+ data?: T;
182
+ id?: string;
183
+ }>;
184
+ /** Failed operations */
185
+ failures: Array<{
186
+ index: number;
187
+ error: string;
188
+ data?: unknown;
189
+ }>;
190
+ /** Operation duration in milliseconds */
191
+ duration: number;
192
+ /** Operation timestamp */
193
+ timestamp: string;
194
+ }
195
+
196
+ /**
197
+ * Database migration entry
198
+ */
199
+ export interface DatabaseMigration extends BaseEntity {
200
+ /** Migration version */
201
+ version: string;
202
+ /** Migration name */
203
+ name: string;
204
+ /** Migration description */
205
+ description?: string;
206
+ /** Migration type */
207
+ type: 'schema' | 'data' | 'index' | 'config';
208
+ /** Migration status */
209
+ status: 'pending' | 'running' | 'completed' | 'failed' | 'rolled-back';
210
+ /** Migration script content */
211
+ script?: string;
212
+ /** Checksum for integrity verification */
213
+ checksum?: string;
214
+ /** Execution duration in milliseconds */
215
+ duration?: number;
216
+ /** Error message if failed */
217
+ error?: string;
218
+ }
219
+
220
+ // ============================================================================
221
+ // ZOD SCHEMAS FOR RUNTIME VALIDATION
222
+ // ============================================================================
223
+
224
+ /**
225
+ * Zod schema for BaseEntity
226
+ */
227
+ export const BaseEntitySchema = z.object({
228
+ id: z.string(),
229
+ createdAt: z.string(),
230
+ updatedAt: z.string(),
231
+ version: z.number().optional(),
232
+ deletedAt: z.string().optional(),
233
+ metadata: z.record(z.unknown()).optional(),
234
+ });
235
+
236
+ /**
237
+ * Zod schema for MemoryStorageEntry
238
+ */
239
+ export const MemoryStorageEntrySchema = BaseEntitySchema.extend({
240
+ namespace: z.string(),
241
+ key: z.string(),
242
+ value: z.unknown(),
243
+ valueType: z.enum(['string', 'number', 'boolean', 'object', 'array', 'null']),
244
+ size: z.number().optional(),
245
+ expiresAt: z.string().optional(),
246
+ accessCount: z.number().optional(),
247
+ lastAccessedAt: z.string().optional(),
248
+ });
249
+
250
+ /**
251
+ * Zod schema for VectorStorageEntry
252
+ */
253
+ export const VectorStorageEntrySchema = BaseEntitySchema.extend({
254
+ content: z.string(),
255
+ embedding: z.array(z.number()),
256
+ dimensions: z.number(),
257
+ sourcePath: z.string().optional(),
258
+ contentHash: z.string().optional(),
259
+ type: z.enum(['document', 'code', 'markdown', 'text']),
260
+ language: z.string().optional(),
261
+ tokenCount: z.number().optional(),
262
+ metadata: z
263
+ .object({
264
+ title: z.string().optional(),
265
+ description: z.string().optional(),
266
+ tags: z.array(z.string()).optional(),
267
+ author: z.string().optional(),
268
+ project: z.string().optional(),
269
+ })
270
+ .catchall(z.unknown())
271
+ .optional(),
272
+ });
273
+
274
+ /**
275
+ * Zod schema for SearchIndexEntry
276
+ */
277
+ export const SearchIndexEntrySchema = BaseEntitySchema.extend({
278
+ documentId: z.string(),
279
+ term: z.string(),
280
+ frequency: z.number(),
281
+ positions: z.array(z.number()).optional(),
282
+ field: z.enum(['title', 'content', 'metadata', 'all']).optional(),
283
+ tfidfScore: z.number().optional(),
284
+ indexMetadata: z.record(z.unknown()).optional(),
285
+ });
286
+
287
+ /**
288
+ * Zod schema for DatabaseHealthCheckResult
289
+ */
290
+ export const DatabaseHealthCheckResultSchema = z.object({
291
+ healthy: z.boolean(),
292
+ timestamp: z.string(),
293
+ error: z.string().optional(),
294
+ details: z
295
+ .object({
296
+ connection: z.enum(['connected', 'disconnected', 'error']).optional(),
297
+ responseTime: z.number().optional(),
298
+ size: z
299
+ .object({
300
+ totalRecords: z.number(),
301
+ totalSize: z.number(),
302
+ indexes: z.number(),
303
+ })
304
+ .optional(),
305
+ memory: z
306
+ .object({
307
+ used: z.number(),
308
+ available: z.number(),
309
+ percentage: z.number(),
310
+ })
311
+ .optional(),
312
+ metrics: z.record(z.union([z.number(), z.string()])).optional(),
313
+ })
314
+ .optional(),
315
+ });
316
+
317
+ /**
318
+ * Zod schema for DatabaseQueryOptions
319
+ */
320
+ export const DatabaseQueryOptionsSchema = z.object({
321
+ limit: z.number().optional(),
322
+ offset: z.number().optional(),
323
+ orderBy: z
324
+ .object({
325
+ field: z.string(),
326
+ direction: z.enum(['asc', 'desc']),
327
+ })
328
+ .optional(),
329
+ where: z.record(z.unknown()).optional(),
330
+ select: z.array(z.string()).optional(),
331
+ includeDeleted: z.boolean().optional(),
332
+ timeout: z.number().optional(),
333
+ });
334
+
335
+ /**
336
+ * Zod schema for DatabaseTransactionOptions
337
+ */
338
+ export const DatabaseTransactionOptionsSchema = z.object({
339
+ isolation: z
340
+ .enum(['read-uncommitted', 'read-committed', 'repeatable-read', 'serializable'])
341
+ .optional(),
342
+ timeout: z.number().optional(),
343
+ readOnly: z.boolean().optional(),
344
+ metadata: z.record(z.unknown()).optional(),
345
+ });
346
+
347
+ /**
348
+ * Zod schema for BatchOperationResult
349
+ */
350
+ export const BatchOperationResultSchema = z.object({
351
+ successCount: z.number(),
352
+ failureCount: z.number(),
353
+ total: z.number(),
354
+ successes: z.array(
355
+ z.object({
356
+ index: z.number(),
357
+ data: z.unknown().optional(),
358
+ id: z.string().optional(),
359
+ })
360
+ ),
361
+ failures: z.array(
362
+ z.object({
363
+ index: z.number(),
364
+ error: z.string(),
365
+ data: z.unknown().optional(),
366
+ })
367
+ ),
368
+ duration: z.number(),
369
+ timestamp: z.string(),
370
+ });
371
+
372
+ /**
373
+ * Zod schema for DatabaseMigration
374
+ */
375
+ export const DatabaseMigrationSchema = BaseEntitySchema.extend({
376
+ version: z.string(),
377
+ name: z.string(),
378
+ description: z.string().optional(),
379
+ type: z.enum(['schema', 'data', 'index', 'config']),
380
+ status: z.enum(['pending', 'running', 'completed', 'failed', 'rolled-back']),
381
+ script: z.string().optional(),
382
+ checksum: z.string().optional(),
383
+ duration: z.number().optional(),
384
+ error: z.string().optional(),
385
+ });
386
+
387
+ // ============================================================================
388
+ // TYPE GUARDS FOR RUNTIME TYPE CHECKING
389
+ // ============================================================================
390
+
391
+ /**
392
+ * Type guard to check if value is BaseEntity
393
+ */
394
+ export function isBaseEntity(value: unknown): value is BaseEntity {
395
+ return BaseEntitySchema.safeParse(value).success;
396
+ }
397
+
398
+ /**
399
+ * Type guard to check if value is MemoryStorageEntry
400
+ */
401
+ export function isMemoryStorageEntry(value: unknown): value is MemoryStorageEntry {
402
+ return MemoryStorageEntrySchema.safeParse(value).success;
403
+ }
404
+
405
+ /**
406
+ * Type guard to check if value is VectorStorageEntry
407
+ */
408
+ export function isVectorStorageEntry(value: unknown): value is VectorStorageEntry {
409
+ return VectorStorageEntrySchema.safeParse(value).success;
410
+ }
411
+
412
+ /**
413
+ * Type guard to check if value is SearchIndexEntry
414
+ */
415
+ export function isSearchIndexEntry(value: unknown): value is SearchIndexEntry {
416
+ return SearchIndexEntrySchema.safeParse(value).success;
417
+ }
418
+
419
+ /**
420
+ * Type guard to check if value is DatabaseHealthCheckResult
421
+ */
422
+ export function isDatabaseHealthCheckResult(value: unknown): value is DatabaseHealthCheckResult {
423
+ return DatabaseHealthCheckResultSchema.safeParse(value).success;
424
+ }
425
+
426
+ /**
427
+ * Type guard to check if value is DatabaseQueryOptions
428
+ */
429
+ export function isDatabaseQueryOptions(value: unknown): value is DatabaseQueryOptions {
430
+ return DatabaseQueryOptionsSchema.safeParse(value).success;
431
+ }
432
+
433
+ /**
434
+ * Type guard to check if value is BatchOperationResult
435
+ */
436
+ export function isBatchOperationResult(value: unknown): value is BatchOperationResult {
437
+ return BatchOperationResultSchema.safeParse(value).success;
438
+ }
439
+
440
+ /**
441
+ * Type guard to check if value is DatabaseMigration
442
+ */
443
+ export function isDatabaseMigration(value: unknown): value is DatabaseMigration {
444
+ return DatabaseMigrationSchema.safeParse(value).success;
445
+ }
446
+
447
+ // ============================================================================
448
+ // UTILITY TYPES AND FUNCTIONS
449
+ // ============================================================================
450
+
451
+ /**
452
+ * Generic database result wrapper
453
+ */
454
+ export interface DatabaseResult<T = unknown> {
455
+ /** Success status */
456
+ success: boolean;
457
+ /** Result data */
458
+ data?: T;
459
+ /** Error information */
460
+ error?: {
461
+ code: string;
462
+ message: string;
463
+ details?: Record<string, unknown>;
464
+ };
465
+ /** Result metadata */
466
+ metadata?: {
467
+ executionTime: number;
468
+ timestamp: string;
469
+ affectedRows?: number;
470
+ };
471
+ }
472
+
473
+ /**
474
+ * Type for database event listeners
475
+ */
476
+ export type DatabaseEventListener<T = unknown> = (event: DatabaseEvent<T>) => void;
477
+
478
+ /**
479
+ * Database event interface
480
+ */
481
+ export interface DatabaseEvent<T = unknown> {
482
+ /** Event type */
483
+ type: 'insert' | 'update' | 'delete' | 'query' | 'transaction' | 'error';
484
+ /** Event timestamp */
485
+ timestamp: string;
486
+ /** Event data */
487
+ data?: T;
488
+ /** Event metadata */
489
+ metadata?: Record<string, unknown>;
490
+ }
491
+
492
+ /**
493
+ * Create a safe database result
494
+ */
495
+ export function createDatabaseResult<T>(
496
+ success: boolean,
497
+ data?: T,
498
+ error?: { code: string; message: string; details?: Record<string, unknown> },
499
+ metadata?: { executionTime: number; timestamp: string; affectedRows?: number }
500
+ ): DatabaseResult<T> {
501
+ return {
502
+ success,
503
+ data,
504
+ error,
505
+ metadata: metadata || {
506
+ executionTime: 0,
507
+ timestamp: new Date().toISOString(),
508
+ },
509
+ };
510
+ }