@codesherlock/codesherlock-beta-mcp-server 0.0.1

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 (87) hide show
  1. package/.env +9 -0
  2. package/README.md +185 -0
  3. package/build/handlers/analyzeCommitHandler.d.ts +36 -0
  4. package/build/handlers/analyzeCommitHandler.d.ts.map +1 -0
  5. package/build/handlers/analyzeCommitHandler.js +397 -0
  6. package/build/handlers/analyzeCommitHandler.js.map +1 -0
  7. package/build/handlers/events.d.ts +7 -0
  8. package/build/handlers/events.d.ts.map +1 -0
  9. package/build/handlers/events.js +15 -0
  10. package/build/handlers/events.js.map +1 -0
  11. package/build/handlers/resources.d.ts +10 -0
  12. package/build/handlers/resources.d.ts.map +1 -0
  13. package/build/handlers/resources.js +14 -0
  14. package/build/handlers/resources.js.map +1 -0
  15. package/build/handlers/tools.d.ts +6 -0
  16. package/build/handlers/tools.d.ts.map +1 -0
  17. package/build/handlers/tools.js +29 -0
  18. package/build/handlers/tools.js.map +1 -0
  19. package/build/index.d.ts +3 -0
  20. package/build/index.d.ts.map +1 -0
  21. package/build/index.js +82 -0
  22. package/build/index.js.map +1 -0
  23. package/build/schemas/toolSchemas.d.ts +50 -0
  24. package/build/schemas/toolSchemas.d.ts.map +1 -0
  25. package/build/schemas/toolSchemas.js +48 -0
  26. package/build/schemas/toolSchemas.js.map +1 -0
  27. package/build/services/backendApiService.d.ts +81 -0
  28. package/build/services/backendApiService.d.ts.map +1 -0
  29. package/build/services/backendApiService.js +265 -0
  30. package/build/services/backendApiService.js.map +1 -0
  31. package/build/services/commitReviewService.d.ts +71 -0
  32. package/build/services/commitReviewService.d.ts.map +1 -0
  33. package/build/services/commitReviewService.js +506 -0
  34. package/build/services/commitReviewService.js.map +1 -0
  35. package/build/services/gitService.d.ts +159 -0
  36. package/build/services/gitService.d.ts.map +1 -0
  37. package/build/services/gitService.js +778 -0
  38. package/build/services/gitService.js.map +1 -0
  39. package/build/services/loggingService.d.ts +64 -0
  40. package/build/services/loggingService.d.ts.map +1 -0
  41. package/build/services/loggingService.js +185 -0
  42. package/build/services/loggingService.js.map +1 -0
  43. package/build/services/zipService.d.ts +9 -0
  44. package/build/services/zipService.d.ts.map +1 -0
  45. package/build/services/zipService.js +47 -0
  46. package/build/services/zipService.js.map +1 -0
  47. package/build/tests/analysisFormatter.test.d.ts +2 -0
  48. package/build/tests/analysisFormatter.test.d.ts.map +1 -0
  49. package/build/tests/analysisFormatter.test.js +92 -0
  50. package/build/tests/analysisFormatter.test.js.map +1 -0
  51. package/build/tests/analyzeCommitHandler.test.d.ts +2 -0
  52. package/build/tests/analyzeCommitHandler.test.d.ts.map +1 -0
  53. package/build/tests/analyzeCommitHandler.test.js +111 -0
  54. package/build/tests/analyzeCommitHandler.test.js.map +1 -0
  55. package/build/tests/backendApiService.test.d.ts +2 -0
  56. package/build/tests/backendApiService.test.d.ts.map +1 -0
  57. package/build/tests/backendApiService.test.js +109 -0
  58. package/build/tests/backendApiService.test.js.map +1 -0
  59. package/build/tests/commitReviewService.test.d.ts +2 -0
  60. package/build/tests/commitReviewService.test.d.ts.map +1 -0
  61. package/build/tests/commitReviewService.test.js +120 -0
  62. package/build/tests/commitReviewService.test.js.map +1 -0
  63. package/build/tests/errorExtractor.test.d.ts +2 -0
  64. package/build/tests/errorExtractor.test.d.ts.map +1 -0
  65. package/build/tests/errorExtractor.test.js +61 -0
  66. package/build/tests/errorExtractor.test.js.map +1 -0
  67. package/build/tests/loggingService.test.d.ts +2 -0
  68. package/build/tests/loggingService.test.d.ts.map +1 -0
  69. package/build/tests/loggingService.test.js +153 -0
  70. package/build/tests/loggingService.test.js.map +1 -0
  71. package/build/tests/setup.test.d.ts +2 -0
  72. package/build/tests/setup.test.d.ts.map +1 -0
  73. package/build/tests/setup.test.js +7 -0
  74. package/build/tests/setup.test.js.map +1 -0
  75. package/build/tests/tools.test.d.ts +2 -0
  76. package/build/tests/tools.test.d.ts.map +1 -0
  77. package/build/tests/tools.test.js +58 -0
  78. package/build/tests/tools.test.js.map +1 -0
  79. package/build/utils/analysisFormatter.d.ts +40 -0
  80. package/build/utils/analysisFormatter.d.ts.map +1 -0
  81. package/build/utils/analysisFormatter.js +97 -0
  82. package/build/utils/analysisFormatter.js.map +1 -0
  83. package/build/utils/errorExtractor.d.ts +36 -0
  84. package/build/utils/errorExtractor.d.ts.map +1 -0
  85. package/build/utils/errorExtractor.js +178 -0
  86. package/build/utils/errorExtractor.js.map +1 -0
  87. package/package.json +55 -0
@@ -0,0 +1,265 @@
1
+ import WebSocket from "ws";
2
+ import JSZip from "jszip";
3
+ import { File, Blob } from "node:buffer";
4
+ import { logger } from "./loggingService.js";
5
+ /**
6
+ * Backend API Service
7
+ * Handles HTTP API calls and WebSocket connections for commit review
8
+ */
9
+ export class BackendApiService {
10
+ baseUrl;
11
+ wsBaseUrl;
12
+ apiKey;
13
+ constructor(baseUrl, apiKey) {
14
+ if (!baseUrl || baseUrl.trim() === "") {
15
+ throw new Error("BACKEND_API_URL environment variable is required but not set. Please configure it in your .env file or environment variables.");
16
+ }
17
+ this.baseUrl = baseUrl;
18
+ // Convert HTTP/HTTPS URLs to WebSocket URLs (ws/wss)
19
+ // Handle both http:// and https:// protocols correctly
20
+ if (baseUrl.startsWith("https://")) {
21
+ this.wsBaseUrl = baseUrl.replace(/^https/, "wss");
22
+ }
23
+ else if (baseUrl.startsWith("http://")) {
24
+ this.wsBaseUrl = baseUrl.replace(/^http/, "ws");
25
+ }
26
+ else {
27
+ // If URL doesn't start with http/https, assume ws protocol
28
+ logger.logWarning("Backend URL doesn't start with http/https, assuming WebSocket protocol", { baseUrl });
29
+ this.wsBaseUrl = baseUrl;
30
+ }
31
+ this.apiKey = apiKey;
32
+ }
33
+ /**
34
+ * Submit commit review to backend
35
+ */
36
+ async submitCommitReview(params) {
37
+ try {
38
+ const url = `${this.baseUrl}/v2/commit-review/${params.factor}`;
39
+ const formData = new FormData();
40
+ formData.append("user_id", params.user_id);
41
+ formData.append("repo_name", params.repo_name);
42
+ formData.append("commit_id", params.commit_id);
43
+ formData.append("username", params.username);
44
+ formData.append("factor", params.factor);
45
+ // Build ZIP
46
+ const zip = new JSZip();
47
+ zip.file("files.json", params.files_json);
48
+ const filesBuffer = await zip.generateAsync({ type: "nodebuffer" });
49
+ // Convert Buffer → Blob → File
50
+ const blob = new Blob([filesBuffer], { type: "application/zip" });
51
+ formData.append("files_zip", new File([blob], "files.zip", { type: "application/zip" }));
52
+ if (params.organization_name) {
53
+ formData.append("organization_name", params.organization_name);
54
+ }
55
+ const response = await fetch(url, {
56
+ method: "POST",
57
+ headers: {
58
+ ...(this.apiKey ? { "X-CS-MCP-API-Key": this.apiKey } : {})
59
+ },
60
+ body: formData
61
+ });
62
+ if (!response.ok) {
63
+ let errorDetail = "Unknown error";
64
+ let rawBody;
65
+ let parsedBody;
66
+ try {
67
+ // Try to parse JSON error response (FastAPI typically returns {detail: "message"})
68
+ parsedBody = await response.json();
69
+ errorDetail = parsedBody.detail || parsedBody.error || parsedBody.message || JSON.stringify(parsedBody);
70
+ }
71
+ catch {
72
+ // If not JSON, use text response
73
+ const errorText = await response.text();
74
+ rawBody = errorText;
75
+ errorDetail = errorText || `HTTP ${response.status}`;
76
+ }
77
+ // Prepare safe string values for logging (logger expects string properties)
78
+ const parsedBodyString = parsedBody ? JSON.stringify(parsedBody) : "";
79
+ const rawBodyString = rawBody ?? "";
80
+ // Log full backend error response for easier debugging
81
+ logger.logError("Backend commit-review HTTP error response", new Error(errorDetail), {
82
+ url,
83
+ status: String(response.status),
84
+ parsedBody: parsedBodyString,
85
+ rawBody: rawBodyString,
86
+ });
87
+ // Create error with status code in message for extraction
88
+ const error = new Error(`HTTP error! status: ${response.status}, detail: ${errorDetail}`);
89
+ error.statusCode = response.status;
90
+ error.errorDetail = errorDetail;
91
+ throw error;
92
+ }
93
+ // Handle 202 Accepted response (FastAPI returns this for background processing)
94
+ if (response.status === 202) {
95
+ let data = {};
96
+ try {
97
+ // Try to parse JSON response (FastAPI may return JSON with message)
98
+ const contentType = response.headers.get("content-type");
99
+ if (contentType && contentType.includes("application/json")) {
100
+ data = await response.json();
101
+ }
102
+ else {
103
+ // If not JSON, read as text
104
+ const text = await response.text();
105
+ data = { message: text || "Commit review request received. Processing in the background." };
106
+ }
107
+ }
108
+ catch {
109
+ // If parsing fails, use default message
110
+ data = { message: "Commit review request received. Processing in the background." };
111
+ }
112
+ return {
113
+ success: true,
114
+ data,
115
+ analysisId: data.analysis_id ? String(data.analysis_id) : undefined,
116
+ message: data.message || "Commit review submitted successfully"
117
+ };
118
+ }
119
+ // Handle other success responses (200, etc.)
120
+ let data = {};
121
+ try {
122
+ data = await response.json();
123
+ }
124
+ catch {
125
+ // If JSON parsing fails, create a default response
126
+ logger.logWarning("Failed to parse JSON response, using default", { status: String(response.status) });
127
+ data = { message: "Commit review submitted successfully" };
128
+ }
129
+ return {
130
+ success: true,
131
+ data,
132
+ analysisId: data.analysis_id ? String(data.analysis_id) : undefined,
133
+ message: data.message || "Commit review submitted successfully"
134
+ };
135
+ }
136
+ catch (error) {
137
+ logger.logError("Error submitting commit review", error);
138
+ throw error;
139
+ }
140
+ }
141
+ /**
142
+ * WebSocket connection for real-time commit analysis
143
+ */
144
+ connectWebSocket(userId, onMessage, onError, onClose) {
145
+ return new Promise((resolve, reject) => {
146
+ try {
147
+ const wsUrl = `${this.wsBaseUrl}/v2/ws/${userId}`;
148
+ logger.logInfo("Connecting to WebSocket", { wsUrl, userId });
149
+ // Validate WebSocket URL format
150
+ if (!wsUrl.startsWith("ws://") && !wsUrl.startsWith("wss://")) {
151
+ const error = new Error(`Invalid WebSocket URL format: ${wsUrl}. ` +
152
+ `Expected URL to start with ws:// or wss://. ` +
153
+ `Please check your BACKEND_API_URL configuration.`);
154
+ logger.logError("Invalid WebSocket URL format", error, { wsUrl, baseUrl: this.baseUrl, wsBaseUrl: this.wsBaseUrl });
155
+ reject(error);
156
+ return;
157
+ }
158
+ const ws = new WebSocket(wsUrl);
159
+ ws.on("open", () => {
160
+ logger.logInfo("WebSocket connection opened", { userId });
161
+ resolve(ws);
162
+ });
163
+ ws.on("message", (data) => {
164
+ try {
165
+ const message = JSON.parse(data.toString());
166
+ onMessage(message);
167
+ }
168
+ catch (error) {
169
+ logger.logError("Error parsing WebSocket message", error);
170
+ }
171
+ });
172
+ ws.on("error", (error) => {
173
+ const errorMessage = error instanceof Error ? error.message : String(error);
174
+ const enhancedError = new Error(`WebSocket connection failed: ${errorMessage}. ` +
175
+ `URL: ${wsUrl}. ` +
176
+ `Please verify that the backend service is running and accessible.`);
177
+ logger.logError("WebSocket error", enhancedError, { userId, wsUrl });
178
+ onError?.(enhancedError);
179
+ reject(enhancedError);
180
+ });
181
+ ws.on("close", (code, reason) => {
182
+ const reasonStr = reason.toString();
183
+ // Log close events with more detail for debugging
184
+ if (code !== 1000) {
185
+ logger.logWarning("WebSocket closed unexpectedly", {
186
+ userId,
187
+ code: String(code),
188
+ reason: reasonStr,
189
+ wsUrl
190
+ });
191
+ }
192
+ onClose?.(code, reasonStr);
193
+ });
194
+ }
195
+ catch (error) {
196
+ const errorMessage = error instanceof Error ? error.message : String(error);
197
+ const enhancedError = new Error(`Failed to create WebSocket connection: ${errorMessage}. ` +
198
+ `Please check your network connection and backend service availability.`);
199
+ logger.logError("Error creating WebSocket connection", enhancedError, {
200
+ userId,
201
+ wsBaseUrl: this.wsBaseUrl
202
+ });
203
+ reject(enhancedError);
204
+ }
205
+ });
206
+ }
207
+ async sendDiff(diff, metadata) {
208
+ return {
209
+ success: true,
210
+ message: "Diff received (legacy method)"
211
+ };
212
+ }
213
+ async getAnalysisResults(analysisId) {
214
+ throw new Error("Not implemented");
215
+ }
216
+ /**
217
+ * Get user information from secure route
218
+ * Uses API key authentication to fetch authenticated user details
219
+ * @returns User information including user_id and username
220
+ */
221
+ async getUserFromSecureRoute() {
222
+ try {
223
+ const url = `${this.baseUrl}/v2/secure_route`;
224
+ if (!this.apiKey) {
225
+ throw new Error("API key is required for secure route authentication");
226
+ }
227
+ const response = await fetch(url, {
228
+ method: "POST",
229
+ headers: {
230
+ "X-CS-MCP-API-Key": this.apiKey,
231
+ "Content-Type": "application/json"
232
+ }
233
+ });
234
+ if (!response.ok) {
235
+ let errorDetail = "Unknown error";
236
+ try {
237
+ // Try to parse JSON error response (FastAPI typically returns {detail: "message"})
238
+ const errorJson = await response.json();
239
+ errorDetail = errorJson.detail || JSON.stringify(errorJson);
240
+ }
241
+ catch {
242
+ // If not JSON, use text response
243
+ const errorText = await response.text();
244
+ errorDetail = errorText || `HTTP ${response.status}`;
245
+ }
246
+ logger.logError(`HTTP error! status: ${response.status}, detail: ${errorDetail}`);
247
+ if (response.status === 401) {
248
+ throw new Error(errorDetail || "Authentication required. Please provide a valid API key.");
249
+ }
250
+ else if (response.status === 404) {
251
+ throw new Error(errorDetail || "User not found.");
252
+ }
253
+ throw new Error(errorDetail || `HTTP error! status: ${response.status}`);
254
+ }
255
+ const user = await response.json();
256
+ logger.logInfo("User retrieved from secure route", { user_id: user.userid });
257
+ return user;
258
+ }
259
+ catch (error) {
260
+ logger.logError("Error fetching user from secure route", error);
261
+ throw error;
262
+ }
263
+ }
264
+ }
265
+ //# sourceMappingURL=backendApiService.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"backendApiService.js","sourceRoot":"","sources":["../../src/services/backendApiService.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,71 @@
1
+ import { BackendApiService } from "./backendApiService.js";
2
+ import { FileChange } from "./gitService.js";
3
+ /**
4
+ * Commit Review Service
5
+ * Handles the full flow of submitting commit review and receiving results via WebSocket
6
+ */
7
+ export declare class CommitReviewService {
8
+ private backendApiService;
9
+ constructor(backendApiService: BackendApiService);
10
+ /**
11
+ * Submit commit review and wait for analysis results via WebSocket
12
+ * @param params - Commit review parameters
13
+ * @returns Analysis results
14
+ */
15
+ submitAndWaitForResults(params: CommitReviewSubmitParams): Promise<CommitReviewResult>;
16
+ /**
17
+ * Collect analysis results via an already-established WebSocket connection
18
+ * This method reuses an existing WebSocket connection instead of creating a new one
19
+ * @param ws - Already-established WebSocket connection (must be in OPEN state)
20
+ * @param userId - User ID for logging
21
+ * @param timeoutMs - Maximum time to wait for results (default: 10 minutes)
22
+ * @returns Array of analysis results
23
+ */
24
+ private collectResultsViaEstablishedWebSocket;
25
+ /**
26
+ * Connect to WebSocket and collect analysis results
27
+ * Handles edge cases:
28
+ * - Timeout scenarios (backend takes too long)
29
+ * - Empty results (no files to analyze)
30
+ * - Partial results (some files succeed, others fail)
31
+ * - WebSocket completion without explicit completion signal
32
+ * @param userId - User ID for WebSocket connection
33
+ * @param onConnection - Callback when connection is established
34
+ * @param timeoutMs - Maximum time to wait for results (default: 10 minutes)
35
+ * @returns Array of analysis results
36
+ */
37
+ private collectResultsViaWebSocket;
38
+ }
39
+ /**
40
+ * Commit review submit parameters
41
+ */
42
+ export interface CommitReviewSubmitParams {
43
+ factor: "power_analysis" | "owasp" | "cwe";
44
+ user_id: string;
45
+ repo_name: string;
46
+ commit_id: string;
47
+ username: string;
48
+ file_changes: FileChange[];
49
+ organization_name?: string;
50
+ }
51
+ /**
52
+ * Analysis result item
53
+ */
54
+ export interface AnalysisResultItem {
55
+ analysis: any;
56
+ language?: string;
57
+ file_name: string;
58
+ analysisId: number;
59
+ }
60
+ /**
61
+ * Commit review result
62
+ */
63
+ export interface CommitReviewResult {
64
+ [key: string]: unknown;
65
+ success: boolean;
66
+ analysisId?: string;
67
+ message?: string;
68
+ results?: AnalysisResultItem[];
69
+ error?: string;
70
+ }
71
+ //# sourceMappingURL=commitReviewService.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"commitReviewService.d.ts","sourceRoot":"","sources":["../../src/services/commitReviewService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAE3D,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAG7C;;;GAGG;AACH,qBAAa,mBAAmB;IAC5B,OAAO,CAAC,iBAAiB,CAAoB;gBAEjC,iBAAiB,EAAE,iBAAiB;IAIhD;;;;OAIG;IACG,uBAAuB,CAAC,MAAM,EAAE,wBAAwB,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAsJ5F;;;;;;;OAOG;YACW,qCAAqC;IAyKnD;;;;;;;;;;;OAWG;YACW,0BAA0B;CAmM3C;AAED;;GAEG;AACH,MAAM,WAAW,wBAAwB;IACrC,MAAM,EAAE,gBAAgB,GAAG,OAAO,GAAG,KAAK,CAAC;IAC3C,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,UAAU,EAAE,CAAC;IAC3B,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC9B;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IAC/B,QAAQ,EAAE,GAAG,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IAC/B,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;IACvB,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,kBAAkB,EAAE,CAAC;IAC/B,KAAK,CAAC,EAAE,MAAM,CAAC;CAClB"}