kiri-mcp-server 0.9.4 → 0.9.6
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/README.md +4 -2
- package/dist/package.json +1 -1
- package/dist/src/client/proxy.js +0 -0
- package/dist/src/daemon/daemon.js +0 -0
- package/dist/src/server/context.d.ts.map +1 -1
- package/dist/src/server/handlers.d.ts +7 -3
- package/dist/src/server/handlers.d.ts.map +1 -1
- package/dist/src/server/handlers.js +165 -20
- package/dist/src/server/handlers.js.map +1 -1
- package/dist/src/server/main.js +0 -0
- package/dist/src/server/rpc.d.ts +40 -4
- package/dist/src/server/rpc.d.ts.map +1 -1
- package/dist/src/server/rpc.js +132 -42
- package/dist/src/server/rpc.js.map +1 -1
- package/dist/src/server/runtime.d.ts.map +1 -1
- package/dist/src/server/runtime.js +2 -1
- package/dist/src/server/runtime.js.map +1 -1
- package/dist/src/shared/security/masker.d.ts +1 -0
- package/dist/src/shared/security/masker.d.ts.map +1 -1
- package/dist/src/shared/security/masker.js +59 -13
- package/dist/src/shared/security/masker.js.map +1 -1
- package/package.json +1 -1
- package/dist/client/cli.js +0 -68
- package/dist/client/cli.js.map +0 -1
- package/dist/client/index.js +0 -5
- package/dist/client/index.js.map +0 -1
- package/dist/eval/metrics.js +0 -47
- package/dist/eval/metrics.js.map +0 -1
- package/dist/indexer/cli.js +0 -362
- package/dist/indexer/cli.js.map +0 -1
- package/dist/indexer/codeintel.js +0 -182
- package/dist/indexer/codeintel.js.map +0 -1
- package/dist/indexer/git.js +0 -30
- package/dist/indexer/git.js.map +0 -1
- package/dist/indexer/language.js +0 -34
- package/dist/indexer/language.js.map +0 -1
- package/dist/indexer/pipeline/filters/denylist.js +0 -71
- package/dist/indexer/pipeline/filters/denylist.js.map +0 -1
- package/dist/indexer/schema.js +0 -101
- package/dist/indexer/schema.js.map +0 -1
- package/dist/server/bootstrap.js +0 -19
- package/dist/server/bootstrap.js.map +0 -1
- package/dist/server/context.js +0 -1
- package/dist/server/context.js.map +0 -1
- package/dist/server/fallbacks/degradeController.js +0 -69
- package/dist/server/fallbacks/degradeController.js.map +0 -1
- package/dist/server/handlers.js +0 -1268
- package/dist/server/handlers.js.map +0 -1
- package/dist/server/main.js +0 -151
- package/dist/server/main.js.map +0 -1
- package/dist/server/observability/metrics.js +0 -56
- package/dist/server/observability/metrics.js.map +0 -1
- package/dist/server/observability/tracing.js +0 -58
- package/dist/server/observability/tracing.js.map +0 -1
- package/dist/server/rpc.js +0 -477
- package/dist/server/rpc.js.map +0 -1
- package/dist/server/runtime.js +0 -47
- package/dist/server/runtime.js.map +0 -1
- package/dist/server/scoring.js +0 -116
- package/dist/server/scoring.js.map +0 -1
- package/dist/server/stdio.js +0 -76
- package/dist/server/stdio.js.map +0 -1
- package/dist/shared/duckdb.js +0 -119
- package/dist/shared/duckdb.js.map +0 -1
- package/dist/shared/embedding.js +0 -98
- package/dist/shared/embedding.js.map +0 -1
- package/dist/shared/index.js +0 -9
- package/dist/shared/index.js.map +0 -1
- package/dist/shared/security/config.js +0 -64
- package/dist/shared/security/config.js.map +0 -1
- package/dist/shared/security/masker.js +0 -56
- package/dist/shared/security/masker.js.map +0 -1
- package/dist/shared/tokenizer.js +0 -4
- package/dist/shared/tokenizer.js.map +0 -1
- package/dist/shared/utils/simpleYaml.js +0 -89
- package/dist/shared/utils/simpleYaml.js.map +0 -1
- package/dist/src/shared/utils/socket.d.ts +0 -57
- package/dist/src/shared/utils/socket.d.ts.map +0 -1
- package/dist/src/shared/utils/socket.js +0 -104
- package/dist/src/shared/utils/socket.js.map +0 -1
|
@@ -1,3 +1,7 @@
|
|
|
1
|
+
const SECRET_BODY_MIN_LENGTH = 10;
|
|
2
|
+
const SECRET_BODY_CHAR_CLASS = "[A-Za-z0-9_\\-+/=]";
|
|
3
|
+
const SECRET_BODY_PATTERN = `${SECRET_BODY_CHAR_CLASS}{${SECRET_BODY_MIN_LENGTH},}`;
|
|
4
|
+
const WORD_CHAR_CLASS = "[A-Za-z0-9]";
|
|
1
5
|
/**
|
|
2
6
|
* トークンパターンの妥当性を検証してReDoS攻撃を防ぐ
|
|
3
7
|
* @param token 検証対象のトークン文字列
|
|
@@ -12,31 +16,66 @@ function validateTokenPattern(token) {
|
|
|
12
16
|
throw new Error("Invalid pattern contains nested quantifiers. Simplify the pattern.");
|
|
13
17
|
}
|
|
14
18
|
}
|
|
15
|
-
function
|
|
16
|
-
|
|
17
|
-
|
|
19
|
+
function looksLikePrefixToken(token) {
|
|
20
|
+
if (!token) {
|
|
21
|
+
return false;
|
|
22
|
+
}
|
|
23
|
+
const trimmed = token.trim();
|
|
24
|
+
if (trimmed.length === 0) {
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
const lastChar = trimmed.charAt(trimmed.length - 1);
|
|
28
|
+
return /[^A-Za-z0-9]/.test(lastChar);
|
|
29
|
+
}
|
|
30
|
+
function createTokenMatchers(tokens) {
|
|
31
|
+
const matchers = [];
|
|
18
32
|
for (const token of tokens) {
|
|
19
33
|
if (!token)
|
|
20
34
|
continue;
|
|
21
|
-
validateTokenPattern(token);
|
|
35
|
+
validateTokenPattern(token);
|
|
22
36
|
const escaped = token.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
37
|
+
if (looksLikePrefixToken(token)) {
|
|
38
|
+
matchers.push({
|
|
39
|
+
pattern: `(?<!${WORD_CHAR_CLASS})${escaped}${SECRET_BODY_PATTERN}`,
|
|
40
|
+
flags: "g",
|
|
41
|
+
});
|
|
42
|
+
continue;
|
|
28
43
|
}
|
|
44
|
+
matchers.push({ pattern: escaped, flags: "g" });
|
|
45
|
+
}
|
|
46
|
+
return matchers;
|
|
47
|
+
}
|
|
48
|
+
function maskString(input, options) {
|
|
49
|
+
if (options.matchers.length === 0) {
|
|
50
|
+
return { masked: input, applied: 0 };
|
|
51
|
+
}
|
|
52
|
+
let applied = 0;
|
|
53
|
+
let output = input;
|
|
54
|
+
for (const matcher of options.matchers) {
|
|
55
|
+
const regex = new RegExp(matcher.pattern, matcher.flags);
|
|
56
|
+
output = output.replace(regex, () => {
|
|
57
|
+
applied += 1;
|
|
58
|
+
return options.replacement;
|
|
59
|
+
});
|
|
29
60
|
}
|
|
30
61
|
return { masked: output, applied };
|
|
31
62
|
}
|
|
32
|
-
|
|
63
|
+
function normalizeOptions(options) {
|
|
64
|
+
const skipKeySet = options.skipKeys && options.skipKeys.length > 0 ? new Set(options.skipKeys) : undefined;
|
|
65
|
+
return {
|
|
66
|
+
matchers: createTokenMatchers(options.tokens),
|
|
67
|
+
replacement: options.replacement ?? "***",
|
|
68
|
+
...(skipKeySet ? { skipKeySet } : {}),
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
function maskValueRecursive(value, normalized) {
|
|
33
72
|
if (typeof value === "string") {
|
|
34
|
-
return maskString(value,
|
|
73
|
+
return maskString(value, normalized);
|
|
35
74
|
}
|
|
36
75
|
if (Array.isArray(value)) {
|
|
37
76
|
let applied = 0;
|
|
38
77
|
const maskedArray = value.map((item) => {
|
|
39
|
-
const result =
|
|
78
|
+
const result = maskValueRecursive(item, normalized);
|
|
40
79
|
applied += result.applied;
|
|
41
80
|
return result.masked;
|
|
42
81
|
});
|
|
@@ -45,7 +84,10 @@ export function maskValue(value, options) {
|
|
|
45
84
|
if (value && typeof value === "object") {
|
|
46
85
|
let applied = 0;
|
|
47
86
|
const entries = Object.entries(value).map(([key, item]) => {
|
|
48
|
-
|
|
87
|
+
if (normalized.skipKeySet?.has(key)) {
|
|
88
|
+
return [key, item];
|
|
89
|
+
}
|
|
90
|
+
const result = maskValueRecursive(item, normalized);
|
|
49
91
|
applied += result.applied;
|
|
50
92
|
return [key, result.masked];
|
|
51
93
|
});
|
|
@@ -53,4 +95,8 @@ export function maskValue(value, options) {
|
|
|
53
95
|
}
|
|
54
96
|
return { masked: value, applied: 0 };
|
|
55
97
|
}
|
|
98
|
+
export function maskValue(value, options) {
|
|
99
|
+
const normalized = normalizeOptions(options);
|
|
100
|
+
return maskValueRecursive(value, normalized);
|
|
101
|
+
}
|
|
56
102
|
//# sourceMappingURL=masker.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"masker.js","sourceRoot":"","sources":["../../../../src/shared/security/masker.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"masker.js","sourceRoot":"","sources":["../../../../src/shared/security/masker.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
package/dist/client/cli.js
DELETED
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
import process from "node:process";
|
|
3
|
-
import { bootstrapServer } from "../server/bootstrap.js";
|
|
4
|
-
import { evaluateSecurityStatus, updateSecurityLock } from "../shared/security/config.js";
|
|
5
|
-
function printUsage() {
|
|
6
|
-
console.info(`Usage: pnpm exec tsx src/client/cli.ts <command> [options]\n`);
|
|
7
|
-
console.info(`Commands:`);
|
|
8
|
-
console.info(` security verify [--write-lock] Verify security baseline matches lock file`);
|
|
9
|
-
}
|
|
10
|
-
function formatStatus() {
|
|
11
|
-
const status = evaluateSecurityStatus();
|
|
12
|
-
const lockInfo = status.lockHash ? `hash=${status.lockHash}` : "missing";
|
|
13
|
-
const matchState = status.matches ? "MATCH" : "MISMATCH";
|
|
14
|
-
return [
|
|
15
|
-
`config: ${status.configPath}`,
|
|
16
|
-
`lock: ${status.lockPath} (${lockInfo})`,
|
|
17
|
-
`state: ${matchState}`,
|
|
18
|
-
].join("\n");
|
|
19
|
-
}
|
|
20
|
-
function handleSecurityVerify(argv) {
|
|
21
|
-
const writeLock = argv.includes("--write-lock");
|
|
22
|
-
const status = evaluateSecurityStatus();
|
|
23
|
-
if (!status.lockHash && writeLock) {
|
|
24
|
-
updateSecurityLock(status.hash);
|
|
25
|
-
console.info("Security lock created.");
|
|
26
|
-
const refreshed = evaluateSecurityStatus();
|
|
27
|
-
console.info([
|
|
28
|
-
`config: ${refreshed.configPath}`,
|
|
29
|
-
`lock: ${refreshed.lockPath} (hash=${refreshed.lockHash})`,
|
|
30
|
-
"state: MATCH",
|
|
31
|
-
].join("\n"));
|
|
32
|
-
return 0;
|
|
33
|
-
}
|
|
34
|
-
try {
|
|
35
|
-
bootstrapServer({ allowWriteLock: writeLock });
|
|
36
|
-
console.info("Security baseline verified.");
|
|
37
|
-
console.info(formatStatus());
|
|
38
|
-
return 0;
|
|
39
|
-
}
|
|
40
|
-
catch (error) {
|
|
41
|
-
console.error(error instanceof Error ? error.message : String(error));
|
|
42
|
-
console.info(formatStatus());
|
|
43
|
-
return 1;
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
export function main(argv = process.argv.slice(2)) {
|
|
47
|
-
const [command, ...rest] = argv;
|
|
48
|
-
switch (command) {
|
|
49
|
-
case "security": {
|
|
50
|
-
const [subcommand, ...subArgs] = rest;
|
|
51
|
-
if (subcommand === "verify") {
|
|
52
|
-
return handleSecurityVerify(subArgs);
|
|
53
|
-
}
|
|
54
|
-
break;
|
|
55
|
-
}
|
|
56
|
-
case undefined:
|
|
57
|
-
printUsage();
|
|
58
|
-
return 1;
|
|
59
|
-
default:
|
|
60
|
-
break;
|
|
61
|
-
}
|
|
62
|
-
printUsage();
|
|
63
|
-
return 1;
|
|
64
|
-
}
|
|
65
|
-
if (process.argv[1] && new URL(import.meta.url).pathname === process.argv[1]) {
|
|
66
|
-
process.exitCode = main();
|
|
67
|
-
}
|
|
68
|
-
//# sourceMappingURL=cli.js.map
|
package/dist/client/cli.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../src/client/cli.ts"],"names":[],"mappings":"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"}
|
package/dist/client/index.js
DELETED
package/dist/client/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/client/index.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,yBAAyB,CACvC,QAAkD;IAElD,qCAAqC;IACrC,OAAO,IAAI,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;AAC/C,CAAC"}
|
package/dist/eval/metrics.js
DELETED
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
export function precisionAtK(retrievedIds, relevantIds, k) {
|
|
2
|
-
if (k <= 0 || retrievedIds.length === 0) {
|
|
3
|
-
return 0;
|
|
4
|
-
}
|
|
5
|
-
const relevantSet = new Set(relevantIds);
|
|
6
|
-
if (relevantSet.size === 0) {
|
|
7
|
-
return 0;
|
|
8
|
-
}
|
|
9
|
-
const limit = Math.min(k, retrievedIds.length);
|
|
10
|
-
let hits = 0;
|
|
11
|
-
for (let index = 0; index < limit; index += 1) {
|
|
12
|
-
const id = retrievedIds[index];
|
|
13
|
-
if (id !== undefined && relevantSet.has(id)) {
|
|
14
|
-
hits += 1;
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
return hits / limit;
|
|
18
|
-
}
|
|
19
|
-
export function timeToFirstUseful(events, options = {}) {
|
|
20
|
-
if (events.length === 0) {
|
|
21
|
-
return Number.POSITIVE_INFINITY;
|
|
22
|
-
}
|
|
23
|
-
const sorted = [...events].sort((a, b) => a.timestampMs - b.timestampMs);
|
|
24
|
-
const baseline = typeof options.startTimestampMs === "number"
|
|
25
|
-
? options.startTimestampMs
|
|
26
|
-
: (sorted[0]?.timestampMs ?? 0);
|
|
27
|
-
for (const event of sorted) {
|
|
28
|
-
if (event.relevant) {
|
|
29
|
-
const deltaMs = event.timestampMs - baseline;
|
|
30
|
-
return Math.max(0, deltaMs) / 1000;
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
return Number.POSITIVE_INFINITY;
|
|
34
|
-
}
|
|
35
|
-
export function evaluateRetrieval(options) {
|
|
36
|
-
const { items, relevant, k } = options;
|
|
37
|
-
const ids = items.map((item) => item.id);
|
|
38
|
-
const precision = precisionAtK(ids, relevant, k);
|
|
39
|
-
const relevantSet = new Set(relevant);
|
|
40
|
-
const latencyEvents = items.map((item) => ({
|
|
41
|
-
timestampMs: item.timestampMs,
|
|
42
|
-
relevant: relevantSet.has(item.id),
|
|
43
|
-
}));
|
|
44
|
-
const ttff = timeToFirstUseful(latencyEvents);
|
|
45
|
-
return { precisionAtK: precision, timeToFirstUseful: ttff };
|
|
46
|
-
}
|
|
47
|
-
//# sourceMappingURL=metrics.js.map
|
package/dist/eval/metrics.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"metrics.js","sourceRoot":"","sources":["../../src/eval/metrics.ts"],"names":[],"mappings":"AAKA,MAAM,UAAU,YAAY,CAC1B,YAAsB,EACtB,WAA6B,EAC7B,CAAS;IAET,IAAI,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACxC,OAAO,CAAC,CAAC;IACX,CAAC;IACD,MAAM,WAAW,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,CAAC;IACzC,IAAI,WAAW,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;QAC3B,OAAO,CAAC,CAAC;IACX,CAAC;IACD,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,YAAY,CAAC,MAAM,CAAC,CAAC;IAC/C,IAAI,IAAI,GAAG,CAAC,CAAC;IACb,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,KAAK,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC;QAC9C,MAAM,EAAE,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,EAAE,KAAK,SAAS,IAAI,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC;YAC5C,IAAI,IAAI,CAAC,CAAC;QACZ,CAAC;IACH,CAAC;IACD,OAAO,IAAI,GAAG,KAAK,CAAC;AACtB,CAAC;AAOD,MAAM,UAAU,iBAAiB,CAC/B,MAAsB,EACtB,UAAyC,EAAE;IAE3C,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACxB,OAAO,MAAM,CAAC,iBAAiB,CAAC;IAClC,CAAC;IACD,MAAM,MAAM,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,GAAG,CAAC,CAAC,WAAW,CAAC,CAAC;IACzE,MAAM,QAAQ,GACZ,OAAO,OAAO,CAAC,gBAAgB,KAAK,QAAQ;QAC1C,CAAC,CAAC,OAAO,CAAC,gBAAgB;QAC1B,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,WAAW,IAAI,CAAC,CAAC,CAAC;IACpC,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QAC3B,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;YACnB,MAAM,OAAO,GAAG,KAAK,CAAC,WAAW,GAAG,QAAQ,CAAC;YAC7C,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;QACrC,CAAC;IACH,CAAC;IACD,OAAO,MAAM,CAAC,iBAAiB,CAAC;AAClC,CAAC;AAaD,MAAM,UAAU,iBAAiB,CAAC,OAAiC;IACjE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC;IACvC,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACzC,MAAM,SAAS,GAAG,YAAY,CAAC,GAAG,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;IACjD,MAAM,WAAW,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,CAAC;IACtC,MAAM,aAAa,GAAmB,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QACzD,WAAW,EAAE,IAAI,CAAC,WAAW;QAC7B,QAAQ,EAAE,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;KACnC,CAAC,CAAC,CAAC;IACJ,MAAM,IAAI,GAAG,iBAAiB,CAAC,aAAa,CAAC,CAAC;IAC9C,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC;AAC9D,CAAC"}
|
package/dist/indexer/cli.js
DELETED
|
@@ -1,362 +0,0 @@
|
|
|
1
|
-
import { createHash } from "node:crypto";
|
|
2
|
-
import { readFile, stat } from "node:fs/promises";
|
|
3
|
-
import { join, resolve, extname } from "node:path";
|
|
4
|
-
import { pathToFileURL } from "node:url";
|
|
5
|
-
import { DuckDBClient } from "../shared/duckdb.js";
|
|
6
|
-
import { generateEmbedding } from "../shared/embedding.js";
|
|
7
|
-
import { analyzeSource, buildFallbackSnippet } from "./codeintel.js";
|
|
8
|
-
import { getDefaultBranch, getHeadCommit, gitLsFiles } from "./git.js";
|
|
9
|
-
import { detectLanguage } from "./language.js";
|
|
10
|
-
import { ensureBaseSchema } from "./schema.js";
|
|
11
|
-
const MAX_SAMPLE_BYTES = 32_768;
|
|
12
|
-
const MAX_FILE_BYTES = 32 * 1024 * 1024; // 32MB limit to prevent memory exhaustion
|
|
13
|
-
const SCAN_BATCH_SIZE = 100; // Process files in batches to limit memory usage
|
|
14
|
-
function countLines(content) {
|
|
15
|
-
if (content.length === 0) {
|
|
16
|
-
return 0;
|
|
17
|
-
}
|
|
18
|
-
return content.split(/\r?\n/).length;
|
|
19
|
-
}
|
|
20
|
-
function isBinaryBuffer(buffer) {
|
|
21
|
-
const sample = buffer.subarray(0, Math.min(buffer.length, MAX_SAMPLE_BYTES));
|
|
22
|
-
if (sample.includes(0)) {
|
|
23
|
-
return true;
|
|
24
|
-
}
|
|
25
|
-
const decoded = sample.toString("utf8");
|
|
26
|
-
return decoded.includes("\uFFFD");
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* Ensures a repository record exists in the database, creating it if necessary.
|
|
30
|
-
* Uses ON CONFLICT with auto-increment to prevent race conditions in concurrent scenarios.
|
|
31
|
-
*
|
|
32
|
-
* @param db - Database client instance
|
|
33
|
-
* @param repoRoot - Absolute path to the repository root
|
|
34
|
-
* @param defaultBranch - Default branch name (e.g., "main", "master"), or null if unknown
|
|
35
|
-
* @returns The repository ID (auto-generated on first insert, reused thereafter)
|
|
36
|
-
*/
|
|
37
|
-
async function ensureRepo(db, repoRoot, defaultBranch) {
|
|
38
|
-
// Atomically insert or update using ON CONFLICT to leverage auto-increment
|
|
39
|
-
// This eliminates the TOCTOU race condition present in manual ID generation
|
|
40
|
-
await db.run(`INSERT INTO repo (root, default_branch, indexed_at)
|
|
41
|
-
VALUES (?, ?, CURRENT_TIMESTAMP)
|
|
42
|
-
ON CONFLICT(root) DO UPDATE SET
|
|
43
|
-
default_branch = COALESCE(excluded.default_branch, repo.default_branch)`, [repoRoot, defaultBranch]);
|
|
44
|
-
// Fetch the ID of the existing or newly created repo
|
|
45
|
-
const rows = await db.all("SELECT id FROM repo WHERE root = ?", [repoRoot]);
|
|
46
|
-
if (rows.length === 0) {
|
|
47
|
-
throw new Error("Failed to create or find repository record. Check database constraints and schema.");
|
|
48
|
-
}
|
|
49
|
-
const row = rows[0];
|
|
50
|
-
if (!row) {
|
|
51
|
-
throw new Error("Failed to retrieve repository record. Database returned empty result.");
|
|
52
|
-
}
|
|
53
|
-
return row.id;
|
|
54
|
-
}
|
|
55
|
-
async function persistBlobs(db, blobs) {
|
|
56
|
-
if (blobs.size === 0)
|
|
57
|
-
return;
|
|
58
|
-
// Use bulk insert for better performance
|
|
59
|
-
const blobArray = Array.from(blobs.values());
|
|
60
|
-
const placeholders = blobArray.map(() => "(?, ?, ?, ?)").join(", ");
|
|
61
|
-
const sql = `INSERT OR REPLACE INTO blob (hash, size_bytes, line_count, content) VALUES ${placeholders}`;
|
|
62
|
-
const params = [];
|
|
63
|
-
for (const blob of blobArray) {
|
|
64
|
-
params.push(blob.hash, blob.sizeBytes, blob.lineCount, blob.content);
|
|
65
|
-
}
|
|
66
|
-
await db.run(sql, params);
|
|
67
|
-
}
|
|
68
|
-
async function persistTrees(db, repoId, commitHash, records) {
|
|
69
|
-
if (records.length === 0)
|
|
70
|
-
return;
|
|
71
|
-
// Use bulk insert for better performance
|
|
72
|
-
const placeholders = records.map(() => "(?, ?, ?, ?, ?, ?, ?, ?)").join(", ");
|
|
73
|
-
const sql = `INSERT OR REPLACE INTO tree (repo_id, commit_hash, path, blob_hash, ext, lang, is_binary, mtime) VALUES ${placeholders}`;
|
|
74
|
-
const params = [];
|
|
75
|
-
for (const record of records) {
|
|
76
|
-
params.push(repoId, commitHash, record.path, record.blobHash, record.ext, record.lang, record.isBinary, record.mtimeIso);
|
|
77
|
-
}
|
|
78
|
-
await db.run(sql, params);
|
|
79
|
-
}
|
|
80
|
-
async function persistFiles(db, repoId, records) {
|
|
81
|
-
if (records.length === 0)
|
|
82
|
-
return;
|
|
83
|
-
// Use bulk insert for better performance
|
|
84
|
-
const placeholders = records.map(() => "(?, ?, ?, ?, ?, ?, ?)").join(", ");
|
|
85
|
-
const sql = `INSERT OR REPLACE INTO file (repo_id, path, blob_hash, ext, lang, is_binary, mtime) VALUES ${placeholders}`;
|
|
86
|
-
const params = [];
|
|
87
|
-
for (const record of records) {
|
|
88
|
-
params.push(repoId, record.path, record.blobHash, record.ext, record.lang, record.isBinary, record.mtimeIso);
|
|
89
|
-
}
|
|
90
|
-
await db.run(sql, params);
|
|
91
|
-
}
|
|
92
|
-
async function persistSymbols(db, repoId, records) {
|
|
93
|
-
if (records.length === 0)
|
|
94
|
-
return;
|
|
95
|
-
const placeholders = records.map(() => "(?, ?, ?, ?, ?, ?, ?, ?, ?)").join(", ");
|
|
96
|
-
const sql = `
|
|
97
|
-
INSERT OR REPLACE INTO symbol (
|
|
98
|
-
repo_id, path, symbol_id, name, kind, range_start_line, range_end_line, signature, doc
|
|
99
|
-
) VALUES ${placeholders}
|
|
100
|
-
`;
|
|
101
|
-
const params = [];
|
|
102
|
-
for (const record of records) {
|
|
103
|
-
params.push(repoId, record.path, record.symbolId, record.name, record.kind, record.rangeStartLine, record.rangeEndLine, record.signature, record.doc);
|
|
104
|
-
}
|
|
105
|
-
await db.run(sql, params);
|
|
106
|
-
}
|
|
107
|
-
async function persistSnippets(db, repoId, records) {
|
|
108
|
-
if (records.length === 0)
|
|
109
|
-
return;
|
|
110
|
-
const placeholders = records.map(() => "(?, ?, ?, ?, ?, ?)").join(", ");
|
|
111
|
-
const sql = `
|
|
112
|
-
INSERT OR REPLACE INTO snippet (
|
|
113
|
-
repo_id, path, snippet_id, start_line, end_line, symbol_id
|
|
114
|
-
) VALUES ${placeholders}
|
|
115
|
-
`;
|
|
116
|
-
const params = [];
|
|
117
|
-
for (const record of records) {
|
|
118
|
-
params.push(repoId, record.path, record.snippetId, record.startLine, record.endLine, record.symbolId);
|
|
119
|
-
}
|
|
120
|
-
await db.run(sql, params);
|
|
121
|
-
}
|
|
122
|
-
async function persistDependencies(db, repoId, records) {
|
|
123
|
-
if (records.length === 0)
|
|
124
|
-
return;
|
|
125
|
-
const placeholders = records.map(() => "(?, ?, ?, ?, ?)").join(", ");
|
|
126
|
-
const sql = `
|
|
127
|
-
INSERT OR REPLACE INTO dependency (
|
|
128
|
-
repo_id, src_path, dst_kind, dst, rel
|
|
129
|
-
) VALUES ${placeholders}
|
|
130
|
-
`;
|
|
131
|
-
const params = [];
|
|
132
|
-
for (const record of records) {
|
|
133
|
-
params.push(repoId, record.srcPath, record.dstKind, record.dst, record.rel);
|
|
134
|
-
}
|
|
135
|
-
await db.run(sql, params);
|
|
136
|
-
}
|
|
137
|
-
async function persistEmbeddings(db, repoId, records) {
|
|
138
|
-
if (records.length === 0)
|
|
139
|
-
return;
|
|
140
|
-
const placeholders = records.map(() => "(?, ?, ?, ?, CURRENT_TIMESTAMP)").join(", ");
|
|
141
|
-
const sql = `
|
|
142
|
-
INSERT OR REPLACE INTO file_embedding (
|
|
143
|
-
repo_id, path, dims, vector_json, updated_at
|
|
144
|
-
) VALUES ${placeholders}
|
|
145
|
-
`;
|
|
146
|
-
const params = [];
|
|
147
|
-
for (const record of records) {
|
|
148
|
-
params.push(repoId, record.path, record.dims, JSON.stringify(record.vector));
|
|
149
|
-
}
|
|
150
|
-
await db.run(sql, params);
|
|
151
|
-
}
|
|
152
|
-
function buildCodeIntel(files, blobs) {
|
|
153
|
-
const fileSet = new Set(files.map((file) => file.path));
|
|
154
|
-
const symbols = [];
|
|
155
|
-
const snippets = [];
|
|
156
|
-
const dependencies = new Map();
|
|
157
|
-
for (const file of files) {
|
|
158
|
-
if (file.isBinary) {
|
|
159
|
-
continue;
|
|
160
|
-
}
|
|
161
|
-
const blob = blobs.get(file.blobHash);
|
|
162
|
-
if (!blob || blob.content === null) {
|
|
163
|
-
continue;
|
|
164
|
-
}
|
|
165
|
-
const analysis = analyzeSource(file.path, file.lang, blob.content, fileSet);
|
|
166
|
-
for (const symbol of analysis.symbols) {
|
|
167
|
-
symbols.push({
|
|
168
|
-
path: file.path,
|
|
169
|
-
symbolId: symbol.symbolId,
|
|
170
|
-
name: symbol.name,
|
|
171
|
-
kind: symbol.kind,
|
|
172
|
-
rangeStartLine: symbol.rangeStartLine,
|
|
173
|
-
rangeEndLine: symbol.rangeEndLine,
|
|
174
|
-
signature: symbol.signature,
|
|
175
|
-
doc: symbol.doc,
|
|
176
|
-
});
|
|
177
|
-
}
|
|
178
|
-
if (analysis.snippets.length > 0) {
|
|
179
|
-
analysis.snippets.forEach((snippet, index) => {
|
|
180
|
-
snippets.push({
|
|
181
|
-
path: file.path,
|
|
182
|
-
snippetId: index + 1,
|
|
183
|
-
startLine: snippet.startLine,
|
|
184
|
-
endLine: snippet.endLine,
|
|
185
|
-
symbolId: snippet.symbolId,
|
|
186
|
-
});
|
|
187
|
-
});
|
|
188
|
-
}
|
|
189
|
-
else if (blob.lineCount !== null) {
|
|
190
|
-
const fallback = buildFallbackSnippet(blob.lineCount);
|
|
191
|
-
snippets.push({
|
|
192
|
-
path: file.path,
|
|
193
|
-
snippetId: 1,
|
|
194
|
-
startLine: fallback.startLine,
|
|
195
|
-
endLine: fallback.endLine,
|
|
196
|
-
symbolId: fallback.symbolId,
|
|
197
|
-
});
|
|
198
|
-
}
|
|
199
|
-
for (const dependency of analysis.dependencies) {
|
|
200
|
-
const key = `${file.path}::${dependency.dstKind}::${dependency.dst}::${dependency.rel}`;
|
|
201
|
-
if (!dependencies.has(key)) {
|
|
202
|
-
dependencies.set(key, {
|
|
203
|
-
srcPath: file.path,
|
|
204
|
-
dstKind: dependency.dstKind,
|
|
205
|
-
dst: dependency.dst,
|
|
206
|
-
rel: dependency.rel,
|
|
207
|
-
});
|
|
208
|
-
}
|
|
209
|
-
}
|
|
210
|
-
}
|
|
211
|
-
return { symbols, snippets, dependencies: Array.from(dependencies.values()) };
|
|
212
|
-
}
|
|
213
|
-
/**
|
|
214
|
-
* scanFilesのバッチ処理版
|
|
215
|
-
* メモリ枯渇を防ぐため、ファイルをバッチで処理する
|
|
216
|
-
*/
|
|
217
|
-
async function scanFilesInBatches(repoRoot, paths) {
|
|
218
|
-
const allBlobs = new Map();
|
|
219
|
-
const allFiles = [];
|
|
220
|
-
const allEmbeddings = [];
|
|
221
|
-
for (let i = 0; i < paths.length; i += SCAN_BATCH_SIZE) {
|
|
222
|
-
const batch = paths.slice(i, i + SCAN_BATCH_SIZE);
|
|
223
|
-
const { blobs, files, embeddings } = await scanFiles(repoRoot, batch);
|
|
224
|
-
// マージ: blobはhashでユニークなので重複排除
|
|
225
|
-
for (const [hash, blob] of blobs) {
|
|
226
|
-
if (!allBlobs.has(hash)) {
|
|
227
|
-
allBlobs.set(hash, blob);
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
allFiles.push(...files);
|
|
231
|
-
allEmbeddings.push(...embeddings);
|
|
232
|
-
// バッチデータを明示的にクリアしてGCを促す
|
|
233
|
-
blobs.clear();
|
|
234
|
-
}
|
|
235
|
-
return { blobs: allBlobs, files: allFiles, embeddings: allEmbeddings };
|
|
236
|
-
}
|
|
237
|
-
async function scanFiles(repoRoot, paths) {
|
|
238
|
-
const blobs = new Map();
|
|
239
|
-
const files = [];
|
|
240
|
-
const embeddings = [];
|
|
241
|
-
for (const relativePath of paths) {
|
|
242
|
-
const absolutePath = join(repoRoot, relativePath);
|
|
243
|
-
try {
|
|
244
|
-
const fileStat = await stat(absolutePath);
|
|
245
|
-
if (!fileStat.isFile()) {
|
|
246
|
-
continue;
|
|
247
|
-
}
|
|
248
|
-
// Check file size before reading to prevent memory exhaustion
|
|
249
|
-
if (fileStat.size > MAX_FILE_BYTES) {
|
|
250
|
-
console.warn(`File ${relativePath} exceeds size limit (${fileStat.size} bytes). Increase MAX_FILE_BYTES constant to include it.`);
|
|
251
|
-
continue;
|
|
252
|
-
}
|
|
253
|
-
const buffer = await readFile(absolutePath);
|
|
254
|
-
const isBinary = isBinaryBuffer(buffer);
|
|
255
|
-
const hash = createHash("sha1").update(buffer).digest("hex");
|
|
256
|
-
const ext = extname(relativePath) || null;
|
|
257
|
-
const lang = ext ? detectLanguage(ext) : null;
|
|
258
|
-
const mtimeIso = fileStat.mtime.toISOString();
|
|
259
|
-
let content = null;
|
|
260
|
-
let lineCount = null;
|
|
261
|
-
if (!isBinary) {
|
|
262
|
-
content = buffer.toString("utf8");
|
|
263
|
-
lineCount = countLines(content);
|
|
264
|
-
}
|
|
265
|
-
if (!blobs.has(hash)) {
|
|
266
|
-
blobs.set(hash, {
|
|
267
|
-
hash,
|
|
268
|
-
sizeBytes: buffer.length,
|
|
269
|
-
lineCount,
|
|
270
|
-
content,
|
|
271
|
-
});
|
|
272
|
-
}
|
|
273
|
-
files.push({
|
|
274
|
-
path: relativePath,
|
|
275
|
-
blobHash: hash,
|
|
276
|
-
ext,
|
|
277
|
-
lang,
|
|
278
|
-
isBinary,
|
|
279
|
-
mtimeIso,
|
|
280
|
-
});
|
|
281
|
-
if (!isBinary && content) {
|
|
282
|
-
const embedding = generateEmbedding(content);
|
|
283
|
-
if (embedding) {
|
|
284
|
-
embeddings.push({ path: relativePath, dims: embedding.dims, vector: embedding.values });
|
|
285
|
-
}
|
|
286
|
-
}
|
|
287
|
-
}
|
|
288
|
-
catch (error) {
|
|
289
|
-
console.warn(`Cannot read ${relativePath} due to filesystem error. Fix file permissions or remove the file.`);
|
|
290
|
-
console.warn(error);
|
|
291
|
-
}
|
|
292
|
-
}
|
|
293
|
-
return { blobs, files, embeddings };
|
|
294
|
-
}
|
|
295
|
-
export async function runIndexer(options) {
|
|
296
|
-
if (!options.full && options.since) {
|
|
297
|
-
console.warn("Incremental indexing is not yet supported. Falling back to full reindex.");
|
|
298
|
-
}
|
|
299
|
-
const repoRoot = resolve(options.repoRoot);
|
|
300
|
-
const databasePath = resolve(options.databasePath);
|
|
301
|
-
const [paths, headCommit, defaultBranch] = await Promise.all([
|
|
302
|
-
gitLsFiles(repoRoot),
|
|
303
|
-
getHeadCommit(repoRoot),
|
|
304
|
-
getDefaultBranch(repoRoot),
|
|
305
|
-
]);
|
|
306
|
-
const { blobs, files, embeddings } = await scanFilesInBatches(repoRoot, paths);
|
|
307
|
-
const codeIntel = buildCodeIntel(files, blobs);
|
|
308
|
-
const db = await DuckDBClient.connect({ databasePath, ensureDirectory: true });
|
|
309
|
-
try {
|
|
310
|
-
await ensureBaseSchema(db);
|
|
311
|
-
const repoId = await ensureRepo(db, repoRoot, defaultBranch);
|
|
312
|
-
await db.transaction(async () => {
|
|
313
|
-
await db.run("DELETE FROM tree WHERE repo_id = ?", [repoId]);
|
|
314
|
-
await db.run("DELETE FROM file WHERE repo_id = ?", [repoId]);
|
|
315
|
-
await db.run("DELETE FROM symbol WHERE repo_id = ?", [repoId]);
|
|
316
|
-
await db.run("DELETE FROM snippet WHERE repo_id = ?", [repoId]);
|
|
317
|
-
await db.run("DELETE FROM dependency WHERE repo_id = ?", [repoId]);
|
|
318
|
-
await db.run("DELETE FROM file_embedding WHERE repo_id = ?", [repoId]);
|
|
319
|
-
await persistBlobs(db, blobs);
|
|
320
|
-
await persistTrees(db, repoId, headCommit, files);
|
|
321
|
-
await persistFiles(db, repoId, files);
|
|
322
|
-
await persistSymbols(db, repoId, codeIntel.symbols);
|
|
323
|
-
await persistSnippets(db, repoId, codeIntel.snippets);
|
|
324
|
-
await persistDependencies(db, repoId, codeIntel.dependencies);
|
|
325
|
-
await persistEmbeddings(db, repoId, embeddings);
|
|
326
|
-
// Update timestamp inside transaction to ensure atomicity
|
|
327
|
-
if (defaultBranch) {
|
|
328
|
-
await db.run("UPDATE repo SET indexed_at = CURRENT_TIMESTAMP, default_branch = ? WHERE id = ?", [defaultBranch, repoId]);
|
|
329
|
-
}
|
|
330
|
-
else {
|
|
331
|
-
await db.run("UPDATE repo SET indexed_at = CURRENT_TIMESTAMP WHERE id = ?", [repoId]);
|
|
332
|
-
}
|
|
333
|
-
});
|
|
334
|
-
}
|
|
335
|
-
finally {
|
|
336
|
-
await db.close();
|
|
337
|
-
}
|
|
338
|
-
console.info(`Indexed ${files.length} files for repo ${repoRoot} at ${databasePath} (commit ${headCommit.slice(0, 12)})`);
|
|
339
|
-
}
|
|
340
|
-
function parseArg(flag) {
|
|
341
|
-
const index = process.argv.indexOf(flag);
|
|
342
|
-
if (index >= 0) {
|
|
343
|
-
return process.argv[index + 1];
|
|
344
|
-
}
|
|
345
|
-
return undefined;
|
|
346
|
-
}
|
|
347
|
-
if (import.meta.url === pathToFileURL(process.argv[1] ?? "").href) {
|
|
348
|
-
const repoRoot = resolve(parseArg("--repo") ?? ".");
|
|
349
|
-
const databasePath = resolve(parseArg("--db") ?? "var/index.duckdb");
|
|
350
|
-
const full = process.argv.includes("--full");
|
|
351
|
-
const since = parseArg("--since");
|
|
352
|
-
const options = { repoRoot, databasePath, full: full || !since };
|
|
353
|
-
if (since) {
|
|
354
|
-
options.since = since;
|
|
355
|
-
}
|
|
356
|
-
runIndexer(options).catch((error) => {
|
|
357
|
-
console.error("Failed to index repository. Retry after resolving the logged error.");
|
|
358
|
-
console.error(error);
|
|
359
|
-
process.exitCode = 1;
|
|
360
|
-
});
|
|
361
|
-
}
|
|
362
|
-
//# sourceMappingURL=cli.js.map
|
package/dist/indexer/cli.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../src/indexer/cli.ts"],"names":[],"mappings":"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"}
|