@structured-world/gitlab-mcp 6.44.0 → 6.45.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/README.md +1 -1
- package/README.md.in +1 -1
- package/dist/src/config.d.ts +3 -0
- package/dist/src/config.js +10 -2
- package/dist/src/config.js.map +1 -1
- package/dist/src/handlers.js +50 -6
- package/dist/src/handlers.js.map +1 -1
- package/dist/src/logging/access-log.d.ts +15 -0
- package/dist/src/logging/access-log.js +159 -0
- package/dist/src/logging/access-log.js.map +1 -0
- package/dist/src/logging/connection-tracker.d.ts +21 -0
- package/dist/src/logging/connection-tracker.js +101 -0
- package/dist/src/logging/connection-tracker.js.map +1 -0
- package/dist/src/logging/index.d.ts +5 -0
- package/dist/src/logging/index.js +27 -0
- package/dist/src/logging/index.js.map +1 -0
- package/dist/src/logging/request-tracker.d.ts +39 -0
- package/dist/src/logging/request-tracker.js +199 -0
- package/dist/src/logging/request-tracker.js.map +1 -0
- package/dist/src/logging/types.d.ts +55 -0
- package/dist/src/logging/types.js +5 -0
- package/dist/src/logging/types.js.map +1 -0
- package/dist/src/server.js +98 -20
- package/dist/src/server.js.map +1 -1
- package/dist/src/utils/fetch.js +5 -0
- package/dist/src/utils/fetch.js.map +1 -1
- package/dist/structured-world-gitlab-mcp-6.45.0.tgz +0 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/dist/structured-world-gitlab-mcp-6.44.0.tgz +0 -0
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import type { RequestStack } from "./types.js";
|
|
2
|
+
export interface RequestContext {
|
|
3
|
+
requestId: string;
|
|
4
|
+
}
|
|
5
|
+
export declare function getCurrentRequestId(): string | undefined;
|
|
6
|
+
export declare function runWithRequestContext<T>(requestId: string, fn: () => T): T;
|
|
7
|
+
export declare function runWithRequestContextAsync<T>(requestId: string, fn: () => Promise<T>): Promise<T>;
|
|
8
|
+
export declare class RequestTracker {
|
|
9
|
+
private stacks;
|
|
10
|
+
private enabled;
|
|
11
|
+
constructor(enabled?: boolean);
|
|
12
|
+
isEnabled(): boolean;
|
|
13
|
+
setEnabled(enabled: boolean): void;
|
|
14
|
+
openStack(requestId: string, clientIp: string, method: string, path: string, sessionId?: string): void;
|
|
15
|
+
getStack(requestId: string): RequestStack | undefined;
|
|
16
|
+
setTool(requestId: string, tool: string, action?: string): void;
|
|
17
|
+
setGitLabResponse(requestId: string, status: number | "timeout" | "error", durationMs?: number): void;
|
|
18
|
+
addDetail(requestId: string, key: string, value: string | number | boolean): void;
|
|
19
|
+
addDetails(requestId: string, details: Record<string, string | number | boolean>): void;
|
|
20
|
+
setError(requestId: string, error: string): void;
|
|
21
|
+
setContext(requestId: string, context: string): void;
|
|
22
|
+
setReadOnly(requestId: string, readOnly: boolean): void;
|
|
23
|
+
setSessionId(requestId: string, sessionId: string): void;
|
|
24
|
+
closeStack(requestId: string, status: number): string | undefined;
|
|
25
|
+
closeStackWithError(requestId: string, error: string): string | undefined;
|
|
26
|
+
hasStack(requestId: string): boolean;
|
|
27
|
+
getOpenStackCount(): number;
|
|
28
|
+
clear(): void;
|
|
29
|
+
setToolForCurrentRequest(tool: string, action?: string): void;
|
|
30
|
+
setGitLabResponseForCurrentRequest(status: number | "timeout" | "error", durationMs?: number): void;
|
|
31
|
+
addDetailForCurrentRequest(key: string, value: string | number | boolean): void;
|
|
32
|
+
addDetailsForCurrentRequest(details: Record<string, string | number | boolean>): void;
|
|
33
|
+
setErrorForCurrentRequest(error: string): void;
|
|
34
|
+
setContextForCurrentRequest(context: string): void;
|
|
35
|
+
setReadOnlyForCurrentRequest(readOnly: boolean): void;
|
|
36
|
+
setSessionIdForCurrentRequest(sessionId: string): void;
|
|
37
|
+
}
|
|
38
|
+
export declare function getRequestTracker(): RequestTracker;
|
|
39
|
+
export declare function resetRequestTracker(): void;
|
|
@@ -0,0 +1,199 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RequestTracker = void 0;
|
|
4
|
+
exports.getCurrentRequestId = getCurrentRequestId;
|
|
5
|
+
exports.runWithRequestContext = runWithRequestContext;
|
|
6
|
+
exports.runWithRequestContextAsync = runWithRequestContextAsync;
|
|
7
|
+
exports.getRequestTracker = getRequestTracker;
|
|
8
|
+
exports.resetRequestTracker = resetRequestTracker;
|
|
9
|
+
const async_hooks_1 = require("async_hooks");
|
|
10
|
+
const access_log_js_1 = require("./access-log.js");
|
|
11
|
+
const logger_js_1 = require("../logger.js");
|
|
12
|
+
const requestContext = new async_hooks_1.AsyncLocalStorage();
|
|
13
|
+
function getCurrentRequestId() {
|
|
14
|
+
return requestContext.getStore()?.requestId;
|
|
15
|
+
}
|
|
16
|
+
function runWithRequestContext(requestId, fn) {
|
|
17
|
+
return requestContext.run({ requestId }, fn);
|
|
18
|
+
}
|
|
19
|
+
async function runWithRequestContextAsync(requestId, fn) {
|
|
20
|
+
return requestContext.run({ requestId }, fn);
|
|
21
|
+
}
|
|
22
|
+
class RequestTracker {
|
|
23
|
+
stacks = new Map();
|
|
24
|
+
enabled;
|
|
25
|
+
constructor(enabled = true) {
|
|
26
|
+
this.enabled = enabled;
|
|
27
|
+
}
|
|
28
|
+
isEnabled() {
|
|
29
|
+
return this.enabled;
|
|
30
|
+
}
|
|
31
|
+
setEnabled(enabled) {
|
|
32
|
+
this.enabled = enabled;
|
|
33
|
+
}
|
|
34
|
+
openStack(requestId, clientIp, method, path, sessionId) {
|
|
35
|
+
if (!this.enabled)
|
|
36
|
+
return;
|
|
37
|
+
const stack = {
|
|
38
|
+
startTime: Date.now(),
|
|
39
|
+
clientIp,
|
|
40
|
+
method,
|
|
41
|
+
path,
|
|
42
|
+
sessionId,
|
|
43
|
+
details: {},
|
|
44
|
+
};
|
|
45
|
+
this.stacks.set(requestId, stack);
|
|
46
|
+
logger_js_1.logger.debug({ requestId, clientIp, method, path }, "Request stack opened");
|
|
47
|
+
}
|
|
48
|
+
getStack(requestId) {
|
|
49
|
+
return this.stacks.get(requestId);
|
|
50
|
+
}
|
|
51
|
+
setTool(requestId, tool, action) {
|
|
52
|
+
const stack = this.stacks.get(requestId);
|
|
53
|
+
if (!stack)
|
|
54
|
+
return;
|
|
55
|
+
stack.tool = tool;
|
|
56
|
+
if (action) {
|
|
57
|
+
stack.action = action;
|
|
58
|
+
}
|
|
59
|
+
logger_js_1.logger.debug({ requestId, tool, action }, "Tool set on request stack");
|
|
60
|
+
}
|
|
61
|
+
setGitLabResponse(requestId, status, durationMs) {
|
|
62
|
+
const stack = this.stacks.get(requestId);
|
|
63
|
+
if (!stack)
|
|
64
|
+
return;
|
|
65
|
+
stack.gitlabStatus = status;
|
|
66
|
+
if (durationMs !== undefined) {
|
|
67
|
+
stack.gitlabDuration = durationMs;
|
|
68
|
+
}
|
|
69
|
+
logger_js_1.logger.debug({ requestId, gitlabStatus: status, gitlabDuration: durationMs }, "GitLab response set on request stack");
|
|
70
|
+
}
|
|
71
|
+
addDetail(requestId, key, value) {
|
|
72
|
+
const stack = this.stacks.get(requestId);
|
|
73
|
+
if (!stack)
|
|
74
|
+
return;
|
|
75
|
+
stack.details[key] = value;
|
|
76
|
+
}
|
|
77
|
+
addDetails(requestId, details) {
|
|
78
|
+
const stack = this.stacks.get(requestId);
|
|
79
|
+
if (!stack)
|
|
80
|
+
return;
|
|
81
|
+
Object.assign(stack.details, details);
|
|
82
|
+
}
|
|
83
|
+
setError(requestId, error) {
|
|
84
|
+
const stack = this.stacks.get(requestId);
|
|
85
|
+
if (!stack)
|
|
86
|
+
return;
|
|
87
|
+
stack.error = error;
|
|
88
|
+
stack.details.err = error;
|
|
89
|
+
}
|
|
90
|
+
setContext(requestId, context) {
|
|
91
|
+
const stack = this.stacks.get(requestId);
|
|
92
|
+
if (!stack)
|
|
93
|
+
return;
|
|
94
|
+
stack.context = context;
|
|
95
|
+
}
|
|
96
|
+
setReadOnly(requestId, readOnly) {
|
|
97
|
+
const stack = this.stacks.get(requestId);
|
|
98
|
+
if (!stack)
|
|
99
|
+
return;
|
|
100
|
+
stack.readOnly = readOnly;
|
|
101
|
+
}
|
|
102
|
+
setSessionId(requestId, sessionId) {
|
|
103
|
+
const stack = this.stacks.get(requestId);
|
|
104
|
+
if (!stack)
|
|
105
|
+
return;
|
|
106
|
+
stack.sessionId = sessionId;
|
|
107
|
+
}
|
|
108
|
+
closeStack(requestId, status) {
|
|
109
|
+
const stack = this.stacks.get(requestId);
|
|
110
|
+
if (!stack) {
|
|
111
|
+
logger_js_1.logger.debug({ requestId }, "Request stack not found on close");
|
|
112
|
+
return undefined;
|
|
113
|
+
}
|
|
114
|
+
this.stacks.delete(requestId);
|
|
115
|
+
stack.status = status;
|
|
116
|
+
if (!this.enabled) {
|
|
117
|
+
return undefined;
|
|
118
|
+
}
|
|
119
|
+
const entry = (0, access_log_js_1.createAccessLogEntry)(stack);
|
|
120
|
+
const logLine = (0, access_log_js_1.formatAccessLog)(entry);
|
|
121
|
+
logger_js_1.logger.info({ accessLog: entry }, logLine);
|
|
122
|
+
return logLine;
|
|
123
|
+
}
|
|
124
|
+
closeStackWithError(requestId, error) {
|
|
125
|
+
const stack = this.stacks.get(requestId);
|
|
126
|
+
if (!stack)
|
|
127
|
+
return undefined;
|
|
128
|
+
stack.error = error;
|
|
129
|
+
stack.details.err = error;
|
|
130
|
+
return this.closeStack(requestId, 0);
|
|
131
|
+
}
|
|
132
|
+
hasStack(requestId) {
|
|
133
|
+
return this.stacks.has(requestId);
|
|
134
|
+
}
|
|
135
|
+
getOpenStackCount() {
|
|
136
|
+
return this.stacks.size;
|
|
137
|
+
}
|
|
138
|
+
clear() {
|
|
139
|
+
this.stacks.clear();
|
|
140
|
+
}
|
|
141
|
+
setToolForCurrentRequest(tool, action) {
|
|
142
|
+
const requestId = getCurrentRequestId();
|
|
143
|
+
if (requestId) {
|
|
144
|
+
this.setTool(requestId, tool, action);
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
setGitLabResponseForCurrentRequest(status, durationMs) {
|
|
148
|
+
const requestId = getCurrentRequestId();
|
|
149
|
+
if (requestId) {
|
|
150
|
+
this.setGitLabResponse(requestId, status, durationMs);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
addDetailForCurrentRequest(key, value) {
|
|
154
|
+
const requestId = getCurrentRequestId();
|
|
155
|
+
if (requestId) {
|
|
156
|
+
this.addDetail(requestId, key, value);
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
addDetailsForCurrentRequest(details) {
|
|
160
|
+
const requestId = getCurrentRequestId();
|
|
161
|
+
if (requestId) {
|
|
162
|
+
this.addDetails(requestId, details);
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
setErrorForCurrentRequest(error) {
|
|
166
|
+
const requestId = getCurrentRequestId();
|
|
167
|
+
if (requestId) {
|
|
168
|
+
this.setError(requestId, error);
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
setContextForCurrentRequest(context) {
|
|
172
|
+
const requestId = getCurrentRequestId();
|
|
173
|
+
if (requestId) {
|
|
174
|
+
this.setContext(requestId, context);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
setReadOnlyForCurrentRequest(readOnly) {
|
|
178
|
+
const requestId = getCurrentRequestId();
|
|
179
|
+
if (requestId) {
|
|
180
|
+
this.setReadOnly(requestId, readOnly);
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
setSessionIdForCurrentRequest(sessionId) {
|
|
184
|
+
const requestId = getCurrentRequestId();
|
|
185
|
+
if (requestId) {
|
|
186
|
+
this.setSessionId(requestId, sessionId);
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
exports.RequestTracker = RequestTracker;
|
|
191
|
+
let globalTracker = null;
|
|
192
|
+
function getRequestTracker() {
|
|
193
|
+
globalTracker ??= new RequestTracker();
|
|
194
|
+
return globalTracker;
|
|
195
|
+
}
|
|
196
|
+
function resetRequestTracker() {
|
|
197
|
+
globalTracker = null;
|
|
198
|
+
}
|
|
199
|
+
//# sourceMappingURL=request-tracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-tracker.js","sourceRoot":"","sources":["../../../src/logging/request-tracker.ts"],"names":[],"mappings":";;;AAuCA,kDAEC;AAKD,sDAEC;AAKD,gEAKC;AAkVD,8CAGC;AAKD,kDAEC;AApYD,6CAAgD;AAEhD,mDAAwE;AACxE,4CAAsC;AAatC,MAAM,cAAc,GAAG,IAAI,+BAAiB,EAAkB,CAAC;AAK/D,SAAgB,mBAAmB;IACjC,OAAO,cAAc,CAAC,QAAQ,EAAE,EAAE,SAAS,CAAC;AAC9C,CAAC;AAKD,SAAgB,qBAAqB,CAAI,SAAiB,EAAE,EAAW;IACrE,OAAO,cAAc,CAAC,GAAG,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC,CAAC;AAC/C,CAAC;AAKM,KAAK,UAAU,0BAA0B,CAC9C,SAAiB,EACjB,EAAoB;IAEpB,OAAO,cAAc,CAAC,GAAG,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC,CAAC;AAC/C,CAAC;AAQD,MAAa,cAAc;IACjB,MAAM,GAA8B,IAAI,GAAG,EAAE,CAAC;IAC9C,OAAO,CAAU;IAEzB,YAAY,OAAO,GAAG,IAAI;QACxB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAKD,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAKD,UAAU,CAAC,OAAgB;QACzB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAWD,SAAS,CACP,SAAiB,EACjB,QAAgB,EAChB,MAAc,EACd,IAAY,EACZ,SAAkB;QAElB,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO;QAE1B,MAAM,KAAK,GAAiB;YAC1B,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,QAAQ;YACR,MAAM;YACN,IAAI;YACJ,SAAS;YACT,OAAO,EAAE,EAAE;SACZ,CAAC;QAEF,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QAElC,kBAAM,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,sBAAsB,CAAC,CAAC;IAC9E,CAAC;IAKD,QAAQ,CAAC,SAAiB;QACxB,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACpC,CAAC;IAKD,OAAO,CAAC,SAAiB,EAAE,IAAY,EAAE,MAAe;QACtD,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK;YAAE,OAAO;QAEnB,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC;QAClB,IAAI,MAAM,EAAE,CAAC;YACX,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;QACxB,CAAC;QAED,kBAAM,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,2BAA2B,CAAC,CAAC;IACzE,CAAC;IAKD,iBAAiB,CACf,SAAiB,EACjB,MAAoC,EACpC,UAAmB;QAEnB,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK;YAAE,OAAO;QAEnB,KAAK,CAAC,YAAY,GAAG,MAAM,CAAC;QAC5B,IAAI,UAAU,KAAK,SAAS,EAAE,CAAC;YAC7B,KAAK,CAAC,cAAc,GAAG,UAAU,CAAC;QACpC,CAAC;QAED,kBAAM,CAAC,KAAK,CACV,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,cAAc,EAAE,UAAU,EAAE,EAC/D,sCAAsC,CACvC,CAAC;IACJ,CAAC;IAKD,SAAS,CAAC,SAAiB,EAAE,GAAW,EAAE,KAAgC;QACxE,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK;YAAE,OAAO;QAEnB,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IAC7B,CAAC;IAKD,UAAU,CAAC,SAAiB,EAAE,OAAkD;QAC9E,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK;YAAE,OAAO;QAEnB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IACxC,CAAC;IAKD,QAAQ,CAAC,SAAiB,EAAE,KAAa;QACvC,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK;YAAE,OAAO;QAEnB,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;QACpB,KAAK,CAAC,OAAO,CAAC,GAAG,GAAG,KAAK,CAAC;IAC5B,CAAC;IAKD,UAAU,CAAC,SAAiB,EAAE,OAAe;QAC3C,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK;YAAE,OAAO;QAEnB,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;IAC1B,CAAC;IAKD,WAAW,CAAC,SAAiB,EAAE,QAAiB;QAC9C,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK;YAAE,OAAO;QAEnB,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC5B,CAAC;IAMD,YAAY,CAAC,SAAiB,EAAE,SAAiB;QAC/C,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK;YAAE,OAAO;QAEnB,KAAK,CAAC,SAAS,GAAG,SAAS,CAAC;IAC9B,CAAC;IASD,UAAU,CAAC,SAAiB,EAAE,MAAc;QAC1C,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,kBAAM,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,EAAE,kCAAkC,CAAC,CAAC;YAChE,OAAO,SAAS,CAAC;QACnB,CAAC;QAGD,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAG9B,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;QAEtB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,OAAO,SAAS,CAAC;QACnB,CAAC;QAGD,MAAM,KAAK,GAAG,IAAA,oCAAoB,EAAC,KAAK,CAAC,CAAC;QAC1C,MAAM,OAAO,GAAG,IAAA,+BAAe,EAAC,KAAK,CAAC,CAAC;QAIvC,kBAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,OAAO,CAAC,CAAC;QAE3C,OAAO,OAAO,CAAC;IACjB,CAAC;IAMD,mBAAmB,CAAC,SAAiB,EAAE,KAAa;QAClD,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK;YAAE,OAAO,SAAS,CAAC;QAE7B,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;QACpB,KAAK,CAAC,OAAO,CAAC,GAAG,GAAG,KAAK,CAAC;QAE1B,OAAO,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;IACvC,CAAC;IAKD,QAAQ,CAAC,SAAiB;QACxB,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACpC,CAAC;IAKD,iBAAiB;QACf,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;IAC1B,CAAC;IAKD,KAAK;QACH,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;IACtB,CAAC;IAUD,wBAAwB,CAAC,IAAY,EAAE,MAAe;QACpD,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAC;QACxC,IAAI,SAAS,EAAE,CAAC;YACd,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IAKD,kCAAkC,CAChC,MAAoC,EACpC,UAAmB;QAEnB,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAC;QACxC,IAAI,SAAS,EAAE,CAAC;YACd,IAAI,CAAC,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;QACxD,CAAC;IACH,CAAC;IAKD,0BAA0B,CAAC,GAAW,EAAE,KAAgC;QACtE,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAC;QACxC,IAAI,SAAS,EAAE,CAAC;YACd,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IAKD,2BAA2B,CAAC,OAAkD;QAC5E,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAC;QACxC,IAAI,SAAS,EAAE,CAAC;YACd,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QACtC,CAAC;IACH,CAAC;IAKD,yBAAyB,CAAC,KAAa;QACrC,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAC;QACxC,IAAI,SAAS,EAAE,CAAC;YACd,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAKD,2BAA2B,CAAC,OAAe;QACzC,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAC;QACxC,IAAI,SAAS,EAAE,CAAC;YACd,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QACtC,CAAC;IACH,CAAC;IAKD,4BAA4B,CAAC,QAAiB;QAC5C,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAC;QACxC,IAAI,SAAS,EAAE,CAAC;YACd,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IAKD,6BAA6B,CAAC,SAAiB;QAC7C,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAC;QACxC,IAAI,SAAS,EAAE,CAAC;YACd,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC;CACF;AA7TD,wCA6TC;AAQD,IAAI,aAAa,GAA0B,IAAI,CAAC;AAKhD,SAAgB,iBAAiB;IAC/B,aAAa,KAAK,IAAI,cAAc,EAAE,CAAC;IACvC,OAAO,aAAa,CAAC;AACvB,CAAC;AAKD,SAAgB,mBAAmB;IACjC,aAAa,GAAG,IAAI,CAAC;AACvB,CAAC"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
export interface RequestStack {
|
|
2
|
+
startTime: number;
|
|
3
|
+
clientIp: string;
|
|
4
|
+
sessionId?: string;
|
|
5
|
+
context?: string;
|
|
6
|
+
readOnly?: boolean;
|
|
7
|
+
method: string;
|
|
8
|
+
path: string;
|
|
9
|
+
tool?: string;
|
|
10
|
+
action?: string;
|
|
11
|
+
gitlabStatus?: number | "timeout" | "error";
|
|
12
|
+
gitlabDuration?: number;
|
|
13
|
+
details: Record<string, string | number | boolean>;
|
|
14
|
+
status?: number;
|
|
15
|
+
error?: string;
|
|
16
|
+
}
|
|
17
|
+
export type ConnectionCloseReason = "client_disconnect" | "idle_timeout" | "server_shutdown" | "transport_error" | "auth_expired";
|
|
18
|
+
export interface ConnectionStats {
|
|
19
|
+
connectedAt: number;
|
|
20
|
+
clientIp: string;
|
|
21
|
+
sessionId: string;
|
|
22
|
+
requestCount: number;
|
|
23
|
+
toolCount: number;
|
|
24
|
+
errorCount: number;
|
|
25
|
+
lastError?: string;
|
|
26
|
+
}
|
|
27
|
+
export interface AccessLogEntry {
|
|
28
|
+
timestamp: string;
|
|
29
|
+
clientIp: string;
|
|
30
|
+
session: string;
|
|
31
|
+
ctx: string;
|
|
32
|
+
ro: string;
|
|
33
|
+
method: string;
|
|
34
|
+
path: string;
|
|
35
|
+
status: number;
|
|
36
|
+
durationMs: number;
|
|
37
|
+
tool: string;
|
|
38
|
+
action: string;
|
|
39
|
+
gitlabStatus: string;
|
|
40
|
+
gitlabDurationMs: string;
|
|
41
|
+
details: string;
|
|
42
|
+
}
|
|
43
|
+
export interface ConnectionCloseEntry {
|
|
44
|
+
timestamp: string;
|
|
45
|
+
clientIp: string;
|
|
46
|
+
session: string;
|
|
47
|
+
duration: string;
|
|
48
|
+
reason: ConnectionCloseReason;
|
|
49
|
+
requests: number;
|
|
50
|
+
tools: number;
|
|
51
|
+
errors: number;
|
|
52
|
+
lastError?: string;
|
|
53
|
+
}
|
|
54
|
+
export type LogFormat = "condensed" | "verbose";
|
|
55
|
+
export declare const DEFAULT_LOG_FORMAT: LogFormat;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/logging/types.ts"],"names":[],"mappings":";;;AA0La,QAAA,kBAAkB,GAAc,WAAW,CAAC"}
|
package/dist/src/server.js
CHANGED
|
@@ -52,6 +52,7 @@ const session_manager_1 = require("./session-manager");
|
|
|
52
52
|
const index_1 = require("./oauth/index");
|
|
53
53
|
const index_2 = require("./middleware/index");
|
|
54
54
|
const request_logger_1 = require("./utils/request-logger");
|
|
55
|
+
const index_3 = require("./logging/index");
|
|
55
56
|
async function sendToolsListChangedNotification() {
|
|
56
57
|
try {
|
|
57
58
|
const sessionManager = (0, session_manager_1.getSessionManager)();
|
|
@@ -192,6 +193,12 @@ async function startServer() {
|
|
|
192
193
|
}
|
|
193
194
|
const sessionManager = (0, session_manager_1.getSessionManager)();
|
|
194
195
|
sessionManager.start();
|
|
196
|
+
const requestTracker = (0, index_3.getRequestTracker)();
|
|
197
|
+
const connectionTracker = (0, index_3.getConnectionTracker)();
|
|
198
|
+
const useCondensedLogging = config_1.LOG_FORMAT === "condensed";
|
|
199
|
+
requestTracker.setEnabled(useCondensedLogging);
|
|
200
|
+
connectionTracker.setEnabled(useCondensedLogging);
|
|
201
|
+
logger_1.logger.info({ logFormat: config_1.LOG_FORMAT }, `Access log format: ${config_1.LOG_FORMAT}`);
|
|
195
202
|
const transportMode = determineTransportMode();
|
|
196
203
|
switch (transportMode) {
|
|
197
204
|
case "stdio": {
|
|
@@ -205,6 +212,31 @@ async function startServer() {
|
|
|
205
212
|
const app = (0, express_1.default)();
|
|
206
213
|
app.use(express_1.default.json());
|
|
207
214
|
configureTrustProxy(app);
|
|
215
|
+
app.use((req, res, next) => {
|
|
216
|
+
if (!useCondensedLogging) {
|
|
217
|
+
next();
|
|
218
|
+
return;
|
|
219
|
+
}
|
|
220
|
+
const requestId = crypto.randomUUID();
|
|
221
|
+
const clientIp = (0, request_logger_1.getIpAddress)(req);
|
|
222
|
+
const sessionId = req.headers["mcp-session-id"];
|
|
223
|
+
res.locals.accessLogRequestId = requestId;
|
|
224
|
+
requestTracker.openStack(requestId, clientIp, req.method, req.path, sessionId);
|
|
225
|
+
res.on("finish", () => {
|
|
226
|
+
requestTracker.closeStack(requestId, res.statusCode);
|
|
227
|
+
});
|
|
228
|
+
res.on("close", () => {
|
|
229
|
+
if (res.writableFinished) {
|
|
230
|
+
return;
|
|
231
|
+
}
|
|
232
|
+
if (!res.headersSent) {
|
|
233
|
+
requestTracker.closeStackWithError(requestId, "connection_closed");
|
|
234
|
+
return;
|
|
235
|
+
}
|
|
236
|
+
requestTracker.closeStack(requestId, res.statusCode);
|
|
237
|
+
});
|
|
238
|
+
next();
|
|
239
|
+
});
|
|
208
240
|
app.use((0, index_2.rateLimiterMiddleware)());
|
|
209
241
|
if ((0, index_1.isOAuthEnabled)()) {
|
|
210
242
|
registerOAuthEndpoints(app);
|
|
@@ -228,10 +260,17 @@ async function startServer() {
|
|
|
228
260
|
logger_1.logger.debug("SSE endpoint hit!");
|
|
229
261
|
const transport = new sse_js_1.SSEServerTransport("/messages", res);
|
|
230
262
|
const sessionId = transport.sessionId;
|
|
263
|
+
const clientIp = (0, request_logger_1.getIpAddress)(req);
|
|
264
|
+
const accessLogRequestId = res.locals?.accessLogRequestId;
|
|
265
|
+
if (accessLogRequestId) {
|
|
266
|
+
requestTracker.setSessionId(accessLogRequestId, sessionId);
|
|
267
|
+
}
|
|
231
268
|
try {
|
|
232
269
|
await sessionManager.createSession(sessionId, transport);
|
|
233
270
|
sseTransports[sessionId] = transport;
|
|
234
271
|
logger_1.logger.debug(`SSE transport created with session: ${sessionId}`);
|
|
272
|
+
connectionTracker.openConnection(sessionId, clientIp);
|
|
273
|
+
connectionTracker.incrementRequests(sessionId);
|
|
235
274
|
}
|
|
236
275
|
catch (error) {
|
|
237
276
|
logger_1.logger.error({ err: error, sessionId }, "Failed to create SSE session");
|
|
@@ -244,6 +283,7 @@ async function startServer() {
|
|
|
244
283
|
res.on("close", () => {
|
|
245
284
|
stopHeartbeat();
|
|
246
285
|
delete sseTransports[sessionId];
|
|
286
|
+
connectionTracker.closeConnection(sessionId, "client_disconnect");
|
|
247
287
|
sessionManager.removeSession(sessionId).catch((error) => {
|
|
248
288
|
logger_1.logger.debug({ err: error, sessionId }, "Error removing SSE session on disconnect");
|
|
249
289
|
});
|
|
@@ -256,10 +296,23 @@ async function startServer() {
|
|
|
256
296
|
res.status(404).json({ error: "Session not found" });
|
|
257
297
|
return;
|
|
258
298
|
}
|
|
299
|
+
connectionTracker.incrementRequests(sessionId);
|
|
300
|
+
const accessLogRequestId = res.locals?.accessLogRequestId;
|
|
301
|
+
if (accessLogRequestId) {
|
|
302
|
+
requestTracker.setSessionId(accessLogRequestId, sessionId);
|
|
303
|
+
}
|
|
259
304
|
try {
|
|
260
305
|
sessionManager.touchSession(sessionId);
|
|
261
306
|
const transport = sseTransports[sessionId];
|
|
262
|
-
|
|
307
|
+
const doHandle = async () => {
|
|
308
|
+
await transport.handlePostMessage(req, res, req.body);
|
|
309
|
+
};
|
|
310
|
+
if (accessLogRequestId) {
|
|
311
|
+
await (0, index_3.runWithRequestContextAsync)(accessLogRequestId, doHandle);
|
|
312
|
+
}
|
|
313
|
+
else {
|
|
314
|
+
await doHandle();
|
|
315
|
+
}
|
|
263
316
|
}
|
|
264
317
|
catch (error) {
|
|
265
318
|
logger_1.logger.error({ err: error }, "Error handling SSE message");
|
|
@@ -270,29 +323,41 @@ async function startServer() {
|
|
|
270
323
|
});
|
|
271
324
|
app.all(["/", "/mcp"], async (req, res) => {
|
|
272
325
|
const sessionId = req.headers["mcp-session-id"];
|
|
326
|
+
const accessLogRequestId = res.locals.accessLogRequestId;
|
|
327
|
+
const clientIp = (0, request_logger_1.getIpAddress)(req);
|
|
273
328
|
const oauthSessionId = res.locals.oauthSessionId;
|
|
274
329
|
const gitlabToken = res.locals.gitlabToken;
|
|
275
330
|
const gitlabUserId = res.locals.gitlabUserId;
|
|
276
331
|
const gitlabUsername = res.locals.gitlabUsername;
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
332
|
+
if (!useCondensedLogging) {
|
|
333
|
+
const requestContext = (0, request_logger_1.getRequestContext)(req, res);
|
|
334
|
+
logger_1.logger.info({
|
|
335
|
+
event: "mcp_request",
|
|
336
|
+
...requestContext,
|
|
337
|
+
hasToken: !!gitlabToken,
|
|
338
|
+
}, "MCP endpoint request received");
|
|
339
|
+
}
|
|
283
340
|
const handleWithContext = async (transport) => {
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
341
|
+
const doHandle = async () => {
|
|
342
|
+
if (gitlabToken && oauthSessionId && gitlabUserId && gitlabUsername) {
|
|
343
|
+
await (0, index_1.runWithTokenContext)({
|
|
344
|
+
gitlabToken,
|
|
345
|
+
gitlabUserId,
|
|
346
|
+
gitlabUsername,
|
|
347
|
+
sessionId: oauthSessionId,
|
|
348
|
+
}, async () => {
|
|
349
|
+
await transport.handleRequest(req, res, req.body);
|
|
350
|
+
});
|
|
351
|
+
}
|
|
352
|
+
else {
|
|
291
353
|
await transport.handleRequest(req, res, req.body);
|
|
292
|
-
}
|
|
354
|
+
}
|
|
355
|
+
};
|
|
356
|
+
if (accessLogRequestId) {
|
|
357
|
+
await (0, index_3.runWithRequestContextAsync)(accessLogRequestId, doHandle);
|
|
293
358
|
}
|
|
294
359
|
else {
|
|
295
|
-
await
|
|
360
|
+
await doHandle();
|
|
296
361
|
}
|
|
297
362
|
};
|
|
298
363
|
try {
|
|
@@ -301,6 +366,7 @@ async function startServer() {
|
|
|
301
366
|
if (sessionId && sessionId in streamableTransports) {
|
|
302
367
|
effectiveSessionId = sessionId;
|
|
303
368
|
sessionManager.touchSession(sessionId);
|
|
369
|
+
connectionTracker.incrementRequests(sessionId);
|
|
304
370
|
transport = streamableTransports[sessionId];
|
|
305
371
|
await handleWithContext(transport);
|
|
306
372
|
}
|
|
@@ -309,16 +375,20 @@ async function startServer() {
|
|
|
309
375
|
effectiveSessionId = newSessionId;
|
|
310
376
|
transport = new streamableHttp_js_1.StreamableHTTPServerTransport({
|
|
311
377
|
sessionIdGenerator: () => newSessionId,
|
|
312
|
-
onsessioninitialized: (
|
|
313
|
-
streamableTransports[
|
|
314
|
-
logger_1.logger.info(`MCP session initialized: ${
|
|
378
|
+
onsessioninitialized: (initializedSessionId) => {
|
|
379
|
+
streamableTransports[initializedSessionId] = transport;
|
|
380
|
+
logger_1.logger.info(`MCP session initialized: ${initializedSessionId} (method: ${req.method})`);
|
|
381
|
+
connectionTracker.openConnection(initializedSessionId, clientIp);
|
|
382
|
+
connectionTracker.incrementRequests(initializedSessionId);
|
|
383
|
+
requestTracker.setSessionIdForCurrentRequest(initializedSessionId);
|
|
315
384
|
if (oauthSessionId) {
|
|
316
|
-
index_1.sessionStore.associateMcpSession(
|
|
385
|
+
index_1.sessionStore.associateMcpSession(initializedSessionId, oauthSessionId);
|
|
317
386
|
}
|
|
318
387
|
},
|
|
319
388
|
onsessionclosed: (closedSessionId) => {
|
|
320
389
|
delete streamableTransports[closedSessionId];
|
|
321
390
|
index_1.sessionStore.removeMcpSessionAssociation(closedSessionId);
|
|
391
|
+
connectionTracker.closeConnection(closedSessionId, "client_disconnect");
|
|
322
392
|
sessionManager.removeSession(closedSessionId).catch((err) => {
|
|
323
393
|
logger_1.logger.debug({ err, sessionId: closedSessionId }, "Error removing closed session");
|
|
324
394
|
});
|
|
@@ -366,6 +436,14 @@ async function startServer() {
|
|
|
366
436
|
}
|
|
367
437
|
async function gracefulShutdown(signal) {
|
|
368
438
|
logger_1.logger.info({ signal }, "Shutting down GitLab MCP Server...");
|
|
439
|
+
try {
|
|
440
|
+
const connTracker = (0, index_3.getConnectionTracker)();
|
|
441
|
+
connTracker.closeAllConnections("server_shutdown");
|
|
442
|
+
logger_1.logger.info("All connections closed for shutdown");
|
|
443
|
+
}
|
|
444
|
+
catch (error) {
|
|
445
|
+
logger_1.logger.error({ err: error }, "Error closing connections");
|
|
446
|
+
}
|
|
369
447
|
try {
|
|
370
448
|
const sm = (0, session_manager_1.getSessionManager)();
|
|
371
449
|
await sm.shutdown();
|
package/dist/src/server.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/server.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/server.ts"],"names":[],"mappings":"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"}
|
package/dist/src/utils/fetch.js
CHANGED
|
@@ -42,6 +42,7 @@ const fs = __importStar(require("fs"));
|
|
|
42
42
|
const logger_1 = require("../logger");
|
|
43
43
|
const config_1 = require("../config");
|
|
44
44
|
const index_1 = require("../oauth/index");
|
|
45
|
+
const index_2 = require("../logging/index");
|
|
45
46
|
const undici = require("undici");
|
|
46
47
|
function loadCookieHeader() {
|
|
47
48
|
if (!config_1.GITLAB_AUTH_COOKIE_PATH) {
|
|
@@ -337,11 +338,13 @@ async function doFetch(url, options = {}) {
|
|
|
337
338
|
fetchOptions.dispatcher = dispatcher;
|
|
338
339
|
}
|
|
339
340
|
const startTime = Date.now();
|
|
341
|
+
const requestTracker = (0, index_2.getRequestTracker)();
|
|
340
342
|
try {
|
|
341
343
|
const response = await fetch(url, fetchOptions);
|
|
342
344
|
cleanup();
|
|
343
345
|
const duration = Date.now() - startTime;
|
|
344
346
|
logger_1.logger.debug({ url: safeUrl, method, status: response.status, duration }, "GitLab API request completed");
|
|
347
|
+
requestTracker.setGitLabResponseForCurrentRequest(response.status, duration);
|
|
345
348
|
return response;
|
|
346
349
|
}
|
|
347
350
|
catch (error) {
|
|
@@ -351,6 +354,7 @@ async function doFetch(url, options = {}) {
|
|
|
351
354
|
const isInternalTimeout = controller.signal.aborted && controller.signal.reason === TIMEOUT_REASON;
|
|
352
355
|
if (isInternalTimeout) {
|
|
353
356
|
logger_1.logger.warn({ url: safeUrl, method, timeout: config_1.API_TIMEOUT_MS, duration }, "GitLab API request timed out");
|
|
357
|
+
requestTracker.setGitLabResponseForCurrentRequest("timeout", duration);
|
|
354
358
|
throw new Error(`GitLab API timeout after ${config_1.API_TIMEOUT_MS}ms`);
|
|
355
359
|
}
|
|
356
360
|
else {
|
|
@@ -364,6 +368,7 @@ async function doFetch(url, options = {}) {
|
|
|
364
368
|
err: error instanceof Error ? error : new Error(String(error)),
|
|
365
369
|
duration,
|
|
366
370
|
}, "GitLab API request failed");
|
|
371
|
+
requestTracker.setGitLabResponseForCurrentRequest("error", duration);
|
|
367
372
|
throw error;
|
|
368
373
|
}
|
|
369
374
|
}
|