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.
- package/LICENSE +21 -0
- package/README.md +100 -0
- package/dist/cli/index.d.ts +14 -0
- package/dist/cli/index.js +68 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/codekg-config.d.ts +14 -0
- package/dist/codekg-config.js +81 -0
- package/dist/codekg-config.js.map +1 -0
- package/dist/commands/graph.d.ts +7 -0
- package/dist/commands/graph.js +49 -0
- package/dist/commands/graph.js.map +1 -0
- package/dist/commands/init.d.ts +6 -0
- package/dist/commands/init.js +13 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/insights.d.ts +7 -0
- package/dist/commands/insights.js +31 -0
- package/dist/commands/insights.js.map +1 -0
- package/dist/commands/path.d.ts +7 -0
- package/dist/commands/path.js +47 -0
- package/dist/commands/path.js.map +1 -0
- package/dist/commands/reindex.d.ts +6 -0
- package/dist/commands/reindex.js +13 -0
- package/dist/commands/reindex.js.map +1 -0
- package/dist/commands/run.d.ts +6 -0
- package/dist/commands/run.js +20 -0
- package/dist/commands/run.js.map +1 -0
- package/dist/commands/serve.d.ts +8 -0
- package/dist/commands/serve.js +25 -0
- package/dist/commands/serve.js.map +1 -0
- package/dist/config/defaults.d.ts +6 -0
- package/dist/config/defaults.js +30 -0
- package/dist/config/defaults.js.map +1 -0
- package/dist/index.d.ts +52 -0
- package/dist/index.js +602 -0
- package/dist/index.js.map +1 -0
- package/dist/indexer/babel-fallback.d.ts +7 -0
- package/dist/indexer/babel-fallback.js +583 -0
- package/dist/indexer/babel-fallback.js.map +1 -0
- package/dist/indexer/file-discovery.d.ts +6 -0
- package/dist/indexer/file-discovery.js +106 -0
- package/dist/indexer/file-discovery.js.map +1 -0
- package/dist/indexer/indexer.d.ts +90 -0
- package/dist/indexer/indexer.js +620 -0
- package/dist/indexer/indexer.js.map +1 -0
- package/dist/indexer/metrics.d.ts +39 -0
- package/dist/indexer/metrics.js +147 -0
- package/dist/indexer/metrics.js.map +1 -0
- package/dist/indexer/structure-detector.d.ts +16 -0
- package/dist/indexer/structure-detector.js +159 -0
- package/dist/indexer/structure-detector.js.map +1 -0
- package/dist/indexer/ts-parser.d.ts +86 -0
- package/dist/indexer/ts-parser.js +437 -0
- package/dist/indexer/ts-parser.js.map +1 -0
- package/dist/model/edge.d.ts +21 -0
- package/dist/model/edge.js +25 -0
- package/dist/model/edge.js.map +1 -0
- package/dist/model/graph.d.ts +10 -0
- package/dist/model/graph.js +20 -0
- package/dist/model/graph.js.map +1 -0
- package/dist/model/node.d.ts +24 -0
- package/dist/model/node.js +22 -0
- package/dist/model/node.js.map +1 -0
- package/dist/query/query-dsl.d.ts +17 -0
- package/dist/query/query-dsl.js +75 -0
- package/dist/query/query-dsl.js.map +1 -0
- package/dist/query/query-engine.d.ts +32 -0
- package/dist/query/query-engine.js +126 -0
- package/dist/query/query-engine.js.map +1 -0
- package/dist/server/api.d.ts +19 -0
- package/dist/server/api.js +29 -0
- package/dist/server/api.js.map +1 -0
- package/dist/server/app.d.ts +7 -0
- package/dist/server/app.js +509 -0
- package/dist/server/app.js.map +1 -0
- package/dist/server/graph-controller.d.ts +147 -0
- package/dist/server/graph-controller.js +186 -0
- package/dist/server/graph-controller.js.map +1 -0
- package/dist/server/routes.d.ts +3 -0
- package/dist/server/routes.js +19 -0
- package/dist/server/routes.js.map +1 -0
- package/dist/server/ui.d.ts +1 -0
- package/dist/server/ui.js +1165 -0
- package/dist/server/ui.js.map +1 -0
- package/dist/store/sqlite-store.d.ts +83 -0
- package/dist/store/sqlite-store.js +647 -0
- package/dist/store/sqlite-store.js.map +1 -0
- package/dist/utils/ids.d.ts +2 -0
- package/dist/utils/ids.js +9 -0
- package/dist/utils/ids.js.map +1 -0
- package/dist/utils/path.d.ts +3 -0
- package/dist/utils/path.js +21 -0
- package/dist/utils/path.js.map +1 -0
- 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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"}
|