@triedotdev/mcp 1.0.121 → 1.0.122

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 (43) hide show
  1. package/dist/chat-store-R46BCMBW.js +15 -0
  2. package/dist/{chunk-GPLRFTMB.js → chunk-3BVNB3GY.js} +4 -4
  3. package/dist/{chunk-PPZYVTUO.js → chunk-6LD7OPJL.js} +5 -5
  4. package/dist/{chunk-5TQ7J7UI.js → chunk-7A5RLKZY.js} +8 -8
  5. package/dist/{chunk-7BY2KVIN.js → chunk-ANQPXOT2.js} +440 -71
  6. package/dist/chunk-ANQPXOT2.js.map +1 -0
  7. package/dist/{chunk-IQBHPTV7.js → chunk-EOLHWFDG.js} +4 -4
  8. package/dist/{chunk-FNW7Z7ZS.js → chunk-F4ZIAHTZ.js} +3 -3
  9. package/dist/chunk-HWXZ3E7B.js +347 -0
  10. package/dist/chunk-HWXZ3E7B.js.map +1 -0
  11. package/dist/{chunk-Y52SNUW5.js → chunk-JG7XVS53.js} +11 -3
  12. package/dist/{chunk-Y52SNUW5.js.map → chunk-JG7XVS53.js.map} +1 -1
  13. package/dist/{chunk-PRFHN2X6.js → chunk-K5EXATBF.js} +2 -2
  14. package/dist/{chunk-4BGAVEO6.js → chunk-UHMMANC2.js} +77 -338
  15. package/dist/chunk-UHMMANC2.js.map +1 -0
  16. package/dist/chunk-WS6OA7H6.js +266 -0
  17. package/dist/chunk-WS6OA7H6.js.map +1 -0
  18. package/dist/cli/main.js +6 -5
  19. package/dist/cli/main.js.map +1 -1
  20. package/dist/cli/yolo-daemon.js +12 -10
  21. package/dist/cli/yolo-daemon.js.map +1 -1
  22. package/dist/{goal-manager-JKTNFJQE.js → goal-manager-O446DRJI.js} +6 -5
  23. package/dist/{goal-validator-RD6QBQJB.js → goal-validator-XYA364W3.js} +3 -2
  24. package/dist/{goal-validator-RD6QBQJB.js.map → goal-validator-XYA364W3.js.map} +1 -1
  25. package/dist/{guardian-agent-ITZIDNQD.js → guardian-agent-KVLNECZ5.js} +9 -8
  26. package/dist/{hypothesis-PEVD2IJR.js → hypothesis-QFGZ5ITT.js} +6 -5
  27. package/dist/hypothesis-QFGZ5ITT.js.map +1 -0
  28. package/dist/index.js +16 -14
  29. package/dist/index.js.map +1 -1
  30. package/dist/insight-store-DZ5C3RFM.js +22 -0
  31. package/dist/insight-store-DZ5C3RFM.js.map +1 -0
  32. package/package.json +1 -1
  33. package/dist/chunk-4BGAVEO6.js.map +0 -1
  34. package/dist/chunk-7BY2KVIN.js.map +0 -1
  35. /package/dist/{goal-manager-JKTNFJQE.js.map → chat-store-R46BCMBW.js.map} +0 -0
  36. /package/dist/{chunk-GPLRFTMB.js.map → chunk-3BVNB3GY.js.map} +0 -0
  37. /package/dist/{chunk-PPZYVTUO.js.map → chunk-6LD7OPJL.js.map} +0 -0
  38. /package/dist/{chunk-5TQ7J7UI.js.map → chunk-7A5RLKZY.js.map} +0 -0
  39. /package/dist/{chunk-IQBHPTV7.js.map → chunk-EOLHWFDG.js.map} +0 -0
  40. /package/dist/{chunk-FNW7Z7ZS.js.map → chunk-F4ZIAHTZ.js.map} +0 -0
  41. /package/dist/{chunk-PRFHN2X6.js.map → chunk-K5EXATBF.js.map} +0 -0
  42. /package/dist/{guardian-agent-ITZIDNQD.js.map → goal-manager-O446DRJI.js.map} +0 -0
  43. /package/dist/{hypothesis-PEVD2IJR.js.map → guardian-agent-KVLNECZ5.js.map} +0 -0
@@ -0,0 +1,266 @@
1
+ // src/utils/backup-manager.ts
2
+ import { copyFile, readdir, unlink, readFile, stat } from "fs/promises";
3
+ import { existsSync } from "fs";
4
+ import { dirname, basename, join } from "path";
5
+ var BackupManager = class {
6
+ filePath;
7
+ maxBackups;
8
+ validator;
9
+ backupDir;
10
+ baseFileName;
11
+ constructor(filePath, options = {}) {
12
+ this.filePath = filePath;
13
+ this.maxBackups = options.maxBackups ?? 5;
14
+ this.validator = options.validator;
15
+ this.backupDir = dirname(filePath);
16
+ this.baseFileName = basename(filePath);
17
+ }
18
+ /**
19
+ * Create a backup of the current file
20
+ *
21
+ * @returns The backup file path, or null if source doesn't exist
22
+ */
23
+ async createBackup() {
24
+ if (!existsSync(this.filePath)) {
25
+ return null;
26
+ }
27
+ const timestamp = Date.now();
28
+ const backupPath = this.getBackupPath(timestamp);
29
+ await copyFile(this.filePath, backupPath);
30
+ await this.pruneOldBackups();
31
+ return backupPath;
32
+ }
33
+ /**
34
+ * List all backups sorted by timestamp (newest first)
35
+ */
36
+ async listBackups() {
37
+ if (!existsSync(this.backupDir)) {
38
+ return [];
39
+ }
40
+ const files = await readdir(this.backupDir);
41
+ const backupPattern = new RegExp(
42
+ `^${this.escapeRegex(this.baseFileName)}\\.backup\\.(\\d+)$`
43
+ );
44
+ const backups = [];
45
+ for (const file of files) {
46
+ const match = file.match(backupPattern);
47
+ if (match) {
48
+ const timestamp = parseInt(match[1], 10);
49
+ const backupPath = join(this.backupDir, file);
50
+ try {
51
+ const stats = await stat(backupPath);
52
+ backups.push({
53
+ path: backupPath,
54
+ timestamp,
55
+ size: stats.size
56
+ });
57
+ } catch {
58
+ }
59
+ }
60
+ }
61
+ return backups.sort((a, b) => b.timestamp - a.timestamp);
62
+ }
63
+ /**
64
+ * Find the first valid backup
65
+ *
66
+ * Iterates through backups from newest to oldest,
67
+ * returning the first one that passes validation.
68
+ *
69
+ * @returns Path to valid backup, or null if none found
70
+ */
71
+ async findValidBackup() {
72
+ const backups = await this.listBackups();
73
+ for (const backup of backups) {
74
+ if (await this.validateBackup(backup.path)) {
75
+ return backup.path;
76
+ }
77
+ }
78
+ return null;
79
+ }
80
+ /**
81
+ * Validate a backup file
82
+ *
83
+ * If a custom validator was provided, uses that.
84
+ * Otherwise, attempts JSON parse for .json files.
85
+ *
86
+ * @returns true if backup is valid
87
+ */
88
+ async validateBackup(backupPath) {
89
+ try {
90
+ const content = await readFile(backupPath, "utf-8");
91
+ if (this.validator) {
92
+ return this.validator(content);
93
+ }
94
+ if (this.filePath.endsWith(".json")) {
95
+ JSON.parse(content);
96
+ return true;
97
+ }
98
+ return content.length > 0;
99
+ } catch {
100
+ return false;
101
+ }
102
+ }
103
+ /**
104
+ * Recover from the most recent valid backup
105
+ *
106
+ * @returns true if recovery was successful
107
+ */
108
+ async recoverFromBackup() {
109
+ const validBackup = await this.findValidBackup();
110
+ if (!validBackup) {
111
+ return false;
112
+ }
113
+ await copyFile(validBackup, this.filePath);
114
+ return true;
115
+ }
116
+ /**
117
+ * Remove old backups beyond the max limit
118
+ */
119
+ async pruneOldBackups() {
120
+ const backups = await this.listBackups();
121
+ const toRemove = backups.slice(this.maxBackups);
122
+ for (const backup of toRemove) {
123
+ try {
124
+ await unlink(backup.path);
125
+ } catch {
126
+ }
127
+ }
128
+ }
129
+ /**
130
+ * Get the backup path for a given timestamp
131
+ */
132
+ getBackupPath(timestamp) {
133
+ return join(this.backupDir, `${this.baseFileName}.backup.${timestamp}`);
134
+ }
135
+ /**
136
+ * Escape special regex characters in a string
137
+ */
138
+ escapeRegex(str) {
139
+ return str.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
140
+ }
141
+ /**
142
+ * Get the number of existing backups
143
+ */
144
+ async getBackupCount() {
145
+ const backups = await this.listBackups();
146
+ return backups.length;
147
+ }
148
+ /**
149
+ * Get the most recent backup timestamp
150
+ */
151
+ async getLatestBackupTime() {
152
+ const backups = await this.listBackups();
153
+ return backups[0]?.timestamp ?? null;
154
+ }
155
+ /**
156
+ * Delete all backups
157
+ */
158
+ async clearBackups() {
159
+ const backups = await this.listBackups();
160
+ let deleted = 0;
161
+ for (const backup of backups) {
162
+ try {
163
+ await unlink(backup.path);
164
+ deleted++;
165
+ } catch {
166
+ }
167
+ }
168
+ return deleted;
169
+ }
170
+ };
171
+
172
+ // src/memory/validation.ts
173
+ import { z } from "zod";
174
+ var StoredIssueSchema = z.object({
175
+ id: z.string(),
176
+ hash: z.string(),
177
+ severity: z.string(),
178
+ issue: z.string(),
179
+ fix: z.string(),
180
+ file: z.string(),
181
+ line: z.number().optional(),
182
+ agent: z.string(),
183
+ category: z.string().optional(),
184
+ timestamp: z.string(),
185
+ project: z.string(),
186
+ resolved: z.boolean().optional(),
187
+ resolvedAt: z.string().optional()
188
+ });
189
+ var IssueIndexSchema = z.array(StoredIssueSchema);
190
+ var FixAppliedSchema = z.object({
191
+ project: z.string(),
192
+ timestamp: z.string(),
193
+ fix: z.string()
194
+ });
195
+ var GlobalPatternSchema = z.object({
196
+ id: z.string(),
197
+ pattern: z.string(),
198
+ description: z.string(),
199
+ severity: z.string(),
200
+ agent: z.string(),
201
+ occurrences: z.number(),
202
+ projects: z.array(z.string()),
203
+ firstSeen: z.string(),
204
+ lastSeen: z.string(),
205
+ fixApplied: FixAppliedSchema.optional()
206
+ });
207
+ var GlobalPatternsIndexSchema = z.array(GlobalPatternSchema);
208
+ var ProjectSummarySchema = z.object({
209
+ name: z.string(),
210
+ path: z.string(),
211
+ lastScan: z.string(),
212
+ healthScore: z.number(),
213
+ totalIssues: z.number(),
214
+ patterns: z.array(z.string())
215
+ });
216
+ var PatternSummarySchema = z.object({
217
+ pattern: z.string(),
218
+ count: z.number(),
219
+ severity: z.string(),
220
+ agent: z.string(),
221
+ exampleFix: z.string()
222
+ });
223
+ var HotFileSchema = z.object({
224
+ file: z.string(),
225
+ count: z.number()
226
+ });
227
+ var CompactedSummarySchema = z.object({
228
+ period: z.string(),
229
+ startDate: z.string(),
230
+ endDate: z.string(),
231
+ totalIssues: z.number(),
232
+ resolvedCount: z.number(),
233
+ bySeverity: z.record(z.string(), z.number()),
234
+ byAgent: z.record(z.string(), z.number()),
235
+ topPatterns: z.array(PatternSummarySchema),
236
+ hotFiles: z.array(HotFileSchema),
237
+ compactedAt: z.string()
238
+ });
239
+ var CompactedSummariesIndexSchema = z.array(CompactedSummarySchema);
240
+ function safeParseAndValidate(content, schema) {
241
+ try {
242
+ const parsed = JSON.parse(content);
243
+ const result = schema.safeParse(parsed);
244
+ if (result.success) {
245
+ return { success: true, data: result.data };
246
+ }
247
+ return {
248
+ success: false,
249
+ error: `Validation failed: ${result.error.issues[0]?.message || "Unknown error"}`
250
+ };
251
+ } catch (error) {
252
+ return {
253
+ success: false,
254
+ error: `JSON parse failed: ${error instanceof Error ? error.message : "Unknown error"}`
255
+ };
256
+ }
257
+ }
258
+
259
+ export {
260
+ BackupManager,
261
+ IssueIndexSchema,
262
+ GlobalPatternsIndexSchema,
263
+ CompactedSummariesIndexSchema,
264
+ safeParseAndValidate
265
+ };
266
+ //# sourceMappingURL=chunk-WS6OA7H6.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils/backup-manager.ts","../src/memory/validation.ts"],"sourcesContent":["/**\n * Backup Manager\n * \n * Maintains rotational backups of critical data files.\n * Provides automatic recovery from corrupted files.\n * \n * Features:\n * - N rotational backups (default: 5)\n * - Automatic pruning of old backups\n * - Validation before recovery\n * - Timestamp-based backup naming\n */\n\nimport { copyFile, readdir, unlink, readFile, stat } from 'fs/promises';\nimport { existsSync } from 'fs';\nimport { dirname, basename, join } from 'path';\n\nexport interface BackupOptions {\n /**\n * Maximum number of backups to keep\n * @default 5\n */\n maxBackups?: number;\n \n /**\n * Custom validator function for backup validation\n * Returns true if the backup is valid\n */\n validator?: (content: string) => boolean;\n}\n\nexport interface BackupInfo {\n path: string;\n timestamp: number;\n size: number;\n}\n\n/**\n * Manages rotational backups for a file\n * \n * @example\n * ```typescript\n * const manager = new BackupManager('/path/to/issues.json');\n * \n * // Create backup before modifying\n * await manager.createBackup();\n * \n * // If corruption detected, recover\n * if (await manager.recoverFromBackup()) {\n * console.log('Recovered from backup');\n * }\n * ```\n */\nexport class BackupManager {\n private readonly filePath: string;\n private readonly maxBackups: number;\n private readonly validator: ((content: string) => boolean) | undefined;\n private readonly backupDir: string;\n private readonly baseFileName: string;\n\n constructor(filePath: string, options: BackupOptions = {}) {\n this.filePath = filePath;\n this.maxBackups = options.maxBackups ?? 5;\n this.validator = options.validator;\n this.backupDir = dirname(filePath);\n this.baseFileName = basename(filePath);\n }\n\n /**\n * Create a backup of the current file\n * \n * @returns The backup file path, or null if source doesn't exist\n */\n async createBackup(): Promise<string | null> {\n if (!existsSync(this.filePath)) {\n return null;\n }\n\n const timestamp = Date.now();\n const backupPath = this.getBackupPath(timestamp);\n\n await copyFile(this.filePath, backupPath);\n await this.pruneOldBackups();\n\n return backupPath;\n }\n\n /**\n * List all backups sorted by timestamp (newest first)\n */\n async listBackups(): Promise<BackupInfo[]> {\n if (!existsSync(this.backupDir)) {\n return [];\n }\n\n const files = await readdir(this.backupDir);\n const backupPattern = new RegExp(\n `^${this.escapeRegex(this.baseFileName)}\\\\.backup\\\\.(\\\\d+)$`\n );\n\n const backups: BackupInfo[] = [];\n\n for (const file of files) {\n const match = file.match(backupPattern);\n if (match) {\n const timestamp = parseInt(match[1]!, 10);\n const backupPath = join(this.backupDir, file);\n \n try {\n const stats = await stat(backupPath);\n backups.push({\n path: backupPath,\n timestamp,\n size: stats.size,\n });\n } catch {\n // Skip files we can't stat\n }\n }\n }\n\n // Sort by timestamp, newest first\n return backups.sort((a, b) => b.timestamp - a.timestamp);\n }\n\n /**\n * Find the first valid backup\n * \n * Iterates through backups from newest to oldest,\n * returning the first one that passes validation.\n * \n * @returns Path to valid backup, or null if none found\n */\n async findValidBackup(): Promise<string | null> {\n const backups = await this.listBackups();\n\n for (const backup of backups) {\n if (await this.validateBackup(backup.path)) {\n return backup.path;\n }\n }\n\n return null;\n }\n\n /**\n * Validate a backup file\n * \n * If a custom validator was provided, uses that.\n * Otherwise, attempts JSON parse for .json files.\n * \n * @returns true if backup is valid\n */\n async validateBackup(backupPath: string): Promise<boolean> {\n try {\n const content = await readFile(backupPath, 'utf-8');\n\n // Use custom validator if provided\n if (this.validator) {\n return this.validator(content);\n }\n\n // Default validation: check if it's valid JSON for .json files\n if (this.filePath.endsWith('.json')) {\n JSON.parse(content);\n return true;\n }\n\n // For non-JSON files, just check it's readable\n return content.length > 0;\n } catch {\n return false;\n }\n }\n\n /**\n * Recover from the most recent valid backup\n * \n * @returns true if recovery was successful\n */\n async recoverFromBackup(): Promise<boolean> {\n const validBackup = await this.findValidBackup();\n \n if (!validBackup) {\n return false;\n }\n\n await copyFile(validBackup, this.filePath);\n return true;\n }\n\n /**\n * Remove old backups beyond the max limit\n */\n private async pruneOldBackups(): Promise<void> {\n const backups = await this.listBackups();\n\n // Remove backups beyond the limit\n const toRemove = backups.slice(this.maxBackups);\n \n for (const backup of toRemove) {\n try {\n await unlink(backup.path);\n } catch {\n // Ignore errors - backup might already be removed\n }\n }\n }\n\n /**\n * Get the backup path for a given timestamp\n */\n private getBackupPath(timestamp: number): string {\n return join(this.backupDir, `${this.baseFileName}.backup.${timestamp}`);\n }\n\n /**\n * Escape special regex characters in a string\n */\n private escapeRegex(str: string): string {\n return str.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n }\n\n /**\n * Get the number of existing backups\n */\n async getBackupCount(): Promise<number> {\n const backups = await this.listBackups();\n return backups.length;\n }\n\n /**\n * Get the most recent backup timestamp\n */\n async getLatestBackupTime(): Promise<number | null> {\n const backups = await this.listBackups();\n return backups[0]?.timestamp ?? null;\n }\n\n /**\n * Delete all backups\n */\n async clearBackups(): Promise<number> {\n const backups = await this.listBackups();\n let deleted = 0;\n\n for (const backup of backups) {\n try {\n await unlink(backup.path);\n deleted++;\n } catch {\n // Ignore errors\n }\n }\n\n return deleted;\n }\n}\n\n/**\n * Default JSON validator\n * \n * Validates that content is valid JSON and optionally\n * checks for required fields.\n */\nexport function createJSONValidator(requiredFields?: string[]): (content: string) => boolean {\n return (content: string): boolean => {\n try {\n const parsed = JSON.parse(content);\n \n if (requiredFields && Array.isArray(parsed)) {\n // For arrays, check first element has required fields\n if (parsed.length > 0) {\n const first = parsed[0];\n return requiredFields.every(field => field in first);\n }\n // Empty array is valid\n return true;\n }\n \n if (requiredFields && typeof parsed === 'object' && parsed !== null) {\n return requiredFields.every(field => field in parsed);\n }\n \n return true;\n } catch {\n return false;\n }\n };\n}\n","/**\n * Memory Validation\n * \n * Schema validation for memory storage files using Zod.\n * Catches corruption early and provides clear error messages.\n * \n * Used by:\n * - issue-store.ts for issues.json\n * - global-memory.ts for global-patterns.json\n * - compactor.ts for compacted-summaries.json\n */\n\nimport { z } from 'zod';\n\n// ============================================================================\n// Issue Schemas\n// ============================================================================\n\n/**\n * Schema for a stored issue in issues.json\n */\nexport const StoredIssueSchema = z.object({\n id: z.string(),\n hash: z.string(),\n severity: z.string(),\n issue: z.string(),\n fix: z.string(),\n file: z.string(),\n line: z.number().optional(),\n agent: z.string(),\n category: z.string().optional(),\n timestamp: z.string(),\n project: z.string(),\n resolved: z.boolean().optional(),\n resolvedAt: z.string().optional(),\n});\n\nexport type ValidatedStoredIssue = z.infer<typeof StoredIssueSchema>;\n\n/**\n * Schema for the issues.json file (array of issues)\n */\nexport const IssueIndexSchema = z.array(StoredIssueSchema);\n\n// ============================================================================\n// Global Pattern Schemas\n// ============================================================================\n\n/**\n * Schema for a fix applied record\n */\nexport const FixAppliedSchema = z.object({\n project: z.string(),\n timestamp: z.string(),\n fix: z.string(),\n});\n\n/**\n * Schema for a global pattern in global-patterns.json\n */\nexport const GlobalPatternSchema = z.object({\n id: z.string(),\n pattern: z.string(),\n description: z.string(),\n severity: z.string(),\n agent: z.string(),\n occurrences: z.number(),\n projects: z.array(z.string()),\n firstSeen: z.string(),\n lastSeen: z.string(),\n fixApplied: FixAppliedSchema.optional(),\n});\n\nexport type ValidatedGlobalPattern = z.infer<typeof GlobalPatternSchema>;\n\n/**\n * Schema for global-patterns.json (array of patterns)\n */\nexport const GlobalPatternsIndexSchema = z.array(GlobalPatternSchema);\n\n// ============================================================================\n// Project Summary Schemas\n// ============================================================================\n\n/**\n * Schema for a project summary\n */\nexport const ProjectSummarySchema = z.object({\n name: z.string(),\n path: z.string(),\n lastScan: z.string(),\n healthScore: z.number(),\n totalIssues: z.number(),\n patterns: z.array(z.string()),\n});\n\nexport type ValidatedProjectSummary = z.infer<typeof ProjectSummarySchema>;\n\n// ============================================================================\n// Compacted Summary Schemas\n// ============================================================================\n\n/**\n * Schema for a pattern summary in compacted data\n */\nexport const PatternSummarySchema = z.object({\n pattern: z.string(),\n count: z.number(),\n severity: z.string(),\n agent: z.string(),\n exampleFix: z.string(),\n});\n\n/**\n * Schema for a hot file entry\n */\nexport const HotFileSchema = z.object({\n file: z.string(),\n count: z.number(),\n});\n\n/**\n * Schema for a compacted summary\n */\nexport const CompactedSummarySchema = z.object({\n period: z.string(),\n startDate: z.string(),\n endDate: z.string(),\n totalIssues: z.number(),\n resolvedCount: z.number(),\n bySeverity: z.record(z.string(), z.number()),\n byAgent: z.record(z.string(), z.number()),\n topPatterns: z.array(PatternSummarySchema),\n hotFiles: z.array(HotFileSchema),\n compactedAt: z.string(),\n});\n\nexport type ValidatedCompactedSummary = z.infer<typeof CompactedSummarySchema>;\n\n/**\n * Schema for compacted-summaries.json (array of summaries)\n */\nexport const CompactedSummariesIndexSchema = z.array(CompactedSummarySchema);\n\n// ============================================================================\n// Validation Error\n// ============================================================================\n\n/**\n * Custom error for validation failures\n */\nexport class ValidationError extends Error {\n constructor(\n message: string,\n public readonly zodError: z.ZodError,\n public readonly filePath?: string\n ) {\n super(message);\n this.name = 'ValidationError';\n }\n\n /**\n * Get a human-readable summary of validation errors\n */\n getSummary(): string {\n const issues = this.zodError.issues.slice(0, 5);\n const lines = issues.map(issue => {\n const path = issue.path.join('.');\n return ` - ${path}: ${issue.message}`;\n });\n \n if (this.zodError.issues.length > 5) {\n lines.push(` ... and ${this.zodError.issues.length - 5} more errors`);\n }\n \n return lines.join('\\n');\n }\n}\n\n// ============================================================================\n// Validation Functions\n// ============================================================================\n\n/**\n * Validate issue index data\n * \n * @throws ValidationError if data is invalid\n * @returns Validated issue array\n */\nexport function validateIssueIndex(\n data: unknown,\n filePath?: string\n): ValidatedStoredIssue[] {\n const result = IssueIndexSchema.safeParse(data);\n \n if (!result.success) {\n throw new ValidationError(\n `Issue index validation failed${filePath ? ` (${filePath})` : ''}`,\n result.error,\n filePath\n );\n }\n \n return result.data;\n}\n\n/**\n * Validate global patterns data\n * \n * @throws ValidationError if data is invalid\n * @returns Validated patterns array\n */\nexport function validateGlobalPatterns(\n data: unknown,\n filePath?: string\n): ValidatedGlobalPattern[] {\n const result = GlobalPatternsIndexSchema.safeParse(data);\n \n if (!result.success) {\n throw new ValidationError(\n `Global patterns validation failed${filePath ? ` (${filePath})` : ''}`,\n result.error,\n filePath\n );\n }\n \n return result.data;\n}\n\n/**\n * Validate project summary data\n * \n * @throws ValidationError if data is invalid\n * @returns Validated project summary\n */\nexport function validateProjectSummary(\n data: unknown,\n filePath?: string\n): ValidatedProjectSummary {\n const result = ProjectSummarySchema.safeParse(data);\n \n if (!result.success) {\n throw new ValidationError(\n `Project summary validation failed${filePath ? ` (${filePath})` : ''}`,\n result.error,\n filePath\n );\n }\n \n return result.data;\n}\n\n/**\n * Validate compacted summaries data\n * \n * @throws ValidationError if data is invalid\n * @returns Validated summaries array\n */\nexport function validateCompactedSummaries(\n data: unknown,\n filePath?: string\n): ValidatedCompactedSummary[] {\n const result = CompactedSummariesIndexSchema.safeParse(data);\n \n if (!result.success) {\n throw new ValidationError(\n `Compacted summaries validation failed${filePath ? ` (${filePath})` : ''}`,\n result.error,\n filePath\n );\n }\n \n return result.data;\n}\n\n/**\n * Safely parse and validate JSON\n * \n * Combines JSON parsing with schema validation.\n * Returns null on any error instead of throwing.\n */\nexport function safeParseAndValidate<T>(\n content: string,\n schema: z.ZodSchema<T>\n): { success: true; data: T } | { success: false; error: string } {\n try {\n const parsed = JSON.parse(content);\n const result = schema.safeParse(parsed);\n \n if (result.success) {\n return { success: true, data: result.data };\n }\n \n return {\n success: false,\n error: `Validation failed: ${result.error.issues[0]?.message || 'Unknown error'}`,\n };\n } catch (error) {\n return {\n success: false,\n error: `JSON parse failed: ${error instanceof Error ? error.message : 'Unknown error'}`,\n };\n }\n}\n\n/**\n * Check if data matches a schema (non-throwing)\n */\nexport function isValidSchema<T>(data: unknown, schema: z.ZodSchema<T>): boolean {\n return schema.safeParse(data).success;\n}\n"],"mappings":"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","names":[]}
package/dist/cli/main.js CHANGED
@@ -34,7 +34,8 @@ import {
34
34
  isTrieInitialized,
35
35
  perceiveCurrentChanges,
36
36
  reasonAboutChangesHumanReadable
37
- } from "../chunk-PPZYVTUO.js";
37
+ } from "../chunk-6LD7OPJL.js";
38
+ import "../chunk-ZV2K6M7T.js";
38
39
  import {
39
40
  GotchaPredictor,
40
41
  findCrossProjectPatterns,
@@ -42,7 +43,7 @@ import {
42
43
  listTrackedProjects,
43
44
  searchGlobalPatterns,
44
45
  updateGlobalMemoryMd
45
- } from "../chunk-FNW7Z7ZS.js";
46
+ } from "../chunk-F4ZIAHTZ.js";
46
47
  import "../chunk-WRGSH5RT.js";
47
48
  import {
48
49
  getDailyLogs,
@@ -51,10 +52,11 @@ import {
51
52
  markIssueResolved,
52
53
  purgeIssues,
53
54
  searchIssues
54
- } from "../chunk-PRFHN2X6.js";
55
+ } from "../chunk-K5EXATBF.js";
55
56
  import {
56
57
  getGuardianState
57
- } from "../chunk-4BGAVEO6.js";
58
+ } from "../chunk-UHMMANC2.js";
59
+ import "../chunk-WS6OA7H6.js";
58
60
  import "../chunk-F4NJ4CBP.js";
59
61
  import "../chunk-IXO4G4D3.js";
60
62
  import {
@@ -64,7 +66,6 @@ import {
64
66
  IncidentIndex
65
67
  } from "../chunk-WHIQAGB7.js";
66
68
  import "../chunk-6NLHFIYA.js";
67
- import "../chunk-ZV2K6M7T.js";
68
69
  import "../chunk-7Q6I2CB4.js";
69
70
  import "../chunk-43X6JBEM.js";
70
71
  import {