openlayer 0.3.0 → 0.7.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 (120) hide show
  1. package/CHANGELOG.md +45 -0
  2. package/README.md +7 -15
  3. package/index.d.mts +5 -0
  4. package/index.d.ts +5 -0
  5. package/index.d.ts.map +1 -1
  6. package/index.js +2 -0
  7. package/index.js.map +1 -1
  8. package/index.mjs +2 -0
  9. package/index.mjs.map +1 -1
  10. package/lib/core/openai-monitor.d.ts +3 -0
  11. package/lib/core/openai-monitor.d.ts.map +1 -1
  12. package/lib/core/openai-monitor.js +7 -1
  13. package/lib/core/openai-monitor.js.map +1 -1
  14. package/lib/core/openai-monitor.mjs +4 -1
  15. package/lib/core/openai-monitor.mjs.map +1 -1
  16. package/lib/integrations/langchainCallback.d.ts +33 -0
  17. package/lib/integrations/langchainCallback.d.ts.map +1 -0
  18. package/lib/integrations/langchainCallback.js +114 -0
  19. package/lib/integrations/langchainCallback.js.map +1 -0
  20. package/lib/integrations/langchainCallback.mjs +110 -0
  21. package/lib/integrations/langchainCallback.mjs.map +1 -0
  22. package/lib/integrations/openAiTracer.d.ts +3 -0
  23. package/lib/integrations/openAiTracer.d.ts.map +1 -0
  24. package/lib/integrations/openAiTracer.js +125 -0
  25. package/lib/integrations/openAiTracer.js.map +1 -0
  26. package/lib/integrations/openAiTracer.mjs +121 -0
  27. package/lib/integrations/openAiTracer.mjs.map +1 -0
  28. package/lib/tracing/enums.d.ts +5 -0
  29. package/lib/tracing/enums.d.ts.map +1 -0
  30. package/lib/tracing/enums.js +9 -0
  31. package/lib/tracing/enums.js.map +1 -0
  32. package/lib/tracing/enums.mjs +6 -0
  33. package/lib/tracing/enums.mjs.map +1 -0
  34. package/lib/tracing/steps.d.ts +57 -0
  35. package/lib/tracing/steps.d.ts.map +1 -0
  36. package/lib/tracing/steps.js +84 -0
  37. package/lib/tracing/steps.js.map +1 -0
  38. package/lib/tracing/steps.mjs +78 -0
  39. package/lib/tracing/steps.mjs.map +1 -0
  40. package/lib/tracing/tracer.d.ts +18 -0
  41. package/lib/tracing/tracer.d.ts.map +1 -0
  42. package/lib/tracing/tracer.js +155 -0
  43. package/lib/tracing/tracer.js.map +1 -0
  44. package/lib/tracing/tracer.mjs +148 -0
  45. package/lib/tracing/tracer.mjs.map +1 -0
  46. package/lib/tracing/traces.d.ts +9 -0
  47. package/lib/tracing/traces.d.ts.map +1 -0
  48. package/lib/tracing/traces.js +17 -0
  49. package/lib/tracing/traces.js.map +1 -0
  50. package/lib/tracing/traces.mjs +13 -0
  51. package/lib/tracing/traces.mjs.map +1 -0
  52. package/package.json +2 -1
  53. package/resources/index.d.ts +2 -1
  54. package/resources/index.d.ts.map +1 -1
  55. package/resources/index.js +3 -1
  56. package/resources/index.js.map +1 -1
  57. package/resources/index.mjs +2 -1
  58. package/resources/index.mjs.map +1 -1
  59. package/resources/inference-pipelines/data.d.ts +2 -2
  60. package/resources/inference-pipelines/data.js +1 -1
  61. package/resources/inference-pipelines/data.mjs +1 -1
  62. package/resources/inference-pipelines/index.d.ts +2 -1
  63. package/resources/inference-pipelines/index.d.ts.map +1 -1
  64. package/resources/inference-pipelines/index.js +3 -1
  65. package/resources/inference-pipelines/index.js.map +1 -1
  66. package/resources/inference-pipelines/index.mjs +2 -1
  67. package/resources/inference-pipelines/index.mjs.map +1 -1
  68. package/resources/inference-pipelines/inference-pipelines.d.ts +166 -0
  69. package/resources/inference-pipelines/inference-pipelines.d.ts.map +1 -1
  70. package/resources/inference-pipelines/inference-pipelines.js +25 -0
  71. package/resources/inference-pipelines/inference-pipelines.js.map +1 -1
  72. package/resources/inference-pipelines/inference-pipelines.mjs +25 -0
  73. package/resources/inference-pipelines/inference-pipelines.mjs.map +1 -1
  74. package/resources/inference-pipelines/rows.d.ts +58 -0
  75. package/resources/inference-pipelines/rows.d.ts.map +1 -0
  76. package/resources/inference-pipelines/rows.js +22 -0
  77. package/resources/inference-pipelines/rows.js.map +1 -0
  78. package/resources/inference-pipelines/rows.mjs +18 -0
  79. package/resources/inference-pipelines/rows.mjs.map +1 -0
  80. package/resources/storage/index.d.ts +3 -0
  81. package/resources/storage/index.d.ts.map +1 -0
  82. package/resources/storage/index.js +9 -0
  83. package/resources/storage/index.js.map +1 -0
  84. package/resources/storage/index.mjs +4 -0
  85. package/resources/storage/index.mjs.map +1 -0
  86. package/resources/storage/presigned-url.d.ts +34 -0
  87. package/resources/storage/presigned-url.d.ts.map +1 -0
  88. package/resources/storage/presigned-url.js +18 -0
  89. package/resources/storage/presigned-url.js.map +1 -0
  90. package/resources/storage/presigned-url.mjs +14 -0
  91. package/resources/storage/presigned-url.mjs.map +1 -0
  92. package/resources/storage/storage.d.ts +11 -0
  93. package/resources/storage/storage.d.ts.map +1 -0
  94. package/resources/storage/storage.js +40 -0
  95. package/resources/storage/storage.js.map +1 -0
  96. package/resources/storage/storage.mjs +13 -0
  97. package/resources/storage/storage.mjs.map +1 -0
  98. package/src/index.ts +6 -0
  99. package/src/lib/core/openai-monitor.ts +7 -1
  100. package/src/lib/index.d.ts +1 -0
  101. package/src/lib/integrations/langchainCallback.ts +141 -0
  102. package/src/lib/integrations/openAiTracer.ts +137 -0
  103. package/src/lib/tracing/enums.ts +4 -0
  104. package/src/lib/tracing/index.d.ts +1 -0
  105. package/src/lib/tracing/steps.ts +118 -0
  106. package/src/lib/tracing/tracer.ts +204 -0
  107. package/src/lib/tracing/traces.ts +19 -0
  108. package/src/resources/index.ts +7 -1
  109. package/src/resources/inference-pipelines/data.ts +2 -2
  110. package/src/resources/inference-pipelines/index.ts +7 -1
  111. package/src/resources/inference-pipelines/inference-pipelines.ts +232 -0
  112. package/src/resources/inference-pipelines/rows.ts +81 -0
  113. package/src/resources/storage/index.ts +4 -0
  114. package/src/resources/storage/presigned-url.ts +47 -0
  115. package/src/resources/storage/storage.ts +14 -0
  116. package/src/version.ts +1 -1
  117. package/version.d.ts +1 -1
  118. package/version.js +1 -1
  119. package/version.mjs +1 -1
  120. package/src/lib/.keep +0 -4
@@ -0,0 +1,110 @@
1
+ import { BaseCallbackHandler } from '@langchain/core/callbacks/base';
2
+ import { AIMessage, SystemMessage } from '@langchain/core/messages';
3
+ import { addChatCompletionStepToTrace } from "../tracing/tracer.mjs";
4
+ const LANGCHAIN_TO_OPENLAYER_PROVIDER_MAP = {
5
+ openai: 'OpenAI',
6
+ 'openai-chat': 'OpenAI',
7
+ 'chat-ollama': 'Ollama',
8
+ vertexai: 'Google',
9
+ };
10
+ const PROVIDER_TO_STEP_NAME = {
11
+ OpenAI: 'OpenAI Chat Completion',
12
+ Ollama: 'Ollama Chat Completion',
13
+ Google: 'Google Vertex AI Chat Completion',
14
+ };
15
+ export class OpenlayerHandler extends BaseCallbackHandler {
16
+ constructor(kwargs = {}) {
17
+ super();
18
+ this.name = 'OpenlayerHandler';
19
+ this.startTime = null;
20
+ this.endTime = null;
21
+ this.prompt = null;
22
+ this.latency = 0;
23
+ this.model = null;
24
+ this.modelParameters = null;
25
+ this.promptTokens = 0;
26
+ this.completionTokens = 0;
27
+ this.totalTokens = 0;
28
+ this.output = '';
29
+ this.metadata = kwargs;
30
+ }
31
+ async handleChatModelStart(llm, messages, runId, parentRunId, extraParams, tags, metadata, name) {
32
+ this.initializeRun(extraParams || {}, metadata || {});
33
+ this.prompt = this.langchainMassagesToPrompt(messages);
34
+ this.startTime = performance.now();
35
+ }
36
+ initializeRun(extraParams, metadata) {
37
+ this.modelParameters = extraParams['invocation_params'] || {};
38
+ const provider = metadata?.['ls_provider'];
39
+ if (provider && LANGCHAIN_TO_OPENLAYER_PROVIDER_MAP[provider]) {
40
+ this.provider = LANGCHAIN_TO_OPENLAYER_PROVIDER_MAP[provider];
41
+ }
42
+ this.model = this.modelParameters?.['model'] || metadata['ls_model_name'] || null;
43
+ this.output = '';
44
+ }
45
+ langchainMassagesToPrompt(messages) {
46
+ let prompt = [];
47
+ for (const message of messages) {
48
+ for (const m of message) {
49
+ if (m instanceof AIMessage) {
50
+ prompt.push({ role: 'assistant', content: m.content });
51
+ }
52
+ else if (m instanceof SystemMessage) {
53
+ prompt.push({ role: 'system', content: m.content });
54
+ }
55
+ else {
56
+ prompt.push({ role: 'user', content: m.content });
57
+ }
58
+ }
59
+ }
60
+ return prompt;
61
+ }
62
+ async handleLLMStart(llm, prompts, runId, parentRunId, extraParams, tags, metadata, runName) {
63
+ this.initializeRun(extraParams || {}, metadata || {});
64
+ this.prompt = prompts.map((p) => ({ role: 'user', content: p }));
65
+ this.startTime = performance.now();
66
+ }
67
+ async handleLLMEnd(output, runId, parentRunId, tags) {
68
+ this.endTime = performance.now();
69
+ this.latency = this.endTime - this.startTime;
70
+ this.extractTokenInformation(output);
71
+ this.extractOutput(output);
72
+ this.addToTrace();
73
+ }
74
+ extractTokenInformation(output) {
75
+ if (this.provider === 'OpenAI') {
76
+ this.openaiTokenInformation(output);
77
+ }
78
+ }
79
+ openaiTokenInformation(output) {
80
+ if (output.llmOutput && 'tokenUsage' in output.llmOutput) {
81
+ this.promptTokens = output.llmOutput?.['tokenUsage']?.promptTokens ?? 0;
82
+ this.completionTokens = output.llmOutput?.['tokenUsage']?.completionTokens ?? 0;
83
+ this.totalTokens = output.llmOutput?.['tokenUsage']?.totalTokens ?? 0;
84
+ }
85
+ }
86
+ extractOutput(output) {
87
+ const lastResponse = output?.generations?.at(-1)?.at(-1) ?? undefined;
88
+ this.output += lastResponse?.text ?? '';
89
+ }
90
+ addToTrace() {
91
+ let name = 'Chat Completion Model';
92
+ if (this.provider && this.provider in PROVIDER_TO_STEP_NAME) {
93
+ name = PROVIDER_TO_STEP_NAME[this.provider] ?? 'Chat Completion Model';
94
+ }
95
+ addChatCompletionStepToTrace({
96
+ name: name,
97
+ inputs: { prompt: this.prompt },
98
+ output: this.output,
99
+ latency: this.latency,
100
+ tokens: this.totalTokens,
101
+ promptTokens: this.promptTokens,
102
+ completionTokens: this.completionTokens,
103
+ model: this.model,
104
+ modelParameters: this.modelParameters,
105
+ metadata: this.metadata,
106
+ provider: this.provider ?? '',
107
+ });
108
+ }
109
+ }
110
+ //# sourceMappingURL=langchainCallback.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"langchainCallback.mjs","sourceRoot":"","sources":["../../src/lib/integrations/langchainCallback.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import OpenAI from 'openai';
2
+ export declare function traceOpenAI(openai: OpenAI): OpenAI;
3
+ //# sourceMappingURL=openAiTracer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openAiTracer.d.ts","sourceRoot":"","sources":["../../src/lib/integrations/openAiTracer.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAI5B,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAgHlD"}
@@ -0,0 +1,125 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.traceOpenAI = void 0;
4
+ const tracer_1 = require("../tracing/tracer.js");
5
+ function traceOpenAI(openai) {
6
+ const createFunction = openai.chat.completions.create;
7
+ openai.chat.completions.create = async function (...args) {
8
+ const [params, options] = args;
9
+ const stream = params?.stream ?? false;
10
+ try {
11
+ const startTime = performance.now();
12
+ // Call the original `create` function
13
+ let response = await createFunction.apply(this, args);
14
+ if (stream) {
15
+ // Handle streaming responses
16
+ const chunks = [];
17
+ let collectedOutputData = [];
18
+ let firstTokenTime;
19
+ let completionTokens = 0;
20
+ if (isAsyncIterable(response)) {
21
+ async function* tracedOutputGenerator() {
22
+ for await (const rawChunk of response) {
23
+ if (chunks.length === 0) {
24
+ firstTokenTime = performance.now();
25
+ }
26
+ chunks.push(rawChunk);
27
+ const delta = rawChunk.choices[0]?.delta;
28
+ if (delta?.content) {
29
+ collectedOutputData.push(delta?.content);
30
+ }
31
+ else if (delta?.tool_calls) {
32
+ const tool_call = delta.tool_calls[0];
33
+ if (tool_call?.function?.name) {
34
+ const functionName = '{\n "name": ' + '"' + tool_call.function.name + '"' + '\n "arguments": ';
35
+ collectedOutputData.push(functionName);
36
+ }
37
+ else if (tool_call?.function?.arguments) {
38
+ collectedOutputData.push(tool_call.function.arguments);
39
+ }
40
+ }
41
+ if (rawChunk.choices[0]?.finish_reason === 'tool_calls') {
42
+ collectedOutputData.push('\n}');
43
+ }
44
+ completionTokens += 1;
45
+ yield rawChunk;
46
+ }
47
+ const endTime = performance.now();
48
+ const traceData = {
49
+ name: 'OpenAI Chat Completion',
50
+ inputs: { prompt: params.messages },
51
+ output: collectedOutputData.join(''),
52
+ latency: endTime - startTime,
53
+ model: chunks[0]?.model,
54
+ modelParameters: getModelParameters(args),
55
+ rawOutput: chunks.map((chunk) => JSON.stringify(chunk, null, 2)).join('\n'),
56
+ metadata: { timeToFistToken: firstTokenTime ? firstTokenTime - startTime : null },
57
+ provider: 'OpenAI',
58
+ completionTokens: completionTokens,
59
+ promptTokens: 0,
60
+ tokens: completionTokens,
61
+ };
62
+ (0, tracer_1.addChatCompletionStepToTrace)(traceData);
63
+ }
64
+ return tracedOutputGenerator();
65
+ }
66
+ }
67
+ else {
68
+ // Handle non-streaming responses
69
+ response = response;
70
+ const completion = response.choices[0];
71
+ const endTime = performance.now();
72
+ let output = '';
73
+ if (completion?.message?.content) {
74
+ output = completion.message.content;
75
+ }
76
+ else if (completion?.message.tool_calls) {
77
+ const tool_call = completion.message.tool_calls[0];
78
+ output = JSON.stringify(tool_call?.function, null, 2);
79
+ }
80
+ const traceData = {
81
+ name: 'OpenAI Chat Completion',
82
+ inputs: { prompt: params.messages },
83
+ output: output,
84
+ latency: endTime - startTime,
85
+ tokens: response.usage?.total_tokens ?? null,
86
+ promptTokens: response.usage?.prompt_tokens ?? null,
87
+ completionTokens: response.usage?.completion_tokens ?? null,
88
+ model: response.model,
89
+ modelParameters: getModelParameters(args),
90
+ rawOutput: JSON.stringify(response, null, 2),
91
+ metadata: {},
92
+ provider: 'OpenAI',
93
+ };
94
+ (0, tracer_1.addChatCompletionStepToTrace)(traceData);
95
+ return response;
96
+ }
97
+ }
98
+ catch (error) {
99
+ console.error('Failed to trace the create chat completion request with Openlayer', error);
100
+ throw error;
101
+ }
102
+ // Ensure a return statement is present
103
+ return undefined;
104
+ };
105
+ return openai;
106
+ }
107
+ exports.traceOpenAI = traceOpenAI;
108
+ function getModelParameters(args) {
109
+ const params = args[0];
110
+ return {
111
+ frequency_penalty: params?.frequencyPenalty ?? 0,
112
+ logit_bias: params?.logitBias ?? null,
113
+ logprobs: params?.logprobs ?? false,
114
+ top_logprobs: params?.topLogprobs ?? null,
115
+ max_tokens: params?.maxTokens ?? null,
116
+ n: params?.n ?? 1,
117
+ presence_penalty: params?.presencePenalty ?? 0,
118
+ seed: params?.seed ?? null,
119
+ stop: params?.stop ?? null,
120
+ temperature: params?.temperature ?? 1,
121
+ top_p: params?.topP ?? 1,
122
+ };
123
+ }
124
+ const isAsyncIterable = (x) => x != null && typeof x === 'object' && typeof x[Symbol.asyncIterator] === 'function';
125
+ //# sourceMappingURL=openAiTracer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openAiTracer.js","sourceRoot":"","sources":["../../src/lib/integrations/openAiTracer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,121 @@
1
+ import { addChatCompletionStepToTrace } from "../tracing/tracer.mjs";
2
+ export function traceOpenAI(openai) {
3
+ const createFunction = openai.chat.completions.create;
4
+ openai.chat.completions.create = async function (...args) {
5
+ const [params, options] = args;
6
+ const stream = params?.stream ?? false;
7
+ try {
8
+ const startTime = performance.now();
9
+ // Call the original `create` function
10
+ let response = await createFunction.apply(this, args);
11
+ if (stream) {
12
+ // Handle streaming responses
13
+ const chunks = [];
14
+ let collectedOutputData = [];
15
+ let firstTokenTime;
16
+ let completionTokens = 0;
17
+ if (isAsyncIterable(response)) {
18
+ async function* tracedOutputGenerator() {
19
+ for await (const rawChunk of response) {
20
+ if (chunks.length === 0) {
21
+ firstTokenTime = performance.now();
22
+ }
23
+ chunks.push(rawChunk);
24
+ const delta = rawChunk.choices[0]?.delta;
25
+ if (delta?.content) {
26
+ collectedOutputData.push(delta?.content);
27
+ }
28
+ else if (delta?.tool_calls) {
29
+ const tool_call = delta.tool_calls[0];
30
+ if (tool_call?.function?.name) {
31
+ const functionName = '{\n "name": ' + '"' + tool_call.function.name + '"' + '\n "arguments": ';
32
+ collectedOutputData.push(functionName);
33
+ }
34
+ else if (tool_call?.function?.arguments) {
35
+ collectedOutputData.push(tool_call.function.arguments);
36
+ }
37
+ }
38
+ if (rawChunk.choices[0]?.finish_reason === 'tool_calls') {
39
+ collectedOutputData.push('\n}');
40
+ }
41
+ completionTokens += 1;
42
+ yield rawChunk;
43
+ }
44
+ const endTime = performance.now();
45
+ const traceData = {
46
+ name: 'OpenAI Chat Completion',
47
+ inputs: { prompt: params.messages },
48
+ output: collectedOutputData.join(''),
49
+ latency: endTime - startTime,
50
+ model: chunks[0]?.model,
51
+ modelParameters: getModelParameters(args),
52
+ rawOutput: chunks.map((chunk) => JSON.stringify(chunk, null, 2)).join('\n'),
53
+ metadata: { timeToFistToken: firstTokenTime ? firstTokenTime - startTime : null },
54
+ provider: 'OpenAI',
55
+ completionTokens: completionTokens,
56
+ promptTokens: 0,
57
+ tokens: completionTokens,
58
+ };
59
+ addChatCompletionStepToTrace(traceData);
60
+ }
61
+ return tracedOutputGenerator();
62
+ }
63
+ }
64
+ else {
65
+ // Handle non-streaming responses
66
+ response = response;
67
+ const completion = response.choices[0];
68
+ const endTime = performance.now();
69
+ let output = '';
70
+ if (completion?.message?.content) {
71
+ output = completion.message.content;
72
+ }
73
+ else if (completion?.message.tool_calls) {
74
+ const tool_call = completion.message.tool_calls[0];
75
+ output = JSON.stringify(tool_call?.function, null, 2);
76
+ }
77
+ const traceData = {
78
+ name: 'OpenAI Chat Completion',
79
+ inputs: { prompt: params.messages },
80
+ output: output,
81
+ latency: endTime - startTime,
82
+ tokens: response.usage?.total_tokens ?? null,
83
+ promptTokens: response.usage?.prompt_tokens ?? null,
84
+ completionTokens: response.usage?.completion_tokens ?? null,
85
+ model: response.model,
86
+ modelParameters: getModelParameters(args),
87
+ rawOutput: JSON.stringify(response, null, 2),
88
+ metadata: {},
89
+ provider: 'OpenAI',
90
+ };
91
+ addChatCompletionStepToTrace(traceData);
92
+ return response;
93
+ }
94
+ }
95
+ catch (error) {
96
+ console.error('Failed to trace the create chat completion request with Openlayer', error);
97
+ throw error;
98
+ }
99
+ // Ensure a return statement is present
100
+ return undefined;
101
+ };
102
+ return openai;
103
+ }
104
+ function getModelParameters(args) {
105
+ const params = args[0];
106
+ return {
107
+ frequency_penalty: params?.frequencyPenalty ?? 0,
108
+ logit_bias: params?.logitBias ?? null,
109
+ logprobs: params?.logprobs ?? false,
110
+ top_logprobs: params?.topLogprobs ?? null,
111
+ max_tokens: params?.maxTokens ?? null,
112
+ n: params?.n ?? 1,
113
+ presence_penalty: params?.presencePenalty ?? 0,
114
+ seed: params?.seed ?? null,
115
+ stop: params?.stop ?? null,
116
+ temperature: params?.temperature ?? 1,
117
+ top_p: params?.topP ?? 1,
118
+ };
119
+ }
120
+ const isAsyncIterable = (x) => x != null && typeof x === 'object' && typeof x[Symbol.asyncIterator] === 'function';
121
+ //# sourceMappingURL=openAiTracer.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openAiTracer.mjs","sourceRoot":"","sources":["../../src/lib/integrations/openAiTracer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ export declare enum StepType {
2
+ USER_CALL = "user_call",
3
+ CHAT_COMPLETION = "chat_completion"
4
+ }
5
+ //# sourceMappingURL=enums.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"enums.d.ts","sourceRoot":"","sources":["../../src/lib/tracing/enums.ts"],"names":[],"mappings":"AAAA,oBAAY,QAAQ;IAClB,SAAS,cAAc;IACvB,eAAe,oBAAoB;CACpC"}
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.StepType = void 0;
4
+ var StepType;
5
+ (function (StepType) {
6
+ StepType["USER_CALL"] = "user_call";
7
+ StepType["CHAT_COMPLETION"] = "chat_completion";
8
+ })(StepType = exports.StepType || (exports.StepType = {}));
9
+ //# sourceMappingURL=enums.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"enums.js","sourceRoot":"","sources":["../../src/lib/tracing/enums.ts"],"names":[],"mappings":";;;AAAA,IAAY,QAGX;AAHD,WAAY,QAAQ;IAClB,mCAAuB,CAAA;IACvB,+CAAmC,CAAA;AACrC,CAAC,EAHW,QAAQ,GAAR,gBAAQ,KAAR,gBAAQ,QAGnB"}
@@ -0,0 +1,6 @@
1
+ export var StepType;
2
+ (function (StepType) {
3
+ StepType["USER_CALL"] = "user_call";
4
+ StepType["CHAT_COMPLETION"] = "chat_completion";
5
+ })(StepType || (StepType = {}));
6
+ //# sourceMappingURL=enums.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"enums.mjs","sourceRoot":"","sources":["../../src/lib/tracing/enums.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,QAGX;AAHD,WAAY,QAAQ;IAClB,mCAAuB,CAAA;IACvB,+CAAmC,CAAA;AACrC,CAAC,EAHW,QAAQ,KAAR,QAAQ,QAGnB"}
@@ -0,0 +1,57 @@
1
+ import { StepType } from "./enums.js";
2
+ export interface StepData {
3
+ name: string;
4
+ id: string;
5
+ type: StepType;
6
+ inputs: any;
7
+ output: any;
8
+ groundTruth: any;
9
+ metadata: Record<string, any>;
10
+ steps: StepData[];
11
+ latency: number | null;
12
+ startTime: number;
13
+ endTime: number | null;
14
+ }
15
+ export interface ChatCompletionStepData extends StepData {
16
+ provider: string | null;
17
+ promptTokens: number | null;
18
+ completionTokens: number | null;
19
+ tokens: number | null;
20
+ cost: number | null;
21
+ model: string | null;
22
+ modelParameters: Record<string, any> | null;
23
+ rawOutput: string | null;
24
+ }
25
+ export declare class Step {
26
+ name: string;
27
+ id: string;
28
+ inputs: any;
29
+ output: any;
30
+ metadata: Record<string, any>;
31
+ stepType: StepType | null;
32
+ startTime: number;
33
+ endTime: number | null;
34
+ groundTruth: any;
35
+ latency: number | null;
36
+ steps: Step[];
37
+ constructor(name: string, inputs?: any, output?: any, metadata?: Record<string, any>);
38
+ addNestedStep(nestedStep: Step): void;
39
+ log(data: Partial<Record<keyof this, any>>): void;
40
+ toJSON(): StepData;
41
+ }
42
+ export declare class UserCallStep extends Step {
43
+ constructor(name: string, inputs?: any, output?: any, metadata?: Record<string, any>);
44
+ }
45
+ export declare class ChatCompletionStep extends Step {
46
+ provider: string | null;
47
+ promptTokens: number | null;
48
+ completionTokens: number | null;
49
+ tokens: number | null;
50
+ cost: number | null;
51
+ model: string | null;
52
+ modelParameters: Record<string, any> | null;
53
+ rawOutput: string | null;
54
+ constructor(name: string, inputs?: any, output?: any, metadata?: Record<string, any>);
55
+ toJSON(): ChatCompletionStepData;
56
+ }
57
+ //# sourceMappingURL=steps.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"steps.d.ts","sourceRoot":"","sources":["../../src/lib/tracing/steps.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,QAAQ,CAAC;IACf,MAAM,EAAE,GAAG,CAAC;IACZ,MAAM,EAAE,GAAG,CAAC;IACZ,WAAW,EAAE,GAAG,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC9B,KAAK,EAAE,QAAQ,EAAE,CAAC;IAClB,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;CACxB;AAED,MAAM,WAAW,sBAAuB,SAAQ,QAAQ;IACtD,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,gBAAgB,EAAE,MAAM,GAAG,IAAI,CAAC;IAChC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IACpB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC;IAC5C,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;CAC1B;AAED,qBAAa,IAAI;IACf,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,GAAG,CAAC;IACZ,MAAM,EAAE,GAAG,CAAC;IACZ,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC9B,QAAQ,EAAE,QAAQ,GAAG,IAAI,CAAQ;IACjC,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,GAAG,IAAI,CAAQ;IAC9B,WAAW,EAAE,GAAG,CAAQ;IACxB,OAAO,EAAE,MAAM,GAAG,IAAI,CAAQ;IAC9B,KAAK,EAAE,IAAI,EAAE,CAAM;gBAEP,IAAI,EAAE,MAAM,EAAE,MAAM,GAAE,GAAU,EAAE,MAAM,GAAE,GAAU,EAAE,QAAQ,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM;IAUpG,aAAa,CAAC,UAAU,EAAE,IAAI,GAAG,IAAI;IAIrC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,MAAM,CAAC,MAAM,IAAI,EAAE,GAAG,CAAC,CAAC,GAAG,IAAI;IASjD,MAAM,IAAI,QAAQ;CAenB;AAED,qBAAa,YAAa,SAAQ,IAAI;gBACxB,IAAI,EAAE,MAAM,EAAE,MAAM,GAAE,GAAU,EAAE,MAAM,GAAE,GAAU,EAAE,QAAQ,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM;CAIrG;AAED,qBAAa,kBAAmB,SAAQ,IAAI;IAC1C,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAQ;IAC/B,YAAY,EAAE,MAAM,GAAG,IAAI,CAAQ;IACnC,gBAAgB,EAAE,MAAM,GAAG,IAAI,CAAQ;IACvC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAQ;IAC7B,IAAI,EAAE,MAAM,GAAG,IAAI,CAAQ;IAC3B,KAAK,EAAE,MAAM,GAAG,IAAI,CAAQ;IAC5B,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,IAAI,CAAQ;IACnD,SAAS,EAAE,MAAM,GAAG,IAAI,CAAQ;gBAEpB,IAAI,EAAE,MAAM,EAAE,MAAM,GAAE,GAAU,EAAE,MAAM,GAAE,GAAU,EAAE,QAAQ,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM;IAK3F,MAAM,IAAI,sBAAsB;CAc1C"}
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ChatCompletionStep = exports.UserCallStep = exports.Step = void 0;
4
+ const uuid_1 = require("uuid");
5
+ const enums_1 = require("./enums.js");
6
+ class Step {
7
+ constructor(name, inputs = null, output = null, metadata = {}) {
8
+ this.stepType = null;
9
+ this.endTime = null;
10
+ this.groundTruth = null;
11
+ this.latency = null;
12
+ this.steps = [];
13
+ this.name = name;
14
+ this.id = (0, uuid_1.v4)();
15
+ this.inputs = inputs;
16
+ this.output = output;
17
+ this.metadata = metadata;
18
+ this.startTime = Date.now();
19
+ }
20
+ addNestedStep(nestedStep) {
21
+ this.steps.push(nestedStep);
22
+ }
23
+ log(data) {
24
+ Object.keys(data).forEach((key) => {
25
+ if (key in this) {
26
+ // @ts-ignore
27
+ this[key] = data[key];
28
+ }
29
+ });
30
+ }
31
+ toJSON() {
32
+ return {
33
+ name: this.name,
34
+ id: this.id,
35
+ type: this.stepType,
36
+ inputs: this.inputs,
37
+ output: this.output,
38
+ groundTruth: this.groundTruth,
39
+ metadata: this.metadata,
40
+ steps: this.steps.map((nestedStep) => nestedStep.toJSON()),
41
+ latency: this.latency,
42
+ startTime: this.startTime,
43
+ endTime: this.endTime,
44
+ };
45
+ }
46
+ }
47
+ exports.Step = Step;
48
+ class UserCallStep extends Step {
49
+ constructor(name, inputs = null, output = null, metadata = {}) {
50
+ super(name, inputs, output, metadata);
51
+ this.stepType = enums_1.StepType.USER_CALL;
52
+ }
53
+ }
54
+ exports.UserCallStep = UserCallStep;
55
+ class ChatCompletionStep extends Step {
56
+ constructor(name, inputs = null, output = null, metadata = {}) {
57
+ super(name, inputs, output, metadata);
58
+ this.provider = null;
59
+ this.promptTokens = null;
60
+ this.completionTokens = null;
61
+ this.tokens = null;
62
+ this.cost = null;
63
+ this.model = null;
64
+ this.modelParameters = null;
65
+ this.rawOutput = null;
66
+ this.stepType = enums_1.StepType.CHAT_COMPLETION;
67
+ }
68
+ toJSON() {
69
+ const stepData = super.toJSON();
70
+ return {
71
+ ...stepData,
72
+ provider: this.provider,
73
+ promptTokens: this.promptTokens,
74
+ completionTokens: this.completionTokens,
75
+ tokens: this.tokens,
76
+ cost: this.cost,
77
+ model: this.model,
78
+ modelParameters: this.modelParameters,
79
+ rawOutput: this.rawOutput,
80
+ };
81
+ }
82
+ }
83
+ exports.ChatCompletionStep = ChatCompletionStep;
84
+ //# sourceMappingURL=steps.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"steps.js","sourceRoot":"","sources":["../../src/lib/tracing/steps.ts"],"names":[],"mappings":"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"}