mcp-use 1.10.0-canary.6 → 1.10.0-canary.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/.tsbuildinfo +1 -1
- package/dist/{chunk-XU3C6BYJ.js → chunk-3BBYQXEN.js} +14 -0
- package/dist/{chunk-464BT6EX.js → chunk-5TGZJKUB.js} +1 -1
- package/dist/{chunk-7AZ4YFTN.js → chunk-EVWXZWIJ.js} +1 -1
- package/dist/{chunk-FWN7BKNM.js → chunk-GPJDNLPU.js} +14 -1
- package/dist/{chunk-YMJL66MY.js → chunk-J77Z4CRV.js} +12 -402
- package/dist/chunk-PP653GKW.js +942 -0
- package/dist/{chunk-T4B7QDPT.js → chunk-QZCF4NHP.js} +20 -4
- package/dist/index.cjs +575 -72
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +46 -13
- package/dist/src/agents/index.cjs +2050 -1603
- package/dist/src/agents/index.js +4 -4
- package/dist/src/agents/mcp_agent.d.ts +5 -0
- package/dist/src/agents/mcp_agent.d.ts.map +1 -1
- package/dist/src/browser.cjs +3189 -2710
- package/dist/src/browser.d.ts +1 -0
- package/dist/src/browser.d.ts.map +1 -1
- package/dist/src/browser.js +9 -4
- package/dist/src/client/browser.d.ts +5 -0
- package/dist/src/client/browser.d.ts.map +1 -1
- package/dist/src/client/prompts.cjs +12 -3
- package/dist/src/client/prompts.js +3 -2
- package/dist/src/client.d.ts +6 -0
- package/dist/src/client.d.ts.map +1 -1
- package/dist/src/connectors/base.d.ts +20 -10
- package/dist/src/connectors/base.d.ts.map +1 -1
- package/dist/src/connectors/http.d.ts.map +1 -1
- package/dist/src/connectors/stdio.d.ts.map +1 -1
- package/dist/src/react/index.cjs +839 -12
- package/dist/src/react/index.js +4 -4
- package/dist/src/server/endpoints/mount-mcp.d.ts.map +1 -1
- package/dist/src/server/index.cjs +1352 -78
- package/dist/src/server/index.d.ts +1 -0
- package/dist/src/server/index.d.ts.map +1 -1
- package/dist/src/server/index.js +199 -53
- package/dist/src/server/mcp-server.d.ts +31 -6
- package/dist/src/server/mcp-server.d.ts.map +1 -1
- package/dist/src/server/tools/tool-execution-helpers.d.ts.map +1 -1
- package/dist/src/server/widgets/mount-widgets-dev.d.ts.map +1 -1
- package/dist/src/telemetry/events.d.ts +219 -0
- package/dist/src/telemetry/events.d.ts.map +1 -1
- package/dist/src/telemetry/index.d.ts +2 -2
- package/dist/src/telemetry/index.d.ts.map +1 -1
- package/dist/src/telemetry/telemetry.d.ts +56 -1
- package/dist/src/telemetry/telemetry.d.ts.map +1 -1
- package/dist/src/telemetry/utils.d.ts +1 -1
- package/dist/src/telemetry/utils.d.ts.map +1 -1
- package/dist/src/version.d.ts +8 -0
- package/dist/src/version.d.ts.map +1 -0
- package/dist/{tool-execution-helpers-M5RO4YO2.js → tool-execution-helpers-PU3NN3NL.js} +3 -2
- package/package.json +5 -4
- package/dist/chunk-MTHLLDCX.js +0 -97
|
@@ -0,0 +1,942 @@
|
|
|
1
|
+
import {
|
|
2
|
+
logger
|
|
3
|
+
} from "./chunk-34R6SIER.js";
|
|
4
|
+
import {
|
|
5
|
+
__name
|
|
6
|
+
} from "./chunk-3GQAWCBQ.js";
|
|
7
|
+
|
|
8
|
+
// src/server/utils/runtime.ts
|
|
9
|
+
var isDeno = typeof globalThis.Deno !== "undefined";
|
|
10
|
+
function getEnv(key) {
|
|
11
|
+
if (isDeno) {
|
|
12
|
+
return globalThis.Deno.env.get(key);
|
|
13
|
+
}
|
|
14
|
+
return process.env[key];
|
|
15
|
+
}
|
|
16
|
+
__name(getEnv, "getEnv");
|
|
17
|
+
function getCwd() {
|
|
18
|
+
if (isDeno) {
|
|
19
|
+
return globalThis.Deno.cwd();
|
|
20
|
+
}
|
|
21
|
+
return process.cwd();
|
|
22
|
+
}
|
|
23
|
+
__name(getCwd, "getCwd");
|
|
24
|
+
var fsHelpers = {
|
|
25
|
+
async readFileSync(path2, encoding = "utf8") {
|
|
26
|
+
if (isDeno) {
|
|
27
|
+
return await globalThis.Deno.readTextFile(path2);
|
|
28
|
+
}
|
|
29
|
+
const { readFileSync: readFileSync2 } = await import("fs");
|
|
30
|
+
const result = readFileSync2(path2, encoding);
|
|
31
|
+
return typeof result === "string" ? result : result.toString(encoding);
|
|
32
|
+
},
|
|
33
|
+
async readFile(path2) {
|
|
34
|
+
if (isDeno) {
|
|
35
|
+
const data = await globalThis.Deno.readFile(path2);
|
|
36
|
+
return data.buffer;
|
|
37
|
+
}
|
|
38
|
+
const { readFileSync: readFileSync2 } = await import("fs");
|
|
39
|
+
const buffer = readFileSync2(path2);
|
|
40
|
+
return buffer.buffer.slice(
|
|
41
|
+
buffer.byteOffset,
|
|
42
|
+
buffer.byteOffset + buffer.byteLength
|
|
43
|
+
);
|
|
44
|
+
},
|
|
45
|
+
async existsSync(path2) {
|
|
46
|
+
if (isDeno) {
|
|
47
|
+
try {
|
|
48
|
+
await globalThis.Deno.stat(path2);
|
|
49
|
+
return true;
|
|
50
|
+
} catch {
|
|
51
|
+
return false;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
const { existsSync: existsSync2 } = await import("fs");
|
|
55
|
+
return existsSync2(path2);
|
|
56
|
+
},
|
|
57
|
+
async readdirSync(path2) {
|
|
58
|
+
if (isDeno) {
|
|
59
|
+
const entries = [];
|
|
60
|
+
for await (const entry of globalThis.Deno.readDir(path2)) {
|
|
61
|
+
entries.push(entry.name);
|
|
62
|
+
}
|
|
63
|
+
return entries;
|
|
64
|
+
}
|
|
65
|
+
const { readdirSync } = await import("fs");
|
|
66
|
+
return readdirSync(path2);
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
var pathHelpers = {
|
|
70
|
+
join(...paths) {
|
|
71
|
+
if (isDeno) {
|
|
72
|
+
return paths.join("/").replace(/\/+/g, "/");
|
|
73
|
+
}
|
|
74
|
+
return paths.join("/").replace(/\/+/g, "/");
|
|
75
|
+
},
|
|
76
|
+
relative(from, to) {
|
|
77
|
+
const fromParts = from.split("/").filter((p) => p);
|
|
78
|
+
const toParts = to.split("/").filter((p) => p);
|
|
79
|
+
let i = 0;
|
|
80
|
+
while (i < fromParts.length && i < toParts.length && fromParts[i] === toParts[i]) {
|
|
81
|
+
i++;
|
|
82
|
+
}
|
|
83
|
+
const upCount = fromParts.length - i;
|
|
84
|
+
const relativeParts = [...Array(upCount).fill(".."), ...toParts.slice(i)];
|
|
85
|
+
return relativeParts.join("/");
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
function generateUUID() {
|
|
89
|
+
return globalThis.crypto.randomUUID();
|
|
90
|
+
}
|
|
91
|
+
__name(generateUUID, "generateUUID");
|
|
92
|
+
|
|
93
|
+
// src/version.ts
|
|
94
|
+
var VERSION = "1.10.0-canary.7";
|
|
95
|
+
function getPackageVersion() {
|
|
96
|
+
return VERSION;
|
|
97
|
+
}
|
|
98
|
+
__name(getPackageVersion, "getPackageVersion");
|
|
99
|
+
|
|
100
|
+
// src/telemetry/telemetry.ts
|
|
101
|
+
import * as fs from "fs";
|
|
102
|
+
import * as os from "os";
|
|
103
|
+
import * as path from "path";
|
|
104
|
+
import { PostHog } from "posthog-node";
|
|
105
|
+
|
|
106
|
+
// src/telemetry/events.ts
|
|
107
|
+
var BaseTelemetryEvent = class {
|
|
108
|
+
static {
|
|
109
|
+
__name(this, "BaseTelemetryEvent");
|
|
110
|
+
}
|
|
111
|
+
};
|
|
112
|
+
var MCPAgentExecutionEvent = class extends BaseTelemetryEvent {
|
|
113
|
+
constructor(data) {
|
|
114
|
+
super();
|
|
115
|
+
this.data = data;
|
|
116
|
+
}
|
|
117
|
+
static {
|
|
118
|
+
__name(this, "MCPAgentExecutionEvent");
|
|
119
|
+
}
|
|
120
|
+
get name() {
|
|
121
|
+
return "mcp_agent_execution";
|
|
122
|
+
}
|
|
123
|
+
get properties() {
|
|
124
|
+
return {
|
|
125
|
+
// Core execution info
|
|
126
|
+
execution_method: this.data.executionMethod,
|
|
127
|
+
query: this.data.query,
|
|
128
|
+
query_length: this.data.query.length,
|
|
129
|
+
success: this.data.success,
|
|
130
|
+
// Agent configuration
|
|
131
|
+
model_provider: this.data.modelProvider,
|
|
132
|
+
model_name: this.data.modelName,
|
|
133
|
+
server_count: this.data.serverCount,
|
|
134
|
+
server_identifiers: this.data.serverIdentifiers,
|
|
135
|
+
total_tools_available: this.data.totalToolsAvailable,
|
|
136
|
+
tools_available_names: this.data.toolsAvailableNames,
|
|
137
|
+
max_steps_configured: this.data.maxStepsConfigured,
|
|
138
|
+
memory_enabled: this.data.memoryEnabled,
|
|
139
|
+
use_server_manager: this.data.useServerManager,
|
|
140
|
+
// Execution parameters (always include, even if null)
|
|
141
|
+
max_steps_used: this.data.maxStepsUsed,
|
|
142
|
+
manage_connector: this.data.manageConnector,
|
|
143
|
+
external_history_used: this.data.externalHistoryUsed,
|
|
144
|
+
// Execution results (always include, even if null)
|
|
145
|
+
steps_taken: this.data.stepsTaken ?? null,
|
|
146
|
+
tools_used_count: this.data.toolsUsedCount ?? null,
|
|
147
|
+
tools_used_names: this.data.toolsUsedNames ?? null,
|
|
148
|
+
response: this.data.response ?? null,
|
|
149
|
+
response_length: this.data.response ? this.data.response.length : null,
|
|
150
|
+
execution_time_ms: this.data.executionTimeMs ?? null,
|
|
151
|
+
error_type: this.data.errorType ?? null,
|
|
152
|
+
conversation_history_length: this.data.conversationHistoryLength ?? null
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
};
|
|
156
|
+
function createServerRunEventData(server, transport) {
|
|
157
|
+
const toolRegistrations = Array.from(server.registrations.tools.values());
|
|
158
|
+
const promptRegistrations = Array.from(server.registrations.prompts.values());
|
|
159
|
+
const resourceRegistrations = Array.from(
|
|
160
|
+
server.registrations.resources.values()
|
|
161
|
+
);
|
|
162
|
+
const templateRegistrations = Array.from(
|
|
163
|
+
server.registrations.resourceTemplates.values()
|
|
164
|
+
);
|
|
165
|
+
const allResources = resourceRegistrations.map((r) => ({
|
|
166
|
+
name: r.config.name,
|
|
167
|
+
title: r.config.title ?? null,
|
|
168
|
+
description: r.config.description ?? null,
|
|
169
|
+
uri: r.config.uri ?? null,
|
|
170
|
+
mime_type: r.config.mimeType ?? null
|
|
171
|
+
}));
|
|
172
|
+
const appsSdkResources = allResources.filter(
|
|
173
|
+
(r) => r.mime_type === "text/html+skybridge"
|
|
174
|
+
);
|
|
175
|
+
const mcpUiResources = allResources.filter(
|
|
176
|
+
(r) => r.mime_type === "text/uri-list" || r.mime_type === "text/html"
|
|
177
|
+
);
|
|
178
|
+
const mcpAppsResources = allResources.filter(
|
|
179
|
+
(r) => r.mime_type === "text/html+mcp"
|
|
180
|
+
);
|
|
181
|
+
return {
|
|
182
|
+
transport,
|
|
183
|
+
toolsNumber: server.registeredTools.length,
|
|
184
|
+
resourcesNumber: server.registeredResources.length,
|
|
185
|
+
promptsNumber: server.registeredPrompts.length,
|
|
186
|
+
auth: !!server.oauthProvider,
|
|
187
|
+
name: server.config.name,
|
|
188
|
+
description: server.config.description ?? null,
|
|
189
|
+
baseUrl: server.serverBaseUrl ?? null,
|
|
190
|
+
toolNames: server.registeredTools.length > 0 ? server.registeredTools : null,
|
|
191
|
+
resourceNames: server.registeredResources.length > 0 ? server.registeredResources : null,
|
|
192
|
+
promptNames: server.registeredPrompts.length > 0 ? server.registeredPrompts : null,
|
|
193
|
+
tools: toolRegistrations.length > 0 ? toolRegistrations.map((r) => ({
|
|
194
|
+
name: r.config.name,
|
|
195
|
+
title: r.config.title ?? null,
|
|
196
|
+
description: r.config.description ?? null,
|
|
197
|
+
input_schema: r.config.schema ? JSON.stringify(r.config.schema) : null,
|
|
198
|
+
output_schema: r.config.outputSchema ? JSON.stringify(r.config.outputSchema) : null
|
|
199
|
+
})) : null,
|
|
200
|
+
resources: allResources.length > 0 ? allResources : null,
|
|
201
|
+
prompts: promptRegistrations.length > 0 ? promptRegistrations.map((r) => ({
|
|
202
|
+
name: r.config.name,
|
|
203
|
+
title: r.config.title ?? null,
|
|
204
|
+
description: r.config.description ?? null,
|
|
205
|
+
args: r.config.args ? JSON.stringify(r.config.args) : null
|
|
206
|
+
})) : null,
|
|
207
|
+
templates: templateRegistrations.length > 0 ? templateRegistrations.map((r) => ({
|
|
208
|
+
name: r.config.name,
|
|
209
|
+
title: r.config.title ?? null,
|
|
210
|
+
description: r.config.description ?? null
|
|
211
|
+
})) : null,
|
|
212
|
+
capabilities: {
|
|
213
|
+
logging: true,
|
|
214
|
+
resources: { subscribe: true, listChanged: true }
|
|
215
|
+
},
|
|
216
|
+
appsSdkResources: appsSdkResources.length > 0 ? appsSdkResources : null,
|
|
217
|
+
appsSdkResourcesNumber: appsSdkResources.length,
|
|
218
|
+
mcpUiResources: mcpUiResources.length > 0 ? mcpUiResources : null,
|
|
219
|
+
mcpUiResourcesNumber: mcpUiResources.length,
|
|
220
|
+
mcpAppsResources: mcpAppsResources.length > 0 ? mcpAppsResources : null,
|
|
221
|
+
mcpAppsResourcesNumber: mcpAppsResources.length
|
|
222
|
+
};
|
|
223
|
+
}
|
|
224
|
+
__name(createServerRunEventData, "createServerRunEventData");
|
|
225
|
+
var ServerRunEvent = class extends BaseTelemetryEvent {
|
|
226
|
+
constructor(data) {
|
|
227
|
+
super();
|
|
228
|
+
this.data = data;
|
|
229
|
+
}
|
|
230
|
+
static {
|
|
231
|
+
__name(this, "ServerRunEvent");
|
|
232
|
+
}
|
|
233
|
+
get name() {
|
|
234
|
+
return "server_run";
|
|
235
|
+
}
|
|
236
|
+
get properties() {
|
|
237
|
+
return {
|
|
238
|
+
transport: this.data.transport,
|
|
239
|
+
tools_number: this.data.toolsNumber,
|
|
240
|
+
resources_number: this.data.resourcesNumber,
|
|
241
|
+
prompts_number: this.data.promptsNumber,
|
|
242
|
+
auth: this.data.auth,
|
|
243
|
+
name: this.data.name,
|
|
244
|
+
description: this.data.description ?? null,
|
|
245
|
+
base_url: this.data.baseUrl ?? null,
|
|
246
|
+
tool_names: this.data.toolNames ?? null,
|
|
247
|
+
resource_names: this.data.resourceNames ?? null,
|
|
248
|
+
prompt_names: this.data.promptNames ?? null,
|
|
249
|
+
tools: this.data.tools ?? null,
|
|
250
|
+
resources: this.data.resources ?? null,
|
|
251
|
+
prompts: this.data.prompts ?? null,
|
|
252
|
+
templates: this.data.templates ?? null,
|
|
253
|
+
capabilities: this.data.capabilities ? JSON.stringify(this.data.capabilities) : null,
|
|
254
|
+
apps_sdk_resources: this.data.appsSdkResources ? JSON.stringify(this.data.appsSdkResources) : null,
|
|
255
|
+
apps_sdk_resources_number: this.data.appsSdkResourcesNumber ?? 0,
|
|
256
|
+
mcp_ui_resources: this.data.mcpUiResources ? JSON.stringify(this.data.mcpUiResources) : null,
|
|
257
|
+
mcp_ui_resources_number: this.data.mcpUiResourcesNumber ?? 0,
|
|
258
|
+
mcp_apps_resources: this.data.mcpAppsResources ? JSON.stringify(this.data.mcpAppsResources) : null,
|
|
259
|
+
mcp_apps_resources_number: this.data.mcpAppsResourcesNumber ?? 0
|
|
260
|
+
};
|
|
261
|
+
}
|
|
262
|
+
};
|
|
263
|
+
var ServerInitializeEvent = class extends BaseTelemetryEvent {
|
|
264
|
+
constructor(data) {
|
|
265
|
+
super();
|
|
266
|
+
this.data = data;
|
|
267
|
+
}
|
|
268
|
+
static {
|
|
269
|
+
__name(this, "ServerInitializeEvent");
|
|
270
|
+
}
|
|
271
|
+
get name() {
|
|
272
|
+
return "server_initialize_call";
|
|
273
|
+
}
|
|
274
|
+
get properties() {
|
|
275
|
+
return {
|
|
276
|
+
protocol_version: this.data.protocolVersion,
|
|
277
|
+
client_info: JSON.stringify(this.data.clientInfo),
|
|
278
|
+
client_capabilities: JSON.stringify(this.data.clientCapabilities),
|
|
279
|
+
session_id: this.data.sessionId ?? null
|
|
280
|
+
};
|
|
281
|
+
}
|
|
282
|
+
};
|
|
283
|
+
var ServerToolCallEvent = class extends BaseTelemetryEvent {
|
|
284
|
+
constructor(data) {
|
|
285
|
+
super();
|
|
286
|
+
this.data = data;
|
|
287
|
+
}
|
|
288
|
+
static {
|
|
289
|
+
__name(this, "ServerToolCallEvent");
|
|
290
|
+
}
|
|
291
|
+
get name() {
|
|
292
|
+
return "server_tool_call";
|
|
293
|
+
}
|
|
294
|
+
get properties() {
|
|
295
|
+
return {
|
|
296
|
+
tool_name: this.data.toolName,
|
|
297
|
+
length_input_argument: this.data.lengthInputArgument,
|
|
298
|
+
success: this.data.success,
|
|
299
|
+
error_type: this.data.errorType ?? null,
|
|
300
|
+
execution_time_ms: this.data.executionTimeMs ?? null
|
|
301
|
+
};
|
|
302
|
+
}
|
|
303
|
+
};
|
|
304
|
+
var ServerResourceCallEvent = class extends BaseTelemetryEvent {
|
|
305
|
+
constructor(data) {
|
|
306
|
+
super();
|
|
307
|
+
this.data = data;
|
|
308
|
+
}
|
|
309
|
+
static {
|
|
310
|
+
__name(this, "ServerResourceCallEvent");
|
|
311
|
+
}
|
|
312
|
+
get name() {
|
|
313
|
+
return "server_resource_call";
|
|
314
|
+
}
|
|
315
|
+
get properties() {
|
|
316
|
+
return {
|
|
317
|
+
name: this.data.name,
|
|
318
|
+
description: this.data.description,
|
|
319
|
+
contents: this.data.contents,
|
|
320
|
+
success: this.data.success,
|
|
321
|
+
error_type: this.data.errorType ?? null
|
|
322
|
+
};
|
|
323
|
+
}
|
|
324
|
+
};
|
|
325
|
+
var ServerPromptCallEvent = class extends BaseTelemetryEvent {
|
|
326
|
+
constructor(data) {
|
|
327
|
+
super();
|
|
328
|
+
this.data = data;
|
|
329
|
+
}
|
|
330
|
+
static {
|
|
331
|
+
__name(this, "ServerPromptCallEvent");
|
|
332
|
+
}
|
|
333
|
+
get name() {
|
|
334
|
+
return "server_prompt_call";
|
|
335
|
+
}
|
|
336
|
+
get properties() {
|
|
337
|
+
return {
|
|
338
|
+
name: this.data.name,
|
|
339
|
+
description: this.data.description,
|
|
340
|
+
success: this.data.success,
|
|
341
|
+
error_type: this.data.errorType ?? null
|
|
342
|
+
};
|
|
343
|
+
}
|
|
344
|
+
};
|
|
345
|
+
var ServerContextEvent = class extends BaseTelemetryEvent {
|
|
346
|
+
constructor(data) {
|
|
347
|
+
super();
|
|
348
|
+
this.data = data;
|
|
349
|
+
}
|
|
350
|
+
static {
|
|
351
|
+
__name(this, "ServerContextEvent");
|
|
352
|
+
}
|
|
353
|
+
get name() {
|
|
354
|
+
return `server_context_${this.data.contextType}`;
|
|
355
|
+
}
|
|
356
|
+
get properties() {
|
|
357
|
+
return {
|
|
358
|
+
context_type: this.data.contextType,
|
|
359
|
+
notification_type: this.data.notificationType ?? null
|
|
360
|
+
};
|
|
361
|
+
}
|
|
362
|
+
};
|
|
363
|
+
var MCPClientInitEvent = class extends BaseTelemetryEvent {
|
|
364
|
+
constructor(data) {
|
|
365
|
+
super();
|
|
366
|
+
this.data = data;
|
|
367
|
+
}
|
|
368
|
+
static {
|
|
369
|
+
__name(this, "MCPClientInitEvent");
|
|
370
|
+
}
|
|
371
|
+
get name() {
|
|
372
|
+
return "mcpclient_init";
|
|
373
|
+
}
|
|
374
|
+
get properties() {
|
|
375
|
+
return {
|
|
376
|
+
code_mode: this.data.codeMode,
|
|
377
|
+
sandbox: this.data.sandbox,
|
|
378
|
+
all_callbacks: this.data.allCallbacks,
|
|
379
|
+
verify: this.data.verify,
|
|
380
|
+
servers: this.data.servers,
|
|
381
|
+
num_servers: this.data.numServers
|
|
382
|
+
};
|
|
383
|
+
}
|
|
384
|
+
};
|
|
385
|
+
var ConnectorInitEvent = class extends BaseTelemetryEvent {
|
|
386
|
+
constructor(data) {
|
|
387
|
+
super();
|
|
388
|
+
this.data = data;
|
|
389
|
+
}
|
|
390
|
+
static {
|
|
391
|
+
__name(this, "ConnectorInitEvent");
|
|
392
|
+
}
|
|
393
|
+
get name() {
|
|
394
|
+
return "connector_init";
|
|
395
|
+
}
|
|
396
|
+
get properties() {
|
|
397
|
+
return {
|
|
398
|
+
connector_type: this.data.connectorType,
|
|
399
|
+
server_command: this.data.serverCommand ?? null,
|
|
400
|
+
server_args: this.data.serverArgs ?? null,
|
|
401
|
+
server_url: this.data.serverUrl ?? null,
|
|
402
|
+
public_identifier: this.data.publicIdentifier ?? null
|
|
403
|
+
};
|
|
404
|
+
}
|
|
405
|
+
};
|
|
406
|
+
|
|
407
|
+
// src/telemetry/utils.ts
|
|
408
|
+
function getModelProvider(llm) {
|
|
409
|
+
return llm._llm_type || llm.constructor.name.toLowerCase();
|
|
410
|
+
}
|
|
411
|
+
__name(getModelProvider, "getModelProvider");
|
|
412
|
+
function getModelName(llm) {
|
|
413
|
+
if ("_identifyingParams" in llm) {
|
|
414
|
+
const identifyingParams = llm._identifyingParams;
|
|
415
|
+
if (typeof identifyingParams === "object" && identifyingParams !== null) {
|
|
416
|
+
for (const key of [
|
|
417
|
+
"model",
|
|
418
|
+
"modelName",
|
|
419
|
+
"model_name",
|
|
420
|
+
"modelId",
|
|
421
|
+
"model_id",
|
|
422
|
+
"deploymentName",
|
|
423
|
+
"deployment_name"
|
|
424
|
+
]) {
|
|
425
|
+
if (key in identifyingParams) {
|
|
426
|
+
return String(identifyingParams[key]);
|
|
427
|
+
}
|
|
428
|
+
}
|
|
429
|
+
}
|
|
430
|
+
}
|
|
431
|
+
return llm.model || llm.modelName || llm.constructor.name;
|
|
432
|
+
}
|
|
433
|
+
__name(getModelName, "getModelName");
|
|
434
|
+
function extractModelInfo(llm) {
|
|
435
|
+
return [getModelProvider(llm), getModelName(llm)];
|
|
436
|
+
}
|
|
437
|
+
__name(extractModelInfo, "extractModelInfo");
|
|
438
|
+
|
|
439
|
+
// src/telemetry/telemetry.ts
|
|
440
|
+
var USER_ID_STORAGE_KEY = "mcp_use_user_id";
|
|
441
|
+
function detectRuntimeEnvironment() {
|
|
442
|
+
try {
|
|
443
|
+
if (typeof globalThis.Bun !== "undefined") {
|
|
444
|
+
return "bun";
|
|
445
|
+
}
|
|
446
|
+
if (typeof globalThis.Deno !== "undefined") {
|
|
447
|
+
return "deno";
|
|
448
|
+
}
|
|
449
|
+
if (typeof navigator !== "undefined" && navigator.userAgent?.includes("Cloudflare-Workers")) {
|
|
450
|
+
return "cloudflare-workers";
|
|
451
|
+
}
|
|
452
|
+
if (typeof globalThis.EdgeRuntime !== "undefined") {
|
|
453
|
+
return "edge";
|
|
454
|
+
}
|
|
455
|
+
if (typeof process !== "undefined" && typeof process.versions?.node !== "undefined" && typeof fs !== "undefined" && typeof fs.existsSync === "function") {
|
|
456
|
+
return "node";
|
|
457
|
+
}
|
|
458
|
+
if (typeof window !== "undefined" && typeof document !== "undefined") {
|
|
459
|
+
return "browser";
|
|
460
|
+
}
|
|
461
|
+
return "unknown";
|
|
462
|
+
} catch {
|
|
463
|
+
return "unknown";
|
|
464
|
+
}
|
|
465
|
+
}
|
|
466
|
+
__name(detectRuntimeEnvironment, "detectRuntimeEnvironment");
|
|
467
|
+
function getStorageCapability(env) {
|
|
468
|
+
switch (env) {
|
|
469
|
+
case "node":
|
|
470
|
+
case "bun":
|
|
471
|
+
return "filesystem";
|
|
472
|
+
case "browser":
|
|
473
|
+
try {
|
|
474
|
+
if (typeof localStorage !== "undefined") {
|
|
475
|
+
localStorage.setItem("__mcp_use_test__", "1");
|
|
476
|
+
localStorage.removeItem("__mcp_use_test__");
|
|
477
|
+
return "localStorage";
|
|
478
|
+
}
|
|
479
|
+
} catch {
|
|
480
|
+
}
|
|
481
|
+
return "session-only";
|
|
482
|
+
case "deno":
|
|
483
|
+
return "session-only";
|
|
484
|
+
default:
|
|
485
|
+
return "session-only";
|
|
486
|
+
}
|
|
487
|
+
}
|
|
488
|
+
__name(getStorageCapability, "getStorageCapability");
|
|
489
|
+
var cachedEnvironment = null;
|
|
490
|
+
function getRuntimeEnvironment() {
|
|
491
|
+
if (cachedEnvironment === null) {
|
|
492
|
+
cachedEnvironment = detectRuntimeEnvironment();
|
|
493
|
+
}
|
|
494
|
+
return cachedEnvironment;
|
|
495
|
+
}
|
|
496
|
+
__name(getRuntimeEnvironment, "getRuntimeEnvironment");
|
|
497
|
+
function isNodeJSEnvironment() {
|
|
498
|
+
const env = getRuntimeEnvironment();
|
|
499
|
+
return env === "node" || env === "bun";
|
|
500
|
+
}
|
|
501
|
+
__name(isNodeJSEnvironment, "isNodeJSEnvironment");
|
|
502
|
+
var ScarfEventLogger = class {
|
|
503
|
+
static {
|
|
504
|
+
__name(this, "ScarfEventLogger");
|
|
505
|
+
}
|
|
506
|
+
endpoint;
|
|
507
|
+
timeout;
|
|
508
|
+
constructor(endpoint, timeout = 3e3) {
|
|
509
|
+
this.endpoint = endpoint;
|
|
510
|
+
this.timeout = timeout;
|
|
511
|
+
}
|
|
512
|
+
async logEvent(properties) {
|
|
513
|
+
try {
|
|
514
|
+
const controller = new AbortController();
|
|
515
|
+
const timeoutId = setTimeout(() => controller.abort(), this.timeout);
|
|
516
|
+
const response = await fetch(this.endpoint, {
|
|
517
|
+
method: "POST",
|
|
518
|
+
headers: {
|
|
519
|
+
"Content-Type": "application/json"
|
|
520
|
+
},
|
|
521
|
+
body: JSON.stringify(properties),
|
|
522
|
+
signal: controller.signal
|
|
523
|
+
});
|
|
524
|
+
clearTimeout(timeoutId);
|
|
525
|
+
if (!response.ok) {
|
|
526
|
+
throw new Error(`HTTP error! status: ${response.status}`);
|
|
527
|
+
}
|
|
528
|
+
} catch (error) {
|
|
529
|
+
logger.debug(`Failed to send Scarf event: ${error}`);
|
|
530
|
+
}
|
|
531
|
+
}
|
|
532
|
+
};
|
|
533
|
+
function getCacheHome() {
|
|
534
|
+
if (!isNodeJSEnvironment()) {
|
|
535
|
+
return "/tmp/mcp_use_cache";
|
|
536
|
+
}
|
|
537
|
+
const envVar = process.env.XDG_CACHE_HOME;
|
|
538
|
+
if (envVar && path.isAbsolute(envVar)) {
|
|
539
|
+
return envVar;
|
|
540
|
+
}
|
|
541
|
+
const platform = process.platform;
|
|
542
|
+
const homeDir = os.homedir();
|
|
543
|
+
if (platform === "win32") {
|
|
544
|
+
const appdata = process.env.LOCALAPPDATA || process.env.APPDATA;
|
|
545
|
+
if (appdata) {
|
|
546
|
+
return appdata;
|
|
547
|
+
}
|
|
548
|
+
return path.join(homeDir, "AppData", "Local");
|
|
549
|
+
} else if (platform === "darwin") {
|
|
550
|
+
return path.join(homeDir, "Library", "Caches");
|
|
551
|
+
} else {
|
|
552
|
+
return path.join(homeDir, ".cache");
|
|
553
|
+
}
|
|
554
|
+
}
|
|
555
|
+
__name(getCacheHome, "getCacheHome");
|
|
556
|
+
var Telemetry = class _Telemetry {
|
|
557
|
+
static {
|
|
558
|
+
__name(this, "Telemetry");
|
|
559
|
+
}
|
|
560
|
+
static instance = null;
|
|
561
|
+
USER_ID_PATH = path.join(
|
|
562
|
+
getCacheHome(),
|
|
563
|
+
"mcp_use_3",
|
|
564
|
+
"telemetry_user_id"
|
|
565
|
+
);
|
|
566
|
+
VERSION_DOWNLOAD_PATH = path.join(
|
|
567
|
+
getCacheHome(),
|
|
568
|
+
"mcp_use",
|
|
569
|
+
"download_version"
|
|
570
|
+
);
|
|
571
|
+
PROJECT_API_KEY = "phc_lyTtbYwvkdSbrcMQNPiKiiRWrrM1seyKIMjycSvItEI";
|
|
572
|
+
HOST = "https://eu.i.posthog.com";
|
|
573
|
+
SCARF_GATEWAY_URL = "https://mcpuse.gateway.scarf.sh/events-ts";
|
|
574
|
+
UNKNOWN_USER_ID = "UNKNOWN_USER_ID";
|
|
575
|
+
_currUserId = null;
|
|
576
|
+
_posthogClient = null;
|
|
577
|
+
_scarfClient = null;
|
|
578
|
+
_runtimeEnvironment;
|
|
579
|
+
_storageCapability;
|
|
580
|
+
_source;
|
|
581
|
+
constructor() {
|
|
582
|
+
this._runtimeEnvironment = getRuntimeEnvironment();
|
|
583
|
+
this._storageCapability = getStorageCapability(this._runtimeEnvironment);
|
|
584
|
+
this._source = typeof process !== "undefined" && process.env?.MCP_USE_TELEMETRY_SOURCE || this._runtimeEnvironment;
|
|
585
|
+
const telemetryDisabled = typeof process !== "undefined" && process.env?.MCP_USE_ANONYMIZED_TELEMETRY?.toLowerCase() === "false" || false;
|
|
586
|
+
const canSupportTelemetry = this._runtimeEnvironment !== "unknown";
|
|
587
|
+
const isServerlessEnvironment = [
|
|
588
|
+
"cloudflare-workers",
|
|
589
|
+
"edge",
|
|
590
|
+
"deno"
|
|
591
|
+
].includes(this._runtimeEnvironment);
|
|
592
|
+
if (telemetryDisabled) {
|
|
593
|
+
this._posthogClient = null;
|
|
594
|
+
this._scarfClient = null;
|
|
595
|
+
logger.debug("Telemetry disabled via environment variable");
|
|
596
|
+
} else if (!canSupportTelemetry) {
|
|
597
|
+
this._posthogClient = null;
|
|
598
|
+
this._scarfClient = null;
|
|
599
|
+
logger.debug(
|
|
600
|
+
`Telemetry disabled - unknown environment: ${this._runtimeEnvironment}`
|
|
601
|
+
);
|
|
602
|
+
} else {
|
|
603
|
+
logger.info(
|
|
604
|
+
"Anonymized telemetry enabled. Set MCP_USE_ANONYMIZED_TELEMETRY=false to disable."
|
|
605
|
+
);
|
|
606
|
+
if (this._runtimeEnvironment !== "browser") {
|
|
607
|
+
try {
|
|
608
|
+
const posthogOptions = {
|
|
609
|
+
host: this.HOST,
|
|
610
|
+
disableGeoip: false
|
|
611
|
+
};
|
|
612
|
+
if (isServerlessEnvironment) {
|
|
613
|
+
posthogOptions.flushAt = 1;
|
|
614
|
+
posthogOptions.flushInterval = 0;
|
|
615
|
+
}
|
|
616
|
+
this._posthogClient = new PostHog(
|
|
617
|
+
this.PROJECT_API_KEY,
|
|
618
|
+
posthogOptions
|
|
619
|
+
);
|
|
620
|
+
} catch (e) {
|
|
621
|
+
logger.warn(`Failed to initialize PostHog telemetry: ${e}`);
|
|
622
|
+
this._posthogClient = null;
|
|
623
|
+
}
|
|
624
|
+
} else {
|
|
625
|
+
this._posthogClient = null;
|
|
626
|
+
}
|
|
627
|
+
try {
|
|
628
|
+
this._scarfClient = new ScarfEventLogger(this.SCARF_GATEWAY_URL, 3e3);
|
|
629
|
+
} catch (e) {
|
|
630
|
+
logger.warn(`Failed to initialize Scarf telemetry: ${e}`);
|
|
631
|
+
this._scarfClient = null;
|
|
632
|
+
}
|
|
633
|
+
}
|
|
634
|
+
}
|
|
635
|
+
/**
|
|
636
|
+
* Get the detected runtime environment
|
|
637
|
+
*/
|
|
638
|
+
get runtimeEnvironment() {
|
|
639
|
+
return this._runtimeEnvironment;
|
|
640
|
+
}
|
|
641
|
+
/**
|
|
642
|
+
* Get the storage capability for this environment
|
|
643
|
+
*/
|
|
644
|
+
get storageCapability() {
|
|
645
|
+
return this._storageCapability;
|
|
646
|
+
}
|
|
647
|
+
static getInstance() {
|
|
648
|
+
if (!_Telemetry.instance) {
|
|
649
|
+
_Telemetry.instance = new _Telemetry();
|
|
650
|
+
}
|
|
651
|
+
return _Telemetry.instance;
|
|
652
|
+
}
|
|
653
|
+
/**
|
|
654
|
+
* Set the source identifier for telemetry events.
|
|
655
|
+
* This allows tracking usage from different applications.
|
|
656
|
+
* @param source - The source identifier (e.g., "my-app", "cli", "vs-code-extension")
|
|
657
|
+
*/
|
|
658
|
+
setSource(source) {
|
|
659
|
+
this._source = source;
|
|
660
|
+
logger.debug(`Telemetry source set to: ${source}`);
|
|
661
|
+
}
|
|
662
|
+
/**
|
|
663
|
+
* Get the current source identifier.
|
|
664
|
+
*/
|
|
665
|
+
getSource() {
|
|
666
|
+
return this._source;
|
|
667
|
+
}
|
|
668
|
+
/**
|
|
669
|
+
* Check if telemetry is enabled.
|
|
670
|
+
* Returns false if telemetry was disabled via environment variable or if not in Node.js environment.
|
|
671
|
+
*/
|
|
672
|
+
get isEnabled() {
|
|
673
|
+
return this._posthogClient !== null || this._scarfClient !== null;
|
|
674
|
+
}
|
|
675
|
+
get userId() {
|
|
676
|
+
if (this._currUserId) {
|
|
677
|
+
return this._currUserId;
|
|
678
|
+
}
|
|
679
|
+
try {
|
|
680
|
+
switch (this._storageCapability) {
|
|
681
|
+
case "filesystem":
|
|
682
|
+
this._currUserId = this.getUserIdFromFilesystem();
|
|
683
|
+
break;
|
|
684
|
+
case "localStorage":
|
|
685
|
+
this._currUserId = this.getUserIdFromLocalStorage();
|
|
686
|
+
break;
|
|
687
|
+
case "session-only":
|
|
688
|
+
default:
|
|
689
|
+
this._currUserId = `session-${generateUUID()}`;
|
|
690
|
+
logger.debug(
|
|
691
|
+
`Using session-based user ID (${this._runtimeEnvironment} environment)`
|
|
692
|
+
);
|
|
693
|
+
break;
|
|
694
|
+
}
|
|
695
|
+
if (this._storageCapability === "filesystem" && this._currUserId) {
|
|
696
|
+
this.trackPackageDownloadInternal(this._currUserId, {
|
|
697
|
+
triggered_by: "user_id_property"
|
|
698
|
+
}).catch((e) => logger.debug(`Failed to track package download: ${e}`));
|
|
699
|
+
}
|
|
700
|
+
} catch (e) {
|
|
701
|
+
logger.debug(`Failed to get/create user ID: ${e}`);
|
|
702
|
+
this._currUserId = this.UNKNOWN_USER_ID;
|
|
703
|
+
}
|
|
704
|
+
return this._currUserId;
|
|
705
|
+
}
|
|
706
|
+
/**
|
|
707
|
+
* Get or create user ID from filesystem (Node.js/Bun)
|
|
708
|
+
*/
|
|
709
|
+
getUserIdFromFilesystem() {
|
|
710
|
+
const isFirstTime = !fs.existsSync(this.USER_ID_PATH);
|
|
711
|
+
if (isFirstTime) {
|
|
712
|
+
logger.debug(`Creating user ID path: ${this.USER_ID_PATH}`);
|
|
713
|
+
fs.mkdirSync(path.dirname(this.USER_ID_PATH), { recursive: true });
|
|
714
|
+
const newUserId = generateUUID();
|
|
715
|
+
fs.writeFileSync(this.USER_ID_PATH, newUserId);
|
|
716
|
+
logger.debug(`User ID path created: ${this.USER_ID_PATH}`);
|
|
717
|
+
return newUserId;
|
|
718
|
+
}
|
|
719
|
+
return fs.readFileSync(this.USER_ID_PATH, "utf-8").trim();
|
|
720
|
+
}
|
|
721
|
+
/**
|
|
722
|
+
* Get or create user ID from localStorage (Browser)
|
|
723
|
+
*/
|
|
724
|
+
getUserIdFromLocalStorage() {
|
|
725
|
+
try {
|
|
726
|
+
let userId = localStorage.getItem(USER_ID_STORAGE_KEY);
|
|
727
|
+
if (!userId) {
|
|
728
|
+
userId = generateUUID();
|
|
729
|
+
localStorage.setItem(USER_ID_STORAGE_KEY, userId);
|
|
730
|
+
logger.debug(`Created new browser user ID`);
|
|
731
|
+
}
|
|
732
|
+
return userId;
|
|
733
|
+
} catch (e) {
|
|
734
|
+
logger.debug(`localStorage access failed: ${e}`);
|
|
735
|
+
return `session-${generateUUID()}`;
|
|
736
|
+
}
|
|
737
|
+
}
|
|
738
|
+
async capture(event) {
|
|
739
|
+
logger.debug(
|
|
740
|
+
`CAPTURE: posthog: ${this._posthogClient !== null}, scarf: ${this._scarfClient !== null}`
|
|
741
|
+
);
|
|
742
|
+
if (!this._posthogClient && !this._scarfClient) {
|
|
743
|
+
return;
|
|
744
|
+
}
|
|
745
|
+
if (this._posthogClient) {
|
|
746
|
+
try {
|
|
747
|
+
const properties = { ...event.properties };
|
|
748
|
+
properties.mcp_use_version = getPackageVersion();
|
|
749
|
+
properties.language = "typescript";
|
|
750
|
+
properties.source = this._source;
|
|
751
|
+
properties.runtime = this._runtimeEnvironment;
|
|
752
|
+
logger.debug(`CAPTURE: PostHog Event ${event.name}`);
|
|
753
|
+
logger.debug(
|
|
754
|
+
`CAPTURE: PostHog Properties ${JSON.stringify(properties)}`
|
|
755
|
+
);
|
|
756
|
+
this._posthogClient.capture({
|
|
757
|
+
distinctId: this.userId,
|
|
758
|
+
event: event.name,
|
|
759
|
+
properties
|
|
760
|
+
});
|
|
761
|
+
} catch (e) {
|
|
762
|
+
logger.debug(`Failed to track PostHog event ${event.name}: ${e}`);
|
|
763
|
+
}
|
|
764
|
+
}
|
|
765
|
+
if (this._scarfClient) {
|
|
766
|
+
try {
|
|
767
|
+
const properties = {};
|
|
768
|
+
properties.mcp_use_version = getPackageVersion();
|
|
769
|
+
properties.user_id = this.userId;
|
|
770
|
+
properties.event = event.name;
|
|
771
|
+
properties.language = "typescript";
|
|
772
|
+
properties.source = this._source;
|
|
773
|
+
properties.runtime = this._runtimeEnvironment;
|
|
774
|
+
await this._scarfClient.logEvent(properties);
|
|
775
|
+
} catch (e) {
|
|
776
|
+
logger.debug(`Failed to track Scarf event ${event.name}: ${e}`);
|
|
777
|
+
}
|
|
778
|
+
}
|
|
779
|
+
}
|
|
780
|
+
/**
|
|
781
|
+
* Track package download event.
|
|
782
|
+
* This is a public wrapper that safely accesses userId.
|
|
783
|
+
*/
|
|
784
|
+
async trackPackageDownload(properties) {
|
|
785
|
+
return this.trackPackageDownloadInternal(this.userId, properties);
|
|
786
|
+
}
|
|
787
|
+
/**
|
|
788
|
+
* Internal method to track package download with explicit userId.
|
|
789
|
+
* This avoids circular dependency when called from the userId getter.
|
|
790
|
+
*/
|
|
791
|
+
async trackPackageDownloadInternal(userId, properties) {
|
|
792
|
+
if (!this._scarfClient) {
|
|
793
|
+
return;
|
|
794
|
+
}
|
|
795
|
+
if (this._storageCapability !== "filesystem") {
|
|
796
|
+
return;
|
|
797
|
+
}
|
|
798
|
+
try {
|
|
799
|
+
const currentVersion = getPackageVersion();
|
|
800
|
+
let shouldTrack = false;
|
|
801
|
+
let firstDownload = false;
|
|
802
|
+
if (!fs.existsSync(this.VERSION_DOWNLOAD_PATH)) {
|
|
803
|
+
shouldTrack = true;
|
|
804
|
+
firstDownload = true;
|
|
805
|
+
fs.mkdirSync(path.dirname(this.VERSION_DOWNLOAD_PATH), {
|
|
806
|
+
recursive: true
|
|
807
|
+
});
|
|
808
|
+
fs.writeFileSync(this.VERSION_DOWNLOAD_PATH, currentVersion);
|
|
809
|
+
} else {
|
|
810
|
+
const savedVersion = fs.readFileSync(this.VERSION_DOWNLOAD_PATH, "utf-8").trim();
|
|
811
|
+
if (currentVersion > savedVersion) {
|
|
812
|
+
shouldTrack = true;
|
|
813
|
+
firstDownload = false;
|
|
814
|
+
fs.writeFileSync(this.VERSION_DOWNLOAD_PATH, currentVersion);
|
|
815
|
+
}
|
|
816
|
+
}
|
|
817
|
+
if (shouldTrack) {
|
|
818
|
+
logger.debug(
|
|
819
|
+
`Tracking package download event with properties: ${JSON.stringify(properties)}`
|
|
820
|
+
);
|
|
821
|
+
const eventProperties = { ...properties || {} };
|
|
822
|
+
eventProperties.mcp_use_version = currentVersion;
|
|
823
|
+
eventProperties.user_id = userId;
|
|
824
|
+
eventProperties.event = "package_download";
|
|
825
|
+
eventProperties.first_download = firstDownload;
|
|
826
|
+
eventProperties.language = "typescript";
|
|
827
|
+
eventProperties.source = this._source;
|
|
828
|
+
eventProperties.runtime = this._runtimeEnvironment;
|
|
829
|
+
await this._scarfClient.logEvent(eventProperties);
|
|
830
|
+
}
|
|
831
|
+
} catch (e) {
|
|
832
|
+
logger.debug(`Failed to track Scarf package_download event: ${e}`);
|
|
833
|
+
}
|
|
834
|
+
}
|
|
835
|
+
// ============================================================================
|
|
836
|
+
// Agent Events
|
|
837
|
+
// ============================================================================
|
|
838
|
+
async trackAgentExecution(data) {
|
|
839
|
+
if (!this.isEnabled) return;
|
|
840
|
+
const event = new MCPAgentExecutionEvent(data);
|
|
841
|
+
await this.capture(event);
|
|
842
|
+
}
|
|
843
|
+
// ============================================================================
|
|
844
|
+
// Server Events
|
|
845
|
+
// ============================================================================
|
|
846
|
+
/**
|
|
847
|
+
* Track server run event directly from an MCPServer instance.
|
|
848
|
+
* This extracts the necessary data from the server and creates the event.
|
|
849
|
+
* @param server - The MCPServer instance (or any object conforming to MCPServerTelemetryInfo)
|
|
850
|
+
* @param transport - The transport type (e.g., "http", "stdio", "supabase")
|
|
851
|
+
*/
|
|
852
|
+
async trackServerRunFromServer(server, transport) {
|
|
853
|
+
if (!this.isEnabled) return;
|
|
854
|
+
const data = createServerRunEventData(server, transport);
|
|
855
|
+
const event = new ServerRunEvent(data);
|
|
856
|
+
await this.capture(event);
|
|
857
|
+
}
|
|
858
|
+
async trackServerInitialize(data) {
|
|
859
|
+
if (!this.isEnabled) return;
|
|
860
|
+
const event = new ServerInitializeEvent(data);
|
|
861
|
+
await this.capture(event);
|
|
862
|
+
}
|
|
863
|
+
async trackServerToolCall(data) {
|
|
864
|
+
if (!this.isEnabled) return;
|
|
865
|
+
const event = new ServerToolCallEvent(data);
|
|
866
|
+
await this.capture(event);
|
|
867
|
+
}
|
|
868
|
+
async trackServerResourceCall(data) {
|
|
869
|
+
if (!this.isEnabled) return;
|
|
870
|
+
const event = new ServerResourceCallEvent(data);
|
|
871
|
+
await this.capture(event);
|
|
872
|
+
}
|
|
873
|
+
async trackServerPromptCall(data) {
|
|
874
|
+
if (!this.isEnabled) return;
|
|
875
|
+
const event = new ServerPromptCallEvent(data);
|
|
876
|
+
await this.capture(event);
|
|
877
|
+
}
|
|
878
|
+
async trackServerContext(data) {
|
|
879
|
+
if (!this.isEnabled) return;
|
|
880
|
+
const event = new ServerContextEvent(data);
|
|
881
|
+
await this.capture(event);
|
|
882
|
+
}
|
|
883
|
+
// ============================================================================
|
|
884
|
+
// Client Events
|
|
885
|
+
// ============================================================================
|
|
886
|
+
async trackMCPClientInit(data) {
|
|
887
|
+
if (!this.isEnabled) return;
|
|
888
|
+
const event = new MCPClientInitEvent(data);
|
|
889
|
+
await this.capture(event);
|
|
890
|
+
}
|
|
891
|
+
async trackConnectorInit(data) {
|
|
892
|
+
if (!this.isEnabled) return;
|
|
893
|
+
const event = new ConnectorInitEvent(data);
|
|
894
|
+
await this.capture(event);
|
|
895
|
+
}
|
|
896
|
+
flush() {
|
|
897
|
+
if (this._posthogClient) {
|
|
898
|
+
try {
|
|
899
|
+
this._posthogClient.flush();
|
|
900
|
+
logger.debug("PostHog client telemetry queue flushed");
|
|
901
|
+
} catch (e) {
|
|
902
|
+
logger.debug(`Failed to flush PostHog client: ${e}`);
|
|
903
|
+
}
|
|
904
|
+
}
|
|
905
|
+
if (this._scarfClient) {
|
|
906
|
+
logger.debug("Scarf telemetry events sent immediately (no flush needed)");
|
|
907
|
+
}
|
|
908
|
+
}
|
|
909
|
+
shutdown() {
|
|
910
|
+
if (this._posthogClient) {
|
|
911
|
+
try {
|
|
912
|
+
this._posthogClient.shutdown();
|
|
913
|
+
logger.debug("PostHog client shutdown successfully");
|
|
914
|
+
} catch (e) {
|
|
915
|
+
logger.debug(`Error shutting down PostHog client: ${e}`);
|
|
916
|
+
}
|
|
917
|
+
}
|
|
918
|
+
if (this._scarfClient) {
|
|
919
|
+
logger.debug("Scarf telemetry client shutdown (no action needed)");
|
|
920
|
+
}
|
|
921
|
+
}
|
|
922
|
+
};
|
|
923
|
+
|
|
924
|
+
// src/telemetry/index.ts
|
|
925
|
+
function setTelemetrySource(source) {
|
|
926
|
+
Telemetry.getInstance().setSource(source);
|
|
927
|
+
}
|
|
928
|
+
__name(setTelemetrySource, "setTelemetrySource");
|
|
929
|
+
|
|
930
|
+
export {
|
|
931
|
+
isDeno,
|
|
932
|
+
getEnv,
|
|
933
|
+
getCwd,
|
|
934
|
+
fsHelpers,
|
|
935
|
+
pathHelpers,
|
|
936
|
+
generateUUID,
|
|
937
|
+
VERSION,
|
|
938
|
+
getPackageVersion,
|
|
939
|
+
extractModelInfo,
|
|
940
|
+
Telemetry,
|
|
941
|
+
setTelemetrySource
|
|
942
|
+
};
|