@brizz/sdk 0.1.1 → 0.1.2-rc.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +339 -19
- package/dist/index.cjs +2937 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +178 -0
- package/dist/index.d.ts +177 -12
- package/dist/index.js +2895 -26
- package/dist/index.js.map +1 -1
- package/dist/loader.mjs +72 -0
- package/dist/preload.cjs +2787 -0
- package/dist/preload.cjs.map +1 -0
- package/dist/preload.d.cts +2 -0
- package/dist/preload.d.ts +2 -0
- package/dist/preload.js +2777 -0
- package/dist/preload.js.map +1 -0
- package/package.json +48 -35
- package/dist/index.d.ts.map +0 -1
- package/dist/internal/config.d.ts +0 -17
- package/dist/internal/config.d.ts.map +0 -1
- package/dist/internal/config.js +0 -94
- package/dist/internal/config.js.map +0 -1
- package/dist/internal/instrumentation/auto-init.d.ts +0 -3
- package/dist/internal/instrumentation/auto-init.d.ts.map +0 -1
- package/dist/internal/instrumentation/auto-init.js +0 -87
- package/dist/internal/instrumentation/auto-init.js.map +0 -1
- package/dist/internal/instrumentation/index.d.ts +0 -2
- package/dist/internal/instrumentation/index.d.ts.map +0 -1
- package/dist/internal/instrumentation/index.js +0 -6
- package/dist/internal/instrumentation/index.js.map +0 -1
- package/dist/internal/instrumentation/registry.d.ts +0 -30
- package/dist/internal/instrumentation/registry.d.ts.map +0 -1
- package/dist/internal/instrumentation/registry.js +0 -94
- package/dist/internal/instrumentation/registry.js.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/index.d.ts +0 -4
- package/dist/internal/instrumentation/vercel-ai/index.d.ts.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/index.js +0 -8
- package/dist/internal/instrumentation/vercel-ai/index.js.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/instrumentation.d.ts +0 -16
- package/dist/internal/instrumentation/vercel-ai/instrumentation.d.ts.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/instrumentation.js +0 -119
- package/dist/internal/instrumentation/vercel-ai/instrumentation.js.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/patchers/base-patcher.d.ts +0 -24
- package/dist/internal/instrumentation/vercel-ai/patchers/base-patcher.d.ts.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/patchers/base-patcher.js +0 -57
- package/dist/internal/instrumentation/vercel-ai/patchers/base-patcher.js.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/patchers/embeddings-patcher.d.ts +0 -16
- package/dist/internal/instrumentation/vercel-ai/patchers/embeddings-patcher.d.ts.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/patchers/embeddings-patcher.js +0 -58
- package/dist/internal/instrumentation/vercel-ai/patchers/embeddings-patcher.js.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/patchers/generate-text-patcher.d.ts +0 -8
- package/dist/internal/instrumentation/vercel-ai/patchers/generate-text-patcher.d.ts.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/patchers/generate-text-patcher.js +0 -59
- package/dist/internal/instrumentation/vercel-ai/patchers/generate-text-patcher.js.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/patchers/index.d.ts +0 -5
- package/dist/internal/instrumentation/vercel-ai/patchers/index.d.ts.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/patchers/index.js +0 -12
- package/dist/internal/instrumentation/vercel-ai/patchers/index.js.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/patchers/stream-text-patcher.d.ts +0 -12
- package/dist/internal/instrumentation/vercel-ai/patchers/stream-text-patcher.d.ts.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/patchers/stream-text-patcher.js +0 -41
- package/dist/internal/instrumentation/vercel-ai/patchers/stream-text-patcher.js.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/semconv.d.ts +0 -53
- package/dist/internal/instrumentation/vercel-ai/semconv.d.ts.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/semconv.js +0 -57
- package/dist/internal/instrumentation/vercel-ai/semconv.js.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/stream-handler.d.ts +0 -13
- package/dist/internal/instrumentation/vercel-ai/stream-handler.d.ts.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/stream-handler.js +0 -101
- package/dist/internal/instrumentation/vercel-ai/stream-handler.js.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/telemetry-recorder.d.ts +0 -13
- package/dist/internal/instrumentation/vercel-ai/telemetry-recorder.d.ts.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/telemetry-recorder.js +0 -115
- package/dist/internal/instrumentation/vercel-ai/telemetry-recorder.js.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/types.d.ts +0 -197
- package/dist/internal/instrumentation/vercel-ai/types.d.ts.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/types.js +0 -3
- package/dist/internal/instrumentation/vercel-ai/types.js.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/utils.d.ts +0 -14
- package/dist/internal/instrumentation/vercel-ai/utils.d.ts.map +0 -1
- package/dist/internal/instrumentation/vercel-ai/utils.js +0 -243
- package/dist/internal/instrumentation/vercel-ai/utils.js.map +0 -1
- package/dist/internal/log/index.d.ts +0 -2
- package/dist/internal/log/index.d.ts.map +0 -1
- package/dist/internal/log/index.js +0 -7
- package/dist/internal/log/index.js.map +0 -1
- package/dist/internal/log/logging.d.ts +0 -21
- package/dist/internal/log/logging.d.ts.map +0 -1
- package/dist/internal/log/logging.js +0 -154
- package/dist/internal/log/logging.js.map +0 -1
- package/dist/internal/logger.d.ts +0 -23
- package/dist/internal/logger.d.ts.map +0 -1
- package/dist/internal/logger.js +0 -163
- package/dist/internal/logger.js.map +0 -1
- package/dist/internal/masking/index.d.ts +0 -4
- package/dist/internal/masking/index.d.ts.map +0 -1
- package/dist/internal/masking/index.js +0 -9
- package/dist/internal/masking/index.js.map +0 -1
- package/dist/internal/masking/patterns.d.ts +0 -3
- package/dist/internal/masking/patterns.d.ts.map +0 -1
- package/dist/internal/masking/patterns.js +0 -378
- package/dist/internal/masking/patterns.js.map +0 -1
- package/dist/internal/masking/types.d.ts +0 -33
- package/dist/internal/masking/types.d.ts.map +0 -1
- package/dist/internal/masking/types.js +0 -3
- package/dist/internal/masking/types.js.map +0 -1
- package/dist/internal/masking/utils.d.ts +0 -6
- package/dist/internal/masking/utils.d.ts.map +0 -1
- package/dist/internal/masking/utils.js +0 -232
- package/dist/internal/masking/utils.js.map +0 -1
- package/dist/internal/metric/index.d.ts +0 -2
- package/dist/internal/metric/index.d.ts.map +0 -1
- package/dist/internal/metric/index.js +0 -8
- package/dist/internal/metric/index.js.map +0 -1
- package/dist/internal/metric/metrics.d.ts +0 -18
- package/dist/internal/metric/metrics.d.ts.map +0 -1
- package/dist/internal/metric/metrics.js +0 -88
- package/dist/internal/metric/metrics.js.map +0 -1
- package/dist/internal/sdk.d.ts +0 -36
- package/dist/internal/sdk.d.ts.map +0 -1
- package/dist/internal/sdk.js +0 -159
- package/dist/internal/sdk.js.map +0 -1
- package/dist/internal/trace/index.d.ts +0 -3
- package/dist/internal/trace/index.d.ts.map +0 -1
- package/dist/internal/trace/index.js +0 -11
- package/dist/internal/trace/index.js.map +0 -1
- package/dist/internal/trace/processors/log-masked.d.ts +0 -16
- package/dist/internal/trace/processors/log-masked.d.ts.map +0 -1
- package/dist/internal/trace/processors/log-masked.js +0 -81
- package/dist/internal/trace/processors/log-masked.js.map +0 -1
- package/dist/internal/trace/processors/span-masked.d.ts +0 -16
- package/dist/internal/trace/processors/span-masked.d.ts.map +0 -1
- package/dist/internal/trace/processors/span-masked.js +0 -87
- package/dist/internal/trace/processors/span-masked.js.map +0 -1
- package/dist/internal/trace/tracing.d.ts +0 -18
- package/dist/internal/trace/tracing.d.ts.map +0 -1
- package/dist/internal/trace/tracing.js +0 -103
- package/dist/internal/trace/tracing.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/internal/config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAEvD,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,UAAU,CAAC;AAExD,OAAO,EAAU,QAAQ,EAA8B,MAAM,UAAU,CAAC;AACxE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAEhD,MAAM,WAAW,oBAAqB,SAAQ,IAAI,CAAC,uBAAuB,EAAE,SAAS,CAAC;IACpF,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChC,YAAY,EAAE,OAAO,CAAC;IACtB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,QAAQ,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IACzB,OAAO,CAAC,EAAE,cAAc,CAAC;CAC1B;AAED,wBAAgB,aAAa,CAAC,OAAO,EAAE,uBAAuB,GAAG,oBAAoB,CA8FpF;AAGD,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,uBAAuB,GAAG,oBAAoB,CAE/F"}
|
package/dist/internal/config.js
DELETED
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.resolveConfig = resolveConfig;
|
|
4
|
-
exports.processEnvironmentConfig = processEnvironmentConfig;
|
|
5
|
-
const logger_1 = require("./logger");
|
|
6
|
-
function resolveConfig(options) {
|
|
7
|
-
const envLogLevel = process.env['BRIZZ_LOG_LEVEL'] || options.logLevel?.toString() || 'info';
|
|
8
|
-
let resolvedLogLevel;
|
|
9
|
-
if (envLogLevel) {
|
|
10
|
-
resolvedLogLevel = (0, logger_1.parseLogLevel)(envLogLevel);
|
|
11
|
-
}
|
|
12
|
-
else if (typeof options.logLevel === 'string') {
|
|
13
|
-
resolvedLogLevel = (0, logger_1.parseLogLevel)(options.logLevel);
|
|
14
|
-
}
|
|
15
|
-
else {
|
|
16
|
-
resolvedLogLevel = options.logLevel || logger_1.LogLevel.NONE;
|
|
17
|
-
}
|
|
18
|
-
(0, logger_1.setLogLevel)(resolvedLogLevel);
|
|
19
|
-
let maskingStatus;
|
|
20
|
-
if (options.masking === true) {
|
|
21
|
-
maskingStatus = 'enabled';
|
|
22
|
-
}
|
|
23
|
-
else if (options.masking === false) {
|
|
24
|
-
maskingStatus = 'disabled';
|
|
25
|
-
}
|
|
26
|
-
else if (typeof options.masking === 'object') {
|
|
27
|
-
maskingStatus = 'custom';
|
|
28
|
-
}
|
|
29
|
-
else {
|
|
30
|
-
maskingStatus = 'default-disabled';
|
|
31
|
-
}
|
|
32
|
-
logger_1.logger.debug('Starting configuration resolution', {
|
|
33
|
-
appName: options.appName,
|
|
34
|
-
baseUrl: options.baseUrl,
|
|
35
|
-
hasApiKey: !!options.apiKey,
|
|
36
|
-
disableBatch: options.disableBatch,
|
|
37
|
-
logLevel: resolvedLogLevel,
|
|
38
|
-
headersCount: Object.keys(options.headers || {}).length,
|
|
39
|
-
masking: maskingStatus,
|
|
40
|
-
});
|
|
41
|
-
let resolvedMasking;
|
|
42
|
-
if (options.masking === true) {
|
|
43
|
-
resolvedMasking = {
|
|
44
|
-
spanMasking: {},
|
|
45
|
-
eventMasking: {},
|
|
46
|
-
};
|
|
47
|
-
}
|
|
48
|
-
else if (options.masking && typeof options.masking === 'object') {
|
|
49
|
-
resolvedMasking = options.masking;
|
|
50
|
-
}
|
|
51
|
-
const resolvedConfig = {
|
|
52
|
-
...options,
|
|
53
|
-
appName: process.env['BRIZZ_APP_NAME'] || options.appName || 'unknown-app',
|
|
54
|
-
baseUrl: process.env['BRIZZ_BASE_URL'] || options.baseUrl || 'https://telemetry.brizz.dev',
|
|
55
|
-
headers: { ...options.headers },
|
|
56
|
-
apiKey: process.env['BRIZZ_API_KEY'] || options.apiKey,
|
|
57
|
-
disableBatch: process.env['BRIZZ_DISABLE_BATCH'] === 'true' || !!options.disableBatch,
|
|
58
|
-
logLevel: resolvedLogLevel,
|
|
59
|
-
masking: resolvedMasking,
|
|
60
|
-
};
|
|
61
|
-
if (resolvedConfig.apiKey) {
|
|
62
|
-
resolvedConfig.headers['Authorization'] = `Bearer ${resolvedConfig.apiKey}`;
|
|
63
|
-
}
|
|
64
|
-
if (process.env['BRIZZ_HEADERS']) {
|
|
65
|
-
try {
|
|
66
|
-
const envHeaders = JSON.parse(process.env['BRIZZ_HEADERS']);
|
|
67
|
-
Object.assign(resolvedConfig.headers, envHeaders);
|
|
68
|
-
logger_1.logger.debug('Added headers from environment variable', {
|
|
69
|
-
headers: Object.keys(envHeaders),
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
catch (error) {
|
|
73
|
-
logger_1.logger.error('Failed to parse BRIZZ_HEADERS environment variable', { error });
|
|
74
|
-
throw new Error('Invalid JSON in BRIZZ_HEADERS environment variable');
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
logger_1.logger.debug('Configuration resolved with environment variables', {
|
|
78
|
-
appName: resolvedConfig.appName,
|
|
79
|
-
baseUrl: resolvedConfig.baseUrl,
|
|
80
|
-
hasApiKey: !!resolvedConfig.apiKey,
|
|
81
|
-
disableBatch: resolvedConfig.disableBatch,
|
|
82
|
-
envOverrides: {
|
|
83
|
-
hasEnvApiKey: !!process.env['BRIZZ_API_KEY'],
|
|
84
|
-
hasEnvBaseUrl: !!process.env['BRIZZ_BASE_URL'],
|
|
85
|
-
hasEnvBatch: !!process.env['BRIZZ_DISABLE_BATCH'],
|
|
86
|
-
hasEnvHeaders: !!process.env['BRIZZ_HEADERS'],
|
|
87
|
-
},
|
|
88
|
-
});
|
|
89
|
-
return resolvedConfig;
|
|
90
|
-
}
|
|
91
|
-
function processEnvironmentConfig(options) {
|
|
92
|
-
return resolveConfig(options);
|
|
93
|
-
}
|
|
94
|
-
//# sourceMappingURL=config.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/internal/config.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auto-init.d.ts","sourceRoot":"","sources":["../../../src/internal/instrumentation/auto-init.ts"],"names":[],"mappings":"AA2BA,QAAA,IAAI,0BAA0B,SAAQ,CAAC;AAqGvC,OAAO,EAAE,0BAA0B,EAAE,CAAC"}
|
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.autoInstrumentationsLoaded = void 0;
|
|
4
|
-
const auto_instrumentations_node_1 = require("@opentelemetry/auto-instrumentations-node");
|
|
5
|
-
const instrumentation_1 = require("@opentelemetry/instrumentation");
|
|
6
|
-
const instrumentation_anthropic_1 = require("@traceloop/instrumentation-anthropic");
|
|
7
|
-
const instrumentation_bedrock_1 = require("@traceloop/instrumentation-bedrock");
|
|
8
|
-
const instrumentation_chromadb_1 = require("@traceloop/instrumentation-chromadb");
|
|
9
|
-
const instrumentation_cohere_1 = require("@traceloop/instrumentation-cohere");
|
|
10
|
-
const instrumentation_langchain_1 = require("@traceloop/instrumentation-langchain");
|
|
11
|
-
const instrumentation_llamaindex_1 = require("@traceloop/instrumentation-llamaindex");
|
|
12
|
-
const instrumentation_openai_1 = require("@traceloop/instrumentation-openai");
|
|
13
|
-
const instrumentation_pinecone_1 = require("@traceloop/instrumentation-pinecone");
|
|
14
|
-
const instrumentation_qdrant_1 = require("@traceloop/instrumentation-qdrant");
|
|
15
|
-
const instrumentation_together_1 = require("@traceloop/instrumentation-together");
|
|
16
|
-
const instrumentation_vertexai_1 = require("@traceloop/instrumentation-vertexai");
|
|
17
|
-
const vercel_ai_1 = require("./vercel-ai");
|
|
18
|
-
let autoInstrumentationsLoaded = false;
|
|
19
|
-
exports.autoInstrumentationsLoaded = autoInstrumentationsLoaded;
|
|
20
|
-
function loadNodeAutoInstrumentations() {
|
|
21
|
-
try {
|
|
22
|
-
const nodeInstrumentations = (0, auto_instrumentations_node_1.getNodeAutoInstrumentations)();
|
|
23
|
-
(0, instrumentation_1.registerInstrumentations)({ instrumentations: nodeInstrumentations });
|
|
24
|
-
return nodeInstrumentations;
|
|
25
|
-
}
|
|
26
|
-
catch (error) {
|
|
27
|
-
console.error(`[Brizz] Failed to load Node.js auto-instrumentations: ${String(error)}`);
|
|
28
|
-
return [];
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
function loadGenAIInstrumentations() {
|
|
32
|
-
const { logger } = require('../logger');
|
|
33
|
-
const instrumentations = [];
|
|
34
|
-
const exceptionLogger = (error) => {
|
|
35
|
-
logger.error(`Exception in instrumentation: ${String(error)}`);
|
|
36
|
-
};
|
|
37
|
-
const genAIInstrumentationClasses = [
|
|
38
|
-
{ class: vercel_ai_1.VercelAIInstrumentation, name: 'Vercel AI' },
|
|
39
|
-
{ class: instrumentation_openai_1.OpenAIInstrumentation, name: 'OpenAI' },
|
|
40
|
-
{ class: instrumentation_anthropic_1.AnthropicInstrumentation, name: 'Anthropic' },
|
|
41
|
-
{ class: instrumentation_cohere_1.CohereInstrumentation, name: 'Cohere' },
|
|
42
|
-
{ class: instrumentation_vertexai_1.VertexAIInstrumentation, name: 'Vertex AI' },
|
|
43
|
-
{ class: instrumentation_bedrock_1.BedrockInstrumentation, name: 'Bedrock' },
|
|
44
|
-
{ class: instrumentation_pinecone_1.PineconeInstrumentation, name: 'Pinecone' },
|
|
45
|
-
{ class: instrumentation_langchain_1.LangChainInstrumentation, name: 'LangChain' },
|
|
46
|
-
{ class: instrumentation_llamaindex_1.LlamaIndexInstrumentation, name: 'LlamaIndex' },
|
|
47
|
-
{ class: instrumentation_chromadb_1.ChromaDBInstrumentation, name: 'ChromaDB' },
|
|
48
|
-
{ class: instrumentation_qdrant_1.QdrantInstrumentation, name: 'Qdrant' },
|
|
49
|
-
{ class: instrumentation_together_1.TogetherInstrumentation, name: 'Together' },
|
|
50
|
-
];
|
|
51
|
-
for (const config of genAIInstrumentationClasses) {
|
|
52
|
-
try {
|
|
53
|
-
const instrumentation = new config.class({ exceptionLogger });
|
|
54
|
-
instrumentations.push(instrumentation);
|
|
55
|
-
logger.debug(`Auto-loaded ${config.name} instrumentation`);
|
|
56
|
-
}
|
|
57
|
-
catch (error) {
|
|
58
|
-
logger.error(`Failed to auto-load ${config.name} instrumentation: ${String(error)}`);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
try {
|
|
62
|
-
(0, instrumentation_1.registerInstrumentations)({ instrumentations });
|
|
63
|
-
logger.info(`Auto-registered ${instrumentations.length} GenAI instrumentations`);
|
|
64
|
-
}
|
|
65
|
-
catch (error) {
|
|
66
|
-
logger.error(`Failed to register GenAI instrumentations: ${String(error)}`);
|
|
67
|
-
}
|
|
68
|
-
return instrumentations;
|
|
69
|
-
}
|
|
70
|
-
function autoInitializeInstrumentations() {
|
|
71
|
-
if (autoInstrumentationsLoaded) {
|
|
72
|
-
return;
|
|
73
|
-
}
|
|
74
|
-
try {
|
|
75
|
-
const nodeInstrumentations = loadNodeAutoInstrumentations();
|
|
76
|
-
const genAIInstrumentations = loadGenAIInstrumentations();
|
|
77
|
-
exports.autoInstrumentationsLoaded = autoInstrumentationsLoaded = true;
|
|
78
|
-
const { logger } = require('../logger');
|
|
79
|
-
logger.info(`Auto-initialization complete: ${nodeInstrumentations.length} node + ${genAIInstrumentations.length} GenAI instrumentations`);
|
|
80
|
-
}
|
|
81
|
-
catch (error) {
|
|
82
|
-
console.error(`[Brizz] Auto-initialization failed: ${String(error)}`);
|
|
83
|
-
exports.autoInstrumentationsLoaded = autoInstrumentationsLoaded = false;
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
autoInitializeInstrumentations();
|
|
87
|
-
//# sourceMappingURL=auto-init.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auto-init.js","sourceRoot":"","sources":["../../../src/internal/instrumentation/auto-init.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/internal/instrumentation/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,KAAK,kBAAkB,EAAE,MAAM,YAAY,CAAC"}
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.InstrumentationRegistry = void 0;
|
|
4
|
-
var registry_1 = require("./registry");
|
|
5
|
-
Object.defineProperty(exports, "InstrumentationRegistry", { enumerable: true, get: function () { return registry_1.InstrumentationRegistry; } });
|
|
6
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/internal/instrumentation/index.ts"],"names":[],"mappings":";;;AAAA,uCAA8E;AAArE,mHAAA,uBAAuB,OAAA"}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import type { Instrumentation } from '@opentelemetry/instrumentation';
|
|
2
|
-
export interface IInstrumentModules {
|
|
3
|
-
openAI?: unknown;
|
|
4
|
-
anthropic?: unknown;
|
|
5
|
-
cohere?: unknown;
|
|
6
|
-
google_vertexai?: unknown;
|
|
7
|
-
google_aiplatform?: unknown;
|
|
8
|
-
bedrock?: unknown;
|
|
9
|
-
pinecone?: unknown;
|
|
10
|
-
langchain?: {
|
|
11
|
-
chains?: unknown;
|
|
12
|
-
agents?: unknown;
|
|
13
|
-
tools?: unknown;
|
|
14
|
-
};
|
|
15
|
-
llamaindex?: unknown;
|
|
16
|
-
chromadb?: unknown;
|
|
17
|
-
qdrant?: unknown;
|
|
18
|
-
together?: unknown;
|
|
19
|
-
vercelAI?: unknown;
|
|
20
|
-
}
|
|
21
|
-
export declare class InstrumentationRegistry {
|
|
22
|
-
private static instance;
|
|
23
|
-
private manualModules;
|
|
24
|
-
static getInstance(): InstrumentationRegistry;
|
|
25
|
-
setManualModules(modules: IInstrumentModules): void;
|
|
26
|
-
private loadInstrumentation;
|
|
27
|
-
getManualInstrumentations(): Instrumentation[];
|
|
28
|
-
private loadManualInstrumentations;
|
|
29
|
-
}
|
|
30
|
-
//# sourceMappingURL=registry.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../../src/internal/instrumentation/registry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AAqBtE,MAAM,WAAW,kBAAkB;IACjC,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE;QACV,MAAM,CAAC,EAAE,OAAO,CAAC;QACjB,MAAM,CAAC,EAAE,OAAO,CAAC;QACjB,KAAK,CAAC,EAAE,OAAO,CAAC;KACjB,CAAC;IACF,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAQD,qBAAa,uBAAuB;IAClC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAA0B;IACjD,OAAO,CAAC,aAAa,CAAmC;WAE1C,WAAW,IAAI,uBAAuB;IAU7C,gBAAgB,CAAC,OAAO,EAAE,kBAAkB,GAAG,IAAI;IAQ1D,OAAO,CAAC,mBAAmB;IA4BpB,yBAAyB,IAAI,eAAe,EAAE;IAqBrD,OAAO,CAAC,0BAA0B;CA0CnC"}
|
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.InstrumentationRegistry = void 0;
|
|
4
|
-
const instrumentation_anthropic_1 = require("@traceloop/instrumentation-anthropic");
|
|
5
|
-
const instrumentation_bedrock_1 = require("@traceloop/instrumentation-bedrock");
|
|
6
|
-
const instrumentation_chromadb_1 = require("@traceloop/instrumentation-chromadb");
|
|
7
|
-
const instrumentation_cohere_1 = require("@traceloop/instrumentation-cohere");
|
|
8
|
-
const instrumentation_langchain_1 = require("@traceloop/instrumentation-langchain");
|
|
9
|
-
const instrumentation_llamaindex_1 = require("@traceloop/instrumentation-llamaindex");
|
|
10
|
-
const instrumentation_openai_1 = require("@traceloop/instrumentation-openai");
|
|
11
|
-
const instrumentation_pinecone_1 = require("@traceloop/instrumentation-pinecone");
|
|
12
|
-
const instrumentation_qdrant_1 = require("@traceloop/instrumentation-qdrant");
|
|
13
|
-
const instrumentation_together_1 = require("@traceloop/instrumentation-together");
|
|
14
|
-
const instrumentation_vertexai_1 = require("@traceloop/instrumentation-vertexai");
|
|
15
|
-
const logger_1 = require("../logger");
|
|
16
|
-
const vercel_ai_1 = require("./vercel-ai");
|
|
17
|
-
class InstrumentationRegistry {
|
|
18
|
-
static instance;
|
|
19
|
-
manualModules = null;
|
|
20
|
-
static getInstance() {
|
|
21
|
-
if (!InstrumentationRegistry.instance) {
|
|
22
|
-
InstrumentationRegistry.instance = new InstrumentationRegistry();
|
|
23
|
-
}
|
|
24
|
-
return InstrumentationRegistry.instance;
|
|
25
|
-
}
|
|
26
|
-
setManualModules(modules) {
|
|
27
|
-
this.manualModules = modules;
|
|
28
|
-
logger_1.logger.info('Manual instrumentation modules configured for Next.js/Webpack compatibility');
|
|
29
|
-
}
|
|
30
|
-
loadInstrumentation(InstrumentationClass, name, manualModule, exceptionLogger) {
|
|
31
|
-
try {
|
|
32
|
-
const inst = new InstrumentationClass({
|
|
33
|
-
exceptionLogger: exceptionLogger ||
|
|
34
|
-
((error) => logger_1.logger.error(`Exception in instrumentation: ${String(error)}`)),
|
|
35
|
-
});
|
|
36
|
-
if (manualModule) {
|
|
37
|
-
inst.manuallyInstrument(manualModule);
|
|
38
|
-
logger_1.logger.debug(`Manual instrumentation enabled for ${name}`);
|
|
39
|
-
}
|
|
40
|
-
return inst;
|
|
41
|
-
}
|
|
42
|
-
catch (error) {
|
|
43
|
-
logger_1.logger.error(`Failed to load ${name} instrumentation: ${String(error)}`);
|
|
44
|
-
return null;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
getManualInstrumentations() {
|
|
48
|
-
if (!this.manualModules || Object.keys(this.manualModules).length === 0) {
|
|
49
|
-
logger_1.logger.debug('No manual instrumentation modules configured');
|
|
50
|
-
return [];
|
|
51
|
-
}
|
|
52
|
-
const instrumentations = [];
|
|
53
|
-
const exceptionLogger = (error) => {
|
|
54
|
-
logger_1.logger.error(`Exception in manual instrumentation: ${String(error)}`);
|
|
55
|
-
};
|
|
56
|
-
this.loadManualInstrumentations(instrumentations, exceptionLogger);
|
|
57
|
-
logger_1.logger.info(`Loaded ${instrumentations.length} manual instrumentations`);
|
|
58
|
-
return instrumentations;
|
|
59
|
-
}
|
|
60
|
-
loadManualInstrumentations(instrumentations, exceptionLogger) {
|
|
61
|
-
const instrumentationConfigs = [
|
|
62
|
-
{ class: instrumentation_openai_1.OpenAIInstrumentation, name: 'OpenAI', module: this.manualModules?.openAI },
|
|
63
|
-
{ class: instrumentation_anthropic_1.AnthropicInstrumentation, name: 'Anthropic', module: this.manualModules?.anthropic },
|
|
64
|
-
{ class: instrumentation_cohere_1.CohereInstrumentation, name: 'Cohere', module: this.manualModules?.cohere },
|
|
65
|
-
{
|
|
66
|
-
class: instrumentation_vertexai_1.VertexAIInstrumentation,
|
|
67
|
-
name: 'Vertex AI',
|
|
68
|
-
module: this.manualModules?.google_vertexai,
|
|
69
|
-
},
|
|
70
|
-
{ class: instrumentation_bedrock_1.BedrockInstrumentation, name: 'Bedrock', module: this.manualModules?.bedrock },
|
|
71
|
-
{ class: instrumentation_pinecone_1.PineconeInstrumentation, name: 'Pinecone', module: this.manualModules?.pinecone },
|
|
72
|
-
{ class: instrumentation_langchain_1.LangChainInstrumentation, name: 'LangChain', module: this.manualModules?.langchain },
|
|
73
|
-
{
|
|
74
|
-
class: instrumentation_llamaindex_1.LlamaIndexInstrumentation,
|
|
75
|
-
name: 'LlamaIndex',
|
|
76
|
-
module: this.manualModules?.llamaindex,
|
|
77
|
-
},
|
|
78
|
-
{ class: instrumentation_chromadb_1.ChromaDBInstrumentation, name: 'ChromaDB', module: this.manualModules?.chromadb },
|
|
79
|
-
{ class: instrumentation_qdrant_1.QdrantInstrumentation, name: 'Qdrant', module: this.manualModules?.qdrant },
|
|
80
|
-
{ class: instrumentation_together_1.TogetherInstrumentation, name: 'Together', module: this.manualModules?.together },
|
|
81
|
-
{ class: vercel_ai_1.VercelAIInstrumentation, name: 'Vercel AI', module: this.manualModules?.vercelAI },
|
|
82
|
-
];
|
|
83
|
-
for (const config of instrumentationConfigs) {
|
|
84
|
-
if (config.module) {
|
|
85
|
-
const instrumentation = this.loadInstrumentation(config.class, config.name, config.module, exceptionLogger);
|
|
86
|
-
if (instrumentation) {
|
|
87
|
-
instrumentations.push(instrumentation);
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
exports.InstrumentationRegistry = InstrumentationRegistry;
|
|
94
|
-
//# sourceMappingURL=registry.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"registry.js","sourceRoot":"","sources":["../../../src/internal/instrumentation/registry.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/internal/instrumentation/vercel-ai/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,mBAAmB,CAAC;AAC5D,YAAY,EAAE,6BAA6B,EAAE,MAAM,SAAS,CAAC;AAC7D,cAAc,WAAW,CAAC"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.VercelAIInstrumentation = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
|
-
var instrumentation_1 = require("./instrumentation");
|
|
6
|
-
Object.defineProperty(exports, "VercelAIInstrumentation", { enumerable: true, get: function () { return instrumentation_1.VercelAIInstrumentation; } });
|
|
7
|
-
tslib_1.__exportStar(require("./semconv"), exports);
|
|
8
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/internal/instrumentation/vercel-ai/index.ts"],"names":[],"mappings":";;;;AAAA,qDAA4D;AAAnD,0HAAA,uBAAuB,OAAA;AAEhC,oDAA0B"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { InstrumentationBase, InstrumentationNodeModuleDefinition } from '@opentelemetry/instrumentation';
|
|
2
|
-
import type { VercelAIInstrumentationConfig } from './types';
|
|
3
|
-
export declare class VercelAIInstrumentation extends InstrumentationBase<VercelAIInstrumentationConfig> {
|
|
4
|
-
private _genaiClientOperationDuration;
|
|
5
|
-
private _genaiClientTokenUsage;
|
|
6
|
-
private _telemetryRecorder;
|
|
7
|
-
private _streamHandler;
|
|
8
|
-
private _patchers;
|
|
9
|
-
constructor(config?: VercelAIInstrumentationConfig);
|
|
10
|
-
setConfig(config?: VercelAIInstrumentationConfig): void;
|
|
11
|
-
private _initializeComponents;
|
|
12
|
-
protected init(): InstrumentationNodeModuleDefinition[];
|
|
13
|
-
_updateMetricInstruments(): void;
|
|
14
|
-
private _createProxiedFunction;
|
|
15
|
-
}
|
|
16
|
-
//# sourceMappingURL=instrumentation.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"instrumentation.d.ts","sourceRoot":"","sources":["../../../../src/internal/instrumentation/vercel-ai/instrumentation.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,mCAAmC,EAAE,MAAM,gCAAgC,CAAC;AAe1G,OAAO,KAAK,EAAE,6BAA6B,EAAE,MAAM,SAAS,CAAC;AAoB7D,qBAAa,uBAAwB,SAAQ,mBAAmB,CAAC,6BAA6B,CAAC;IAC7F,OAAO,CAAC,6BAA6B,CAAa;IAClD,OAAO,CAAC,sBAAsB,CAAa;IAC3C,OAAO,CAAC,kBAAkB,CAAqB;IAC/C,OAAO,CAAC,cAAc,CAAiB;IACvC,OAAO,CAAC,SAAS,CAAuC;gBAE5C,MAAM,GAAE,6BAAkC;IAa7C,SAAS,CAAC,MAAM,GAAE,6BAAkC,GAAG,IAAI;IAgBpE,OAAO,CAAC,qBAAqB;IAiC7B,SAAS,CAAC,IAAI,IAAI,mCAAmC,EAAE;IAoC9C,wBAAwB,IAAI,IAAI;IAwCzC,OAAO,CAAC,sBAAsB;CAyB/B"}
|
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.VercelAIInstrumentation = void 0;
|
|
4
|
-
const instrumentation_1 = require("@opentelemetry/instrumentation");
|
|
5
|
-
const patchers_1 = require("./patchers");
|
|
6
|
-
const semconv_1 = require("./semconv");
|
|
7
|
-
const stream_handler_1 = require("./stream-handler");
|
|
8
|
-
const telemetry_recorder_1 = require("./telemetry-recorder");
|
|
9
|
-
const utils_1 = require("./utils");
|
|
10
|
-
const PACKAGE_NAME = '@brizz/vercel-ai-instrumentation';
|
|
11
|
-
const PACKAGE_VERSION = '0.1.0';
|
|
12
|
-
class VercelAIInstrumentation extends instrumentation_1.InstrumentationBase {
|
|
13
|
-
_genaiClientOperationDuration;
|
|
14
|
-
_genaiClientTokenUsage;
|
|
15
|
-
_telemetryRecorder;
|
|
16
|
-
_streamHandler;
|
|
17
|
-
_patchers = new Map();
|
|
18
|
-
constructor(config = {}) {
|
|
19
|
-
super(PACKAGE_NAME, PACKAGE_VERSION, config);
|
|
20
|
-
const cfg = this.getConfig();
|
|
21
|
-
const envCC = (0, utils_1.getEnvBool)('OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT');
|
|
22
|
-
if (envCC !== undefined) {
|
|
23
|
-
cfg.captureMessageContent = envCC;
|
|
24
|
-
}
|
|
25
|
-
this._initializeComponents();
|
|
26
|
-
}
|
|
27
|
-
setConfig(config = {}) {
|
|
28
|
-
const { captureMessageContent = true, enableMetrics = true, emitEvents = true, ...validConfig } = config;
|
|
29
|
-
const fullConfig = {
|
|
30
|
-
...validConfig,
|
|
31
|
-
captureMessageContent,
|
|
32
|
-
enableMetrics,
|
|
33
|
-
emitEvents,
|
|
34
|
-
};
|
|
35
|
-
super.setConfig(fullConfig);
|
|
36
|
-
}
|
|
37
|
-
_initializeComponents() {
|
|
38
|
-
this._telemetryRecorder = new telemetry_recorder_1.TelemetryRecorder(this._genaiClientOperationDuration, this._genaiClientTokenUsage, this.logger);
|
|
39
|
-
this._streamHandler = new stream_handler_1.StreamHandler({
|
|
40
|
-
recordTokenMetrics: this._telemetryRecorder.recordTokenMetrics.bind(this._telemetryRecorder),
|
|
41
|
-
recordDurationMetric: this._telemetryRecorder.recordDurationMetric.bind(this._telemetryRecorder),
|
|
42
|
-
});
|
|
43
|
-
const patcherContext = {
|
|
44
|
-
tracer: this.tracer,
|
|
45
|
-
getConfig: this.getConfig.bind(this),
|
|
46
|
-
recordTokenMetrics: this._telemetryRecorder.recordTokenMetrics.bind(this._telemetryRecorder),
|
|
47
|
-
recordDurationMetric: this._telemetryRecorder.recordDurationMetric.bind(this._telemetryRecorder),
|
|
48
|
-
emitMessageEvents: this._telemetryRecorder.emitMessageEvents.bind(this._telemetryRecorder),
|
|
49
|
-
emitAssistantMessageEvent: this._telemetryRecorder.emitAssistantMessageEvent.bind(this._telemetryRecorder),
|
|
50
|
-
};
|
|
51
|
-
this._patchers.set('generateText', new patchers_1.GenerateTextPatcher(patcherContext));
|
|
52
|
-
this._patchers.set('streamText', new patchers_1.StreamTextPatcher(patcherContext, this._streamHandler));
|
|
53
|
-
this._patchers.set('embed', new patchers_1.EmbeddingsPatcher(patcherContext));
|
|
54
|
-
this._patchers.set('embedMany', new patchers_1.EmbeddingsPatcher(patcherContext));
|
|
55
|
-
}
|
|
56
|
-
init() {
|
|
57
|
-
return [
|
|
58
|
-
new instrumentation_1.InstrumentationNodeModuleDefinition('ai', ['>=5.0.0 <6'], (moduleExports) => {
|
|
59
|
-
this._diag.info('Starting instrumentation of Vercel AI SDK module');
|
|
60
|
-
const proxiedModule = new Proxy(moduleExports, {
|
|
61
|
-
get: (target, prop, receiver) => {
|
|
62
|
-
const originalValue = Reflect.get(target, prop, receiver);
|
|
63
|
-
if (typeof originalValue === 'function' && typeof prop === 'string' && this._patchers.has(prop)) {
|
|
64
|
-
return this._createProxiedFunction(originalValue, prop);
|
|
65
|
-
}
|
|
66
|
-
return originalValue;
|
|
67
|
-
},
|
|
68
|
-
});
|
|
69
|
-
return proxiedModule;
|
|
70
|
-
}, (moduleExports) => {
|
|
71
|
-
this._diag.debug('Uninstrumenting @vercel/ai module');
|
|
72
|
-
return moduleExports;
|
|
73
|
-
}),
|
|
74
|
-
];
|
|
75
|
-
}
|
|
76
|
-
_updateMetricInstruments() {
|
|
77
|
-
const config = this.getConfig();
|
|
78
|
-
if (!config.enableMetrics) {
|
|
79
|
-
return;
|
|
80
|
-
}
|
|
81
|
-
this._genaiClientOperationDuration = this.meter.createHistogram(semconv_1.METRIC_GEN_AI_CLIENT_OPERATION_DURATION, {
|
|
82
|
-
description: 'GenAI operation duration',
|
|
83
|
-
unit: 's',
|
|
84
|
-
advice: {
|
|
85
|
-
explicitBucketBoundaries: [
|
|
86
|
-
0.01, 0.02, 0.04, 0.08, 0.16, 0.32, 0.64, 1.28, 2.56, 5.12, 10.24, 20.48, 40.96, 81.92,
|
|
87
|
-
],
|
|
88
|
-
},
|
|
89
|
-
});
|
|
90
|
-
this._genaiClientTokenUsage = this.meter.createHistogram(semconv_1.METRIC_GEN_AI_CLIENT_TOKEN_USAGE, {
|
|
91
|
-
description: 'Measures number of input and output tokens used',
|
|
92
|
-
unit: '{token}',
|
|
93
|
-
advice: {
|
|
94
|
-
explicitBucketBoundaries: [
|
|
95
|
-
1, 4, 16, 64, 256, 1024, 4096, 16_384, 65_536, 262_144, 1_048_576, 4_194_304, 16_777_216, 67_108_864,
|
|
96
|
-
],
|
|
97
|
-
},
|
|
98
|
-
});
|
|
99
|
-
this._telemetryRecorder = new telemetry_recorder_1.TelemetryRecorder(this._genaiClientOperationDuration, this._genaiClientTokenUsage, this.logger);
|
|
100
|
-
}
|
|
101
|
-
_createProxiedFunction(originalFunction, functionName) {
|
|
102
|
-
return ((...args) => {
|
|
103
|
-
if (!this.isEnabled()) {
|
|
104
|
-
return originalFunction(...args);
|
|
105
|
-
}
|
|
106
|
-
const patcher = this._patchers.get(functionName);
|
|
107
|
-
if (!patcher) {
|
|
108
|
-
return originalFunction(...args);
|
|
109
|
-
}
|
|
110
|
-
const isEmbedMany = functionName === 'embedMany';
|
|
111
|
-
const patchedFunction = isEmbedMany
|
|
112
|
-
? patcher.patch(originalFunction, true)
|
|
113
|
-
: patcher.patch(originalFunction);
|
|
114
|
-
return patchedFunction(...args);
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
exports.VercelAIInstrumentation = VercelAIInstrumentation;
|
|
119
|
-
//# sourceMappingURL=instrumentation.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"instrumentation.js","sourceRoot":"","sources":["../../../../src/internal/instrumentation/vercel-ai/instrumentation.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import type { Span, Tracer } from '@opentelemetry/api';
|
|
2
|
-
import type { VercelAIInstrumentationConfig, GenerationParams, ProviderInfo, AIMessage } from '../types';
|
|
3
|
-
export interface IPatcherContext {
|
|
4
|
-
tracer: Tracer;
|
|
5
|
-
getConfig: () => VercelAIInstrumentationConfig;
|
|
6
|
-
recordTokenMetrics: (usage: any, system: string, model: string) => void;
|
|
7
|
-
recordDurationMetric: (duration: number, system: string, model: string, operation: string) => void;
|
|
8
|
-
emitMessageEvents: (messages: AIMessage[], system: string, span: Span) => void;
|
|
9
|
-
emitAssistantMessageEvent: (text: string, system: string, span: Span) => void;
|
|
10
|
-
}
|
|
11
|
-
export type PatcherContext = IPatcherContext;
|
|
12
|
-
export declare abstract class BasePatcher {
|
|
13
|
-
protected context: PatcherContext;
|
|
14
|
-
constructor(context: PatcherContext);
|
|
15
|
-
protected createSpan(spanName: string, params: GenerationParams, operationName: string, additionalAttributes?: Record<string, any>): {
|
|
16
|
-
span: Span;
|
|
17
|
-
provider: ProviderInfo;
|
|
18
|
-
modelId: string;
|
|
19
|
-
};
|
|
20
|
-
protected handleError(error: unknown, span: Span): void;
|
|
21
|
-
protected finalizeDuration(span: Span, startTime: number, config: VercelAIInstrumentationConfig, provider: ProviderInfo, modelId: string, operationName: string): void;
|
|
22
|
-
abstract patch(original: Function): Function;
|
|
23
|
-
}
|
|
24
|
-
//# sourceMappingURL=base-patcher.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"base-patcher.d.ts","sourceRoot":"","sources":["../../../../../src/internal/instrumentation/vercel-ai/patchers/base-patcher.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAevD,OAAO,KAAK,EAAE,6BAA6B,EAAE,gBAAgB,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAGzG,MAAM,WAAW,eAAe;IAC9B,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,6BAA6B,CAAC;IAE/C,kBAAkB,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACxE,oBAAoB,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IACnG,iBAAiB,EAAE,CAAC,QAAQ,EAAE,SAAS,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IAC/E,yBAAyB,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;CAC/E;AAGD,MAAM,MAAM,cAAc,GAAG,eAAe,CAAC;AAE7C,8BAAsB,WAAW;IACnB,SAAS,CAAC,OAAO,EAAE,cAAc;gBAAvB,OAAO,EAAE,cAAc;IAE7C,SAAS,CAAC,UAAU,CAClB,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,gBAAgB,EACxB,aAAa,EAAE,MAAM,EAErB,oBAAoB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GACzC;QAAE,IAAI,EAAE,IAAI,CAAC;QAAC,QAAQ,EAAE,YAAY,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE;IAiC1D,SAAS,CAAC,WAAW,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,GAAG,IAAI;IAOvD,SAAS,CAAC,gBAAgB,CACxB,IAAI,EAAE,IAAI,EACV,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,6BAA6B,EACrC,QAAQ,EAAE,YAAY,EACtB,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,MAAM,GACpB,IAAI;IASP,QAAQ,CAAC,KAAK,CAAC,QAAQ,EAAE,QAAQ,GAAG,QAAQ;CAC7C"}
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.BasePatcher = void 0;
|
|
4
|
-
const api_1 = require("@opentelemetry/api");
|
|
5
|
-
const semconv_1 = require("../semconv");
|
|
6
|
-
const utils_1 = require("../utils");
|
|
7
|
-
class BasePatcher {
|
|
8
|
-
context;
|
|
9
|
-
constructor(context) {
|
|
10
|
-
this.context = context;
|
|
11
|
-
}
|
|
12
|
-
createSpan(spanName, params, operationName, additionalAttributes) {
|
|
13
|
-
const provider = (0, utils_1.detectProvider)(params.model);
|
|
14
|
-
const modelId = (0, utils_1.extractModelId)(params.model);
|
|
15
|
-
const span = this.context.tracer.startSpan(spanName, {
|
|
16
|
-
kind: api_1.SpanKind.CLIENT,
|
|
17
|
-
attributes: {
|
|
18
|
-
[semconv_1.ATTR_GEN_AI_SYSTEM]: provider.system,
|
|
19
|
-
[semconv_1.ATTR_GEN_AI_OPERATION_NAME]: operationName,
|
|
20
|
-
[semconv_1.ATTR_GEN_AI_REQUEST_MODEL]: modelId,
|
|
21
|
-
...(params.maxTokens && { [semconv_1.ATTR_GEN_AI_REQUEST_MAX_TOKENS]: params.maxTokens }),
|
|
22
|
-
...(params.temperature !== undefined && {
|
|
23
|
-
[semconv_1.ATTR_GEN_AI_REQUEST_TEMPERATURE]: params.temperature,
|
|
24
|
-
}),
|
|
25
|
-
...(params.topP !== undefined && { [semconv_1.ATTR_GEN_AI_REQUEST_TOP_P]: params.topP }),
|
|
26
|
-
...(params.topK !== undefined && { [semconv_1.ATTR_GEN_AI_REQUEST_TOP_K]: params.topK }),
|
|
27
|
-
...(params.frequencyPenalty !== undefined && {
|
|
28
|
-
[semconv_1.ATTR_GEN_AI_REQUEST_FREQUENCY_PENALTY]: params.frequencyPenalty,
|
|
29
|
-
}),
|
|
30
|
-
...(params.presencePenalty !== undefined && {
|
|
31
|
-
[semconv_1.ATTR_GEN_AI_REQUEST_PRESENCE_PENALTY]: params.presencePenalty,
|
|
32
|
-
}),
|
|
33
|
-
...(params.stopSequences && {
|
|
34
|
-
[semconv_1.ATTR_GEN_AI_REQUEST_STOP_SEQUENCES]: params.stopSequences,
|
|
35
|
-
}),
|
|
36
|
-
...(provider.apiBase && { [semconv_1.ATTR_GEN_AI_OPENAI_API_BASE]: provider.apiBase }),
|
|
37
|
-
...additionalAttributes,
|
|
38
|
-
},
|
|
39
|
-
});
|
|
40
|
-
return { span, provider, modelId };
|
|
41
|
-
}
|
|
42
|
-
handleError(error, span) {
|
|
43
|
-
if ((0, utils_1.shouldRecordError)(error)) {
|
|
44
|
-
span.recordException(error);
|
|
45
|
-
span.setStatus({ code: api_1.SpanStatusCode.ERROR, message: error.message });
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
finalizeDuration(span, startTime, config, provider, modelId, operationName) {
|
|
49
|
-
if (config.enableMetrics) {
|
|
50
|
-
const duration = (globalThis.performance.now() - startTime) / 1000;
|
|
51
|
-
this.context.recordDurationMetric(duration, provider.system, modelId, operationName);
|
|
52
|
-
}
|
|
53
|
-
span.end();
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
exports.BasePatcher = BasePatcher;
|
|
57
|
-
//# sourceMappingURL=base-patcher.js.map
|