@stackguide/mcp-server 3.8.1 → 3.10.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/dist/handlers/prompts.d.ts.map +1 -1
- package/dist/handlers/prompts.js +13 -2
- package/dist/handlers/prompts.js.map +1 -1
- package/dist/handlers/review.d.ts +2 -1
- package/dist/handlers/review.d.ts.map +1 -1
- package/dist/handlers/review.js +106 -17
- package/dist/handlers/review.js.map +1 -1
- package/dist/services/codeAnalyzer.d.ts +24 -1
- package/dist/services/codeAnalyzer.d.ts.map +1 -1
- package/dist/services/codeAnalyzer.js +57 -2
- package/dist/services/codeAnalyzer.js.map +1 -1
- package/dist/services/cursorDirectory.d.ts.map +1 -1
- package/dist/services/cursorDirectory.js +45 -10
- package/dist/services/cursorDirectory.js.map +1 -1
- package/dist/services/httpClient.d.ts +33 -2
- package/dist/services/httpClient.d.ts.map +1 -1
- package/dist/services/httpClient.js +117 -17
- package/dist/services/httpClient.js.map +1 -1
- package/dist/services/projectFs.d.ts.map +1 -1
- package/dist/services/projectFs.js +25 -4
- package/dist/services/projectFs.js.map +1 -1
- package/dist/services/rulesEngine.d.ts +2 -2
- package/dist/services/rulesEngine.d.ts.map +1 -1
- package/dist/services/rulesEngine.js +42 -2
- package/dist/services/rulesEngine.js.map +1 -1
- package/dist/services/webDocumentation.d.ts +2 -0
- package/dist/services/webDocumentation.d.ts.map +1 -1
- package/dist/services/webDocumentation.js +88 -27
- package/dist/services/webDocumentation.js.map +1 -1
- package/dist/storage/sqlite.d.ts +1 -1
- package/dist/storage/sqlite.d.ts.map +1 -1
- package/dist/storage/sqlite.js +200 -24
- package/dist/storage/sqlite.js.map +1 -1
- package/dist/storage/types.d.ts +32 -2
- package/dist/storage/types.d.ts.map +1 -1
- package/dist/storage/types.js +4 -2
- package/dist/storage/types.js.map +1 -1
- package/dist/utils/circuitBreaker.d.ts +144 -0
- package/dist/utils/circuitBreaker.d.ts.map +1 -0
- package/dist/utils/circuitBreaker.js +329 -0
- package/dist/utils/circuitBreaker.js.map +1 -0
- package/dist/utils/resilienceMetrics.d.ts +104 -0
- package/dist/utils/resilienceMetrics.d.ts.map +1 -0
- package/dist/utils/resilienceMetrics.js +260 -0
- package/dist/utils/resilienceMetrics.js.map +1 -0
- package/dist/utils/safeFetch.d.ts +12 -0
- package/dist/utils/safeFetch.d.ts.map +1 -0
- package/dist/utils/safeFetch.js +107 -0
- package/dist/utils/safeFetch.js.map +1 -0
- package/dist/validation/index.d.ts +1 -1
- package/dist/validation/index.d.ts.map +1 -1
- package/dist/validation/index.js +1 -1
- package/dist/validation/index.js.map +1 -1
- package/dist/validation/schemas.d.ts +8 -1
- package/dist/validation/schemas.d.ts.map +1 -1
- package/dist/validation/schemas.js +47 -5
- package/dist/validation/schemas.js.map +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prompts.d.ts","sourceRoot":"","sources":["../../src/handlers/prompts.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"prompts.d.ts","sourceRoot":"","sources":["../../src/handlers/prompts.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAOzC,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,GAAG,WAAW,CAAC;IAC3B,OAAO,EAAE;QACP,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;KACd,CAAC;CACH;AAED,MAAM,WAAW,YAAY;IAC3B,QAAQ,EAAE,aAAa,EAAE,CAAC;CAC3B;AAED,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,KAAK,CAAC;QACf,IAAI,EAAE,MAAM,CAAC;QACb,WAAW,EAAE,MAAM,CAAC;QACpB,QAAQ,EAAE,OAAO,CAAC;KACnB,CAAC,CAAC;CACJ;AAaD,wBAAgB,cAAc,IAAI,UAAU,EAAE,CA+B7C;AAMD,wBAAgB,mBAAmB,IAAI,YAAY,CA8BlD;AAED,wBAAgB,4BAA4B,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,YAAY,CAwCxF;AAED,wBAAsB,sBAAsB,CAC1C,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,KAAK,EAAE,WAAW,GACjB,OAAO,CAAC,YAAY,CAAC,CAiEvB;AAED,wBAAgB,yBAAyB,CACvC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,KAAK,EAAE,WAAW,GACjB,YAAY,CA+Bd;AAMD,wBAAsB,YAAY,CAChC,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,KAAK,EAAE,WAAW,GACjB,OAAO,CAAC,YAAY,CAAC,CAkBvB"}
|
package/dist/handlers/prompts.js
CHANGED
|
@@ -4,6 +4,13 @@
|
|
|
4
4
|
*/
|
|
5
5
|
import { SUPPORTED_PROJECTS } from '../config/types.js';
|
|
6
6
|
import * as autoDetect from '../services/autoDetect.js';
|
|
7
|
+
import { safeFetch } from '../utils/safeFetch.js';
|
|
8
|
+
const ALLOWED_PROMPT_HOSTS = [
|
|
9
|
+
'github.com',
|
|
10
|
+
'raw.githubusercontent.com',
|
|
11
|
+
'gitlab.com',
|
|
12
|
+
'bitbucket.org'
|
|
13
|
+
];
|
|
7
14
|
// ============================================================================
|
|
8
15
|
// Prompt Definitions
|
|
9
16
|
// ============================================================================
|
|
@@ -132,11 +139,15 @@ export async function handleCodeReviewPrompt(args, state) {
|
|
|
132
139
|
}
|
|
133
140
|
if (url && !codeToReview) {
|
|
134
141
|
try {
|
|
135
|
-
const response = await
|
|
142
|
+
const response = await safeFetch(url, {
|
|
143
|
+
allowedHosts: ALLOWED_PROMPT_HOSTS,
|
|
144
|
+
timeoutMs: 8000,
|
|
145
|
+
maxBytes: 1024 * 512, // 512 KB cap from prompts
|
|
146
|
+
});
|
|
136
147
|
codeToReview = await response.text();
|
|
137
148
|
source = url;
|
|
138
149
|
}
|
|
139
|
-
catch { /* ignore */ }
|
|
150
|
+
catch { /* ignore to keep prompt usable */ }
|
|
140
151
|
}
|
|
141
152
|
const rules = state.loadedRules
|
|
142
153
|
.filter(r => !state.activeConfiguration || state.activeConfiguration.selectedRules.includes(r.id))
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prompts.js","sourceRoot":"","sources":["../../src/handlers/prompts.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAe,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACrE,OAAO,KAAK,UAAU,MAAM,2BAA2B,CAAC;
|
|
1
|
+
{"version":3,"file":"prompts.js","sourceRoot":"","sources":["../../src/handlers/prompts.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAe,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACrE,OAAO,KAAK,UAAU,MAAM,2BAA2B,CAAC;AAExD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AA4BlD,MAAM,oBAAoB,GAAG;IAC3B,YAAY;IACZ,2BAA2B;IAC3B,YAAY;IACZ,eAAe;CAChB,CAAC;AAEF,+EAA+E;AAC/E,qBAAqB;AACrB,+EAA+E;AAE/E,MAAM,UAAU,cAAc;IAC5B,OAAO;QACL;YACE,IAAI,EAAE,SAAS;YACf,WAAW,EAAE,wDAAwD;YACrE,SAAS,EAAE,EAAE;SACd;QACD;YACE,IAAI,EAAE,mBAAmB;YACzB,WAAW,EAAE,iEAAiE;YAC9E,SAAS,EAAE;gBACT,EAAE,IAAI,EAAE,aAAa,EAAE,WAAW,EAAE,sDAAsD,EAAE,QAAQ,EAAE,KAAK,EAAE;aAC9G;SACF;QACD;YACE,IAAI,EAAE,aAAa;YACnB,WAAW,EAAE,iEAAiE;YAC9E,SAAS,EAAE;gBACT,EAAE,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,sCAAsC,EAAE,QAAQ,EAAE,KAAK,EAAE;gBAC1F,EAAE,IAAI,EAAE,KAAK,EAAE,WAAW,EAAE,oCAAoC,EAAE,QAAQ,EAAE,KAAK,EAAE;gBACnF,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,mCAAmC,EAAE,QAAQ,EAAE,KAAK,EAAE;aACpF;SACF;QACD;YACE,IAAI,EAAE,gBAAgB;YACtB,WAAW,EAAE,iDAAiD;YAC9D,SAAS,EAAE;gBACT,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,8BAA8B,EAAE,QAAQ,EAAE,IAAI,EAAE;aAC9E;SACF;KACF,CAAC;AACJ,CAAC;AAED,+EAA+E;AAC/E,kBAAkB;AAClB,+EAA+E;AAE/E,MAAM,UAAU,mBAAmB;IACjC,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,kBAAkB,CAAC;SACnD,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,OAAO,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;SAClE,IAAI,CAAC,IAAI,CAAC,CAAC;IAEd,OAAO;QACL,QAAQ,EAAE,CAAC;gBACT,IAAI,EAAE,MAAM;gBACZ,OAAO,EAAE;oBACP,IAAI,EAAE,MAAM;oBACZ,IAAI,EAAE;;;;;;;;EAQZ,YAAY;;;;;;;;kEAQoD;iBAC3D;aACF,CAAC;KACH,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,4BAA4B,CAAC,IAA6B;IACxE,MAAM,WAAW,GAAI,IAAI,CAAC,WAAsB,IAAI,GAAG,CAAC;IACxD,MAAM,YAAY,GAAG,WAAW,KAAK,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC;IAEvE,IAAI,SAAS,GAAsC,IAAI,CAAC;IACxD,IAAI,CAAC;QACH,SAAS,GAAG,UAAU,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC;IACzD,CAAC;IAAC,MAAM,CAAC,CAAC,0BAA0B,CAAC,CAAC;IAEtC,IAAI,SAAS,EAAE,QAAQ,IAAI,SAAS,CAAC,WAAW,EAAE,CAAC;QACjD,OAAO;YACL,QAAQ,EAAE,CAAC;oBACT,IAAI,EAAE,MAAM;oBACZ,OAAO,EAAE;wBACP,IAAI,EAAE,MAAM;wBACZ,IAAI,EAAE;;YAEJ,SAAS,CAAC,WAAW;kBACf,SAAS,CAAC,UAAU;iBACrB,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC;kBAC7B,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC;;0CAEP;qBACjC;iBACF,CAAC;SACH,CAAC;IACJ,CAAC;IAED,OAAO;QACL,QAAQ,EAAE,CAAC;gBACT,IAAI,EAAE,MAAM;gBACZ,OAAO,EAAE;oBACP,IAAI,EAAE,MAAM;oBACZ,IAAI,EAAE;;;EAGZ,MAAM,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;iBAChF;aACF,CAAC;KACH,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAC1C,IAA6B,EAC7B,KAAkB;IAElB,MAAM,EAAE,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,IAA0D,CAAC;IAC3F,MAAM,WAAW,GAAG,KAAK,CAAC,iBAAiB;QACzC,CAAC,CAAC,kBAAkB,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,IAAI;QAClD,CAAC,CAAC,qBAAqB,CAAC;IAE1B,IAAI,YAAY,GAAG,IAAI,IAAI,EAAE,CAAC;IAC9B,IAAI,MAAM,GAAG,eAAe,CAAC;IAE7B,IAAI,QAAQ,IAAI,CAAC,YAAY,EAAE,CAAC;QAC9B,IAAI,CAAC;YACH,MAAM,EAAE,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,CAAC;YAC9B,MAAM,IAAI,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,CAAC;YAClC,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,QAAQ,CAAC,CAAC;YAC3F,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC5B,YAAY,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;gBAClD,MAAM,GAAG,QAAQ,CAAC;YACpB,CAAC;QACH,CAAC;QAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC;IAC1B,CAAC;IAED,IAAI,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QACzB,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,MAAM,SAAS,CAAC,GAAG,EAAE;gBACpC,YAAY,EAAE,oBAAoB;gBAClC,SAAS,EAAE,IAAI;gBACf,QAAQ,EAAE,IAAI,GAAG,GAAG,EAAE,0BAA0B;aACjD,CAAC,CAAC;YACH,YAAY,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YACrC,MAAM,GAAG,GAAG,CAAC;QACf,CAAC;QAAC,MAAM,CAAC,CAAC,kCAAkC,CAAC,CAAC;IAChD,CAAC;IAED,MAAM,KAAK,GAAG,KAAK,CAAC,WAAW;SAC5B,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,mBAAmB,IAAI,KAAK,CAAC,mBAAmB,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;SACjG,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;SACzC,IAAI,CAAC,IAAI,CAAC,CAAC;IAEd,OAAO;QACL,QAAQ,EAAE,CAAC;gBACT,IAAI,EAAE,MAAM;gBACZ,OAAO,EAAE;oBACP,IAAI,EAAE,MAAM;oBACZ,IAAI,EAAE,iCAAiC,WAAW;;UAEhD,MAAM;;;EAGd,KAAK,IAAI,2DAA2D;;;;EAIpE,YAAY,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC;;EAEhC,YAAY,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,+BAA+B,CAAC,CAAC,CAAC,EAAE;;;;;;;0BAO1C;iBACnB;aACF,CAAC;KACH,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,yBAAyB,CACvC,IAA6B,EAC7B,KAAkB;IAElB,MAAM,IAAI,GAAI,IAAI,CAAC,IAAe,IAAI,EAAE,CAAC;IACzC,MAAM,WAAW,GAAG,KAAK,CAAC,iBAAiB;QACzC,CAAC,CAAC,kBAAkB,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,IAAI;QAClD,CAAC,CAAC,qBAAqB,CAAC;IAE1B,MAAM,SAAS,GAAG,KAAK,CAAC,eAAe;SACpC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,mBAAmB,EAAE,iBAAiB,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;SACxE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;SAC3C,IAAI,CAAC,MAAM,CAAC,CAAC;IAEhB,OAAO;QACL,QAAQ,EAAE,CAAC;gBACT,IAAI,EAAE,MAAM;gBACZ,OAAO,EAAE;oBACP,IAAI,EAAE,MAAM;oBACZ,IAAI,EAAE,oCAAoC,WAAW;;QAErD,IAAI;;;EAGV,SAAS,IAAI,yDAAyD;;;;;;uCAMjC;iBAChC;aACF,CAAC;KACH,CAAC;AACJ,CAAC;AAED,+EAA+E;AAC/E,8BAA8B;AAC9B,+EAA+E;AAE/E,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,IAAY,EACZ,IAA6B,EAC7B,KAAkB;IAElB,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,SAAS;YACZ,OAAO,mBAAmB,EAAE,CAAC;QAC/B,KAAK,mBAAmB;YACtB,OAAO,4BAA4B,CAAC,IAAI,CAAC,CAAC;QAC5C,KAAK,aAAa;YAChB,OAAO,MAAM,sBAAsB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACnD,KAAK,gBAAgB;YACnB,OAAO,yBAAyB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAChD;YACE,OAAO;gBACL,QAAQ,EAAE,CAAC;wBACT,IAAI,EAAE,MAAM;wBACZ,OAAO,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,mBAAmB,IAAI,EAAE,EAAE;qBAC3D,CAAC;aACH,CAAC;IACN,CAAC;AACH,CAAC"}
|
|
@@ -3,12 +3,13 @@
|
|
|
3
3
|
* Phase 3: Real code analysis with pattern matching
|
|
4
4
|
*
|
|
5
5
|
* Improvements:
|
|
6
|
-
* -
|
|
6
|
+
* - Security limits to prevent DoS (max files, max size, timeout)
|
|
7
7
|
* - Parallel file analysis with batching
|
|
8
8
|
* - Respects .gitignore patterns
|
|
9
9
|
* - Configurable scan depth (default 10)
|
|
10
10
|
* - Incremental mode using git diff
|
|
11
11
|
* - Analysis caching by file hash
|
|
12
|
+
* - Symlink detection and skipping
|
|
12
13
|
*/
|
|
13
14
|
import { ServerState, ToolResponse } from './types.js';
|
|
14
15
|
interface ReviewArgs {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"review.d.ts","sourceRoot":"","sources":["../../src/handlers/review.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"review.d.ts","sourceRoot":"","sources":["../../src/handlers/review.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAaH,OAAO,EAAE,WAAW,EAAE,YAAY,EAA8B,MAAM,YAAY,CAAC;AAWnF,UAAU,UAAU;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,KAAK,GAAG,UAAU,GAAG,aAAa,GAAG,cAAc,GAAG,kBAAkB,CAAC;IACjF,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AA8JD,wBAAsB,YAAY,CAChC,IAAI,EAAE,UAAU,EAChB,KAAK,EAAE,WAAW,GACjB,OAAO,CAAC,YAAY,CAAC,CAyVvB"}
|
package/dist/handlers/review.js
CHANGED
|
@@ -3,12 +3,13 @@
|
|
|
3
3
|
* Phase 3: Real code analysis with pattern matching
|
|
4
4
|
*
|
|
5
5
|
* Improvements:
|
|
6
|
-
* -
|
|
6
|
+
* - Security limits to prevent DoS (max files, max size, timeout)
|
|
7
7
|
* - Parallel file analysis with batching
|
|
8
8
|
* - Respects .gitignore patterns
|
|
9
9
|
* - Configurable scan depth (default 10)
|
|
10
10
|
* - Incremental mode using git diff
|
|
11
11
|
* - Analysis caching by file hash
|
|
12
|
+
* - Symlink detection and skipping
|
|
12
13
|
*/
|
|
13
14
|
import * as rulesProvider from '../resources/rulesProvider.js';
|
|
14
15
|
import * as knowledgeProvider from '../resources/knowledgeProvider.js';
|
|
@@ -18,6 +19,18 @@ import { AnalysisCacheManager } from '../services/analysisCache.js';
|
|
|
18
19
|
import { jsonResponse, textResponse } from './types.js';
|
|
19
20
|
import { logger } from '../utils/logger.js';
|
|
20
21
|
import { sanitizePath } from '../validation/schemas.js';
|
|
22
|
+
import { safeFetch } from '../utils/safeFetch.js';
|
|
23
|
+
// Security: Default limits to prevent DoS
|
|
24
|
+
const DEFAULT_MAX_FILES = 500;
|
|
25
|
+
const DEFAULT_MAX_TOTAL_SIZE = 20 * 1024 * 1024; // 20 MB
|
|
26
|
+
const DEFAULT_MAX_FILE_SIZE = 100 * 1024; // 100 KB per file
|
|
27
|
+
const SCAN_TIMEOUT_MS = 60000; // 60 seconds max scan time
|
|
28
|
+
const ALLOWED_REVIEW_HOSTS = [
|
|
29
|
+
'github.com',
|
|
30
|
+
'raw.githubusercontent.com',
|
|
31
|
+
'gitlab.com',
|
|
32
|
+
'bitbucket.org'
|
|
33
|
+
];
|
|
21
34
|
// Default ignore patterns (in addition to .gitignore)
|
|
22
35
|
const DEFAULT_IGNORE_PATTERNS = [
|
|
23
36
|
'node_modules',
|
|
@@ -45,10 +58,16 @@ function parseGitignore(projectPath) {
|
|
|
45
58
|
const fs = require('fs');
|
|
46
59
|
const path = require('path');
|
|
47
60
|
const gitignorePath = path.join(projectPath, '.gitignore');
|
|
48
|
-
if (!fs.existsSync(gitignorePath)) {
|
|
49
|
-
return [];
|
|
50
|
-
}
|
|
51
61
|
try {
|
|
62
|
+
if (!fs.existsSync(gitignorePath)) {
|
|
63
|
+
return [];
|
|
64
|
+
}
|
|
65
|
+
const stat = fs.lstatSync(gitignorePath);
|
|
66
|
+
// Security: skip symlinks
|
|
67
|
+
if (stat.isSymbolicLink()) {
|
|
68
|
+
logger.warn('Skipping symlinked .gitignore', { path: gitignorePath });
|
|
69
|
+
return [];
|
|
70
|
+
}
|
|
52
71
|
const content = fs.readFileSync(gitignorePath, 'utf-8');
|
|
53
72
|
return content
|
|
54
73
|
.split('\n')
|
|
@@ -183,15 +202,47 @@ export async function handleReview(args, state) {
|
|
|
183
202
|
const exts = ['.ts', '.tsx', '.js', '.jsx', '.py', '.go', '.rs', '.rb', '.php'];
|
|
184
203
|
let skippedByIgnore = 0;
|
|
185
204
|
let skippedBySize = 0;
|
|
205
|
+
let skippedBySymlink = 0;
|
|
206
|
+
let totalBytesRead = 0;
|
|
207
|
+
let scanAborted = false;
|
|
208
|
+
let abortReason = '';
|
|
209
|
+
// Security: apply default limits
|
|
210
|
+
const effectiveMaxFiles = maxFiles ?? DEFAULT_MAX_FILES;
|
|
211
|
+
const scanStartTime = Date.now();
|
|
186
212
|
function scan(dir, depth = 0) {
|
|
213
|
+
// Security: check timeout
|
|
214
|
+
if (Date.now() - scanStartTime > SCAN_TIMEOUT_MS) {
|
|
215
|
+
if (!scanAborted) {
|
|
216
|
+
scanAborted = true;
|
|
217
|
+
abortReason = `Scan timeout exceeded (${SCAN_TIMEOUT_MS / 1000}s)`;
|
|
218
|
+
logger.warn('Review scan aborted: timeout', { timeout: SCAN_TIMEOUT_MS });
|
|
219
|
+
}
|
|
220
|
+
return;
|
|
221
|
+
}
|
|
187
222
|
if (depth > maxDepth)
|
|
188
223
|
return;
|
|
189
|
-
if (
|
|
224
|
+
if (filesToAnalyze.length >= effectiveMaxFiles) {
|
|
225
|
+
if (!scanAborted) {
|
|
226
|
+
scanAborted = true;
|
|
227
|
+
abortReason = `Max files limit reached (${effectiveMaxFiles})`;
|
|
228
|
+
}
|
|
229
|
+
return;
|
|
230
|
+
}
|
|
231
|
+
// Security: check total size limit
|
|
232
|
+
if (totalBytesRead >= DEFAULT_MAX_TOTAL_SIZE) {
|
|
233
|
+
if (!scanAborted) {
|
|
234
|
+
scanAborted = true;
|
|
235
|
+
abortReason = `Max total size exceeded (${DEFAULT_MAX_TOTAL_SIZE / 1024 / 1024}MB)`;
|
|
236
|
+
logger.warn('Review scan aborted: size limit', { totalBytes: totalBytesRead });
|
|
237
|
+
}
|
|
190
238
|
return;
|
|
239
|
+
}
|
|
191
240
|
try {
|
|
192
241
|
const items = fs.readdirSync(dir);
|
|
193
242
|
for (const item of items) {
|
|
194
|
-
if (
|
|
243
|
+
if (scanAborted)
|
|
244
|
+
return;
|
|
245
|
+
if (filesToAnalyze.length >= effectiveMaxFiles)
|
|
195
246
|
return;
|
|
196
247
|
if (item.startsWith('.'))
|
|
197
248
|
continue;
|
|
@@ -202,13 +253,19 @@ export async function handleReview(args, state) {
|
|
|
202
253
|
skippedByIgnore++;
|
|
203
254
|
continue;
|
|
204
255
|
}
|
|
205
|
-
|
|
256
|
+
// Security: use lstat to detect symlinks
|
|
257
|
+
const stat = fs.lstatSync(full);
|
|
258
|
+
// Security: skip symlinks to prevent loops and escapes
|
|
259
|
+
if (stat.isSymbolicLink()) {
|
|
260
|
+
skippedBySymlink++;
|
|
261
|
+
continue;
|
|
262
|
+
}
|
|
206
263
|
if (stat.isDirectory()) {
|
|
207
264
|
scan(full, depth + 1);
|
|
208
265
|
}
|
|
209
266
|
else if (exts.some(e => item.endsWith(e))) {
|
|
210
267
|
// Check file size (skip files > 100KB)
|
|
211
|
-
if (stat.size >
|
|
268
|
+
if (stat.size > DEFAULT_MAX_FILE_SIZE) {
|
|
212
269
|
skippedBySize++;
|
|
213
270
|
continue;
|
|
214
271
|
}
|
|
@@ -218,6 +275,7 @@ export async function handleReview(args, state) {
|
|
|
218
275
|
}
|
|
219
276
|
try {
|
|
220
277
|
const content = fs.readFileSync(full, 'utf-8');
|
|
278
|
+
totalBytesRead += Buffer.byteLength(content, 'utf-8');
|
|
221
279
|
filesToAnalyze.push({ path: relativePath, content });
|
|
222
280
|
}
|
|
223
281
|
catch { /* ignore unreadable files */ }
|
|
@@ -261,8 +319,11 @@ export async function handleReview(args, state) {
|
|
|
261
319
|
if (useCache) {
|
|
262
320
|
report.push(`**Cache:** ${cacheHits} hits, ${cacheMisses} misses`);
|
|
263
321
|
}
|
|
264
|
-
if (skippedByIgnore > 0 || skippedBySize > 0) {
|
|
265
|
-
report.push(`**Skipped:** ${skippedByIgnore} by ignore patterns, ${skippedBySize} by size limit`);
|
|
322
|
+
if (skippedByIgnore > 0 || skippedBySize > 0 || skippedBySymlink > 0) {
|
|
323
|
+
report.push(`**Skipped:** ${skippedByIgnore} by ignore patterns, ${skippedBySize} by size limit, ${skippedBySymlink} symlinks`);
|
|
324
|
+
}
|
|
325
|
+
if (scanAborted) {
|
|
326
|
+
report.push(`**⚠️ Scan Aborted:** ${abortReason}`);
|
|
266
327
|
}
|
|
267
328
|
report.push('');
|
|
268
329
|
report.push(`## Overall Score: ${overall.averageScore}/100`);
|
|
@@ -308,6 +369,17 @@ export async function handleReview(args, state) {
|
|
|
308
369
|
analysisTime: `${analysisTime}ms`,
|
|
309
370
|
cache: useCache ? { hits: cacheHits, misses: cacheMisses } : undefined,
|
|
310
371
|
incremental,
|
|
372
|
+
scanAborted: scanAborted ? abortReason : undefined,
|
|
373
|
+
skipped: {
|
|
374
|
+
byIgnore: skippedByIgnore,
|
|
375
|
+
bySize: skippedBySize,
|
|
376
|
+
bySymlink: skippedBySymlink
|
|
377
|
+
},
|
|
378
|
+
limits: {
|
|
379
|
+
maxFiles: effectiveMaxFiles,
|
|
380
|
+
maxTotalSize: `${DEFAULT_MAX_TOTAL_SIZE / 1024 / 1024}MB`,
|
|
381
|
+
timeout: `${SCAN_TIMEOUT_MS / 1000}s`
|
|
382
|
+
},
|
|
311
383
|
report: report.join('\n')
|
|
312
384
|
});
|
|
313
385
|
}
|
|
@@ -316,12 +388,16 @@ export async function handleReview(args, state) {
|
|
|
316
388
|
let source = '';
|
|
317
389
|
if (url) {
|
|
318
390
|
try {
|
|
319
|
-
const response = await
|
|
391
|
+
const response = await safeFetch(url, {
|
|
392
|
+
allowedHosts: ALLOWED_REVIEW_HOSTS,
|
|
393
|
+
timeoutMs: 8000,
|
|
394
|
+
maxBytes: 1024 * 1024, // 1 MB cap for reviews
|
|
395
|
+
});
|
|
320
396
|
content = await response.text();
|
|
321
397
|
source = url;
|
|
322
398
|
}
|
|
323
399
|
catch (e) {
|
|
324
|
-
return textResponse(`Error fetching URL: ${e}`);
|
|
400
|
+
return textResponse(`Error fetching URL: ${e instanceof Error ? e.message : String(e)}`);
|
|
325
401
|
}
|
|
326
402
|
}
|
|
327
403
|
else if (file) {
|
|
@@ -333,21 +409,34 @@ export async function handleReview(args, state) {
|
|
|
333
409
|
const resolved = path.isAbsolute(sanitized)
|
|
334
410
|
? path.resolve(sanitized)
|
|
335
411
|
: path.resolve(cwd, sanitized);
|
|
336
|
-
//
|
|
337
|
-
|
|
412
|
+
// Resolve symlinks and enforce real path containment
|
|
413
|
+
const realCwd = fs.realpathSync(cwd);
|
|
414
|
+
// First containment check without resolving symlinks to avoid ENOENT on missing files
|
|
415
|
+
if (!resolved.startsWith(realCwd + path.sep) && resolved !== realCwd) {
|
|
338
416
|
logger.audit('PATH_TRAVERSAL_BLOCK', {
|
|
339
417
|
originalPath: file,
|
|
340
418
|
sanitizedPath: sanitized,
|
|
341
419
|
resolvedPath: resolved,
|
|
342
|
-
cwd,
|
|
343
|
-
action: '
|
|
420
|
+
cwd: realCwd,
|
|
421
|
+
action: 'path_traversal_block_pre_realpath'
|
|
344
422
|
});
|
|
345
423
|
return textResponse(`Error: Path traversal detected. Access denied to: ${file}`);
|
|
346
424
|
}
|
|
347
425
|
if (!fs.existsSync(resolved)) {
|
|
348
426
|
return textResponse(`File not found: ${resolved}`);
|
|
349
427
|
}
|
|
350
|
-
|
|
428
|
+
const realResolved = fs.realpathSync(resolved);
|
|
429
|
+
if (!realResolved.startsWith(realCwd + path.sep) && realResolved !== realCwd) {
|
|
430
|
+
logger.audit('PATH_TRAVERSAL_BLOCK', {
|
|
431
|
+
originalPath: file,
|
|
432
|
+
sanitizedPath: sanitized,
|
|
433
|
+
resolvedPath: realResolved,
|
|
434
|
+
cwd: realCwd,
|
|
435
|
+
action: 'path_traversal_block'
|
|
436
|
+
});
|
|
437
|
+
return textResponse(`Error: Path traversal detected. Access denied to: ${file}`);
|
|
438
|
+
}
|
|
439
|
+
content = fs.readFileSync(realResolved, 'utf-8');
|
|
351
440
|
source = file;
|
|
352
441
|
}
|
|
353
442
|
else {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"review.js","sourceRoot":"","sources":["../../src/handlers/review.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"review.js","sourceRoot":"","sources":["../../src/handlers/review.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Code Analyzer Service - v3.
|
|
2
|
+
* Code Analyzer Service - v3.3.0
|
|
3
3
|
* Unified rule pipeline that supports builtin, user, and project rules
|
|
4
4
|
* Now with AST-based analysis using ts-morph
|
|
5
5
|
* Added multi-language parser support (Python, Go, Rust)
|
|
@@ -10,6 +10,29 @@ import { parserRegistry } from './parsers/index.js';
|
|
|
10
10
|
export type { QuickFix, CodeIssue, AnalysisResult };
|
|
11
11
|
export { clearASTCache };
|
|
12
12
|
export { parserRegistry };
|
|
13
|
+
/**
|
|
14
|
+
* Maximum file size for analysis (1MB)
|
|
15
|
+
* Files larger than this will be rejected to prevent memory exhaustion
|
|
16
|
+
*/
|
|
17
|
+
export declare const MAX_FILE_SIZE_BYTES: number;
|
|
18
|
+
/**
|
|
19
|
+
* Maximum number of lines for analysis (50,000)
|
|
20
|
+
* Prevents hanging on extremely long files
|
|
21
|
+
*/
|
|
22
|
+
export declare const MAX_LINE_COUNT = 50000;
|
|
23
|
+
/**
|
|
24
|
+
* Maximum number of files in a batch analysis
|
|
25
|
+
*/
|
|
26
|
+
export declare const MAX_BATCH_FILES = 100;
|
|
27
|
+
/**
|
|
28
|
+
* Timeout for AST analysis (30 seconds)
|
|
29
|
+
*/
|
|
30
|
+
export declare const AST_ANALYSIS_TIMEOUT_MS = 30000;
|
|
31
|
+
/**
|
|
32
|
+
* Validate file content before analysis
|
|
33
|
+
* Throws if content exceeds safe limits
|
|
34
|
+
*/
|
|
35
|
+
export declare function validateFileForAnalysis(filepath: string, content: string): void;
|
|
13
36
|
/**
|
|
14
37
|
* In-memory registry of all active rules (Pattern + AST)
|
|
15
38
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"codeAnalyzer.d.ts","sourceRoot":"","sources":["../../src/services/codeAnalyzer.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,EACL,WAAW,EACX,OAAO,EACP,SAAS,EACT,cAAc,EACd,QAAQ,EAGT,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAqC,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAGpD,YAAY,EAAE,QAAQ,EAAE,SAAS,EAAE,cAAc,EAAE,CAAC;AAGpD,OAAO,EAAE,aAAa,EAAE,CAAC;AAGzB,OAAO,EAAE,cAAc,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"codeAnalyzer.d.ts","sourceRoot":"","sources":["../../src/services/codeAnalyzer.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Code Analyzer Service - v3.
|
|
2
|
+
* Code Analyzer Service - v3.3.0
|
|
3
3
|
* Unified rule pipeline that supports builtin, user, and project rules
|
|
4
4
|
* Now with AST-based analysis using ts-morph
|
|
5
5
|
* Added multi-language parser support (Python, Go, Rust)
|
|
@@ -12,10 +12,63 @@ export { clearASTCache };
|
|
|
12
12
|
// Re-export parser registry
|
|
13
13
|
export { parserRegistry };
|
|
14
14
|
// =============================================================================
|
|
15
|
+
// RESOURCE LIMITS (DoS Protection)
|
|
16
|
+
// =============================================================================
|
|
17
|
+
/**
|
|
18
|
+
* Maximum file size for analysis (1MB)
|
|
19
|
+
* Files larger than this will be rejected to prevent memory exhaustion
|
|
20
|
+
*/
|
|
21
|
+
export const MAX_FILE_SIZE_BYTES = 1 * 1024 * 1024;
|
|
22
|
+
/**
|
|
23
|
+
* Maximum number of lines for analysis (50,000)
|
|
24
|
+
* Prevents hanging on extremely long files
|
|
25
|
+
*/
|
|
26
|
+
export const MAX_LINE_COUNT = 50_000;
|
|
27
|
+
/**
|
|
28
|
+
* Maximum number of files in a batch analysis
|
|
29
|
+
*/
|
|
30
|
+
export const MAX_BATCH_FILES = 100;
|
|
31
|
+
/**
|
|
32
|
+
* Timeout for AST analysis (30 seconds)
|
|
33
|
+
*/
|
|
34
|
+
export const AST_ANALYSIS_TIMEOUT_MS = 30_000;
|
|
35
|
+
/**
|
|
36
|
+
* Validate file content before analysis
|
|
37
|
+
* Throws if content exceeds safe limits
|
|
38
|
+
*/
|
|
39
|
+
export function validateFileForAnalysis(filepath, content) {
|
|
40
|
+
const byteSize = Buffer.byteLength(content, 'utf-8');
|
|
41
|
+
if (byteSize > MAX_FILE_SIZE_BYTES) {
|
|
42
|
+
throw new Error(`File too large for analysis: ${filepath} (${(byteSize / 1024 / 1024).toFixed(2)}MB). ` +
|
|
43
|
+
`Maximum allowed: ${MAX_FILE_SIZE_BYTES / 1024 / 1024}MB`);
|
|
44
|
+
}
|
|
45
|
+
const lineCount = content.split('\n').length;
|
|
46
|
+
if (lineCount > MAX_LINE_COUNT) {
|
|
47
|
+
throw new Error(`File has too many lines for analysis: ${filepath} (${lineCount} lines). ` +
|
|
48
|
+
`Maximum allowed: ${MAX_LINE_COUNT} lines`);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
// =============================================================================
|
|
15
52
|
// BUILTIN PATTERN RULES
|
|
16
53
|
// =============================================================================
|
|
54
|
+
/**
|
|
55
|
+
* IMPORTANT: Pattern-based security rules are supplementary and can be evaded.
|
|
56
|
+
* For production-critical security scanning, prefer AST-based rules (see astAnalyzer.ts).
|
|
57
|
+
*
|
|
58
|
+
* Pattern rules are useful for:
|
|
59
|
+
* - Quick initial scans
|
|
60
|
+
* - Non-TS/JS languages where AST analysis isn't available
|
|
61
|
+
* - Catching obvious issues during development
|
|
62
|
+
*
|
|
63
|
+
* Pattern rules are NOT reliable for:
|
|
64
|
+
* - Detecting obfuscated vulnerabilities
|
|
65
|
+
* - Comprehensive security audits
|
|
66
|
+
* - Code with complex control flow
|
|
67
|
+
*
|
|
68
|
+
* @deprecated for security-critical use cases. Prefer AST rules.
|
|
69
|
+
*/
|
|
17
70
|
const BUILTIN_PATTERN_RULES = [
|
|
18
|
-
// Security
|
|
71
|
+
// Security (Pattern-based - supplementary, not authoritative)
|
|
19
72
|
{
|
|
20
73
|
id: 'SEC001',
|
|
21
74
|
type: 'pattern',
|
|
@@ -757,6 +810,8 @@ function getLineNumber(content, index) {
|
|
|
757
810
|
* Analyze code using the unified rule pipeline
|
|
758
811
|
*/
|
|
759
812
|
export function analyzeCode(file, content, focus = 'all') {
|
|
813
|
+
// SECURITY: Validate file size/line count before processing
|
|
814
|
+
validateFileForAnalysis(file, content);
|
|
760
815
|
const language = detectLanguage(file, content);
|
|
761
816
|
const issues = [];
|
|
762
817
|
logger.debug('Analyzing code', { file, language, focus, contentLength: content.length });
|