@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.
@@ -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":"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"}
@@ -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,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DEFAULT_LOG_FORMAT = void 0;
4
+ exports.DEFAULT_LOG_FORMAT = "condensed";
5
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/logging/types.ts"],"names":[],"mappings":";;;AA0La,QAAA,kBAAkB,GAAc,WAAW,CAAC"}
@@ -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
- await transport.handlePostMessage(req, res, req.body);
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
- const requestContext = (0, request_logger_1.getRequestContext)(req, res);
278
- logger_1.logger.info({
279
- event: "mcp_request",
280
- ...requestContext,
281
- hasToken: !!gitlabToken,
282
- }, "MCP endpoint request received");
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
- if (gitlabToken && oauthSessionId && gitlabUserId && gitlabUsername) {
285
- await (0, index_1.runWithTokenContext)({
286
- gitlabToken,
287
- gitlabUserId,
288
- gitlabUsername,
289
- sessionId: oauthSessionId,
290
- }, async () => {
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 transport.handleRequest(req, res, req.body);
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: (sessionId) => {
313
- streamableTransports[sessionId] = transport;
314
- logger_1.logger.info(`MCP session initialized: ${sessionId} (method: ${req.method})`);
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(sessionId, oauthSessionId);
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();
@@ -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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8DA,4EAOC;AA0ND,kCA2YC;AA1qBD,oEAA6E;AAC7E,wEAAiF;AACjF,0FAAmG;AACnG,sDAA2C;AAC3C,+CAAiC;AACjC,2CAA6B;AAC7B,6CAA+B;AAC/B,uCAAyB;AACzB,qCAWkB;AAElB,qCAAkC;AAClC,uDAAsD;AAGtD,yCAeuB;AAEvB,8CAAgF;AAGhF,2DAAyE;AAGzE,2CAIyB;AAUlB,KAAK,UAAU,gCAAgC;IACpD,IAAI,CAAC;QACH,MAAM,cAAc,GAAG,IAAA,mCAAiB,GAAE,CAAC;QAC3C,MAAM,cAAc,CAAC,yBAAyB,EAAE,CAAC;IACnD,CAAC;IAAC,OAAO,KAAc,EAAE,CAAC;QACxB,eAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,qDAAqD,CAAC,CAAC;IACtF,CAAC;AACH,CAAC;AAoBD,SAAS,sBAAsB,CAAC,GAAY;IAK1C,GAAG,CAAC,GAAG,CAAC,yCAAyC,EAAE,uBAAe,CAAC,CAAC;IAGpE,GAAG,CAAC,GAAG,CAAC,uCAAuC,EAAE,gCAAwB,CAAC,CAAC;IAK3E,GAAG,CAAC,GAAG,CAAC,YAAY,EAAE,wBAAgB,CAAC,CAAC;IAGxC,GAAG,CAAC,GAAG,CAAC,aAAa,EAAE,mBAAW,CAAC,CAAC;IAIpC,GAAG,CAAC,GAAG,CAAC,iBAAiB,EAAE,uBAAe,CAAC,CAAC;IAI5C,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,iBAAO,CAAC,UAAU,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,EAAE,oBAAY,CAAC,CAAC;IAGzE,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,iBAAO,CAAC,IAAI,EAAE,EAAE,uBAAe,CAAC,CAAC;IAGvD,GAAG,CAAC,GAAG,CAAC,SAAS,EAAE,qBAAa,CAAC,CAAC;IAElC,eAAM,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;AAC5C,CAAC;AAKD,SAAS,YAAY;IACnB,OAAO,CAAC,CAAC,CAAC,sBAAa,IAAI,qBAAY,CAAC,CAAC;AAC3C,CAAC;AAKD,SAAS,cAAc;IACrB,IAAI,CAAC,sBAAa,IAAI,CAAC,qBAAY,EAAE,CAAC;QACpC,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,IAAI,CAAC;QACH,MAAM,OAAO,GAAwB;YACnC,IAAI,EAAE,EAAE,CAAC,YAAY,CAAC,sBAAa,CAAC;YACpC,GAAG,EAAE,EAAE,CAAC,YAAY,CAAC,qBAAY,CAAC;SACnC,CAAC;QAEF,IAAI,oBAAW,EAAE,CAAC;YAChB,OAAO,CAAC,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,oBAAW,CAAC,CAAC;YAC1C,eAAM,CAAC,IAAI,CAAC,8BAA8B,oBAAW,EAAE,CAAC,CAAC;QAC3D,CAAC;QAED,IAAI,uBAAc,EAAE,CAAC;YACnB,OAAO,CAAC,UAAU,GAAG,uBAAc,CAAC;QACtC,CAAC;QAED,eAAM,CAAC,IAAI,CAAC,gCAAgC,sBAAa,EAAE,CAAC,CAAC;QAC7D,OAAO,OAAO,CAAC;IACjB,CAAC;IAAC,OAAO,KAAc,EAAE,CAAC;QACxB,eAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,iCAAiC,CAAC,CAAC;QAChE,MAAM,IAAI,KAAK,CAAC,oCAAoC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IACvE,CAAC;AACH,CAAC;AAKD,SAAS,mBAAmB,CAAC,GAAY;IACvC,IAAI,CAAC,oBAAW,EAAE,CAAC;QACjB,OAAO;IACT,CAAC;IAGD,IAAI,UAAU,GAA8B,oBAAW,CAAC;IACxD,IAAI,oBAAW,KAAK,MAAM,IAAI,oBAAW,KAAK,GAAG,EAAE,CAAC;QAClD,UAAU,GAAG,IAAI,CAAC;IACpB,CAAC;SAAM,IAAI,oBAAW,KAAK,OAAO,IAAI,oBAAW,KAAK,GAAG,EAAE,CAAC;QAC1D,UAAU,GAAG,KAAK,CAAC;IACrB,CAAC;SAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,oBAAW,CAAC,CAAC,EAAE,CAAC;QACvC,UAAU,GAAG,MAAM,CAAC,oBAAW,CAAC,CAAC;IACnC,CAAC;IAED,GAAG,CAAC,GAAG,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;IACnC,eAAM,CAAC,IAAI,CAAC,2BAA2B,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;AAC/D,CAAC;AAUD,SAAS,uBAAuB,CAAC,MAAkC;IACjE,MAAM,CAAC,gBAAgB,GAAG,kCAAyB,CAAC;IACpD,MAAM,CAAC,cAAc,GAAG,kCAAyB,GAAG,IAAI,CAAC;IACzD,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC;IAEnB,eAAM,CAAC,IAAI,CACT;QACE,gBAAgB,EAAE,MAAM,CAAC,gBAAgB;QACzC,cAAc,EAAE,MAAM,CAAC,cAAc;QACrC,OAAO,EAAE,MAAM,CAAC,OAAO;KACxB,EACD,mDAAmD,CACpD,CAAC;AACJ,CAAC;AAKD,SAAS,eAAe,CAAC,GAAY,EAAE,QAAoB;IACzD,MAAM,UAAU,GAAG,cAAc,EAAE,CAAC;IAEpC,IAAI,UAAU,EAAE,CAAC;QACf,MAAM,WAAW,GAAG,KAAK,CAAC,YAAY,CAAC,UAAU,EAAE,GAA2B,CAAC,CAAC;QAChF,uBAAuB,CAAC,WAAW,CAAC,CAAC;QACrC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,aAAI,CAAC,EAAE,aAAI,EAAE,QAAQ,CAAC,CAAC;IACnD,CAAC;SAAM,CAAC;QACN,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,GAA2B,CAAC,CAAC;QAClE,uBAAuB,CAAC,UAAU,CAAC,CAAC;QACpC,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,aAAI,CAAC,EAAE,aAAI,EAAE,QAAQ,CAAC,CAAC;IAClD,CAAC;AACH,CAAC;AAKD,SAAS,WAAW;IAClB,OAAO,YAAY,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;AAC3C,CAAC;AAaD,SAAS,iBAAiB,CAAC,GAAqB,EAAE,SAAiB;IACjE,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE;QAChC,IAAI,CAAC;YACH,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;gBACvB,GAAG,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;YAC1B,CAAC;iBAAM,CAAC;gBACN,aAAa,CAAC,QAAQ,CAAC,CAAC;YAC1B,CAAC;QACH,CAAC;QAAC,MAAM,CAAC;YACP,aAAa,CAAC,QAAQ,CAAC,CAAC;QAC1B,CAAC;IACH,CAAC,EAAE,yBAAgB,CAAC,CAAC;IAErB,eAAM,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,UAAU,EAAE,yBAAgB,EAAE,EAAE,uBAAuB,CAAC,CAAC;IAEnF,OAAO,GAAG,EAAE;QACV,aAAa,CAAC,QAAQ,CAAC,CAAC;QACxB,eAAM,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,EAAE,uBAAuB,CAAC,CAAC;IACvD,CAAC,CAAC;AACJ,CAAC;AAED,SAAS,sBAAsB;IAC7B,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAEnC,eAAM,CAAC,IAAI,CAAC,kCAAkC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,aAAI,EAAE,CAAC,CAAC;IAGpF,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;QAC3B,eAAM,CAAC,IAAI,CAAC,yCAAyC,CAAC,CAAC;QACvD,OAAO,OAAwB,CAAC;IAClC,CAAC;IAGD,IAAI,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;QACrB,eAAM,CAAC,IAAI,CACT,0FAA0F,CAC3F,CAAC;QACF,OAAO,MAAuB,CAAC;IACjC,CAAC;IAGD,eAAM,CAAC,IAAI,CAAC,oDAAoD,CAAC,CAAC;IAClE,OAAO,OAAwB,CAAC;AAClC,CAAC;AAEM,KAAK,UAAU,WAAW;IAE/B,MAAM,WAAW,GAAG,IAAA,uBAAe,GAAE,CAAC;IACtC,IAAI,WAAW,EAAE,CAAC;QAChB,eAAM,CAAC,IAAI,CAAC,kDAAkD,CAAC,CAAC;QAChE,eAAM,CAAC,IAAI,CAAC,oBAAoB,WAAW,CAAC,cAAc,EAAE,CAAC,CAAC;IAChE,CAAC;SAAM,CAAC;QAEN,IAAA,4BAAoB,GAAE,CAAC;QACvB,eAAM,CAAC,IAAI,CAAC,qDAAqD,CAAC,CAAC;IACrE,CAAC;IAED,eAAM,CAAC,IAAI,CAAC,wBAAwB,IAAA,8BAAsB,GAAE,EAAE,CAAC,CAAC;IAGhE,IAAI,WAAW,EAAE,CAAC;QAChB,MAAM,oBAAY,CAAC,UAAU,EAAE,CAAC;IAClC,CAAC;IAGD,MAAM,cAAc,GAAG,IAAA,mCAAiB,GAAE,CAAC;IAC3C,cAAc,CAAC,KAAK,EAAE,CAAC;IAGvB,MAAM,cAAc,GAAG,IAAA,yBAAiB,GAAE,CAAC;IAC3C,MAAM,iBAAiB,GAAG,IAAA,4BAAoB,GAAE,CAAC;IACjD,MAAM,mBAAmB,GAAG,mBAAU,KAAK,WAAW,CAAC;IACvD,cAAc,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC;IAC/C,iBAAiB,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC;IAClD,eAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,mBAAU,EAAE,EAAE,sBAAsB,mBAAU,EAAE,CAAC,CAAC;IAE3E,MAAM,aAAa,GAAG,sBAAsB,EAAE,CAAC;IAE/C,QAAQ,aAAa,EAAE,CAAC;QACtB,KAAK,OAAO,CAAC,CAAC,CAAC;YACb,MAAM,SAAS,GAAG,IAAI,+BAAoB,EAAE,CAAC;YAC7C,MAAM,cAAc,CAAC,aAAa,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;YACvD,eAAM,CAAC,IAAI,CAAC,oCAAoC,CAAC,CAAC;YAClD,MAAM;QACR,CAAC;QAED,KAAK,MAAM,CAAC,CAAC,CAAC;YACZ,eAAM,CAAC,IAAI,CAAC,0DAA0D,CAAC,CAAC;YACxE,MAAM,GAAG,GAAG,IAAA,iBAAO,GAAE,CAAC;YACtB,GAAG,CAAC,GAAG,CAAC,iBAAO,CAAC,IAAI,EAAE,CAAC,CAAC;YAGxB,mBAAmB,CAAC,GAAG,CAAC,CAAC;YAKzB,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;gBACzB,IAAI,CAAC,mBAAmB,EAAE,CAAC;oBACzB,IAAI,EAAE,CAAC;oBACP,OAAO;gBACT,CAAC;gBAED,MAAM,SAAS,GAAG,MAAM,CAAC,UAAU,EAAE,CAAC;gBACtC,MAAM,QAAQ,GAAG,IAAA,6BAAY,EAAC,GAAG,CAAC,CAAC;gBACnC,MAAM,SAAS,GAAG,GAAG,CAAC,OAAO,CAAC,gBAAgB,CAAuB,CAAC;gBAGtE,GAAG,CAAC,MAAM,CAAC,kBAAkB,GAAG,SAAS,CAAC;gBAU1C,cAAc,CAAC,SAAS,CAAC,SAAS,EAAE,QAAQ,EAAE,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;gBAG/E,GAAG,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;oBACpB,cAAc,CAAC,UAAU,CAAC,SAAS,EAAE,GAAG,CAAC,UAAU,CAAC,CAAC;gBACvD,CAAC,CAAC,CAAC;gBAOH,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;oBACnB,IAAI,GAAG,CAAC,gBAAgB,EAAE,CAAC;wBAEzB,OAAO;oBACT,CAAC;oBAED,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;wBAErB,cAAc,CAAC,mBAAmB,CAAC,SAAS,EAAE,mBAAmB,CAAC,CAAC;wBACnE,OAAO;oBACT,CAAC;oBAMD,cAAc,CAAC,UAAU,CAAC,SAAS,EAAE,GAAG,CAAC,UAAU,CAAC,CAAC;gBACvD,CAAC,CAAC,CAAC;gBAEH,IAAI,EAAE,CAAC;YACT,CAAC,CAAC,CAAC;YAGH,GAAG,CAAC,GAAG,CAAC,IAAA,6BAAqB,GAAE,CAAC,CAAC;YAGjC,IAAI,IAAA,sBAAc,GAAE,EAAE,CAAC;gBACrB,sBAAsB,CAAC,GAAG,CAAC,CAAC;YAC9B,CAAC;YAKD,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;gBACxC,MAAM,MAAM,GAAG,GAAG,CAAC,OAAO,CAAC,MAAM,IAAI,EAAE,CAAC;gBACxC,IAAI,GAAG,CAAC,MAAM,KAAK,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,mBAAmB,CAAC,EAAE,CAAC;oBAEnE,GAAG,CAAC,OAAO,CAAC,MAAM,GAAG,MAAM;wBACzB,CAAC,CAAC,GAAG,MAAM,qBAAqB;wBAChC,CAAC,CAAC,qCAAqC,CAAC;oBAC1C,eAAM,CAAC,KAAK,CACV,EAAE,cAAc,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,CAAC,OAAO,CAAC,MAAM,EAAE,EACzD,8CAA8C,CAC/C,CAAC;gBACJ,CAAC;gBACD,IAAI,EAAE,CAAC;YACT,CAAC,CAAC,CAAC;YAIH,IAAI,IAAA,sBAAc,GAAE,EAAE,CAAC;gBACrB,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,MAAM,CAAC,EAAE,2BAAmB,CAAC,CAAC;YAC9C,CAAC;YAGD,MAAM,aAAa,GAAgD,EAAE,CAAC;YACtE,MAAM,oBAAoB,GAA2D,EAAE,CAAC;YAGxF,GAAG,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE;gBACjC,eAAM,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC;gBAClC,MAAM,SAAS,GAAG,IAAI,2BAAkB,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;gBAC3D,MAAM,SAAS,GAAG,SAAS,CAAC,SAAS,CAAC;gBACtC,MAAM,QAAQ,GAAG,IAAA,6BAAY,EAAC,GAAG,CAAC,CAAC;gBAGnC,MAAM,kBAAkB,GAAG,GAAG,CAAC,MAAM,EAAE,kBAAwC,CAAC;gBAChF,IAAI,kBAAkB,EAAE,CAAC;oBACvB,cAAc,CAAC,YAAY,CAAC,kBAAkB,EAAE,SAAS,CAAC,CAAC;gBAC7D,CAAC;gBAED,IAAI,CAAC;oBAEH,MAAM,cAAc,CAAC,aAAa,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;oBACzD,aAAa,CAAC,SAAS,CAAC,GAAG,SAAS,CAAC;oBACrC,eAAM,CAAC,KAAK,CAAC,uCAAuC,SAAS,EAAE,CAAC,CAAC;oBAGjE,iBAAiB,CAAC,cAAc,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;oBAEtD,iBAAiB,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;gBACjD,CAAC;gBAAC,OAAO,KAAc,EAAE,CAAC;oBACxB,eAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,8BAA8B,CAAC,CAAC;oBACxE,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;wBACrB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;oBACxB,CAAC;oBACD,OAAO;gBACT,CAAC;gBAGD,MAAM,aAAa,GAAG,iBAAiB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;gBAGxD,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;oBACnB,aAAa,EAAE,CAAC;oBAChB,OAAO,aAAa,CAAC,SAAS,CAAC,CAAC;oBAGhC,iBAAiB,CAAC,eAAe,CAAC,SAAS,EAAE,mBAAmB,CAAC,CAAC;oBAElE,cAAc,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,KAAc,EAAE,EAAE;wBAC/D,eAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,0CAA0C,CAAC,CAAC;oBACtF,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YAEH,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAiB,EAAE;gBACtD,eAAM,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;gBAC3C,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,SAAmB,CAAC;gBAEhD,IAAI,CAAC,SAAS,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,CAAC;oBAC5C,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,mBAAmB,EAAE,CAAC,CAAC;oBACrD,OAAO;gBACT,CAAC;gBAGD,iBAAiB,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;gBAG/C,MAAM,kBAAkB,GAAG,GAAG,CAAC,MAAM,EAAE,kBAAwC,CAAC;gBAGhF,IAAI,kBAAkB,EAAE,CAAC;oBACvB,cAAc,CAAC,YAAY,CAAC,kBAAkB,EAAE,SAAS,CAAC,CAAC;gBAC7D,CAAC;gBAED,IAAI,CAAC;oBACH,cAAc,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;oBACvC,MAAM,SAAS,GAAG,aAAa,CAAC,SAAS,CAAC,CAAC;oBAG3C,MAAM,QAAQ,GAAG,KAAK,IAAI,EAAE;wBAC1B,MAAM,SAAS,CAAC,iBAAiB,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;oBACxD,CAAC,CAAC;oBAEF,IAAI,kBAAkB,EAAE,CAAC;wBACvB,MAAM,IAAA,kCAA0B,EAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAC;oBACjE,CAAC;yBAAM,CAAC;wBACN,MAAM,QAAQ,EAAE,CAAC;oBACnB,CAAC;gBACH,CAAC;gBAAC,OAAO,KAAc,EAAE,CAAC;oBACxB,eAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,4BAA4B,CAAC,CAAC;oBAC3D,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;wBACrB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,uBAAuB,EAAE,CAAC,CAAC;oBAC3D,CAAC;gBACH,CAAC;YACH,CAAC,CAAC,CAAC;YAIH,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,MAAM,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE;gBACxC,MAAM,SAAS,GAAG,GAAG,CAAC,OAAO,CAAC,gBAAgB,CAAW,CAAC;gBAC1D,MAAM,kBAAkB,GAAG,GAAG,CAAC,MAAM,CAAC,kBAAwC,CAAC;gBAC/E,MAAM,QAAQ,GAAG,IAAA,6BAAY,EAAC,GAAG,CAAC,CAAC;gBAGnC,MAAM,cAAc,GAAG,GAAG,CAAC,MAAM,CAAC,cAAoC,CAAC;gBACvE,MAAM,WAAW,GAAG,GAAG,CAAC,MAAM,CAAC,WAAiC,CAAC;gBACjE,MAAM,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC,YAAkC,CAAC;gBACnE,MAAM,cAAc,GAAG,GAAG,CAAC,MAAM,CAAC,cAAoC,CAAC;gBAGvE,IAAI,CAAC,mBAAmB,EAAE,CAAC;oBACzB,MAAM,cAAc,GAAG,IAAA,kCAAiB,EAAC,GAAG,EAAE,GAAG,CAAC,CAAC;oBACnD,eAAM,CAAC,IAAI,CACT;wBACE,KAAK,EAAE,aAAa;wBACpB,GAAG,cAAc;wBACjB,QAAQ,EAAE,CAAC,CAAC,WAAW;qBACxB,EACD,+BAA+B,CAChC,CAAC;gBACJ,CAAC;gBAGD,MAAM,iBAAiB,GAAG,KAAK,EAC7B,SAAwC,EACzB,EAAE;oBAEjB,MAAM,QAAQ,GAAG,KAAK,IAAI,EAAE;wBAC1B,IAAI,WAAW,IAAI,cAAc,IAAI,YAAY,IAAI,cAAc,EAAE,CAAC;4BAEpE,MAAM,IAAA,2BAAmB,EACvB;gCACE,WAAW;gCACX,YAAY;gCACZ,cAAc;gCACd,SAAS,EAAE,cAAc;6BAC1B,EACD,KAAK,IAAI,EAAE;gCACT,MAAM,SAAS,CAAC,aAAa,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;4BACpD,CAAC,CACF,CAAC;wBACJ,CAAC;6BAAM,CAAC;4BAEN,MAAM,SAAS,CAAC,aAAa,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;wBACpD,CAAC;oBACH,CAAC,CAAC;oBAGF,IAAI,kBAAkB,EAAE,CAAC;wBACvB,MAAM,IAAA,kCAA0B,EAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAC;oBACjE,CAAC;yBAAM,CAAC;wBACN,MAAM,QAAQ,EAAE,CAAC;oBACnB,CAAC;gBACH,CAAC,CAAC;gBAEF,IAAI,CAAC;oBACH,IAAI,SAAwC,CAAC;oBAC7C,IAAI,kBAA0B,CAAC;oBAE/B,IAAI,SAAS,IAAI,SAAS,IAAI,oBAAoB,EAAE,CAAC;wBACnD,kBAAkB,GAAG,SAAS,CAAC;wBAC/B,cAAc,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;wBAGvC,iBAAiB,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;wBAE/C,SAAS,GAAG,oBAAoB,CAAC,SAAS,CAAC,CAAC;wBAC5C,MAAM,iBAAiB,CAAC,SAAS,CAAC,CAAC;oBACrC,CAAC;yBAAM,CAAC;wBAEN,MAAM,YAAY,GAAG,MAAM,CAAC,UAAU,EAAE,CAAC;wBACzC,kBAAkB,GAAG,YAAY,CAAC;wBAElC,SAAS,GAAG,IAAI,iDAA6B,CAAC;4BAC5C,kBAAkB,EAAE,GAAG,EAAE,CAAC,YAAY;4BACtC,oBAAoB,EAAE,CAAC,oBAA4B,EAAE,EAAE;gCACrD,oBAAoB,CAAC,oBAAoB,CAAC,GAAG,SAAS,CAAC;gCACvD,eAAM,CAAC,IAAI,CACT,4BAA4B,oBAAoB,aAAa,GAAG,CAAC,MAAM,GAAG,CAC3E,CAAC;gCAGF,iBAAiB,CAAC,cAAc,CAAC,oBAAoB,EAAE,QAAQ,CAAC,CAAC;gCAEjE,iBAAiB,CAAC,iBAAiB,CAAC,oBAAoB,CAAC,CAAC;gCAI1D,cAAc,CAAC,6BAA6B,CAAC,oBAAoB,CAAC,CAAC;gCAGnE,IAAI,cAAc,EAAE,CAAC;oCACnB,oBAAY,CAAC,mBAAmB,CAAC,oBAAoB,EAAE,cAAc,CAAC,CAAC;gCACzE,CAAC;4BACH,CAAC;4BACD,eAAe,EAAE,CAAC,eAAuB,EAAE,EAAE;gCAC3C,OAAO,oBAAoB,CAAC,eAAe,CAAC,CAAC;gCAC7C,oBAAY,CAAC,2BAA2B,CAAC,eAAe,CAAC,CAAC;gCAG1D,iBAAiB,CAAC,eAAe,CAAC,eAAe,EAAE,mBAAmB,CAAC,CAAC;gCAExE,cAAc,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC,KAAK,CAAC,CAAC,GAAY,EAAE,EAAE;oCACnE,eAAM,CAAC,KAAK,CACV,EAAE,GAAG,EAAE,SAAS,EAAE,eAAe,EAAE,EACnC,+BAA+B,CAChC,CAAC;gCACJ,CAAC,CAAC,CAAC;gCACH,eAAM,CAAC,IAAI,CAAC,uBAAuB,eAAe,EAAE,CAAC,CAAC;4BACxD,CAAC;yBACF,CAAC,CAAC;wBAIH,MAAM,cAAc,CAAC,aAAa,CAAC,YAAY,EAAE,SAAS,CAAC,CAAC;wBAE5D,MAAM,iBAAiB,CAAC,SAAS,CAAC,CAAC;oBACrC,CAAC;oBAGD,IAAI,GAAG,CAAC,MAAM,KAAK,KAAK,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;wBAC/C,MAAM,aAAa,GAAG,iBAAiB,CAAC,GAAG,EAAE,kBAAkB,CAAC,CAAC;wBACjE,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;4BACnB,aAAa,EAAE,CAAC;wBAClB,CAAC,CAAC,CAAC;oBACL,CAAC;gBACH,CAAC;gBAAC,OAAO,KAAc,EAAE,CAAC;oBACxB,eAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,mCAAmC,CAAC,CAAC;oBAClE,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;wBACrB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,uBAAuB,EAAE,CAAC,CAAC;oBAC3D,CAAC;gBACH,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,eAAe,CAAC,GAAG,EAAE,GAAG,EAAE;gBACxB,MAAM,GAAG,GAAG,GAAG,WAAW,EAAE,MAAM,aAAI,IAAI,aAAI,EAAE,CAAC;gBACjD,eAAM,CAAC,IAAI,CAAC,gCAAgC,GAAG,EAAE,CAAC,CAAC;gBACnD,IAAI,YAAY,EAAE,EAAE,CAAC;oBACnB,eAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;gBACnC,CAAC;gBACD,eAAM,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;gBAC3C,eAAM,CAAC,IAAI,CAAC,mBAAmB,GAAG,gCAAgC,CAAC,CAAC;gBACpE,eAAM,CAAC,IAAI,CAAC,8BAA8B,GAAG,wCAAwC,CAAC,CAAC;gBACvF,IAAI,IAAA,sBAAc,GAAE,EAAE,CAAC;oBACrB,eAAM,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;oBAClC,eAAM,CAAC,IAAI,CAAC,qBAAqB,GAAG,yCAAyC,CAAC,CAAC;oBAC/E,eAAM,CAAC,IAAI,CAAC,oBAAoB,GAAG,YAAY,CAAC,CAAC;oBACjD,eAAM,CAAC,IAAI,CAAC,qBAAqB,GAAG,QAAQ,CAAC,CAAC;gBAChD,CAAC;gBACD,eAAM,CAAC,IAAI,CACT,EAAE,WAAW,EAAE,yBAAgB,EAAE,kBAAkB,EAAE,kCAAyB,EAAE,EAChF,wDAAwD,CACzD,CAAC;gBACF,eAAM,CAAC,IAAI,CAAC,4CAA4C,CAAC,CAAC;YAC5D,CAAC,CAAC,CAAC;YACH,MAAM;QACR,CAAC;IACH,CAAC;AACH,CAAC;AAGD,KAAK,UAAU,gBAAgB,CAAC,MAAc;IAC5C,eAAM,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,EAAE,oCAAoC,CAAC,CAAC;IAG9D,IAAI,CAAC;QACH,MAAM,WAAW,GAAG,IAAA,4BAAoB,GAAE,CAAC;QAC3C,WAAW,CAAC,mBAAmB,CAAC,iBAAiB,CAAC,CAAC;QACnD,eAAM,CAAC,IAAI,CAAC,qCAAqC,CAAC,CAAC;IACrD,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,eAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,KAAc,EAAE,EAAE,2BAA2B,CAAC,CAAC;IACrE,CAAC;IAED,IAAI,CAAC;QAEH,MAAM,EAAE,GAAG,IAAA,mCAAiB,GAAE,CAAC;QAC/B,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC;QACpB,eAAM,CAAC,IAAI,CAAC,wCAAwC,CAAC,CAAC;IACxD,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,eAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,KAAc,EAAE,EAAE,qCAAqC,CAAC,CAAC;IAC/E,CAAC;IAED,IAAI,CAAC;QAEH,MAAM,oBAAY,CAAC,KAAK,EAAE,CAAC;QAC3B,eAAM,CAAC,IAAI,CAAC,mCAAmC,CAAC,CAAC;IACnD,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,eAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,KAAc,EAAE,EAAE,6BAA6B,CAAC,CAAC;IACvE,CAAC;IAED,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC;AAED,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;IACxB,gBAAgB,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;QACrC,eAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,EAAE,gCAAgC,CAAC,CAAC;QACxD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,GAAG,EAAE;IACzB,gBAAgB,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;QACtC,eAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,EAAE,gCAAgC,CAAC,CAAC;QACxD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -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
  }