@brizz/sdk 0.1.1 → 0.1.2-rc.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.
Files changed (136) hide show
  1. package/README.md +339 -19
  2. package/dist/index.cjs +2936 -0
  3. package/dist/index.cjs.map +1 -0
  4. package/dist/index.d.cts +178 -0
  5. package/dist/index.d.ts +177 -12
  6. package/dist/index.js +2895 -26
  7. package/dist/index.js.map +1 -1
  8. package/dist/loader.mjs +72 -0
  9. package/dist/preload.cjs +2786 -0
  10. package/dist/preload.cjs.map +1 -0
  11. package/dist/preload.d.cts +2 -0
  12. package/dist/preload.d.ts +2 -0
  13. package/dist/preload.js +2777 -0
  14. package/dist/preload.js.map +1 -0
  15. package/package.json +48 -35
  16. package/dist/index.d.ts.map +0 -1
  17. package/dist/internal/config.d.ts +0 -17
  18. package/dist/internal/config.d.ts.map +0 -1
  19. package/dist/internal/config.js +0 -94
  20. package/dist/internal/config.js.map +0 -1
  21. package/dist/internal/instrumentation/auto-init.d.ts +0 -3
  22. package/dist/internal/instrumentation/auto-init.d.ts.map +0 -1
  23. package/dist/internal/instrumentation/auto-init.js +0 -87
  24. package/dist/internal/instrumentation/auto-init.js.map +0 -1
  25. package/dist/internal/instrumentation/index.d.ts +0 -2
  26. package/dist/internal/instrumentation/index.d.ts.map +0 -1
  27. package/dist/internal/instrumentation/index.js +0 -6
  28. package/dist/internal/instrumentation/index.js.map +0 -1
  29. package/dist/internal/instrumentation/registry.d.ts +0 -30
  30. package/dist/internal/instrumentation/registry.d.ts.map +0 -1
  31. package/dist/internal/instrumentation/registry.js +0 -94
  32. package/dist/internal/instrumentation/registry.js.map +0 -1
  33. package/dist/internal/instrumentation/vercel-ai/index.d.ts +0 -4
  34. package/dist/internal/instrumentation/vercel-ai/index.d.ts.map +0 -1
  35. package/dist/internal/instrumentation/vercel-ai/index.js +0 -8
  36. package/dist/internal/instrumentation/vercel-ai/index.js.map +0 -1
  37. package/dist/internal/instrumentation/vercel-ai/instrumentation.d.ts +0 -16
  38. package/dist/internal/instrumentation/vercel-ai/instrumentation.d.ts.map +0 -1
  39. package/dist/internal/instrumentation/vercel-ai/instrumentation.js +0 -119
  40. package/dist/internal/instrumentation/vercel-ai/instrumentation.js.map +0 -1
  41. package/dist/internal/instrumentation/vercel-ai/patchers/base-patcher.d.ts +0 -24
  42. package/dist/internal/instrumentation/vercel-ai/patchers/base-patcher.d.ts.map +0 -1
  43. package/dist/internal/instrumentation/vercel-ai/patchers/base-patcher.js +0 -57
  44. package/dist/internal/instrumentation/vercel-ai/patchers/base-patcher.js.map +0 -1
  45. package/dist/internal/instrumentation/vercel-ai/patchers/embeddings-patcher.d.ts +0 -16
  46. package/dist/internal/instrumentation/vercel-ai/patchers/embeddings-patcher.d.ts.map +0 -1
  47. package/dist/internal/instrumentation/vercel-ai/patchers/embeddings-patcher.js +0 -58
  48. package/dist/internal/instrumentation/vercel-ai/patchers/embeddings-patcher.js.map +0 -1
  49. package/dist/internal/instrumentation/vercel-ai/patchers/generate-text-patcher.d.ts +0 -8
  50. package/dist/internal/instrumentation/vercel-ai/patchers/generate-text-patcher.d.ts.map +0 -1
  51. package/dist/internal/instrumentation/vercel-ai/patchers/generate-text-patcher.js +0 -59
  52. package/dist/internal/instrumentation/vercel-ai/patchers/generate-text-patcher.js.map +0 -1
  53. package/dist/internal/instrumentation/vercel-ai/patchers/index.d.ts +0 -5
  54. package/dist/internal/instrumentation/vercel-ai/patchers/index.d.ts.map +0 -1
  55. package/dist/internal/instrumentation/vercel-ai/patchers/index.js +0 -12
  56. package/dist/internal/instrumentation/vercel-ai/patchers/index.js.map +0 -1
  57. package/dist/internal/instrumentation/vercel-ai/patchers/stream-text-patcher.d.ts +0 -12
  58. package/dist/internal/instrumentation/vercel-ai/patchers/stream-text-patcher.d.ts.map +0 -1
  59. package/dist/internal/instrumentation/vercel-ai/patchers/stream-text-patcher.js +0 -41
  60. package/dist/internal/instrumentation/vercel-ai/patchers/stream-text-patcher.js.map +0 -1
  61. package/dist/internal/instrumentation/vercel-ai/semconv.d.ts +0 -53
  62. package/dist/internal/instrumentation/vercel-ai/semconv.d.ts.map +0 -1
  63. package/dist/internal/instrumentation/vercel-ai/semconv.js +0 -57
  64. package/dist/internal/instrumentation/vercel-ai/semconv.js.map +0 -1
  65. package/dist/internal/instrumentation/vercel-ai/stream-handler.d.ts +0 -13
  66. package/dist/internal/instrumentation/vercel-ai/stream-handler.d.ts.map +0 -1
  67. package/dist/internal/instrumentation/vercel-ai/stream-handler.js +0 -101
  68. package/dist/internal/instrumentation/vercel-ai/stream-handler.js.map +0 -1
  69. package/dist/internal/instrumentation/vercel-ai/telemetry-recorder.d.ts +0 -13
  70. package/dist/internal/instrumentation/vercel-ai/telemetry-recorder.d.ts.map +0 -1
  71. package/dist/internal/instrumentation/vercel-ai/telemetry-recorder.js +0 -115
  72. package/dist/internal/instrumentation/vercel-ai/telemetry-recorder.js.map +0 -1
  73. package/dist/internal/instrumentation/vercel-ai/types.d.ts +0 -197
  74. package/dist/internal/instrumentation/vercel-ai/types.d.ts.map +0 -1
  75. package/dist/internal/instrumentation/vercel-ai/types.js +0 -3
  76. package/dist/internal/instrumentation/vercel-ai/types.js.map +0 -1
  77. package/dist/internal/instrumentation/vercel-ai/utils.d.ts +0 -14
  78. package/dist/internal/instrumentation/vercel-ai/utils.d.ts.map +0 -1
  79. package/dist/internal/instrumentation/vercel-ai/utils.js +0 -243
  80. package/dist/internal/instrumentation/vercel-ai/utils.js.map +0 -1
  81. package/dist/internal/log/index.d.ts +0 -2
  82. package/dist/internal/log/index.d.ts.map +0 -1
  83. package/dist/internal/log/index.js +0 -7
  84. package/dist/internal/log/index.js.map +0 -1
  85. package/dist/internal/log/logging.d.ts +0 -21
  86. package/dist/internal/log/logging.d.ts.map +0 -1
  87. package/dist/internal/log/logging.js +0 -154
  88. package/dist/internal/log/logging.js.map +0 -1
  89. package/dist/internal/logger.d.ts +0 -23
  90. package/dist/internal/logger.d.ts.map +0 -1
  91. package/dist/internal/logger.js +0 -163
  92. package/dist/internal/logger.js.map +0 -1
  93. package/dist/internal/masking/index.d.ts +0 -4
  94. package/dist/internal/masking/index.d.ts.map +0 -1
  95. package/dist/internal/masking/index.js +0 -9
  96. package/dist/internal/masking/index.js.map +0 -1
  97. package/dist/internal/masking/patterns.d.ts +0 -3
  98. package/dist/internal/masking/patterns.d.ts.map +0 -1
  99. package/dist/internal/masking/patterns.js +0 -378
  100. package/dist/internal/masking/patterns.js.map +0 -1
  101. package/dist/internal/masking/types.d.ts +0 -33
  102. package/dist/internal/masking/types.d.ts.map +0 -1
  103. package/dist/internal/masking/types.js +0 -3
  104. package/dist/internal/masking/types.js.map +0 -1
  105. package/dist/internal/masking/utils.d.ts +0 -6
  106. package/dist/internal/masking/utils.d.ts.map +0 -1
  107. package/dist/internal/masking/utils.js +0 -232
  108. package/dist/internal/masking/utils.js.map +0 -1
  109. package/dist/internal/metric/index.d.ts +0 -2
  110. package/dist/internal/metric/index.d.ts.map +0 -1
  111. package/dist/internal/metric/index.js +0 -8
  112. package/dist/internal/metric/index.js.map +0 -1
  113. package/dist/internal/metric/metrics.d.ts +0 -18
  114. package/dist/internal/metric/metrics.d.ts.map +0 -1
  115. package/dist/internal/metric/metrics.js +0 -88
  116. package/dist/internal/metric/metrics.js.map +0 -1
  117. package/dist/internal/sdk.d.ts +0 -36
  118. package/dist/internal/sdk.d.ts.map +0 -1
  119. package/dist/internal/sdk.js +0 -159
  120. package/dist/internal/sdk.js.map +0 -1
  121. package/dist/internal/trace/index.d.ts +0 -3
  122. package/dist/internal/trace/index.d.ts.map +0 -1
  123. package/dist/internal/trace/index.js +0 -11
  124. package/dist/internal/trace/index.js.map +0 -1
  125. package/dist/internal/trace/processors/log-masked.d.ts +0 -16
  126. package/dist/internal/trace/processors/log-masked.d.ts.map +0 -1
  127. package/dist/internal/trace/processors/log-masked.js +0 -81
  128. package/dist/internal/trace/processors/log-masked.js.map +0 -1
  129. package/dist/internal/trace/processors/span-masked.d.ts +0 -16
  130. package/dist/internal/trace/processors/span-masked.d.ts.map +0 -1
  131. package/dist/internal/trace/processors/span-masked.js +0 -87
  132. package/dist/internal/trace/processors/span-masked.js.map +0 -1
  133. package/dist/internal/trace/tracing.d.ts +0 -18
  134. package/dist/internal/trace/tracing.d.ts.map +0 -1
  135. package/dist/internal/trace/tracing.js +0 -103
  136. 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"}
@@ -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,3 +0,0 @@
1
- declare let autoInstrumentationsLoaded: boolean;
2
- export { autoInstrumentationsLoaded };
3
- //# sourceMappingURL=auto-init.d.ts.map
@@ -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":";;;AAAA,0FAAwF;AAExF,oEAA0E;AAC1E,oFAAgF;AAChF,gFAA4E;AAC5E,kFAA8E;AAC9E,8EAA0E;AAC1E,oFAAgF;AAChF,sFAAkF;AAClF,8EAA0E;AAC1E,kFAA8E;AAC9E,8EAA0E;AAC1E,kFAA8E;AAC9E,kFAA8E;AAE9E,2CAAsD;AAYtD,IAAI,0BAA0B,GAAG,KAAK,CAAC;AAqG9B,gEAA0B;AAnGnC,SAAS,4BAA4B;IACnC,IAAI,CAAC;QACH,MAAM,oBAAoB,GAAG,IAAA,wDAA2B,GAAE,CAAC;QAC3D,IAAA,0CAAwB,EAAC,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,CAAC,CAAC;QACrE,OAAO,oBAAoB,CAAC;IAC9B,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QAEf,OAAO,CAAC,KAAK,CAAC,yDAAyD,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACxF,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC;AAED,SAAS,yBAAyB;IAGhC,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IAExC,MAAM,gBAAgB,GAAsB,EAAE,CAAC;IAC/C,MAAM,eAAe,GAAG,CAAC,KAAY,EAAE,EAAE;QAEvC,MAAM,CAAC,KAAK,CAAC,iCAAiC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IACjE,CAAC,CAAC;IAEF,MAAM,2BAA2B,GAAG;QAClC,EAAE,KAAK,EAAE,mCAAuB,EAAE,IAAI,EAAE,WAAW,EAAE;QACrD,EAAE,KAAK,EAAE,8CAAqB,EAAE,IAAI,EAAE,QAAQ,EAAE;QAChD,EAAE,KAAK,EAAE,oDAAwB,EAAE,IAAI,EAAE,WAAW,EAAE;QACtD,EAAE,KAAK,EAAE,8CAAqB,EAAE,IAAI,EAAE,QAAQ,EAAE;QAChD,EAAE,KAAK,EAAE,kDAAuB,EAAE,IAAI,EAAE,WAAW,EAAE;QACrD,EAAE,KAAK,EAAE,gDAAsB,EAAE,IAAI,EAAE,SAAS,EAAE;QAClD,EAAE,KAAK,EAAE,kDAAuB,EAAE,IAAI,EAAE,UAAU,EAAE;QACpD,EAAE,KAAK,EAAE,oDAAwB,EAAE,IAAI,EAAE,WAAW,EAAE;QACtD,EAAE,KAAK,EAAE,sDAAyB,EAAE,IAAI,EAAE,YAAY,EAAE;QACxD,EAAE,KAAK,EAAE,kDAAuB,EAAE,IAAI,EAAE,UAAU,EAAE;QACpD,EAAE,KAAK,EAAE,8CAAqB,EAAE,IAAI,EAAE,QAAQ,EAAE;QAChD,EAAE,KAAK,EAAE,kDAAuB,EAAE,IAAI,EAAE,UAAU,EAAE;KACrD,CAAC;IAEF,KAAK,MAAM,MAAM,IAAI,2BAA2B,EAAE,CAAC;QACjD,IAAI,CAAC;YACH,MAAM,eAAe,GAAG,IAAI,MAAM,CAAC,KAAK,CAAC,EAAE,eAAe,EAAE,CAAC,CAAC;YAC9D,gBAAgB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAEvC,MAAM,CAAC,KAAK,CAAC,eAAe,MAAM,CAAC,IAAI,kBAAkB,CAAC,CAAC;QAC7D,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAEf,MAAM,CAAC,KAAK,CAAC,uBAAuB,MAAM,CAAC,IAAI,qBAAqB,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACvF,CAAC;IACH,CAAC;IAED,IAAI,CAAC;QACH,IAAA,0CAAwB,EAAC,EAAE,gBAAgB,EAAE,CAAC,CAAC;QAE/C,MAAM,CAAC,IAAI,CAAC,mBAAmB,gBAAgB,CAAC,MAAM,yBAAyB,CAAC,CAAC;IACnF,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QAEf,MAAM,CAAC,KAAK,CAAC,8CAA8C,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IAC9E,CAAC;IAED,OAAO,gBAAgB,CAAC;AAC1B,CAAC;AAMD,SAAS,8BAA8B;IACrC,IAAI,0BAA0B,EAAE,CAAC;QAC/B,OAAO;IACT,CAAC;IAED,IAAI,CAAC;QAEH,MAAM,oBAAoB,GAAG,4BAA4B,EAAE,CAAC;QAM5D,MAAM,qBAAqB,GAAG,yBAAyB,EAAE,CAAC;QAE1D,qCAAA,0BAA0B,GAAG,IAAI,CAAC;QAIlC,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;QAExC,MAAM,CAAC,IAAI,CACT,iCAAiC,oBAAoB,CAAC,MAAM,WAAW,qBAAqB,CAAC,MAAM,yBAAyB,CAC7H,CAAC;IACJ,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,uCAAuC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACtE,qCAAA,0BAA0B,GAAG,KAAK,CAAC;IACrC,CAAC;AACH,CAAC;AAGD,8BAA8B,EAAE,CAAC"}
@@ -1,2 +0,0 @@
1
- export { InstrumentationRegistry, type IInstrumentModules } from './registry';
2
- //# sourceMappingURL=index.d.ts.map
@@ -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,4 +0,0 @@
1
- export { VercelAIInstrumentation } from './instrumentation';
2
- export type { VercelAIInstrumentationConfig } from './types';
3
- export * from './semconv';
4
- //# sourceMappingURL=index.d.ts.map
@@ -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