code-kg 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (93) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +100 -0
  3. package/dist/cli/index.d.ts +14 -0
  4. package/dist/cli/index.js +68 -0
  5. package/dist/cli/index.js.map +1 -0
  6. package/dist/codekg-config.d.ts +14 -0
  7. package/dist/codekg-config.js +81 -0
  8. package/dist/codekg-config.js.map +1 -0
  9. package/dist/commands/graph.d.ts +7 -0
  10. package/dist/commands/graph.js +49 -0
  11. package/dist/commands/graph.js.map +1 -0
  12. package/dist/commands/init.d.ts +6 -0
  13. package/dist/commands/init.js +13 -0
  14. package/dist/commands/init.js.map +1 -0
  15. package/dist/commands/insights.d.ts +7 -0
  16. package/dist/commands/insights.js +31 -0
  17. package/dist/commands/insights.js.map +1 -0
  18. package/dist/commands/path.d.ts +7 -0
  19. package/dist/commands/path.js +47 -0
  20. package/dist/commands/path.js.map +1 -0
  21. package/dist/commands/reindex.d.ts +6 -0
  22. package/dist/commands/reindex.js +13 -0
  23. package/dist/commands/reindex.js.map +1 -0
  24. package/dist/commands/run.d.ts +6 -0
  25. package/dist/commands/run.js +20 -0
  26. package/dist/commands/run.js.map +1 -0
  27. package/dist/commands/serve.d.ts +8 -0
  28. package/dist/commands/serve.js +25 -0
  29. package/dist/commands/serve.js.map +1 -0
  30. package/dist/config/defaults.d.ts +6 -0
  31. package/dist/config/defaults.js +30 -0
  32. package/dist/config/defaults.js.map +1 -0
  33. package/dist/index.d.ts +52 -0
  34. package/dist/index.js +602 -0
  35. package/dist/index.js.map +1 -0
  36. package/dist/indexer/babel-fallback.d.ts +7 -0
  37. package/dist/indexer/babel-fallback.js +583 -0
  38. package/dist/indexer/babel-fallback.js.map +1 -0
  39. package/dist/indexer/file-discovery.d.ts +6 -0
  40. package/dist/indexer/file-discovery.js +106 -0
  41. package/dist/indexer/file-discovery.js.map +1 -0
  42. package/dist/indexer/indexer.d.ts +90 -0
  43. package/dist/indexer/indexer.js +620 -0
  44. package/dist/indexer/indexer.js.map +1 -0
  45. package/dist/indexer/metrics.d.ts +39 -0
  46. package/dist/indexer/metrics.js +147 -0
  47. package/dist/indexer/metrics.js.map +1 -0
  48. package/dist/indexer/structure-detector.d.ts +16 -0
  49. package/dist/indexer/structure-detector.js +159 -0
  50. package/dist/indexer/structure-detector.js.map +1 -0
  51. package/dist/indexer/ts-parser.d.ts +86 -0
  52. package/dist/indexer/ts-parser.js +437 -0
  53. package/dist/indexer/ts-parser.js.map +1 -0
  54. package/dist/model/edge.d.ts +21 -0
  55. package/dist/model/edge.js +25 -0
  56. package/dist/model/edge.js.map +1 -0
  57. package/dist/model/graph.d.ts +10 -0
  58. package/dist/model/graph.js +20 -0
  59. package/dist/model/graph.js.map +1 -0
  60. package/dist/model/node.d.ts +24 -0
  61. package/dist/model/node.js +22 -0
  62. package/dist/model/node.js.map +1 -0
  63. package/dist/query/query-dsl.d.ts +17 -0
  64. package/dist/query/query-dsl.js +75 -0
  65. package/dist/query/query-dsl.js.map +1 -0
  66. package/dist/query/query-engine.d.ts +32 -0
  67. package/dist/query/query-engine.js +126 -0
  68. package/dist/query/query-engine.js.map +1 -0
  69. package/dist/server/api.d.ts +19 -0
  70. package/dist/server/api.js +29 -0
  71. package/dist/server/api.js.map +1 -0
  72. package/dist/server/app.d.ts +7 -0
  73. package/dist/server/app.js +509 -0
  74. package/dist/server/app.js.map +1 -0
  75. package/dist/server/graph-controller.d.ts +147 -0
  76. package/dist/server/graph-controller.js +186 -0
  77. package/dist/server/graph-controller.js.map +1 -0
  78. package/dist/server/routes.d.ts +3 -0
  79. package/dist/server/routes.js +19 -0
  80. package/dist/server/routes.js.map +1 -0
  81. package/dist/server/ui.d.ts +1 -0
  82. package/dist/server/ui.js +1165 -0
  83. package/dist/server/ui.js.map +1 -0
  84. package/dist/store/sqlite-store.d.ts +83 -0
  85. package/dist/store/sqlite-store.js +647 -0
  86. package/dist/store/sqlite-store.js.map +1 -0
  87. package/dist/utils/ids.d.ts +2 -0
  88. package/dist/utils/ids.js +9 -0
  89. package/dist/utils/ids.js.map +1 -0
  90. package/dist/utils/path.d.ts +3 -0
  91. package/dist/utils/path.js +21 -0
  92. package/dist/utils/path.js.map +1 -0
  93. package/package.json +58 -0
@@ -0,0 +1,509 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.createApp = createApp;
7
+ const express_1 = __importDefault(require("express"));
8
+ const node_fs_1 = require("node:fs");
9
+ const node_path_1 = __importDefault(require("node:path"));
10
+ const api_1 = require("./api");
11
+ const graph_controller_1 = require("./graph-controller");
12
+ const routes_1 = require("./routes");
13
+ const ui_1 = require("./ui");
14
+ function resolveVendorAsset(...candidates) {
15
+ for (const candidate of candidates) {
16
+ try {
17
+ return require.resolve(candidate);
18
+ }
19
+ catch {
20
+ continue;
21
+ }
22
+ }
23
+ return null;
24
+ }
25
+ function resolveModuleSiblingAsset(moduleId, fileName) {
26
+ const entryPoint = resolveVendorAsset(moduleId);
27
+ if (!entryPoint) {
28
+ return null;
29
+ }
30
+ const candidate = node_path_1.default.join(node_path_1.default.dirname(entryPoint), fileName);
31
+ return (0, node_fs_1.existsSync)(candidate) ? candidate : null;
32
+ }
33
+ function mountLocalVendorAssets(app) {
34
+ app.get("/assets/vendor/three.min.js", (_req, res) => {
35
+ const resolved = resolveModuleSiblingAsset("three", "three.min.js");
36
+ if (!resolved) {
37
+ return (0, api_1.sendError)(res, "ASSET_NOT_FOUND", "Local Three.js asset is unavailable.", 404);
38
+ }
39
+ return res.sendFile(node_path_1.default.resolve(resolved));
40
+ });
41
+ app.get("/assets/vendor/3d-force-graph.min.js", (_req, res) => {
42
+ const resolved = resolveModuleSiblingAsset("3d-force-graph", "3d-force-graph.min.js");
43
+ if (!resolved) {
44
+ return (0, api_1.sendError)(res, "ASSET_NOT_FOUND", "Local 3d-force-graph asset is unavailable.", 404);
45
+ }
46
+ return res.sendFile(node_path_1.default.resolve(resolved));
47
+ });
48
+ }
49
+ function createDefaultGraphQueryEngine() {
50
+ const nodes = [
51
+ { id: 'file:src/server/app.ts', type: 'File', name: 'app.ts', path: 'src/server/app.ts' },
52
+ { id: 'file:src/server/routes.ts', type: 'File', name: 'routes.ts', path: 'src/server/routes.ts' },
53
+ {
54
+ id: 'file:src/server/graph-controller.ts',
55
+ type: 'File',
56
+ name: 'graph-controller.ts',
57
+ path: 'src/server/graph-controller.ts',
58
+ },
59
+ { id: 'file:src/server/ui.ts', type: 'File', name: 'ui.ts', path: 'src/server/ui.ts' },
60
+ { id: 'symbol:createApp', type: 'Function', name: 'createApp', path: 'src/server/app.ts' },
61
+ {
62
+ id: 'symbol:GraphController',
63
+ type: 'Class',
64
+ name: 'GraphController',
65
+ path: 'src/server/graph-controller.ts',
66
+ },
67
+ {
68
+ id: 'symbol:renderUiHtml',
69
+ type: 'Function',
70
+ name: 'renderUiHtml',
71
+ path: 'src/server/ui.ts',
72
+ },
73
+ {
74
+ id: 'route:getMeta',
75
+ type: 'Route',
76
+ name: 'GET /api/meta',
77
+ path: 'src/server/routes.ts',
78
+ props: { method: 'GET', routePath: '/api/meta' },
79
+ },
80
+ {
81
+ id: 'route:postQuery',
82
+ type: 'Route',
83
+ name: 'POST /api/query',
84
+ path: 'src/server/routes.ts',
85
+ props: { method: 'POST', routePath: '/api/query' },
86
+ },
87
+ ];
88
+ const edges = [
89
+ { id: 'edge:1', from: 'file:src/server/app.ts', to: 'file:src/server/routes.ts', type: 'IMPORTS' },
90
+ {
91
+ id: 'edge:2',
92
+ from: 'file:src/server/routes.ts',
93
+ to: 'file:src/server/graph-controller.ts',
94
+ type: 'IMPORTS',
95
+ },
96
+ { id: 'edge:3', from: 'file:src/server/app.ts', to: 'file:src/server/ui.ts', type: 'IMPORTS' },
97
+ { id: 'edge:4', from: 'symbol:createApp', to: 'symbol:GraphController', type: 'CALLS' },
98
+ { id: 'edge:5', from: 'symbol:createApp', to: 'symbol:renderUiHtml', type: 'CALLS' },
99
+ { id: 'edge:6', from: 'route:getMeta', to: 'symbol:GraphController', type: 'HANDLES_ROUTE' },
100
+ { id: 'edge:7', from: 'route:postQuery', to: 'symbol:GraphController', type: 'HANDLES_ROUTE' },
101
+ { id: 'edge:8', from: 'file:src/server/graph-controller.ts', to: 'file:src/server/routes.ts', type: 'DEPENDS_ON' },
102
+ ];
103
+ const routeMap = [
104
+ {
105
+ id: 'route:getMeta',
106
+ method: 'GET',
107
+ path: '/api/meta',
108
+ handler: 'GraphController.getMeta',
109
+ file: 'src/server/routes.ts',
110
+ dependencies: ['src/server/graph-controller.ts'],
111
+ },
112
+ {
113
+ id: 'route:getSearch',
114
+ method: 'GET',
115
+ path: '/api/search',
116
+ handler: 'GraphController.search',
117
+ file: 'src/server/routes.ts',
118
+ dependencies: ['src/server/graph-controller.ts'],
119
+ },
120
+ {
121
+ id: 'route:getNode',
122
+ method: 'GET',
123
+ path: '/api/node/:id',
124
+ handler: 'GraphController.getNode',
125
+ file: 'src/server/routes.ts',
126
+ dependencies: ['src/server/graph-controller.ts'],
127
+ },
128
+ {
129
+ id: 'route:getGraph',
130
+ method: 'GET',
131
+ path: '/api/graph',
132
+ handler: 'GraphController.getGraph',
133
+ file: 'src/server/routes.ts',
134
+ dependencies: ['src/server/graph-controller.ts'],
135
+ },
136
+ {
137
+ id: 'route:getRoutes',
138
+ method: 'GET',
139
+ path: '/api/routes',
140
+ handler: 'GraphController.getRoutes',
141
+ file: 'src/server/routes.ts',
142
+ dependencies: ['src/server/graph-controller.ts'],
143
+ },
144
+ {
145
+ id: 'route:getCycles',
146
+ method: 'GET',
147
+ path: '/api/cycles',
148
+ handler: 'GraphController.getCycles',
149
+ file: 'src/server/routes.ts',
150
+ dependencies: ['src/server/graph-controller.ts'],
151
+ },
152
+ {
153
+ id: 'route:postQuery',
154
+ method: 'POST',
155
+ path: '/api/query',
156
+ handler: 'GraphController.postQuery',
157
+ file: 'src/server/routes.ts',
158
+ dependencies: ['src/server/graph-controller.ts'],
159
+ },
160
+ {
161
+ id: 'route:postLlmQuery',
162
+ method: 'POST',
163
+ path: '/api/llm/query',
164
+ handler: 'GraphController.postLlmQuery',
165
+ file: 'src/server/routes.ts',
166
+ dependencies: ['src/server/graph-controller.ts'],
167
+ },
168
+ ];
169
+ const cycles = [
170
+ {
171
+ id: 'cycle:server-core',
172
+ nodes: ['file:src/server/routes.ts', 'file:src/server/graph-controller.ts'],
173
+ size: 2,
174
+ severity: 'medium',
175
+ },
176
+ ];
177
+ function isFileNode(node) {
178
+ return node.type.toLowerCase() === 'file';
179
+ }
180
+ function isFileDependencyEdge(edge) {
181
+ return edge.type === 'IMPORTS' || edge.type === 'DEPENDS_ON';
182
+ }
183
+ function buildRefactorInsights(limit) {
184
+ const fileNodes = nodes.filter(isFileNode);
185
+ const fanIn = new Map();
186
+ const fanOut = new Map();
187
+ for (const fileNode of fileNodes) {
188
+ fanIn.set(fileNode.id, 0);
189
+ fanOut.set(fileNode.id, 0);
190
+ }
191
+ for (const edge of edges.filter(isFileDependencyEdge)) {
192
+ if (fanOut.has(edge.from)) {
193
+ fanOut.set(edge.from, (fanOut.get(edge.from) ?? 0) + 1);
194
+ }
195
+ if (fanIn.has(edge.to)) {
196
+ fanIn.set(edge.to, (fanIn.get(edge.to) ?? 0) + 1);
197
+ }
198
+ }
199
+ const hotspots = fileNodes
200
+ .map((node) => {
201
+ const incoming = fanIn.get(node.id) ?? 0;
202
+ const outgoing = fanOut.get(node.id) ?? 0;
203
+ return {
204
+ nodeId: node.id,
205
+ path: node.path,
206
+ fanIn: incoming,
207
+ fanOut: outgoing,
208
+ score: incoming + outgoing,
209
+ };
210
+ })
211
+ .sort((a, b) => b.score - a.score)
212
+ .slice(0, limit);
213
+ const orphanModules = fileNodes
214
+ .filter((node) => (fanIn.get(node.id) ?? 0) === 0 && (fanOut.get(node.id) ?? 0) === 0)
215
+ .map((node) => ({ nodeId: node.id, path: node.path }));
216
+ return {
217
+ hotspots,
218
+ orphanModules,
219
+ cycleCount: cycles.length,
220
+ recommendation: 'Reduce coupling in top hotspot files first, then eliminate SCC groups to simplify future changes.',
221
+ };
222
+ }
223
+ function buildGraphView(view) {
224
+ if (view === 'fileDeps') {
225
+ const viewNodes = nodes.filter(isFileNode);
226
+ const viewEdges = edges.filter((edge) => isFileDependencyEdge(edge) &&
227
+ viewNodes.some((node) => node.id === edge.from) &&
228
+ viewNodes.some((node) => node.id === edge.to));
229
+ return { view, nodes: viewNodes, edges: viewEdges };
230
+ }
231
+ if (view === 'symbolGraph') {
232
+ const viewNodes = nodes.filter((node) => ['function', 'class', 'interface', 'route'].includes(node.type.toLowerCase()));
233
+ const allowedTypes = new Set(['CALLS', 'REFERENCES', 'HANDLES_ROUTE']);
234
+ const viewNodeIds = new Set(viewNodes.map((node) => node.id));
235
+ const viewEdges = edges.filter((edge) => allowedTypes.has(edge.type) && viewNodeIds.has(edge.from) && viewNodeIds.has(edge.to));
236
+ return { view, nodes: viewNodes, edges: viewEdges };
237
+ }
238
+ return { view, nodes, edges };
239
+ }
240
+ function applyGraphFilters(graph, options) {
241
+ const nodeTypeFilter = options.nodeTypes?.map((value) => value.toLowerCase()) ?? [];
242
+ const edgeTypeFilter = options.edgeTypes?.map((value) => value.toUpperCase()) ?? [];
243
+ const query = options.q?.toLowerCase().trim() ?? "";
244
+ const limit = Math.max(0, Math.floor(options.limit ?? 0));
245
+ let filteredNodes = graph.nodes;
246
+ if (nodeTypeFilter.length > 0) {
247
+ const nodeTypeSet = new Set(nodeTypeFilter);
248
+ filteredNodes = filteredNodes.filter((node) => nodeTypeSet.has(node.type.toLowerCase()));
249
+ }
250
+ if (query.length > 0) {
251
+ filteredNodes = filteredNodes.filter((node) => `${node.id} ${node.type} ${node.name} ${node.path ?? ""}`.toLowerCase().includes(query));
252
+ }
253
+ filteredNodes = [...filteredNodes].sort((left, right) => left.id.localeCompare(right.id));
254
+ if (limit > 0) {
255
+ filteredNodes = filteredNodes.slice(0, limit);
256
+ }
257
+ const nodeIds = new Set(filteredNodes.map((node) => node.id));
258
+ let filteredEdges = graph.edges.filter((edge) => nodeIds.has(edge.from) && nodeIds.has(edge.to));
259
+ if (edgeTypeFilter.length > 0) {
260
+ const edgeTypeSet = new Set(edgeTypeFilter);
261
+ filteredEdges = filteredEdges.filter((edge) => edgeTypeSet.has(edge.type.toUpperCase()));
262
+ }
263
+ return {
264
+ view: graph.view,
265
+ nodes: filteredNodes,
266
+ edges: [...filteredEdges].sort((left, right) => left.id.localeCompare(right.id)),
267
+ };
268
+ }
269
+ function buildSubgraph(seed, depth, direction) {
270
+ const seedNode = nodes.find((node) => node.id === seed);
271
+ if (!seedNode) {
272
+ return { seed, depth, direction, nodes: [], edges: [] };
273
+ }
274
+ const maxDepth = Math.max(0, Math.floor(depth));
275
+ const visitedNodes = new Set([seed]);
276
+ const visitedEdges = new Map();
277
+ const queue = [{ nodeId: seed, remaining: maxDepth }];
278
+ while (queue.length > 0) {
279
+ const next = queue.shift();
280
+ if (!next || next.remaining < 0) {
281
+ continue;
282
+ }
283
+ const outgoing = direction === "in" ? [] : edges.filter((edge) => edge.from === next.nodeId);
284
+ const incoming = direction === "out" ? [] : edges.filter((edge) => edge.to === next.nodeId);
285
+ const related = [...outgoing, ...incoming];
286
+ for (const edge of related) {
287
+ visitedEdges.set(edge.id, edge);
288
+ const neighborId = edge.from === next.nodeId ? edge.to : edge.from;
289
+ if (!visitedNodes.has(neighborId)) {
290
+ visitedNodes.add(neighborId);
291
+ }
292
+ if (next.remaining > 0) {
293
+ queue.push({ nodeId: neighborId, remaining: next.remaining - 1 });
294
+ }
295
+ }
296
+ }
297
+ const subgraphNodes = nodes
298
+ .filter((node) => visitedNodes.has(node.id))
299
+ .sort((left, right) => left.id.localeCompare(right.id));
300
+ const subgraphNodeIds = new Set(subgraphNodes.map((node) => node.id));
301
+ const subgraphEdges = [...visitedEdges.values()]
302
+ .filter((edge) => subgraphNodeIds.has(edge.from) && subgraphNodeIds.has(edge.to))
303
+ .sort((left, right) => left.id.localeCompare(right.id));
304
+ return {
305
+ seed,
306
+ depth: maxDepth,
307
+ direction,
308
+ nodes: subgraphNodes,
309
+ edges: subgraphEdges,
310
+ };
311
+ }
312
+ function buildPath(from, to, maxDepth, edgeTypes) {
313
+ const fromExists = nodes.some((node) => node.id === from);
314
+ const toExists = nodes.some((node) => node.id === to);
315
+ const boundedDepth = Math.max(1, Math.floor(maxDepth));
316
+ if (!fromExists || !toExists) {
317
+ return {
318
+ from,
319
+ to,
320
+ maxDepth: boundedDepth,
321
+ found: false,
322
+ length: 0,
323
+ nodeIds: [],
324
+ edgeIds: [],
325
+ nodes: [],
326
+ edges: [],
327
+ };
328
+ }
329
+ const edgeTypeSet = edgeTypes?.length
330
+ ? new Set(edgeTypes.map((value) => value.trim().toUpperCase()).filter((value) => value.length > 0))
331
+ : undefined;
332
+ const eligibleEdges = edgeTypeSet
333
+ ? edges.filter((edge) => edgeTypeSet.has(edge.type.toUpperCase()))
334
+ : edges;
335
+ const outgoingByNode = new Map();
336
+ for (const edge of eligibleEdges) {
337
+ const list = outgoingByNode.get(edge.from) ?? [];
338
+ list.push(edge);
339
+ outgoingByNode.set(edge.from, list);
340
+ }
341
+ const queue = [{ nodeId: from, depth: 0 }];
342
+ const visited = new Set([from]);
343
+ const previous = new Map();
344
+ let found = false;
345
+ while (queue.length > 0) {
346
+ const current = queue.shift();
347
+ if (!current) {
348
+ continue;
349
+ }
350
+ if (current.nodeId === to) {
351
+ found = true;
352
+ break;
353
+ }
354
+ if (current.depth >= boundedDepth) {
355
+ continue;
356
+ }
357
+ const outgoing = outgoingByNode.get(current.nodeId) ?? [];
358
+ for (const edge of outgoing) {
359
+ if (visited.has(edge.to)) {
360
+ continue;
361
+ }
362
+ visited.add(edge.to);
363
+ previous.set(edge.to, { nodeId: current.nodeId, edge });
364
+ queue.push({ nodeId: edge.to, depth: current.depth + 1 });
365
+ }
366
+ }
367
+ if (!found) {
368
+ return {
369
+ from,
370
+ to,
371
+ maxDepth: boundedDepth,
372
+ found: false,
373
+ length: 0,
374
+ nodeIds: [],
375
+ edgeIds: [],
376
+ nodes: [],
377
+ edges: [],
378
+ };
379
+ }
380
+ const nodeIds = [to];
381
+ const pathEdges = [];
382
+ let cursor = to;
383
+ while (cursor !== from) {
384
+ const previousHop = previous.get(cursor);
385
+ if (!previousHop) {
386
+ break;
387
+ }
388
+ pathEdges.push(previousHop.edge);
389
+ nodeIds.push(previousHop.nodeId);
390
+ cursor = previousHop.nodeId;
391
+ }
392
+ nodeIds.reverse();
393
+ pathEdges.reverse();
394
+ const pathNodeSet = new Set(nodeIds);
395
+ const pathNodes = nodes
396
+ .filter((node) => pathNodeSet.has(node.id))
397
+ .sort((left, right) => left.id.localeCompare(right.id));
398
+ return {
399
+ from,
400
+ to,
401
+ maxDepth: boundedDepth,
402
+ found: true,
403
+ length: pathEdges.length,
404
+ nodeIds,
405
+ edgeIds: pathEdges.map((edge) => edge.id),
406
+ nodes: pathNodes,
407
+ edges: pathEdges,
408
+ };
409
+ }
410
+ return {
411
+ async getMeta() {
412
+ return {
413
+ project: 'agentic-codegraph',
414
+ version: '0.1.0',
415
+ generatedAt: new Date().toISOString(),
416
+ counts: {
417
+ nodes: nodes.length,
418
+ edges: edges.length,
419
+ files: nodes.filter(isFileNode).length,
420
+ symbols: nodes.filter((node) => ['Function', 'Class', 'Interface'].includes(node.type)).length,
421
+ routes: routeMap.length,
422
+ },
423
+ };
424
+ },
425
+ async search(query) {
426
+ const normalizedQuery = query.toLowerCase();
427
+ const results = nodes
428
+ .map((node) => {
429
+ const haystack = `${node.name} ${node.path ?? ''}`.toLowerCase();
430
+ if (!haystack.includes(normalizedQuery)) {
431
+ return null;
432
+ }
433
+ const score = node.name.toLowerCase().startsWith(normalizedQuery) ? 1 : 0.7;
434
+ return {
435
+ nodeId: node.id,
436
+ type: node.type,
437
+ name: node.name,
438
+ path: node.path,
439
+ score,
440
+ };
441
+ })
442
+ .filter((value) => Boolean(value));
443
+ return { query, results };
444
+ },
445
+ async getNode(id) {
446
+ const node = nodes.find((item) => item.id === id);
447
+ if (!node) {
448
+ return null;
449
+ }
450
+ const inbound = edges.filter((edge) => edge.to === id);
451
+ const outbound = edges.filter((edge) => edge.from === id);
452
+ return { node, inbound, outbound };
453
+ },
454
+ async getGraph(options) {
455
+ const view = options.view || "fileDeps";
456
+ return applyGraphFilters(buildGraphView(view), options);
457
+ },
458
+ async getSubgraph(seed, depth, direction) {
459
+ return buildSubgraph(seed, depth, direction);
460
+ },
461
+ async getPath(from, to, maxDepth, edgeTypes) {
462
+ return buildPath(from, to, maxDepth, edgeTypes);
463
+ },
464
+ async getRoutes() {
465
+ return { routes: routeMap };
466
+ },
467
+ async getCycles() {
468
+ return { cycles };
469
+ },
470
+ async runQuery(query) {
471
+ const type = typeof query.type === 'string' ? query.type : 'generic';
472
+ if (type === 'refactorInsights') {
473
+ const rawLimit = query.limit;
474
+ const limit = typeof rawLimit === 'number' && Number.isFinite(rawLimit)
475
+ ? Math.min(Math.max(Math.floor(rawLimit), 1), 20)
476
+ : 5;
477
+ return {
478
+ query,
479
+ result: buildRefactorInsights(limit),
480
+ };
481
+ }
482
+ return {
483
+ query,
484
+ result: {
485
+ message: 'Query executed',
486
+ availableQueryTypes: ['refactorInsights'],
487
+ },
488
+ };
489
+ },
490
+ };
491
+ }
492
+ function createApp(options = {}) {
493
+ const app = (0, express_1.default)();
494
+ const engine = options.engine ?? createDefaultGraphQueryEngine();
495
+ const controller = new graph_controller_1.GraphController(engine);
496
+ app.disable('x-powered-by');
497
+ app.use(express_1.default.json({ limit: '1mb' }));
498
+ mountLocalVendorAssets(app);
499
+ app.get('/', (_req, res) => {
500
+ res.status(200).type('html').send((0, ui_1.renderUiHtml)());
501
+ });
502
+ app.use('/api', (0, routes_1.createApiRouter)(controller));
503
+ app.use((_req, res) => {
504
+ (0, api_1.sendError)(res, 'NOT_FOUND', 'Route not found.', 404);
505
+ });
506
+ return app;
507
+ }
508
+ exports.default = createApp;
509
+ //# sourceMappingURL=app.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app.js","sourceRoot":"","sources":["../../src/server/app.ts"],"names":[],"mappings":"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"}