@jamesaphoenix/tx-core 0.4.3 → 0.4.5

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 (94) hide show
  1. package/dist/db.d.ts.map +1 -1
  2. package/dist/db.js +8 -2
  3. package/dist/db.js.map +1 -1
  4. package/dist/layer.d.ts +3 -3
  5. package/dist/services/auto-sync-service.d.ts +1 -1
  6. package/dist/services/cycle-scan-service.d.ts.map +1 -1
  7. package/dist/services/cycle-scan-service.js +6 -2
  8. package/dist/services/cycle-scan-service.js.map +1 -1
  9. package/dist/services/learning-service.d.ts +1 -1
  10. package/dist/services/orchestrator-service.d.ts +1 -1
  11. package/dist/services/orchestrator-service.d.ts.map +1 -1
  12. package/dist/services/orchestrator-service.js +14 -13
  13. package/dist/services/orchestrator-service.js.map +1 -1
  14. package/dist/services/retriever-service.d.ts +2 -2
  15. package/dist/services/sync-service.d.ts.map +1 -1
  16. package/dist/services/sync-service.js +9 -8
  17. package/dist/services/sync-service.js.map +1 -1
  18. package/dist/services/task-service.d.ts.map +1 -1
  19. package/dist/services/task-service.js +3 -2
  20. package/dist/services/task-service.js.map +1 -1
  21. package/dist/services/worker-process.d.ts +1 -1
  22. package/dist/services/worker-process.d.ts.map +1 -1
  23. package/dist/services/worker-process.js +9 -2
  24. package/dist/services/worker-process.js.map +1 -1
  25. package/dist/worker/run-worker.d.ts +1 -1
  26. package/package.json +1 -1
  27. package/dist/mappers/anchor.d.ts +0 -28
  28. package/dist/mappers/anchor.d.ts.map +0 -1
  29. package/dist/mappers/anchor.js +0 -105
  30. package/dist/mappers/anchor.js.map +0 -1
  31. package/dist/mappers/candidate.d.ts +0 -25
  32. package/dist/mappers/candidate.d.ts.map +0 -1
  33. package/dist/mappers/candidate.js +0 -83
  34. package/dist/mappers/candidate.js.map +0 -1
  35. package/dist/mappers/edge.d.ts +0 -19
  36. package/dist/mappers/edge.d.ts.map +0 -1
  37. package/dist/mappers/edge.js +0 -81
  38. package/dist/mappers/edge.js.map +0 -1
  39. package/dist/repo/anchor-repo.d.ts +0 -52
  40. package/dist/repo/anchor-repo.d.ts.map +0 -1
  41. package/dist/repo/anchor-repo.js +0 -245
  42. package/dist/repo/anchor-repo.js.map +0 -1
  43. package/dist/repo/candidate-repo.d.ts +0 -16
  44. package/dist/repo/candidate-repo.d.ts.map +0 -1
  45. package/dist/repo/candidate-repo.js +0 -164
  46. package/dist/repo/candidate-repo.js.map +0 -1
  47. package/dist/repo/compaction-repo.d.ts +0 -41
  48. package/dist/repo/compaction-repo.d.ts.map +0 -1
  49. package/dist/repo/compaction-repo.js +0 -84
  50. package/dist/repo/compaction-repo.js.map +0 -1
  51. package/dist/repo/edge-repo.d.ts +0 -26
  52. package/dist/repo/edge-repo.d.ts.map +0 -1
  53. package/dist/repo/edge-repo.js +0 -258
  54. package/dist/repo/edge-repo.js.map +0 -1
  55. package/dist/services/anchor-service.d.ts +0 -147
  56. package/dist/services/anchor-service.d.ts.map +0 -1
  57. package/dist/services/anchor-service.js +0 -540
  58. package/dist/services/anchor-service.js.map +0 -1
  59. package/dist/services/anchor-verification.d.ts +0 -102
  60. package/dist/services/anchor-verification.d.ts.map +0 -1
  61. package/dist/services/anchor-verification.js +0 -817
  62. package/dist/services/anchor-verification.js.map +0 -1
  63. package/dist/services/ast-grep-service.d.ts +0 -58
  64. package/dist/services/ast-grep-service.d.ts.map +0 -1
  65. package/dist/services/ast-grep-service.js +0 -427
  66. package/dist/services/ast-grep-service.js.map +0 -1
  67. package/dist/services/candidate-extractor-service.d.ts +0 -56
  68. package/dist/services/candidate-extractor-service.d.ts.map +0 -1
  69. package/dist/services/candidate-extractor-service.js +0 -365
  70. package/dist/services/candidate-extractor-service.js.map +0 -1
  71. package/dist/services/compaction-service.d.ts +0 -105
  72. package/dist/services/compaction-service.d.ts.map +0 -1
  73. package/dist/services/compaction-service.js +0 -369
  74. package/dist/services/compaction-service.js.map +0 -1
  75. package/dist/services/edge-service.d.ts +0 -78
  76. package/dist/services/edge-service.d.ts.map +0 -1
  77. package/dist/services/edge-service.js +0 -158
  78. package/dist/services/edge-service.js.map +0 -1
  79. package/dist/services/feedback-tracker.d.ts +0 -64
  80. package/dist/services/feedback-tracker.d.ts.map +0 -1
  81. package/dist/services/feedback-tracker.js +0 -110
  82. package/dist/services/feedback-tracker.js.map +0 -1
  83. package/dist/services/graph-expansion.d.ts +0 -158
  84. package/dist/services/graph-expansion.d.ts.map +0 -1
  85. package/dist/services/graph-expansion.js +0 -487
  86. package/dist/services/graph-expansion.js.map +0 -1
  87. package/dist/services/promotion-service.d.ts +0 -67
  88. package/dist/services/promotion-service.d.ts.map +0 -1
  89. package/dist/services/promotion-service.js +0 -151
  90. package/dist/services/promotion-service.js.map +0 -1
  91. package/dist/services/swarm-verification.d.ts +0 -104
  92. package/dist/services/swarm-verification.d.ts.map +0 -1
  93. package/dist/services/swarm-verification.js +0 -406
  94. package/dist/services/swarm-verification.js.map +0 -1
@@ -1,487 +0,0 @@
1
- import { Context, Effect, Layer } from "effect";
2
- import { EdgeService } from "./edge-service.js";
3
- import { LearningRepository } from "../repo/learning-repo.js";
4
- import { AnchorRepository } from "../repo/anchor-repo.js";
5
- import { ValidationError } from "../errors.js";
6
- import { EDGE_TYPES } from "@jamesaphoenix/tx-types";
7
- export class GraphExpansionService extends Context.Tag("GraphExpansionService")() {
8
- }
9
- /**
10
- * Noop implementation that returns seeds without expansion.
11
- * Used when graph expansion is disabled or for testing.
12
- */
13
- export const GraphExpansionServiceNoop = Layer.succeed(GraphExpansionService, {
14
- expand: (seeds) => Effect.succeed({
15
- seeds: seeds.map(s => ({
16
- learning: s.learning,
17
- hops: 0,
18
- decayedScore: s.score,
19
- path: [s.learning.id],
20
- sourceEdge: null,
21
- edgeWeight: null
22
- })),
23
- expanded: [],
24
- all: seeds.map(s => ({
25
- learning: s.learning,
26
- hops: 0,
27
- decayedScore: s.score,
28
- path: [s.learning.id],
29
- sourceEdge: null,
30
- edgeWeight: null
31
- })),
32
- stats: {
33
- seedCount: seeds.length,
34
- expandedCount: 0,
35
- maxDepthReached: 0,
36
- nodesVisited: seeds.length,
37
- maxNodesReached: false
38
- }
39
- }),
40
- expandFromFiles: (files) => Effect.succeed({
41
- anchored: [],
42
- expanded: [],
43
- all: [],
44
- stats: {
45
- inputFileCount: files.length,
46
- anchoredCount: 0,
47
- expandedCount: 0,
48
- maxDepthReached: 0,
49
- filesVisited: files.length
50
- }
51
- })
52
- });
53
- /**
54
- * Default expansion options.
55
- */
56
- const DEFAULT_OPTIONS = {
57
- depth: 2,
58
- decayFactor: 0.7,
59
- maxNodes: 100,
60
- direction: "both",
61
- };
62
- /**
63
- * Type guard to check if edgeTypes is a simple array (backwards compatibility).
64
- */
65
- const isSimpleEdgeTypeArray = (edgeTypes) => {
66
- if (edgeTypes === undefined)
67
- return true;
68
- return Array.isArray(edgeTypes);
69
- };
70
- /**
71
- * Validate an EdgeTypeFilter for conflicting include/exclude entries.
72
- * Returns a ValidationError if the same edge type appears in both include and exclude.
73
- */
74
- const validateEdgeTypeFilter = (filter, context = "edgeTypes") => Effect.gen(function* () {
75
- const { include, exclude, perHop } = filter;
76
- // Check for overlapping types in include and exclude
77
- if (include && exclude) {
78
- const includeSet = new Set(include);
79
- const overlap = exclude.filter(t => includeSet.has(t));
80
- if (overlap.length > 0) {
81
- return yield* Effect.fail(new ValidationError({
82
- reason: `${context}: conflicting filters - edge types appear in both include and exclude: ${overlap.join(", ")}`
83
- }));
84
- }
85
- }
86
- // Recursively validate perHop filters
87
- if (perHop) {
88
- for (const [hop, hopFilter] of Object.entries(perHop)) {
89
- yield* validateEdgeTypeFilter(hopFilter, `${context}.perHop[${hop}]`);
90
- }
91
- }
92
- });
93
- /**
94
- * Resolve EdgeTypeFilter to an array of edge types for a specific hop.
95
- * Returns undefined if all edge types should be traversed.
96
- */
97
- const resolveEdgeTypesForHop = (filter, hop) => {
98
- // Simple array or undefined - pass through
99
- if (isSimpleEdgeTypeArray(filter)) {
100
- return filter;
101
- }
102
- // Check for hop-specific override
103
- const hopFilter = filter.perHop?.[hop];
104
- if (hopFilter) {
105
- // Recursively resolve (perHop filters don't have perHop themselves typically)
106
- return resolveEdgeTypesForHop(hopFilter, hop);
107
- }
108
- // Apply include/exclude from base filter
109
- const { include, exclude } = filter;
110
- if (include && include.length > 0) {
111
- return include;
112
- }
113
- if (exclude && exclude.length > 0) {
114
- // Return all edge types except excluded ones
115
- return EDGE_TYPES.filter(t => !exclude.includes(t));
116
- }
117
- // No filtering - return undefined to traverse all
118
- return undefined;
119
- };
120
- /**
121
- * Validate expansion options.
122
- */
123
- const validateOptions = (options) => Effect.gen(function* () {
124
- const depth = options.depth ?? DEFAULT_OPTIONS.depth;
125
- const decayFactor = options.decayFactor ?? DEFAULT_OPTIONS.decayFactor;
126
- const maxNodes = options.maxNodes ?? DEFAULT_OPTIONS.maxNodes;
127
- if (depth < 0) {
128
- return yield* Effect.fail(new ValidationError({
129
- reason: `Expansion depth must be >= 0, got: ${depth}`
130
- }));
131
- }
132
- if (depth > 10) {
133
- return yield* Effect.fail(new ValidationError({
134
- reason: `Expansion depth must be <= 10, got: ${depth}`
135
- }));
136
- }
137
- if (decayFactor <= 0 || decayFactor > 1) {
138
- return yield* Effect.fail(new ValidationError({
139
- reason: `Decay factor must be in (0, 1], got: ${decayFactor}`
140
- }));
141
- }
142
- if (maxNodes < 1) {
143
- return yield* Effect.fail(new ValidationError({
144
- reason: `Max nodes must be >= 1, got: ${maxNodes}`
145
- }));
146
- }
147
- // Validate EdgeTypeFilter if provided
148
- if (options.edgeTypes && !isSimpleEdgeTypeArray(options.edgeTypes)) {
149
- yield* validateEdgeTypeFilter(options.edgeTypes);
150
- }
151
- });
152
- export const GraphExpansionServiceLive = Layer.effect(GraphExpansionService, Effect.gen(function* () {
153
- const edgeService = yield* EdgeService;
154
- const learningRepo = yield* LearningRepository;
155
- const anchorRepo = yield* AnchorRepository;
156
- return {
157
- expand: (seeds, options = {}) => Effect.gen(function* () {
158
- // Validate options
159
- yield* validateOptions(options);
160
- const depth = options.depth ?? DEFAULT_OPTIONS.depth;
161
- const decayFactor = options.decayFactor ?? DEFAULT_OPTIONS.decayFactor;
162
- const maxNodes = options.maxNodes ?? DEFAULT_OPTIONS.maxNodes;
163
- const edgeTypeFilter = options.edgeTypes;
164
- // Map direction option to findNeighbors terminology
165
- const directionOpt = options.direction ?? DEFAULT_OPTIONS.direction;
166
- const findDirection = directionOpt === "outbound" ? "outgoing"
167
- : directionOpt === "inbound" ? "incoming"
168
- : "both";
169
- // Handle empty seeds
170
- if (seeds.length === 0) {
171
- return {
172
- seeds: [],
173
- expanded: [],
174
- all: [],
175
- stats: {
176
- seedCount: 0,
177
- expandedCount: 0,
178
- maxDepthReached: 0,
179
- nodesVisited: 0,
180
- maxNodesReached: false,
181
- },
182
- };
183
- }
184
- // Track visited learning IDs to prevent cycles
185
- const visited = new Set();
186
- // Convert seeds to ExpandedLearning format
187
- const seedLearnings = seeds.map((seed) => {
188
- visited.add(seed.learning.id);
189
- return {
190
- learning: seed.learning,
191
- hops: 0,
192
- decayedScore: seed.score,
193
- path: [seed.learning.id],
194
- sourceEdge: null,
195
- edgeWeight: null,
196
- };
197
- });
198
- // If depth is 0, just return seeds
199
- if (depth === 0) {
200
- return {
201
- seeds: seedLearnings,
202
- expanded: [],
203
- all: seedLearnings,
204
- stats: {
205
- seedCount: seedLearnings.length,
206
- expandedCount: 0,
207
- maxDepthReached: 0,
208
- nodesVisited: seedLearnings.length,
209
- maxNodesReached: seedLearnings.length >= maxNodes,
210
- },
211
- };
212
- }
213
- let frontier = seeds.map((seed) => ({
214
- learningId: seed.learning.id,
215
- score: seed.score,
216
- path: [seed.learning.id],
217
- }));
218
- const expanded = [];
219
- let maxDepthReached = 0;
220
- let maxNodesReached = false;
221
- const totalNodes = () => seedLearnings.length + expanded.length;
222
- // BFS traversal
223
- for (let currentHop = 1; currentHop <= depth; currentHop++) {
224
- if (frontier.length === 0)
225
- break;
226
- if (totalNodes() >= maxNodes) {
227
- maxNodesReached = true;
228
- break;
229
- }
230
- const nextFrontier = [];
231
- for (const node of frontier) {
232
- if (totalNodes() >= maxNodes) {
233
- maxNodesReached = true;
234
- break;
235
- }
236
- // Find neighbors bidirectionally (per PRD-016 resolved question #1)
237
- // Resolve edge types for this specific hop (supports per-hop overrides)
238
- const edgeTypesForHop = resolveEdgeTypesForHop(edgeTypeFilter, currentHop);
239
- const neighbors = yield* edgeService.findNeighbors("learning", String(node.learningId), {
240
- depth: 1,
241
- direction: findDirection,
242
- edgeTypes: edgeTypesForHop,
243
- });
244
- // Filter to only learning neighbors and process
245
- const learningNeighbors = neighbors.filter((n) => n.nodeType === "learning");
246
- for (const neighbor of learningNeighbors) {
247
- if (totalNodes() >= maxNodes) {
248
- maxNodesReached = true;
249
- break;
250
- }
251
- const neighborId = parseInt(neighbor.nodeId, 10);
252
- if (isNaN(neighborId))
253
- continue;
254
- if (visited.has(neighborId))
255
- continue;
256
- visited.add(neighborId);
257
- // Fetch the learning to include in results
258
- const learning = yield* learningRepo.findById(neighborId);
259
- if (!learning)
260
- continue;
261
- // Calculate decayed score: parentScore * edgeWeight * decayFactor
262
- const newScore = node.score * neighbor.weight * decayFactor;
263
- const newPath = [...node.path, learning.id];
264
- expanded.push({
265
- learning,
266
- hops: currentHop,
267
- decayedScore: newScore,
268
- path: newPath,
269
- sourceEdge: neighbor.edgeType,
270
- edgeWeight: neighbor.weight,
271
- });
272
- maxDepthReached = currentHop;
273
- // Add to next frontier for further expansion
274
- nextFrontier.push({
275
- learningId: learning.id,
276
- score: newScore,
277
- path: newPath,
278
- });
279
- }
280
- }
281
- frontier = nextFrontier;
282
- }
283
- // Sort expanded by decayed score (highest first)
284
- expanded.sort((a, b) => b.decayedScore - a.decayedScore);
285
- // Enforce maxNodes limit on total (seeds + expanded)
286
- const expandedLimit = Math.max(0, maxNodes - seedLearnings.length);
287
- const limitedExpanded = expanded.slice(0, expandedLimit);
288
- if (expanded.length > expandedLimit)
289
- maxNodesReached = true;
290
- const all = [...seedLearnings, ...limitedExpanded];
291
- return {
292
- seeds: seedLearnings,
293
- expanded: limitedExpanded,
294
- all,
295
- stats: {
296
- seedCount: seedLearnings.length,
297
- expandedCount: limitedExpanded.length,
298
- maxDepthReached,
299
- nodesVisited: visited.size,
300
- maxNodesReached,
301
- },
302
- };
303
- }),
304
- expandFromFiles: (files, options = {}) => Effect.gen(function* () {
305
- // Validate options
306
- const depth = options.depth ?? DEFAULT_OPTIONS.depth;
307
- const decayFactor = options.decayFactor ?? DEFAULT_OPTIONS.decayFactor;
308
- const maxNodes = options.maxNodes ?? DEFAULT_OPTIONS.maxNodes;
309
- if (depth < 0) {
310
- return yield* Effect.fail(new ValidationError({
311
- reason: `Expansion depth must be >= 0, got: ${depth}`
312
- }));
313
- }
314
- if (depth > 10) {
315
- return yield* Effect.fail(new ValidationError({
316
- reason: `Expansion depth must be <= 10, got: ${depth}`
317
- }));
318
- }
319
- if (decayFactor <= 0 || decayFactor > 1) {
320
- return yield* Effect.fail(new ValidationError({
321
- reason: `Decay factor must be in (0, 1], got: ${decayFactor}`
322
- }));
323
- }
324
- if (maxNodes < 1) {
325
- return yield* Effect.fail(new ValidationError({
326
- reason: `Max nodes must be >= 1, got: ${maxNodes}`
327
- }));
328
- }
329
- // Handle empty files input
330
- if (files.length === 0) {
331
- return {
332
- anchored: [],
333
- expanded: [],
334
- all: [],
335
- stats: {
336
- inputFileCount: 0,
337
- anchoredCount: 0,
338
- expandedCount: 0,
339
- maxDepthReached: 0,
340
- filesVisited: 0,
341
- },
342
- };
343
- }
344
- // Track visited files and learnings to prevent duplicates
345
- const visitedFiles = new Set(files);
346
- const visitedLearningIds = new Set();
347
- // Step 1: Find learnings ANCHORED_TO the input files (hop 0)
348
- const anchoredLearnings = [];
349
- for (const filePath of files) {
350
- const anchors = yield* anchorRepo.findByFilePath(filePath);
351
- // Filter to only valid anchors
352
- const validAnchors = anchors.filter(a => a.status === "valid");
353
- for (const anchor of validAnchors) {
354
- if (visitedLearningIds.has(anchor.learningId))
355
- continue;
356
- visitedLearningIds.add(anchor.learningId);
357
- const learning = yield* learningRepo.findById(anchor.learningId);
358
- if (!learning)
359
- continue;
360
- anchoredLearnings.push({
361
- learning,
362
- sourceFile: filePath,
363
- hops: 0,
364
- decayedScore: 1.0, // Base score for directly anchored learnings
365
- sourceEdge: "ANCHORED_TO",
366
- edgeWeight: null,
367
- });
368
- }
369
- }
370
- // If depth is 0, just return anchored learnings
371
- if (depth === 0) {
372
- const limitedAnchored = anchoredLearnings.slice(0, maxNodes);
373
- return {
374
- anchored: limitedAnchored,
375
- expanded: [],
376
- all: limitedAnchored,
377
- stats: {
378
- inputFileCount: files.length,
379
- anchoredCount: limitedAnchored.length,
380
- expandedCount: 0,
381
- maxDepthReached: 0,
382
- filesVisited: files.length,
383
- },
384
- };
385
- }
386
- let frontier = files.map(f => ({
387
- filePath: f,
388
- score: 1.0,
389
- }));
390
- const expandedLearnings = [];
391
- let maxDepthReached = 0;
392
- const totalLearnings = () => anchoredLearnings.length + expandedLearnings.length;
393
- // BFS traversal through file relationships
394
- for (let currentHop = 1; currentHop <= depth; currentHop++) {
395
- if (frontier.length === 0)
396
- break;
397
- if (totalLearnings() >= maxNodes)
398
- break;
399
- const nextFrontier = [];
400
- for (const node of frontier) {
401
- if (totalLearnings() >= maxNodes)
402
- break;
403
- // Find related files via IMPORTS and CO_CHANGES_WITH edges
404
- // Note: For file nodes, nodeType is "file" and nodeId is the file path
405
- const neighbors = yield* edgeService.findNeighbors("file", node.filePath, {
406
- depth: 1,
407
- direction: "both",
408
- edgeTypes: ["IMPORTS", "CO_CHANGES_WITH"],
409
- });
410
- // Filter to only file neighbors
411
- const fileNeighbors = neighbors.filter((n) => n.nodeType === "file");
412
- for (const neighbor of fileNeighbors) {
413
- if (totalLearnings() >= maxNodes)
414
- break;
415
- const relatedFilePath = neighbor.nodeId;
416
- if (visitedFiles.has(relatedFilePath))
417
- continue;
418
- visitedFiles.add(relatedFilePath);
419
- // Calculate decayed score for this hop
420
- const hopScore = node.score * neighbor.weight * decayFactor;
421
- // Find learnings anchored to this related file
422
- const anchors = yield* anchorRepo.findByFilePath(relatedFilePath);
423
- const validAnchors = anchors.filter(a => a.status === "valid");
424
- for (const anchor of validAnchors) {
425
- if (totalLearnings() >= maxNodes)
426
- break;
427
- if (visitedLearningIds.has(anchor.learningId))
428
- continue;
429
- visitedLearningIds.add(anchor.learningId);
430
- const learning = yield* learningRepo.findById(anchor.learningId);
431
- if (!learning)
432
- continue;
433
- expandedLearnings.push({
434
- learning,
435
- sourceFile: relatedFilePath,
436
- hops: currentHop,
437
- decayedScore: hopScore,
438
- sourceEdge: neighbor.edgeType,
439
- edgeWeight: neighbor.weight,
440
- });
441
- maxDepthReached = currentHop;
442
- }
443
- // Add to next frontier for further expansion
444
- nextFrontier.push({
445
- filePath: relatedFilePath,
446
- score: hopScore,
447
- });
448
- }
449
- }
450
- frontier = nextFrontier;
451
- }
452
- // Sort expanded by decayed score (highest first)
453
- expandedLearnings.sort((a, b) => b.decayedScore - a.decayedScore);
454
- // Enforce maxNodes limit
455
- const totalAvailable = anchoredLearnings.length + expandedLearnings.length;
456
- let limitedAnchored = anchoredLearnings;
457
- let limitedExpanded = expandedLearnings;
458
- if (totalAvailable > maxNodes) {
459
- // Prioritize anchored learnings, then fill with expanded
460
- if (anchoredLearnings.length >= maxNodes) {
461
- limitedAnchored = anchoredLearnings.slice(0, maxNodes);
462
- limitedExpanded = [];
463
- }
464
- else {
465
- const remainingSlots = maxNodes - anchoredLearnings.length;
466
- limitedExpanded = expandedLearnings.slice(0, remainingSlots);
467
- }
468
- }
469
- // Combine all and sort by decayedScore
470
- const all = [...limitedAnchored, ...limitedExpanded];
471
- all.sort((a, b) => b.decayedScore - a.decayedScore);
472
- return {
473
- anchored: limitedAnchored,
474
- expanded: limitedExpanded,
475
- all,
476
- stats: {
477
- inputFileCount: files.length,
478
- anchoredCount: limitedAnchored.length,
479
- expandedCount: limitedExpanded.length,
480
- maxDepthReached,
481
- filesVisited: visitedFiles.size,
482
- },
483
- };
484
- }),
485
- };
486
- }));
487
- //# sourceMappingURL=graph-expansion.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"graph-expansion.js","sourceRoot":"","sources":["../../src/services/graph-expansion.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,QAAQ,CAAA;AAC/C,OAAO,EAAE,WAAW,EAA0B,MAAM,mBAAmB,CAAA;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAA;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAA;AACzD,OAAO,EAAiB,eAAe,EAAE,MAAM,cAAc,CAAA;AAE7D,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAA;AAkIpD,MAAM,OAAO,qBAAsB,SAAQ,OAAO,CAAC,GAAG,CAAC,uBAAuB,CAAC,EA+B5E;CAAG;AAEN;;;GAGG;AACH,MAAM,CAAC,MAAM,yBAAyB,GAAG,KAAK,CAAC,OAAO,CACpD,qBAAqB,EACrB;IACE,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE,CAChB,MAAM,CAAC,OAAO,CAAC;QACb,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YACrB,QAAQ,EAAE,CAAC,CAAC,QAAQ;YACpB,IAAI,EAAE,CAAC;YACP,YAAY,EAAE,CAAC,CAAC,KAAK;YACrB,IAAI,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC;YACrB,UAAU,EAAE,IAAI;YAChB,UAAU,EAAE,IAAI;SACjB,CAAC,CAAC;QACH,QAAQ,EAAE,EAAE;QACZ,GAAG,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YACnB,QAAQ,EAAE,CAAC,CAAC,QAAQ;YACpB,IAAI,EAAE,CAAC;YACP,YAAY,EAAE,CAAC,CAAC,KAAK;YACrB,IAAI,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC;YACrB,UAAU,EAAE,IAAI;YAChB,UAAU,EAAE,IAAI;SACjB,CAAC,CAAC;QACH,KAAK,EAAE;YACL,SAAS,EAAE,KAAK,CAAC,MAAM;YACvB,aAAa,EAAE,CAAC;YAChB,eAAe,EAAE,CAAC;YAClB,YAAY,EAAE,KAAK,CAAC,MAAM;YAC1B,eAAe,EAAE,KAAK;SACvB;KACF,CAAC;IAEJ,eAAe,EAAE,CAAC,KAAK,EAAE,EAAE,CACzB,MAAM,CAAC,OAAO,CAAC;QACb,QAAQ,EAAE,EAAE;QACZ,QAAQ,EAAE,EAAE;QACZ,GAAG,EAAE,EAAE;QACP,KAAK,EAAE;YACL,cAAc,EAAE,KAAK,CAAC,MAAM;YAC5B,aAAa,EAAE,CAAC;YAChB,aAAa,EAAE,CAAC;YAChB,eAAe,EAAE,CAAC;YAClB,YAAY,EAAE,KAAK,CAAC,MAAM;SAC3B;KACF,CAAC;CACL,CACF,CAAA;AAED;;GAEG;AACH,MAAM,eAAe,GAAuD;IAC1E,KAAK,EAAE,CAAC;IACR,WAAW,EAAE,GAAG;IAChB,QAAQ,EAAE,GAAG;IACb,SAAS,EAAE,MAAM;CAClB,CAAA;AAED;;GAEG;AACH,MAAM,qBAAqB,GAAG,CAC5B,SAA2D,EACb,EAAE;IAChD,IAAI,SAAS,KAAK,SAAS;QAAE,OAAO,IAAI,CAAA;IACxC,OAAO,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAA;AACjC,CAAC,CAAA;AAED;;;GAGG;AACH,MAAM,sBAAsB,GAAG,CAC7B,MAAsB,EACtB,UAAkB,WAAW,EACS,EAAE,CACxC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;IAClB,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,CAAA;IAE3C,qDAAqD;IACrD,IAAI,OAAO,IAAI,OAAO,EAAE,CAAC;QACvB,MAAM,UAAU,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,CAAA;QACnC,MAAM,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;QACtD,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACvB,OAAO,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC;gBAC5C,MAAM,EAAE,GAAG,OAAO,0EAA0E,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;aACjH,CAAC,CAAC,CAAA;QACL,CAAC;IACH,CAAC;IAED,sCAAsC;IACtC,IAAI,MAAM,EAAE,CAAC;QACX,KAAK,MAAM,CAAC,GAAG,EAAE,SAAS,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YACtD,KAAK,CAAC,CAAC,sBAAsB,CAAC,SAAS,EAAE,GAAG,OAAO,WAAW,GAAG,GAAG,CAAC,CAAA;QACvE,CAAC;IACH,CAAC;AACH,CAAC,CAAC,CAAA;AAEJ;;;GAGG;AACH,MAAM,sBAAsB,GAAG,CAC7B,MAAwD,EACxD,GAAW,EACsB,EAAE;IACnC,2CAA2C;IAC3C,IAAI,qBAAqB,CAAC,MAAM,CAAC,EAAE,CAAC;QAClC,OAAO,MAAM,CAAA;IACf,CAAC;IAED,kCAAkC;IAClC,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAA;IACtC,IAAI,SAAS,EAAE,CAAC;QACd,8EAA8E;QAC9E,OAAO,sBAAsB,CAAC,SAAS,EAAE,GAAG,CAAC,CAAA;IAC/C,CAAC;IAED,yCAAyC;IACzC,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,CAAA;IAEnC,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAClC,OAAO,OAAO,CAAA;IAChB,CAAC;IAED,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAClC,6CAA6C;QAC7C,OAAO,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAA;IACrD,CAAC;IAED,kDAAkD;IAClD,OAAO,SAAS,CAAA;AAClB,CAAC,CAAA;AAED;;GAEG;AACH,MAAM,eAAe,GAAG,CAAC,OAA8B,EAAwC,EAAE,CAC/F,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;IAClB,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,eAAe,CAAC,KAAK,CAAA;IACpD,MAAM,WAAW,GAAG,OAAO,CAAC,WAAW,IAAI,eAAe,CAAC,WAAW,CAAA;IACtE,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,eAAe,CAAC,QAAQ,CAAA;IAE7D,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;QACd,OAAO,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC;YAC5C,MAAM,EAAE,sCAAsC,KAAK,EAAE;SACtD,CAAC,CAAC,CAAA;IACL,CAAC;IAED,IAAI,KAAK,GAAG,EAAE,EAAE,CAAC;QACf,OAAO,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC;YAC5C,MAAM,EAAE,uCAAuC,KAAK,EAAE;SACvD,CAAC,CAAC,CAAA;IACL,CAAC;IAED,IAAI,WAAW,IAAI,CAAC,IAAI,WAAW,GAAG,CAAC,EAAE,CAAC;QACxC,OAAO,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC;YAC5C,MAAM,EAAE,wCAAwC,WAAW,EAAE;SAC9D,CAAC,CAAC,CAAA;IACL,CAAC;IAED,IAAI,QAAQ,GAAG,CAAC,EAAE,CAAC;QACjB,OAAO,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC;YAC5C,MAAM,EAAE,gCAAgC,QAAQ,EAAE;SACnD,CAAC,CAAC,CAAA;IACL,CAAC;IAED,sCAAsC;IACtC,IAAI,OAAO,CAAC,SAAS,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;QACnE,KAAK,CAAC,CAAC,sBAAsB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAA;IAClD,CAAC;AACH,CAAC,CAAC,CAAA;AAEJ,MAAM,CAAC,MAAM,yBAAyB,GAAG,KAAK,CAAC,MAAM,CACnD,qBAAqB,EACrB,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;IAClB,MAAM,WAAW,GAAG,KAAK,CAAC,CAAC,WAAW,CAAA;IACtC,MAAM,YAAY,GAAG,KAAK,CAAC,CAAC,kBAAkB,CAAA;IAC9C,MAAM,UAAU,GAAG,KAAK,CAAC,CAAC,gBAAgB,CAAA;IAE1C,OAAO;QACL,MAAM,EAAE,CAAC,KAAK,EAAE,OAAO,GAAG,EAAE,EAAE,EAAE,CAC9B,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;YAClB,mBAAmB;YACnB,KAAK,CAAC,CAAC,eAAe,CAAC,OAAO,CAAC,CAAA;YAE/B,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,eAAe,CAAC,KAAK,CAAA;YACpD,MAAM,WAAW,GAAG,OAAO,CAAC,WAAW,IAAI,eAAe,CAAC,WAAW,CAAA;YACtE,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,eAAe,CAAC,QAAQ,CAAA;YAC7D,MAAM,cAAc,GAAG,OAAO,CAAC,SAAS,CAAA;YACxC,oDAAoD;YACpD,MAAM,YAAY,GAAG,OAAO,CAAC,SAAS,IAAI,eAAe,CAAC,SAAS,CAAA;YACnE,MAAM,aAAa,GACjB,YAAY,KAAK,UAAU,CAAC,CAAC,CAAC,UAAU;gBACtC,CAAC,CAAC,YAAY,KAAK,SAAS,CAAC,CAAC,CAAC,UAAU;oBACzC,CAAC,CAAC,MAAM,CAAA;YAEZ,qBAAqB;YACrB,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvB,OAAO;oBACL,KAAK,EAAE,EAAE;oBACT,QAAQ,EAAE,EAAE;oBACZ,GAAG,EAAE,EAAE;oBACP,KAAK,EAAE;wBACL,SAAS,EAAE,CAAC;wBACZ,aAAa,EAAE,CAAC;wBAChB,eAAe,EAAE,CAAC;wBAClB,YAAY,EAAE,CAAC;wBACf,eAAe,EAAE,KAAK;qBACvB;iBACF,CAAA;YACH,CAAC;YAED,+CAA+C;YAC/C,MAAM,OAAO,GAAG,IAAI,GAAG,EAAU,CAAA;YAEjC,2CAA2C;YAC3C,MAAM,aAAa,GAAuB,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;gBAC3D,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;gBAC7B,OAAO;oBACL,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,IAAI,EAAE,CAAC;oBACP,YAAY,EAAE,IAAI,CAAC,KAAK;oBACxB,IAAI,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;oBACxB,UAAU,EAAE,IAAI;oBAChB,UAAU,EAAE,IAAI;iBACjB,CAAA;YACH,CAAC,CAAC,CAAA;YAEF,mCAAmC;YACnC,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;gBAChB,OAAO;oBACL,KAAK,EAAE,aAAa;oBACpB,QAAQ,EAAE,EAAE;oBACZ,GAAG,EAAE,aAAa;oBAClB,KAAK,EAAE;wBACL,SAAS,EAAE,aAAa,CAAC,MAAM;wBAC/B,aAAa,EAAE,CAAC;wBAChB,eAAe,EAAE,CAAC;wBAClB,YAAY,EAAE,aAAa,CAAC,MAAM;wBAClC,eAAe,EAAE,aAAa,CAAC,MAAM,IAAI,QAAQ;qBAClD;iBACF,CAAA;YACH,CAAC;YASD,IAAI,QAAQ,GAAmB,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;gBAClD,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE;gBAC5B,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,IAAI,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;aACzB,CAAC,CAAC,CAAA;YAEH,MAAM,QAAQ,GAAuB,EAAE,CAAA;YACvC,IAAI,eAAe,GAAG,CAAC,CAAA;YACvB,IAAI,eAAe,GAAG,KAAK,CAAA;YAC3B,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,aAAa,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAA;YAE/D,gBAAgB;YAChB,KAAK,IAAI,UAAU,GAAG,CAAC,EAAE,UAAU,IAAI,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC;gBAC3D,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;oBAAE,MAAK;gBAChC,IAAI,UAAU,EAAE,IAAI,QAAQ,EAAE,CAAC;oBAAC,eAAe,GAAG,IAAI,CAAC;oBAAC,MAAK;gBAAC,CAAC;gBAE/D,MAAM,YAAY,GAAmB,EAAE,CAAA;gBAEvC,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;oBAC5B,IAAI,UAAU,EAAE,IAAI,QAAQ,EAAE,CAAC;wBAAC,eAAe,GAAG,IAAI,CAAC;wBAAC,MAAK;oBAAC,CAAC;oBAE/D,oEAAoE;oBACpE,wEAAwE;oBACxE,MAAM,eAAe,GAAG,sBAAsB,CAAC,cAAc,EAAE,UAAU,CAAC,CAAA;oBAC1E,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,WAAW,CAAC,aAAa,CAChD,UAAU,EACV,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,EACvB;wBACE,KAAK,EAAE,CAAC;wBACR,SAAS,EAAE,aAAa;wBACxB,SAAS,EAAE,eAAe;qBAC3B,CACF,CAAA;oBAED,gDAAgD;oBAChD,MAAM,iBAAiB,GAAG,SAAS,CAAC,MAAM,CACxC,CAAC,CAAC,EAAqD,EAAE,CACvD,CAAC,CAAC,QAAQ,KAAK,UAAU,CAC5B,CAAA;oBAED,KAAK,MAAM,QAAQ,IAAI,iBAAiB,EAAE,CAAC;wBACzC,IAAI,UAAU,EAAE,IAAI,QAAQ,EAAE,CAAC;4BAAC,eAAe,GAAG,IAAI,CAAC;4BAAC,MAAK;wBAAC,CAAC;wBAE/D,MAAM,UAAU,GAAG,QAAQ,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;wBAChD,IAAI,KAAK,CAAC,UAAU,CAAC;4BAAE,SAAQ;wBAC/B,IAAI,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC;4BAAE,SAAQ;wBAErC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAA;wBAEvB,2CAA2C;wBAC3C,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,YAAY,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAA;wBACzD,IAAI,CAAC,QAAQ;4BAAE,SAAQ;wBAEvB,kEAAkE;wBAClE,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC,MAAM,GAAG,WAAW,CAAA;wBAC3D,MAAM,OAAO,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAA;wBAE3C,QAAQ,CAAC,IAAI,CAAC;4BACZ,QAAQ;4BACR,IAAI,EAAE,UAAU;4BAChB,YAAY,EAAE,QAAQ;4BACtB,IAAI,EAAE,OAAO;4BACb,UAAU,EAAE,QAAQ,CAAC,QAAQ;4BAC7B,UAAU,EAAE,QAAQ,CAAC,MAAM;yBAC5B,CAAC,CAAA;wBAEF,eAAe,GAAG,UAAU,CAAA;wBAE5B,6CAA6C;wBAC7C,YAAY,CAAC,IAAI,CAAC;4BAChB,UAAU,EAAE,QAAQ,CAAC,EAAE;4BACvB,KAAK,EAAE,QAAQ;4BACf,IAAI,EAAE,OAAO;yBACd,CAAC,CAAA;oBACJ,CAAC;gBACH,CAAC;gBAED,QAAQ,GAAG,YAAY,CAAA;YACzB,CAAC;YAED,iDAAiD;YACjD,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,GAAG,CAAC,CAAC,YAAY,CAAC,CAAA;YAExD,qDAAqD;YACrD,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,QAAQ,GAAG,aAAa,CAAC,MAAM,CAAC,CAAA;YAClE,MAAM,eAAe,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,aAAa,CAAC,CAAA;YACxD,IAAI,QAAQ,CAAC,MAAM,GAAG,aAAa;gBAAE,eAAe,GAAG,IAAI,CAAA;YAE3D,MAAM,GAAG,GAAG,CAAC,GAAG,aAAa,EAAE,GAAG,eAAe,CAAC,CAAA;YAElD,OAAO;gBACL,KAAK,EAAE,aAAa;gBACpB,QAAQ,EAAE,eAAe;gBACzB,GAAG;gBACH,KAAK,EAAE;oBACL,SAAS,EAAE,aAAa,CAAC,MAAM;oBAC/B,aAAa,EAAE,eAAe,CAAC,MAAM;oBACrC,eAAe;oBACf,YAAY,EAAE,OAAO,CAAC,IAAI;oBAC1B,eAAe;iBAChB;aACF,CAAA;QACH,CAAC,CAAC;QAEJ,eAAe,EAAE,CAAC,KAAK,EAAE,OAAO,GAAG,EAAE,EAAE,EAAE,CACvC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;YAClB,mBAAmB;YACnB,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,eAAe,CAAC,KAAK,CAAA;YACpD,MAAM,WAAW,GAAG,OAAO,CAAC,WAAW,IAAI,eAAe,CAAC,WAAW,CAAA;YACtE,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,eAAe,CAAC,QAAQ,CAAA;YAE7D,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;gBACd,OAAO,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC;oBAC5C,MAAM,EAAE,sCAAsC,KAAK,EAAE;iBACtD,CAAC,CAAC,CAAA;YACL,CAAC;YAED,IAAI,KAAK,GAAG,EAAE,EAAE,CAAC;gBACf,OAAO,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC;oBAC5C,MAAM,EAAE,uCAAuC,KAAK,EAAE;iBACvD,CAAC,CAAC,CAAA;YACL,CAAC;YAED,IAAI,WAAW,IAAI,CAAC,IAAI,WAAW,GAAG,CAAC,EAAE,CAAC;gBACxC,OAAO,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC;oBAC5C,MAAM,EAAE,wCAAwC,WAAW,EAAE;iBAC9D,CAAC,CAAC,CAAA;YACL,CAAC;YAED,IAAI,QAAQ,GAAG,CAAC,EAAE,CAAC;gBACjB,OAAO,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC;oBAC5C,MAAM,EAAE,gCAAgC,QAAQ,EAAE;iBACnD,CAAC,CAAC,CAAA;YACL,CAAC;YAED,2BAA2B;YAC3B,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvB,OAAO;oBACL,QAAQ,EAAE,EAAE;oBACZ,QAAQ,EAAE,EAAE;oBACZ,GAAG,EAAE,EAAE;oBACP,KAAK,EAAE;wBACL,cAAc,EAAE,CAAC;wBACjB,aAAa,EAAE,CAAC;wBAChB,aAAa,EAAE,CAAC;wBAChB,eAAe,EAAE,CAAC;wBAClB,YAAY,EAAE,CAAC;qBAChB;iBACF,CAAA;YACH,CAAC;YAED,0DAA0D;YAC1D,MAAM,YAAY,GAAG,IAAI,GAAG,CAAS,KAAK,CAAC,CAAA;YAC3C,MAAM,kBAAkB,GAAG,IAAI,GAAG,EAAU,CAAA;YAE5C,6DAA6D;YAC7D,MAAM,iBAAiB,GAA2B,EAAE,CAAA;YAEpD,KAAK,MAAM,QAAQ,IAAI,KAAK,EAAE,CAAC;gBAC7B,MAAM,OAAO,GAAG,KAAK,CAAC,CAAC,UAAU,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAA;gBAE1D,+BAA+B;gBAC/B,MAAM,YAAY,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,OAAO,CAAC,CAAA;gBAE9D,KAAK,MAAM,MAAM,IAAI,YAAY,EAAE,CAAC;oBAClC,IAAI,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC;wBAAE,SAAQ;oBACvD,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;oBAEzC,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;oBAChE,IAAI,CAAC,QAAQ;wBAAE,SAAQ;oBAEvB,iBAAiB,CAAC,IAAI,CAAC;wBACrB,QAAQ;wBACR,UAAU,EAAE,QAAQ;wBACpB,IAAI,EAAE,CAAC;wBACP,YAAY,EAAE,GAAG,EAAE,6CAA6C;wBAChE,UAAU,EAAE,aAAa;wBACzB,UAAU,EAAE,IAAI;qBACjB,CAAC,CAAA;gBACJ,CAAC;YACH,CAAC;YAED,gDAAgD;YAChD,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;gBAChB,MAAM,eAAe,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAA;gBAC5D,OAAO;oBACL,QAAQ,EAAE,eAAe;oBACzB,QAAQ,EAAE,EAAE;oBACZ,GAAG,EAAE,eAAe;oBACpB,KAAK,EAAE;wBACL,cAAc,EAAE,KAAK,CAAC,MAAM;wBAC5B,aAAa,EAAE,eAAe,CAAC,MAAM;wBACrC,aAAa,EAAE,CAAC;wBAChB,eAAe,EAAE,CAAC;wBAClB,YAAY,EAAE,KAAK,CAAC,MAAM;qBAC3B;iBACF,CAAA;YACH,CAAC;YAQD,IAAI,QAAQ,GAAuB,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;gBACjD,QAAQ,EAAE,CAAC;gBACX,KAAK,EAAE,GAAG;aACX,CAAC,CAAC,CAAA;YAEH,MAAM,iBAAiB,GAA2B,EAAE,CAAA;YACpD,IAAI,eAAe,GAAG,CAAC,CAAA;YACvB,MAAM,cAAc,GAAG,GAAG,EAAE,CAAC,iBAAiB,CAAC,MAAM,GAAG,iBAAiB,CAAC,MAAM,CAAA;YAEhF,2CAA2C;YAC3C,KAAK,IAAI,UAAU,GAAG,CAAC,EAAE,UAAU,IAAI,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC;gBAC3D,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;oBAAE,MAAK;gBAChC,IAAI,cAAc,EAAE,IAAI,QAAQ;oBAAE,MAAK;gBAEvC,MAAM,YAAY,GAAuB,EAAE,CAAA;gBAE3C,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;oBAC5B,IAAI,cAAc,EAAE,IAAI,QAAQ;wBAAE,MAAK;oBAEvC,2DAA2D;oBAC3D,uEAAuE;oBACvE,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,WAAW,CAAC,aAAa,CAChD,MAAM,EACN,IAAI,CAAC,QAAQ,EACb;wBACE,KAAK,EAAE,CAAC;wBACR,SAAS,EAAE,MAAM;wBACjB,SAAS,EAAE,CAAC,SAAS,EAAE,iBAAiB,CAAC;qBAC1C,CACF,CAAA;oBAED,gCAAgC;oBAChC,MAAM,aAAa,GAAG,SAAS,CAAC,MAAM,CACpC,CAAC,CAAC,EAAiD,EAAE,CACnD,CAAC,CAAC,QAAQ,KAAK,MAAM,CACxB,CAAA;oBAED,KAAK,MAAM,QAAQ,IAAI,aAAa,EAAE,CAAC;wBACrC,IAAI,cAAc,EAAE,IAAI,QAAQ;4BAAE,MAAK;wBAEvC,MAAM,eAAe,GAAG,QAAQ,CAAC,MAAM,CAAA;wBACvC,IAAI,YAAY,CAAC,GAAG,CAAC,eAAe,CAAC;4BAAE,SAAQ;wBAC/C,YAAY,CAAC,GAAG,CAAC,eAAe,CAAC,CAAA;wBAEjC,uCAAuC;wBACvC,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC,MAAM,GAAG,WAAW,CAAA;wBAE3D,+CAA+C;wBAC/C,MAAM,OAAO,GAAG,KAAK,CAAC,CAAC,UAAU,CAAC,cAAc,CAAC,eAAe,CAAC,CAAA;wBACjE,MAAM,YAAY,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,OAAO,CAAC,CAAA;wBAE9D,KAAK,MAAM,MAAM,IAAI,YAAY,EAAE,CAAC;4BAClC,IAAI,cAAc,EAAE,IAAI,QAAQ;gCAAE,MAAK;4BACvC,IAAI,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC;gCAAE,SAAQ;4BACvD,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;4BAEzC,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;4BAChE,IAAI,CAAC,QAAQ;gCAAE,SAAQ;4BAEvB,iBAAiB,CAAC,IAAI,CAAC;gCACrB,QAAQ;gCACR,UAAU,EAAE,eAAe;gCAC3B,IAAI,EAAE,UAAU;gCAChB,YAAY,EAAE,QAAQ;gCACtB,UAAU,EAAE,QAAQ,CAAC,QAAQ;gCAC7B,UAAU,EAAE,QAAQ,CAAC,MAAM;6BAC5B,CAAC,CAAA;4BAEF,eAAe,GAAG,UAAU,CAAA;wBAC9B,CAAC;wBAED,6CAA6C;wBAC7C,YAAY,CAAC,IAAI,CAAC;4BAChB,QAAQ,EAAE,eAAe;4BACzB,KAAK,EAAE,QAAQ;yBAChB,CAAC,CAAA;oBACJ,CAAC;gBACH,CAAC;gBAED,QAAQ,GAAG,YAAY,CAAA;YACzB,CAAC;YAED,iDAAiD;YACjD,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,GAAG,CAAC,CAAC,YAAY,CAAC,CAAA;YAEjE,yBAAyB;YACzB,MAAM,cAAc,GAAG,iBAAiB,CAAC,MAAM,GAAG,iBAAiB,CAAC,MAAM,CAAA;YAC1E,IAAI,eAAe,GAAG,iBAAiB,CAAA;YACvC,IAAI,eAAe,GAAG,iBAAiB,CAAA;YAEvC,IAAI,cAAc,GAAG,QAAQ,EAAE,CAAC;gBAC9B,yDAAyD;gBACzD,IAAI,iBAAiB,CAAC,MAAM,IAAI,QAAQ,EAAE,CAAC;oBACzC,eAAe,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAA;oBACtD,eAAe,GAAG,EAAE,CAAA;gBACtB,CAAC;qBAAM,CAAC;oBACN,MAAM,cAAc,GAAG,QAAQ,GAAG,iBAAiB,CAAC,MAAM,CAAA;oBAC1D,eAAe,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC,EAAE,cAAc,CAAC,CAAA;gBAC9D,CAAC;YACH,CAAC;YAED,uCAAuC;YACvC,MAAM,GAAG,GAAG,CAAC,GAAG,eAAe,EAAE,GAAG,eAAe,CAAC,CAAA;YACpD,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,GAAG,CAAC,CAAC,YAAY,CAAC,CAAA;YAEnD,OAAO;gBACL,QAAQ,EAAE,eAAe;gBACzB,QAAQ,EAAE,eAAe;gBACzB,GAAG;gBACH,KAAK,EAAE;oBACL,cAAc,EAAE,KAAK,CAAC,MAAM;oBAC5B,aAAa,EAAE,eAAe,CAAC,MAAM;oBACrC,aAAa,EAAE,eAAe,CAAC,MAAM;oBACrC,eAAe;oBACf,YAAY,EAAE,YAAY,CAAC,IAAI;iBAChC;aACF,CAAA;QACH,CAAC,CAAC;KACL,CAAA;AACH,CAAC,CAAC,CACH,CAAA"}
@@ -1,67 +0,0 @@
1
- import { Context, Effect, Layer } from "effect";
2
- import { CandidateNotFoundError, DatabaseError, ValidationError } from "../errors.js";
3
- import { CandidateRepository } from "../repo/candidate-repo.js";
4
- import { LearningService } from "./learning-service.js";
5
- import { EdgeService } from "./edge-service.js";
6
- import type { LearningCandidate, CandidateFilter, CandidateId, Learning } from "@jamesaphoenix/tx-types";
7
- /**
8
- * Result of promoting a candidate to the learnings table.
9
- */
10
- export interface PromotionResult {
11
- /** The updated candidate with promoted status */
12
- readonly candidate: LearningCandidate;
13
- /** The newly created learning */
14
- readonly learning: Learning;
15
- }
16
- /**
17
- * Result of auto-promotion batch operation.
18
- */
19
- export interface AutoPromoteResult {
20
- /** Number of candidates auto-promoted */
21
- readonly promoted: number;
22
- /** Number of candidates skipped (already processed or low confidence) */
23
- readonly skipped: number;
24
- /** Number of candidates that failed to promote */
25
- readonly failed: number;
26
- /** IDs of promoted learnings */
27
- readonly learningIds: readonly number[];
28
- }
29
- declare const PromotionService_base: Context.TagClass<PromotionService, "PromotionService", {
30
- /**
31
- * List candidates matching the given filter.
32
- * Supports filtering by status, confidence, category, and pagination.
33
- */
34
- readonly list: (filter: CandidateFilter) => Effect.Effect<readonly LearningCandidate[], DatabaseError>;
35
- /**
36
- * Promote a candidate to the learnings table.
37
- * Creates a new learning and updates the candidate status to 'promoted'.
38
- */
39
- readonly promote: (id: CandidateId) => Effect.Effect<PromotionResult, CandidateNotFoundError | DatabaseError>;
40
- /**
41
- * Reject a candidate with a reason.
42
- * Updates the candidate status to 'rejected' and stores the rejection reason.
43
- */
44
- readonly reject: (id: CandidateId, reason: string) => Effect.Effect<LearningCandidate, CandidateNotFoundError | ValidationError | DatabaseError>;
45
- /**
46
- * Auto-promote high-confidence candidates.
47
- * Promotes all pending candidates with 'high' confidence level.
48
- * Uses 'auto' as the reviewer identifier.
49
- */
50
- readonly autoPromote: () => Effect.Effect<AutoPromoteResult, DatabaseError>;
51
- /**
52
- * Get all pending candidates awaiting review.
53
- * Convenience method equivalent to list({ status: 'pending' }).
54
- */
55
- readonly getPending: () => Effect.Effect<readonly LearningCandidate[], DatabaseError>;
56
- }>;
57
- /**
58
- * PromotionService manages the lifecycle of learning candidates,
59
- * including listing, promoting to learnings, rejecting, and auto-promotion.
60
- *
61
- * @see PRD-015 for the knowledge promotion pipeline
62
- */
63
- export declare class PromotionService extends PromotionService_base {
64
- }
65
- export declare const PromotionServiceLive: Layer.Layer<PromotionService, never, LearningService | CandidateRepository | EdgeService>;
66
- export {};
67
- //# sourceMappingURL=promotion-service.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"promotion-service.d.ts","sourceRoot":"","sources":["../../src/services/promotion-service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,QAAQ,CAAA;AAC/C,OAAO,EAAE,sBAAsB,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AACrF,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAA;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAA;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAA;AAC/C,OAAO,KAAK,EACV,iBAAiB,EACjB,eAAe,EACf,WAAW,EACX,QAAQ,EACT,MAAM,yBAAyB,CAAA;AAEhC;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,iDAAiD;IACjD,QAAQ,CAAC,SAAS,EAAE,iBAAiB,CAAA;IACrC,iCAAiC;IACjC,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAA;CAC5B;AAED;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,yCAAyC;IACzC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAA;IACzB,yEAAyE;IACzE,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAA;IACxB,kDAAkD;IAClD,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAA;IACvB,gCAAgC;IAChC,QAAQ,CAAC,WAAW,EAAE,SAAS,MAAM,EAAE,CAAA;CACxC;;IAWG;;;OAGG;mBACY,CAAC,MAAM,EAAE,eAAe,KAAK,MAAM,CAAC,MAAM,CAAC,SAAS,iBAAiB,EAAE,EAAE,aAAa,CAAC;IAEtG;;;OAGG;sBACe,CAAC,EAAE,EAAE,WAAW,KAAK,MAAM,CAAC,MAAM,CAAC,eAAe,EAAE,sBAAsB,GAAG,aAAa,CAAC;IAE7G;;;OAGG;qBACc,CAAC,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,KAAK,MAAM,CAAC,MAAM,CAAC,iBAAiB,EAAE,sBAAsB,GAAG,eAAe,GAAG,aAAa,CAAC;IAEhJ;;;;OAIG;0BACmB,MAAM,MAAM,CAAC,MAAM,CAAC,iBAAiB,EAAE,aAAa,CAAC;IAE3E;;;OAGG;yBACkB,MAAM,MAAM,CAAC,MAAM,CAAC,SAAS,iBAAiB,EAAE,EAAE,aAAa,CAAC;;AAtCzF;;;;;GAKG;AACH,qBAAa,gBAAiB,SAAQ,qBAkCnC;CAAG;AAKN,eAAO,MAAM,oBAAoB,2FAiLhC,CAAA"}