driftdetect-mcp 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/LICENSE ADDED
@@ -0,0 +1,121 @@
1
+ Apache License
2
+ Version 2.0, January 2004
3
+ http://www.apache.org/licenses/
4
+
5
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
6
+
7
+ 1. Definitions.
8
+
9
+ "License" shall mean the terms and conditions for use, reproduction,
10
+ and distribution as defined by Sections 1 through 9 of this document.
11
+
12
+ "Licensor" shall mean the copyright owner or entity authorized by
13
+ the copyright owner that is granting the License.
14
+
15
+ "Legal Entity" shall mean the union of the acting entity and all
16
+ other entities that control, are controlled by, or are under common
17
+ control with that entity. For the purposes of this definition,
18
+ "control" means (i) the power, direct or indirect, to cause the
19
+ direction or management of such entity, whether by contract or
20
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
21
+ outstanding shares, or (iii) beneficial ownership of such entity.
22
+
23
+ "You" (or "Your") shall mean an individual or Legal Entity
24
+ exercising permissions granted by this License.
25
+
26
+ "Source" form shall mean the preferred form for making modifications,
27
+ including but not limited to software source code, documentation
28
+ source, and configuration files.
29
+
30
+ "Object" form shall mean any form resulting from mechanical
31
+ transformation or translation of a Source form, including but
32
+ not limited to compiled object code, generated documentation,
33
+ and conversions to other media types.
34
+
35
+ "Work" shall mean the work of authorship, whether in Source or
36
+ Object form, made available under the License, as indicated by a
37
+ copyright notice that is included in or attached to the work.
38
+
39
+ "Derivative Works" shall mean any work, whether in Source or Object
40
+ form, that is based on (or derived from) the Work and for which the
41
+ editorial revisions, annotations, elaborations, or other modifications
42
+ represent, as a whole, an original work of authorship.
43
+
44
+ "Contribution" shall mean any work of authorship, including
45
+ the original version of the Work and any modifications or additions
46
+ to that Work or Derivative Works thereof, that is intentionally
47
+ submitted to the Licensor for inclusion in the Work by the copyright owner.
48
+
49
+ "Contributor" shall mean Licensor and any individual or Legal Entity
50
+ on behalf of whom a Contribution has been received by Licensor and
51
+ subsequently incorporated within the Work.
52
+
53
+ 2. Grant of Copyright License. Subject to the terms and conditions of
54
+ this License, each Contributor hereby grants to You a perpetual,
55
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
56
+ copyright license to reproduce, prepare Derivative Works of,
57
+ publicly display, publicly perform, sublicense, and distribute the
58
+ Work and such Derivative Works in Source or Object form.
59
+
60
+ 3. Grant of Patent License. Subject to the terms and conditions of
61
+ this License, each Contributor hereby grants to You a perpetual,
62
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
63
+ patent license to make, have made, use, offer to sell, sell, import,
64
+ and otherwise transfer the Work.
65
+
66
+ 4. Redistribution. You may reproduce and distribute copies of the
67
+ Work or Derivative Works thereof in any medium, with or without
68
+ modifications, and in Source or Object form, provided that You
69
+ meet the following conditions:
70
+
71
+ (a) You must give any other recipients of the Work or
72
+ Derivative Works a copy of this License; and
73
+
74
+ (b) You must cause any modified files to carry prominent notices
75
+ stating that You changed the files; and
76
+
77
+ (c) You must retain, in the Source form of any Derivative Works
78
+ that You distribute, all copyright, patent, trademark, and
79
+ attribution notices from the Source form of the Work; and
80
+
81
+ (d) If the Work includes a "NOTICE" text file as part of its
82
+ distribution, then any Derivative Works that You distribute must
83
+ include a readable copy of the attribution notices contained
84
+ within such NOTICE file.
85
+
86
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
87
+ any Contribution intentionally submitted for inclusion in the Work
88
+ by You to the Licensor shall be under the terms and conditions of
89
+ this License, without any additional terms or conditions.
90
+
91
+ 6. Trademarks. This License does not grant permission to use the trade
92
+ names, trademarks, service marks, or product names of the Licensor.
93
+
94
+ 7. Disclaimer of Warranty. Unless required by applicable law or
95
+ agreed to in writing, Licensor provides the Work on an "AS IS" BASIS,
96
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND.
97
+
98
+ 8. Limitation of Liability. In no event and under no legal theory,
99
+ shall any Contributor be liable to You for damages, including any
100
+ direct, indirect, special, incidental, or consequential damages.
101
+
102
+ 9. Accepting Warranty or Additional Liability. While redistributing
103
+ the Work or Derivative Works thereof, You may choose to offer,
104
+ and charge a fee for, acceptance of support, warranty, indemnity,
105
+ or other liability obligations.
106
+
107
+ END OF TERMS AND CONDITIONS
108
+
109
+ Copyright 2025 Geoffrey Fernald
110
+
111
+ Licensed under the Apache License, Version 2.0 (the "License");
112
+ you may not use this file except in compliance with the License.
113
+ You may obtain a copy of the License at
114
+
115
+ http://www.apache.org/licenses/LICENSE-2.0
116
+
117
+ Unless required by applicable law or agreed to in writing, software
118
+ distributed under the License is distributed on an "AS IS" BASIS,
119
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
120
+ See the License for the specific language governing permissions and
121
+ limitations under the License.
@@ -0,0 +1,30 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Drift MCP HTTP Server Entry Point
4
+ *
5
+ * Exposes the MCP server over HTTP using SSE (Server-Sent Events) transport.
6
+ * This enables running Drift MCP as a containerized service accessible via HTTP.
7
+ *
8
+ * Usage:
9
+ * drift-mcp-http # Run server on default port 3000
10
+ * drift-mcp-http --port 8080 # Run on custom port
11
+ * drift-mcp-http --project /path/to/proj # Analyze specific project
12
+ *
13
+ * Environment Variables:
14
+ * PORT - HTTP server port (default: 3000)
15
+ * PROJECT_ROOT - Path to project to analyze (default: /project)
16
+ * ENABLE_CACHE - Enable response caching (default: true)
17
+ * ENABLE_RATE_LIMIT - Enable rate limiting (default: true)
18
+ * VERBOSE - Enable verbose logging (default: false)
19
+ *
20
+ * Endpoints:
21
+ * GET /health - Health check endpoint
22
+ * GET /sse - SSE endpoint for MCP communication
23
+ * POST /message - Send messages to MCP server
24
+ *
25
+ * Docker:
26
+ * docker compose up -d
27
+ * # Then configure your MCP client to connect to http://localhost:3000
28
+ */
29
+ export {};
30
+ //# sourceMappingURL=http-server.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"http-server.d.ts","sourceRoot":"","sources":["../../src/bin/http-server.ts"],"names":[],"mappings":";AACA;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG"}
@@ -0,0 +1,299 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Drift MCP HTTP Server Entry Point
4
+ *
5
+ * Exposes the MCP server over HTTP using SSE (Server-Sent Events) transport.
6
+ * This enables running Drift MCP as a containerized service accessible via HTTP.
7
+ *
8
+ * Usage:
9
+ * drift-mcp-http # Run server on default port 3000
10
+ * drift-mcp-http --port 8080 # Run on custom port
11
+ * drift-mcp-http --project /path/to/proj # Analyze specific project
12
+ *
13
+ * Environment Variables:
14
+ * PORT - HTTP server port (default: 3000)
15
+ * PROJECT_ROOT - Path to project to analyze (default: /project)
16
+ * ENABLE_CACHE - Enable response caching (default: true)
17
+ * ENABLE_RATE_LIMIT - Enable rate limiting (default: true)
18
+ * VERBOSE - Enable verbose logging (default: false)
19
+ *
20
+ * Endpoints:
21
+ * GET /health - Health check endpoint
22
+ * GET /sse - SSE endpoint for MCP communication
23
+ * POST /message - Send messages to MCP server
24
+ *
25
+ * Docker:
26
+ * docker compose up -d
27
+ * # Then configure your MCP client to connect to http://localhost:3000
28
+ */
29
+ import { createServer } from 'http';
30
+ import { SSEServerTransport } from '@modelcontextprotocol/sdk/server/sse.js';
31
+ import {} from '@modelcontextprotocol/sdk/server/index.js';
32
+ import { createEnterpriseMCPServer } from '../enterprise-server.js';
33
+ // Server version (matches enterprise-server)
34
+ const SERVER_VERSION = '2.0.0';
35
+ // Track active transports for cleanup
36
+ const activeTransports = new Map();
37
+ let transportIdCounter = 0;
38
+ /**
39
+ * Set CORS headers for cross-origin requests
40
+ */
41
+ function setCorsHeaders(res) {
42
+ res.setHeader('Access-Control-Allow-Origin', '*');
43
+ res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS');
44
+ res.setHeader('Access-Control-Allow-Headers', 'Content-Type, Accept');
45
+ res.setHeader('Access-Control-Expose-Headers', 'X-Transport-Id');
46
+ }
47
+ /**
48
+ * Create health check handler
49
+ */
50
+ function createHealthHandler(projectRoot) {
51
+ return function handleHealthCheck(res) {
52
+ setCorsHeaders(res);
53
+ res.writeHead(200, { 'Content-Type': 'application/json' });
54
+ res.end(JSON.stringify({
55
+ status: 'healthy',
56
+ service: 'drift-mcp',
57
+ version: SERVER_VERSION,
58
+ projectRoot,
59
+ activeConnections: activeTransports.size,
60
+ timestamp: new Date().toISOString(),
61
+ }));
62
+ };
63
+ }
64
+ /**
65
+ * Create SSE connection handler
66
+ */
67
+ function createSSEHandler(mcpServer, verbose) {
68
+ return async function handleSSE(req, res) {
69
+ const transportId = `transport-${++transportIdCounter}`;
70
+ if (verbose) {
71
+ console.error(`[drift-mcp-http] New SSE connection: ${transportId}`);
72
+ }
73
+ setCorsHeaders(res);
74
+ // Create SSE transport
75
+ const transport = new SSEServerTransport('/message', res);
76
+ activeTransports.set(transportId, transport);
77
+ // Add transport ID header so client knows which ID to use for messages
78
+ res.setHeader('X-Transport-Id', transportId);
79
+ // Clean up on disconnect
80
+ req.on('close', () => {
81
+ if (verbose) {
82
+ console.error(`[drift-mcp-http] SSE connection closed: ${transportId}`);
83
+ }
84
+ activeTransports.delete(transportId);
85
+ });
86
+ // Connect to MCP server
87
+ try {
88
+ await mcpServer.connect(transport);
89
+ }
90
+ catch (error) {
91
+ console.error(`[drift-mcp-http] Failed to connect transport ${transportId}:`, error);
92
+ activeTransports.delete(transportId);
93
+ }
94
+ };
95
+ }
96
+ /**
97
+ * Handle message POST requests
98
+ */
99
+ async function handleMessage(req, res) {
100
+ setCorsHeaders(res);
101
+ // Read body
102
+ let body = '';
103
+ for await (const chunk of req) {
104
+ body += chunk;
105
+ }
106
+ try {
107
+ // Find the transport to use
108
+ // The transport ID can be passed in the URL or we use the most recent one
109
+ const url = new URL(req.url ?? '/', `http://${req.headers.host}`);
110
+ const transportId = url.searchParams.get('transportId');
111
+ let transport;
112
+ if (transportId) {
113
+ transport = activeTransports.get(transportId);
114
+ }
115
+ else {
116
+ // Use the most recent transport
117
+ const entries = Array.from(activeTransports.entries());
118
+ const lastEntry = entries[entries.length - 1];
119
+ if (lastEntry) {
120
+ transport = lastEntry[1];
121
+ }
122
+ }
123
+ if (!transport) {
124
+ res.writeHead(400, { 'Content-Type': 'application/json' });
125
+ res.end(JSON.stringify({
126
+ error: 'No active SSE connection',
127
+ hint: 'Connect to /sse first before sending messages',
128
+ }));
129
+ return;
130
+ }
131
+ // Parse and forward the message
132
+ const message = JSON.parse(body);
133
+ await transport.handlePostMessage(req, res, message);
134
+ }
135
+ catch (error) {
136
+ console.error('[drift-mcp-http] Message handling error:', error);
137
+ res.writeHead(500, { 'Content-Type': 'application/json' });
138
+ res.end(JSON.stringify({
139
+ error: 'Internal server error',
140
+ message: error instanceof Error ? error.message : 'Unknown error',
141
+ }));
142
+ }
143
+ }
144
+ /**
145
+ * Create request router
146
+ */
147
+ function createRequestHandler(handleHealthCheck, handleSSE, projectRoot) {
148
+ return async function handleRequest(req, res) {
149
+ const url = new URL(req.url ?? '/', `http://${req.headers.host}`);
150
+ const pathname = url.pathname;
151
+ const method = req.method?.toUpperCase();
152
+ // Handle CORS preflight
153
+ if (method === 'OPTIONS') {
154
+ setCorsHeaders(res);
155
+ res.writeHead(204);
156
+ res.end();
157
+ return;
158
+ }
159
+ // Route requests
160
+ switch (pathname) {
161
+ case '/health':
162
+ handleHealthCheck(res);
163
+ break;
164
+ case '/sse':
165
+ if (method === 'GET') {
166
+ await handleSSE(req, res);
167
+ }
168
+ else {
169
+ res.writeHead(405, { 'Content-Type': 'application/json' });
170
+ res.end(JSON.stringify({ error: 'Method not allowed' }));
171
+ }
172
+ break;
173
+ case '/message':
174
+ if (method === 'POST') {
175
+ await handleMessage(req, res);
176
+ }
177
+ else {
178
+ res.writeHead(405, { 'Content-Type': 'application/json' });
179
+ res.end(JSON.stringify({ error: 'Method not allowed' }));
180
+ }
181
+ break;
182
+ default:
183
+ // Root endpoint - provide API info
184
+ if (pathname === '/' && method === 'GET') {
185
+ setCorsHeaders(res);
186
+ res.writeHead(200, { 'Content-Type': 'application/json' });
187
+ res.end(JSON.stringify({
188
+ name: 'Drift MCP Server',
189
+ version: SERVER_VERSION,
190
+ description: 'MCP server for codebase intelligence',
191
+ endpoints: {
192
+ '/health': 'Health check endpoint (GET)',
193
+ '/sse': 'SSE endpoint for MCP communication (GET)',
194
+ '/message': 'Send messages to MCP server (POST)',
195
+ },
196
+ projectRoot,
197
+ documentation: 'https://github.com/dadbodgeoff/drift',
198
+ }));
199
+ }
200
+ else {
201
+ res.writeHead(404, { 'Content-Type': 'application/json' });
202
+ res.end(JSON.stringify({ error: 'Not found' }));
203
+ }
204
+ }
205
+ };
206
+ }
207
+ /**
208
+ * Create graceful shutdown handler
209
+ */
210
+ function createShutdownHandler(mcpServer, httpServer, verbose) {
211
+ return async function shutdown() {
212
+ console.error('[drift-mcp-http] Shutting down...');
213
+ // Close all SSE connections
214
+ for (const [transportId] of activeTransports) {
215
+ if (verbose) {
216
+ console.error(`[drift-mcp-http] Closing transport: ${transportId}`);
217
+ }
218
+ }
219
+ activeTransports.clear();
220
+ // Close MCP server
221
+ await mcpServer.close();
222
+ // Close HTTP server
223
+ httpServer.close(() => {
224
+ console.error('[drift-mcp-http] Server stopped');
225
+ process.exit(0);
226
+ });
227
+ };
228
+ }
229
+ async function main() {
230
+ // Configuration from environment variables
231
+ const envPort = parseInt(process.env['PORT'] ?? '3000', 10);
232
+ const envProjectRoot = process.env['PROJECT_ROOT'] ?? '/project';
233
+ const enableCache = process.env['ENABLE_CACHE'] !== 'false';
234
+ const enableRateLimit = process.env['ENABLE_RATE_LIMIT'] !== 'false';
235
+ const verbose = process.env['VERBOSE'] === 'true';
236
+ const skipWarmup = process.env['SKIP_WARMUP'] === 'true';
237
+ // Parse command line arguments (override env vars)
238
+ const args = process.argv.slice(2);
239
+ let port = envPort;
240
+ let projectRoot = envProjectRoot;
241
+ for (let i = 0; i < args.length; i++) {
242
+ const arg = args[i];
243
+ const nextArg = args[i + 1];
244
+ if (arg === '--port' && nextArg) {
245
+ port = parseInt(nextArg, 10);
246
+ i++;
247
+ }
248
+ else if (arg === '--project' && nextArg) {
249
+ projectRoot = nextArg;
250
+ i++;
251
+ }
252
+ else if (arg === '--verbose' || arg === '-v') {
253
+ // Allow --verbose flag like the stdio server
254
+ }
255
+ }
256
+ if (verbose) {
257
+ console.error(`[drift-mcp-http] Starting server for: ${projectRoot}`);
258
+ }
259
+ // Create MCP server instance
260
+ const mcpServer = createEnterpriseMCPServer({
261
+ projectRoot,
262
+ enableCache,
263
+ enableRateLimiting: enableRateLimit,
264
+ enableMetrics: true,
265
+ verbose,
266
+ skipWarmup,
267
+ });
268
+ // Create handlers
269
+ const handleHealthCheck = createHealthHandler(projectRoot);
270
+ const handleSSE = createSSEHandler(mcpServer, verbose);
271
+ const handleRequest = createRequestHandler(handleHealthCheck, handleSSE, projectRoot);
272
+ // Create HTTP server
273
+ const httpServer = createServer(async (req, res) => {
274
+ try {
275
+ await handleRequest(req, res);
276
+ }
277
+ catch (error) {
278
+ console.error('[drift-mcp-http] Request error:', error);
279
+ res.writeHead(500, { 'Content-Type': 'application/json' });
280
+ res.end(JSON.stringify({ error: 'Internal server error' }));
281
+ }
282
+ });
283
+ // Setup graceful shutdown
284
+ const shutdown = createShutdownHandler(mcpServer, httpServer, verbose);
285
+ process.on('SIGINT', shutdown);
286
+ process.on('SIGTERM', shutdown);
287
+ // Start server
288
+ httpServer.listen(port, '0.0.0.0', () => {
289
+ console.error(`[drift-mcp-http] Server running at http://0.0.0.0:${port}`);
290
+ console.error(`[drift-mcp-http] Project root: ${projectRoot}`);
291
+ console.error(`[drift-mcp-http] Cache: ${enableCache ? 'enabled' : 'disabled'}`);
292
+ console.error(`[drift-mcp-http] Rate limiting: ${enableRateLimit ? 'enabled' : 'disabled'}`);
293
+ });
294
+ }
295
+ main().catch((error) => {
296
+ console.error('Failed to start Drift MCP HTTP server:', error);
297
+ process.exit(1);
298
+ });
299
+ //# sourceMappingURL=http-server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"http-server.js","sourceRoot":"","sources":["../../src/bin/http-server.ts"],"names":[],"mappings":"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"}
File without changes
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "driftdetect-mcp",
3
- "version": "0.9.4",
3
+ "version": "0.9.6",
4
4
  "description": "MCP server that gives AI agents (Claude, Cursor, Copilot) deep understanding of your codebase patterns, conventions, and architecture. Query patterns, security boundaries, call graphs in real-time.",
5
5
  "license": "Apache-2.0",
6
6
  "author": "Geoffrey Fernald",
@@ -35,7 +35,8 @@
35
35
  "main": "./dist/index.js",
36
36
  "types": "./dist/index.d.ts",
37
37
  "bin": {
38
- "drift-mcp": "./dist/bin/server.js"
38
+ "drift-mcp": "./dist/bin/server.js",
39
+ "drift-mcp-http": "./dist/bin/http-server.js"
39
40
  },
40
41
  "exports": {
41
42
  ".": {
@@ -46,20 +47,20 @@
46
47
  "files": [
47
48
  "dist"
48
49
  ],
49
- "scripts": {
50
- "build": "tsc",
51
- "clean": "rm -rf dist",
52
- "dev": "tsc --watch",
53
- "start": "node dist/bin/server.js",
54
- "typecheck": "tsc --noEmit"
55
- },
56
50
  "dependencies": {
57
51
  "@modelcontextprotocol/sdk": "^1.0.0",
58
- "driftdetect-core": "workspace:*",
59
- "driftdetect-detectors": "workspace:*"
52
+ "driftdetect-core": "0.9.6",
53
+ "driftdetect-detectors": "0.9.6"
60
54
  },
61
55
  "devDependencies": {
62
56
  "@types/node": "^20.10.0",
63
57
  "typescript": "^5.3.0"
58
+ },
59
+ "scripts": {
60
+ "build": "tsc",
61
+ "clean": "rm -rf dist",
62
+ "dev": "tsc --watch",
63
+ "start": "node dist/bin/server.js",
64
+ "typecheck": "tsc --noEmit"
64
65
  }
65
- }
66
+ }