@thinkhive/sdk 2.0.1 → 3.0.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.
- package/MIGRATION.md +274 -0
- package/README.md +6 -22
- package/dist/api/calibration.d.ts +168 -0
- package/dist/api/calibration.js +176 -0
- package/dist/api/claims.d.ts +262 -0
- package/dist/api/claims.js +262 -0
- package/dist/api/runs.d.ts +200 -0
- package/dist/api/runs.js +262 -0
- package/dist/core/client.d.ts +29 -0
- package/dist/core/client.js +89 -0
- package/dist/core/config.d.ts +38 -0
- package/dist/core/config.js +76 -0
- package/dist/core/types.d.ts +354 -0
- package/dist/core/types.js +8 -0
- package/dist/index.d.ts +222 -512
- package/dist/index.js +169 -394
- package/dist/instrumentation/langchain.d.ts +194 -0
- package/dist/instrumentation/langchain.js +429 -0
- package/dist/instrumentation/openai.d.ts +141 -0
- package/dist/instrumentation/openai.js +279 -0
- package/dist/integrations/customer-context.d.ts +203 -0
- package/dist/integrations/customer-context.js +274 -0
- package/dist/integrations/ticket-linking.d.ts +217 -0
- package/dist/integrations/ticket-linking.js +259 -0
- package/package.json +61 -9
package/dist/index.js
CHANGED
|
@@ -1,64 +1,86 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
/**
|
|
3
|
-
* ThinkHive
|
|
4
|
-
* OpenTelemetry-based observability for AI agents with Explainer integration
|
|
3
|
+
* ThinkHive SDK v3.0.0
|
|
5
4
|
*
|
|
6
|
-
*
|
|
5
|
+
* Run-centric AI agent observability platform with:
|
|
6
|
+
* - Facts vs Inferences (claims API)
|
|
7
|
+
* - Deterministic ticket linking (7 methods)
|
|
8
|
+
* - Customer context snapshots (time-series)
|
|
9
|
+
* - Calibrated predictions (Brier scores)
|
|
10
|
+
*
|
|
11
|
+
* @version 3.0.0
|
|
12
|
+
* @license MIT
|
|
7
13
|
*/
|
|
8
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
-
exports.
|
|
15
|
+
exports.ThinkHiveValidationError = exports.ThinkHiveApiError = exports.calculateHealthTrend = exports.calculateArrChange = exports.toContextSnapshot = exports.getContextAsOf = exports.captureCustomerContext = exports.LINK_METHOD_CONFIDENCE = exports.getBestLinkMethod = exports.linkRunToZendeskTicket = exports.linkRunToTicket = exports.removeZendeskMarker = exports.hasZendeskMarker = exports.parseZendeskMarker = exports.generateZendeskMarker = exports.getCalibrationQuality = exports.isWellCalibrated = exports.calculateECE = exports.calculateBrierScore = exports.groupClaimsByCategory = exports.groupClaimsByType = exports.getHighConfidenceClaims = exports.isComputed = exports.isInference = exports.isFact = exports.fromOpenAIMessages = exports.toOpenAIMessages = exports.createRunWithContext = exports.customerContext = exports.linking = exports.calibration = exports.claims = exports.runs = exports.DEFAULT_ENDPOINT = exports.SDK_VERSION = exports.isInitialized = exports.explainer = void 0;
|
|
10
16
|
exports.init = init;
|
|
11
17
|
exports.getTracer = getTracer;
|
|
12
|
-
exports.
|
|
18
|
+
exports.shutdown = shutdown;
|
|
13
19
|
exports.traceLLM = traceLLM;
|
|
14
20
|
exports.traceRetrieval = traceRetrieval;
|
|
15
21
|
exports.traceTool = traceTool;
|
|
16
22
|
exports.traceChain = traceChain;
|
|
17
|
-
exports.createAndAnalyze = createAndAnalyze;
|
|
18
23
|
const api_1 = require("@opentelemetry/api");
|
|
19
24
|
const exporter_trace_otlp_proto_1 = require("@opentelemetry/exporter-trace-otlp-proto");
|
|
20
25
|
const resources_1 = require("@opentelemetry/resources");
|
|
21
26
|
const sdk_trace_node_1 = require("@opentelemetry/sdk-trace-node");
|
|
22
27
|
const sdk_trace_base_1 = require("@opentelemetry/sdk-trace-base");
|
|
28
|
+
// Core
|
|
29
|
+
const config_1 = require("./core/config");
|
|
30
|
+
Object.defineProperty(exports, "isInitialized", { enumerable: true, get: function () { return config_1.isInitialized; } });
|
|
31
|
+
Object.defineProperty(exports, "SDK_VERSION", { enumerable: true, get: function () { return config_1.SDK_VERSION; } });
|
|
32
|
+
Object.defineProperty(exports, "DEFAULT_ENDPOINT", { enumerable: true, get: function () { return config_1.DEFAULT_ENDPOINT; } });
|
|
33
|
+
const client_1 = require("./core/client");
|
|
34
|
+
Object.defineProperty(exports, "ThinkHiveApiError", { enumerable: true, get: function () { return client_1.ThinkHiveApiError; } });
|
|
35
|
+
Object.defineProperty(exports, "ThinkHiveValidationError", { enumerable: true, get: function () { return client_1.ThinkHiveValidationError; } });
|
|
36
|
+
// API clients
|
|
37
|
+
const runs_1 = require("./api/runs");
|
|
38
|
+
Object.defineProperty(exports, "runs", { enumerable: true, get: function () { return runs_1.runs; } });
|
|
39
|
+
Object.defineProperty(exports, "createRunWithContext", { enumerable: true, get: function () { return runs_1.createRunWithContext; } });
|
|
40
|
+
Object.defineProperty(exports, "toOpenAIMessages", { enumerable: true, get: function () { return runs_1.toOpenAIMessages; } });
|
|
41
|
+
Object.defineProperty(exports, "fromOpenAIMessages", { enumerable: true, get: function () { return runs_1.fromOpenAIMessages; } });
|
|
42
|
+
const claims_1 = require("./api/claims");
|
|
43
|
+
Object.defineProperty(exports, "claims", { enumerable: true, get: function () { return claims_1.claims; } });
|
|
44
|
+
Object.defineProperty(exports, "isFact", { enumerable: true, get: function () { return claims_1.isFact; } });
|
|
45
|
+
Object.defineProperty(exports, "isInference", { enumerable: true, get: function () { return claims_1.isInference; } });
|
|
46
|
+
Object.defineProperty(exports, "isComputed", { enumerable: true, get: function () { return claims_1.isComputed; } });
|
|
47
|
+
Object.defineProperty(exports, "getHighConfidenceClaims", { enumerable: true, get: function () { return claims_1.getHighConfidenceClaims; } });
|
|
48
|
+
Object.defineProperty(exports, "groupClaimsByType", { enumerable: true, get: function () { return claims_1.groupClaimsByType; } });
|
|
49
|
+
Object.defineProperty(exports, "groupClaimsByCategory", { enumerable: true, get: function () { return claims_1.groupClaimsByCategory; } });
|
|
50
|
+
const calibration_1 = require("./api/calibration");
|
|
51
|
+
Object.defineProperty(exports, "calibration", { enumerable: true, get: function () { return calibration_1.calibration; } });
|
|
52
|
+
Object.defineProperty(exports, "calculateBrierScore", { enumerable: true, get: function () { return calibration_1.calculateBrierScore; } });
|
|
53
|
+
Object.defineProperty(exports, "calculateECE", { enumerable: true, get: function () { return calibration_1.calculateECE; } });
|
|
54
|
+
Object.defineProperty(exports, "isWellCalibrated", { enumerable: true, get: function () { return calibration_1.isWellCalibrated; } });
|
|
55
|
+
Object.defineProperty(exports, "getCalibrationQuality", { enumerable: true, get: function () { return calibration_1.getCalibrationQuality; } });
|
|
56
|
+
// Integrations
|
|
57
|
+
const ticket_linking_1 = require("./integrations/ticket-linking");
|
|
58
|
+
Object.defineProperty(exports, "linking", { enumerable: true, get: function () { return ticket_linking_1.linking; } });
|
|
59
|
+
Object.defineProperty(exports, "generateZendeskMarker", { enumerable: true, get: function () { return ticket_linking_1.generateZendeskMarker; } });
|
|
60
|
+
Object.defineProperty(exports, "parseZendeskMarker", { enumerable: true, get: function () { return ticket_linking_1.parseZendeskMarker; } });
|
|
61
|
+
Object.defineProperty(exports, "hasZendeskMarker", { enumerable: true, get: function () { return ticket_linking_1.hasZendeskMarker; } });
|
|
62
|
+
Object.defineProperty(exports, "removeZendeskMarker", { enumerable: true, get: function () { return ticket_linking_1.removeZendeskMarker; } });
|
|
63
|
+
Object.defineProperty(exports, "linkRunToTicket", { enumerable: true, get: function () { return ticket_linking_1.linkRunToTicket; } });
|
|
64
|
+
Object.defineProperty(exports, "linkRunToZendeskTicket", { enumerable: true, get: function () { return ticket_linking_1.linkRunToZendeskTicket; } });
|
|
65
|
+
Object.defineProperty(exports, "getBestLinkMethod", { enumerable: true, get: function () { return ticket_linking_1.getBestLinkMethod; } });
|
|
66
|
+
Object.defineProperty(exports, "LINK_METHOD_CONFIDENCE", { enumerable: true, get: function () { return ticket_linking_1.LINK_METHOD_CONFIDENCE; } });
|
|
67
|
+
const customer_context_1 = require("./integrations/customer-context");
|
|
68
|
+
Object.defineProperty(exports, "customerContext", { enumerable: true, get: function () { return customer_context_1.customerContext; } });
|
|
69
|
+
Object.defineProperty(exports, "captureCustomerContext", { enumerable: true, get: function () { return customer_context_1.captureCustomerContext; } });
|
|
70
|
+
Object.defineProperty(exports, "getContextAsOf", { enumerable: true, get: function () { return customer_context_1.getContextAsOf; } });
|
|
71
|
+
Object.defineProperty(exports, "toContextSnapshot", { enumerable: true, get: function () { return customer_context_1.toContextSnapshot; } });
|
|
72
|
+
Object.defineProperty(exports, "calculateArrChange", { enumerable: true, get: function () { return customer_context_1.calculateArrChange; } });
|
|
73
|
+
Object.defineProperty(exports, "calculateHealthTrend", { enumerable: true, get: function () { return customer_context_1.calculateHealthTrend; } });
|
|
23
74
|
// ============================================================================
|
|
24
75
|
// GLOBAL STATE
|
|
25
76
|
// ============================================================================
|
|
26
77
|
let tracer = null;
|
|
27
|
-
let
|
|
28
|
-
let config;
|
|
29
|
-
const DEFAULT_ENDPOINT = "https://thinkhivemind-h25z7pvd3q-uc.a.run.app";
|
|
30
|
-
// ============================================================================
|
|
31
|
-
// HTTP CLIENT
|
|
32
|
-
// ============================================================================
|
|
33
|
-
async function apiRequest(path, options = {}) {
|
|
34
|
-
const { method = 'GET', body, headers = {} } = options;
|
|
35
|
-
const url = `${config.endpoint}/api/v1${path}`;
|
|
36
|
-
const requestHeaders = {
|
|
37
|
-
'Content-Type': 'application/json',
|
|
38
|
-
...headers,
|
|
39
|
-
};
|
|
40
|
-
if (config.apiKey) {
|
|
41
|
-
requestHeaders['Authorization'] = `Bearer ${config.apiKey}`;
|
|
42
|
-
}
|
|
43
|
-
else if (config.agentId) {
|
|
44
|
-
requestHeaders['X-Agent-ID'] = config.agentId;
|
|
45
|
-
}
|
|
46
|
-
const response = await fetch(url, {
|
|
47
|
-
method,
|
|
48
|
-
headers: requestHeaders,
|
|
49
|
-
body: body ? JSON.stringify(body) : undefined,
|
|
50
|
-
});
|
|
51
|
-
if (!response.ok) {
|
|
52
|
-
const error = await response.text();
|
|
53
|
-
throw new Error(`ThinkHive API error: ${response.status} - ${error}`);
|
|
54
|
-
}
|
|
55
|
-
return response.json();
|
|
56
|
-
}
|
|
78
|
+
let provider = null;
|
|
57
79
|
// ============================================================================
|
|
58
80
|
// INITIALIZATION
|
|
59
81
|
// ============================================================================
|
|
60
82
|
/**
|
|
61
|
-
* Initialize ThinkHive SDK
|
|
83
|
+
* Initialize ThinkHive SDK v3
|
|
62
84
|
*
|
|
63
85
|
* @example
|
|
64
86
|
* ```typescript
|
|
@@ -73,33 +95,18 @@ async function apiRequest(path, options = {}) {
|
|
|
73
95
|
* ```
|
|
74
96
|
*/
|
|
75
97
|
function init(options = {}) {
|
|
76
|
-
if (
|
|
77
|
-
|
|
78
|
-
console.log('ThinkHive SDK already initialized');
|
|
79
|
-
}
|
|
98
|
+
if ((0, config_1.isInitialized)()) {
|
|
99
|
+
(0, config_1.debugLog)('ThinkHive SDK already initialized');
|
|
80
100
|
return;
|
|
81
101
|
}
|
|
82
|
-
const
|
|
83
|
-
const agentId = options.agentId || process.env.THINKHIVE_AGENT_ID;
|
|
84
|
-
if (!apiKey && !agentId) {
|
|
85
|
-
throw new Error("Either apiKey or agentId must be provided (or set THINKHIVE_API_KEY env var)");
|
|
86
|
-
}
|
|
87
|
-
config = {
|
|
88
|
-
apiKey: apiKey || '',
|
|
89
|
-
agentId: agentId || '',
|
|
90
|
-
endpoint: options.endpoint || process.env.THINKHIVE_ENDPOINT || DEFAULT_ENDPOINT,
|
|
91
|
-
serviceName: options.serviceName || process.env.THINKHIVE_SERVICE_NAME || 'my-ai-agent',
|
|
92
|
-
autoInstrument: options.autoInstrument ?? false,
|
|
93
|
-
frameworks: options.frameworks || ['langchain', 'openai'],
|
|
94
|
-
debug: options.debug ?? false,
|
|
95
|
-
};
|
|
102
|
+
const config = (0, config_1.initConfig)(options);
|
|
96
103
|
// Configure OTLP exporter
|
|
97
104
|
const exporterHeaders = {};
|
|
98
105
|
if (config.apiKey) {
|
|
99
|
-
exporterHeaders[
|
|
106
|
+
exporterHeaders['Authorization'] = `Bearer ${config.apiKey}`;
|
|
100
107
|
}
|
|
101
108
|
else if (config.agentId) {
|
|
102
|
-
exporterHeaders[
|
|
109
|
+
exporterHeaders['X-Agent-ID'] = config.agentId;
|
|
103
110
|
}
|
|
104
111
|
const exporter = new exporter_trace_otlp_proto_1.OTLPTraceExporter({
|
|
105
112
|
url: `${config.endpoint}/v1/traces`,
|
|
@@ -107,24 +114,25 @@ function init(options = {}) {
|
|
|
107
114
|
});
|
|
108
115
|
// Create OpenTelemetry resource
|
|
109
116
|
const resource = resources_1.Resource.default().merge(new resources_1.Resource({
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
117
|
+
'service.name': config.serviceName,
|
|
118
|
+
'thinkhive.sdk.version': config_1.SDK_VERSION,
|
|
119
|
+
'thinkhive.sdk.language': 'typescript',
|
|
120
|
+
'thinkhive.api.version': config.apiVersion,
|
|
113
121
|
}));
|
|
114
122
|
// Create provider with span processor
|
|
115
|
-
|
|
123
|
+
provider = new sdk_trace_node_1.NodeTracerProvider({
|
|
116
124
|
resource,
|
|
117
125
|
spanProcessors: [new sdk_trace_base_1.BatchSpanProcessor(exporter)],
|
|
118
126
|
});
|
|
119
127
|
// Register provider
|
|
120
128
|
provider.register();
|
|
121
129
|
// Get tracer
|
|
122
|
-
tracer = api_1.trace.getTracer(
|
|
123
|
-
initialized = true;
|
|
130
|
+
tracer = api_1.trace.getTracer('thinkhive', config_1.SDK_VERSION);
|
|
124
131
|
if (config.debug) {
|
|
125
|
-
console.log(`✅ ThinkHive SDK initialized`);
|
|
132
|
+
console.log(`✅ ThinkHive SDK v${config_1.SDK_VERSION} initialized`);
|
|
126
133
|
console.log(` Endpoint: ${config.endpoint}`);
|
|
127
134
|
console.log(` Service: ${config.serviceName}`);
|
|
135
|
+
console.log(` API Version: ${config.apiVersion}`);
|
|
128
136
|
console.log(` Auto-instrument: ${config.autoInstrument}`);
|
|
129
137
|
}
|
|
130
138
|
// Setup auto-instrumentation if enabled
|
|
@@ -136,48 +144,43 @@ function init(options = {}) {
|
|
|
136
144
|
* Get the global tracer
|
|
137
145
|
*/
|
|
138
146
|
function getTracer() {
|
|
139
|
-
if (!
|
|
140
|
-
throw new Error(
|
|
147
|
+
if (!tracer) {
|
|
148
|
+
throw new Error('ThinkHive SDK not initialized. Call init() first.');
|
|
141
149
|
}
|
|
142
150
|
return tracer;
|
|
143
151
|
}
|
|
144
152
|
/**
|
|
145
|
-
*
|
|
153
|
+
* Shutdown the SDK and flush pending spans
|
|
146
154
|
*/
|
|
147
|
-
function
|
|
148
|
-
|
|
155
|
+
async function shutdown() {
|
|
156
|
+
if (provider) {
|
|
157
|
+
await provider.shutdown();
|
|
158
|
+
provider = null;
|
|
159
|
+
}
|
|
160
|
+
tracer = null;
|
|
161
|
+
(0, config_1.resetConfig)();
|
|
162
|
+
(0, config_1.debugLog)('ThinkHive SDK shutdown complete');
|
|
149
163
|
}
|
|
150
164
|
// ============================================================================
|
|
151
165
|
// TRACING FUNCTIONS
|
|
152
166
|
// ============================================================================
|
|
153
167
|
/**
|
|
154
168
|
* Trace an LLM call
|
|
155
|
-
*
|
|
156
|
-
* @example
|
|
157
|
-
* ```typescript
|
|
158
|
-
* const response = await traceLLM({
|
|
159
|
-
* name: 'chat_completion',
|
|
160
|
-
* modelName: 'gpt-4',
|
|
161
|
-
* provider: 'openai',
|
|
162
|
-
* }, async () => {
|
|
163
|
-
* return await openai.chat.completions.create({ ... });
|
|
164
|
-
* });
|
|
165
|
-
* ```
|
|
166
169
|
*/
|
|
167
170
|
function traceLLM(options, fn) {
|
|
168
171
|
const t = getTracer();
|
|
169
172
|
return t.startActiveSpan(options.name, {
|
|
170
173
|
attributes: {
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
174
|
+
'openinference.span.kind': 'LLM',
|
|
175
|
+
'llm.model_name': options.modelName,
|
|
176
|
+
'llm.provider': options.provider,
|
|
177
|
+
'input.value': options.input ? JSON.stringify(options.input).substring(0, 10000) : undefined,
|
|
175
178
|
},
|
|
176
179
|
}, async (span) => {
|
|
177
180
|
const startTime = Date.now();
|
|
178
181
|
try {
|
|
179
182
|
const result = await fn();
|
|
180
|
-
span.setAttribute(
|
|
183
|
+
span.setAttribute('output.value', JSON.stringify(result).substring(0, 10000));
|
|
181
184
|
span.setStatus({ code: api_1.SpanStatusCode.OK });
|
|
182
185
|
return result;
|
|
183
186
|
}
|
|
@@ -188,39 +191,28 @@ function traceLLM(options, fn) {
|
|
|
188
191
|
throw error;
|
|
189
192
|
}
|
|
190
193
|
finally {
|
|
191
|
-
span.setAttribute(
|
|
194
|
+
span.setAttribute('duration_ms', Date.now() - startTime);
|
|
192
195
|
span.end();
|
|
193
196
|
}
|
|
194
197
|
});
|
|
195
198
|
}
|
|
196
199
|
/**
|
|
197
200
|
* Trace a retrieval operation
|
|
198
|
-
*
|
|
199
|
-
* @example
|
|
200
|
-
* ```typescript
|
|
201
|
-
* const docs = await traceRetrieval({
|
|
202
|
-
* name: 'vector_search',
|
|
203
|
-
* query: 'What is the return policy?',
|
|
204
|
-
* }, async () => {
|
|
205
|
-
* return await vectorStore.similaritySearch(query, 5);
|
|
206
|
-
* });
|
|
207
|
-
* ```
|
|
208
201
|
*/
|
|
209
202
|
function traceRetrieval(options, fn) {
|
|
210
203
|
const t = getTracer();
|
|
211
204
|
return t.startActiveSpan(options.name, {
|
|
212
205
|
attributes: {
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
206
|
+
'openinference.span.kind': 'RETRIEVER',
|
|
207
|
+
'retrieval.query': options.query,
|
|
208
|
+
'retrieval.top_k': options.topK,
|
|
216
209
|
},
|
|
217
210
|
}, async (span) => {
|
|
218
211
|
const startTime = Date.now();
|
|
219
212
|
try {
|
|
220
213
|
const result = await fn();
|
|
221
|
-
// Try to extract document count from result
|
|
222
214
|
if (Array.isArray(result)) {
|
|
223
|
-
span.setAttribute(
|
|
215
|
+
span.setAttribute('retrieval.document_count', result.length);
|
|
224
216
|
}
|
|
225
217
|
span.setStatus({ code: api_1.SpanStatusCode.OK });
|
|
226
218
|
return result;
|
|
@@ -232,38 +224,27 @@ function traceRetrieval(options, fn) {
|
|
|
232
224
|
throw error;
|
|
233
225
|
}
|
|
234
226
|
finally {
|
|
235
|
-
span.setAttribute(
|
|
227
|
+
span.setAttribute('duration_ms', Date.now() - startTime);
|
|
236
228
|
span.end();
|
|
237
229
|
}
|
|
238
230
|
});
|
|
239
231
|
}
|
|
240
232
|
/**
|
|
241
233
|
* Trace a tool call
|
|
242
|
-
*
|
|
243
|
-
* @example
|
|
244
|
-
* ```typescript
|
|
245
|
-
* const result = await traceTool({
|
|
246
|
-
* name: 'search_orders',
|
|
247
|
-
* toolName: 'OrderLookup',
|
|
248
|
-
* parameters: { orderId: '12345' },
|
|
249
|
-
* }, async () => {
|
|
250
|
-
* return await orderService.lookup('12345');
|
|
251
|
-
* });
|
|
252
|
-
* ```
|
|
253
234
|
*/
|
|
254
235
|
function traceTool(options, fn) {
|
|
255
236
|
const t = getTracer();
|
|
256
237
|
return t.startActiveSpan(options.toolName || options.name, {
|
|
257
238
|
attributes: {
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
239
|
+
'openinference.span.kind': 'TOOL',
|
|
240
|
+
'tool.name': options.toolName || options.name,
|
|
241
|
+
'tool.parameters': options.parameters ? JSON.stringify(options.parameters) : undefined,
|
|
261
242
|
},
|
|
262
243
|
}, async (span) => {
|
|
263
244
|
const startTime = Date.now();
|
|
264
245
|
try {
|
|
265
246
|
const result = await fn();
|
|
266
|
-
span.setAttribute(
|
|
247
|
+
span.setAttribute('tool.output', JSON.stringify(result).substring(0, 10000));
|
|
267
248
|
span.setStatus({ code: api_1.SpanStatusCode.OK });
|
|
268
249
|
return result;
|
|
269
250
|
}
|
|
@@ -274,35 +255,26 @@ function traceTool(options, fn) {
|
|
|
274
255
|
throw error;
|
|
275
256
|
}
|
|
276
257
|
finally {
|
|
277
|
-
span.setAttribute(
|
|
258
|
+
span.setAttribute('duration_ms', Date.now() - startTime);
|
|
278
259
|
span.end();
|
|
279
260
|
}
|
|
280
261
|
});
|
|
281
262
|
}
|
|
282
263
|
/**
|
|
283
264
|
* Trace a chain/workflow
|
|
284
|
-
*
|
|
285
|
-
* @example
|
|
286
|
-
* ```typescript
|
|
287
|
-
* const result = await traceChain({
|
|
288
|
-
* name: 'customer_support_chain',
|
|
289
|
-
* }, async () => {
|
|
290
|
-
* // Multiple LLM calls, tools, etc.
|
|
291
|
-
* });
|
|
292
|
-
* ```
|
|
293
265
|
*/
|
|
294
266
|
function traceChain(options, fn) {
|
|
295
267
|
const t = getTracer();
|
|
296
268
|
return t.startActiveSpan(options.name, {
|
|
297
269
|
attributes: {
|
|
298
|
-
|
|
299
|
-
|
|
270
|
+
'openinference.span.kind': 'CHAIN',
|
|
271
|
+
'input.value': options.input ? JSON.stringify(options.input).substring(0, 10000) : undefined,
|
|
300
272
|
},
|
|
301
273
|
}, async (span) => {
|
|
302
274
|
const startTime = Date.now();
|
|
303
275
|
try {
|
|
304
276
|
const result = await fn();
|
|
305
|
-
span.setAttribute(
|
|
277
|
+
span.setAttribute('output.value', JSON.stringify(result).substring(0, 10000));
|
|
306
278
|
span.setStatus({ code: api_1.SpanStatusCode.OK });
|
|
307
279
|
return result;
|
|
308
280
|
}
|
|
@@ -313,327 +285,130 @@ function traceChain(options, fn) {
|
|
|
313
285
|
throw error;
|
|
314
286
|
}
|
|
315
287
|
finally {
|
|
316
|
-
span.setAttribute(
|
|
288
|
+
span.setAttribute('duration_ms', Date.now() - startTime);
|
|
317
289
|
span.end();
|
|
318
290
|
}
|
|
319
291
|
});
|
|
320
292
|
}
|
|
321
293
|
// ============================================================================
|
|
322
|
-
// EXPLAINER CLIENT
|
|
294
|
+
// V2 COMPATIBILITY - EXPLAINER CLIENT
|
|
323
295
|
// ============================================================================
|
|
324
296
|
/**
|
|
325
|
-
* Explainer API client
|
|
297
|
+
* Explainer API client (v2 compatibility)
|
|
298
|
+
* @deprecated Use runs and claims APIs instead
|
|
326
299
|
*/
|
|
327
300
|
exports.explainer = {
|
|
328
301
|
/**
|
|
329
|
-
* Analyze a trace
|
|
330
|
-
*
|
|
331
|
-
* @example
|
|
332
|
-
* ```typescript
|
|
333
|
-
* const result = await explainer.analyze({
|
|
334
|
-
* userMessage: 'Help me with my order #12345',
|
|
335
|
-
* agentResponse: 'I found your order...',
|
|
336
|
-
* outcome: 'success',
|
|
337
|
-
* spans: [
|
|
338
|
-
* { name: 'order_lookup', type: 'tool', durationMs: 150 },
|
|
339
|
-
* { name: 'gpt-4', type: 'llm', durationMs: 2500, model: 'gpt-4' },
|
|
340
|
-
* ],
|
|
341
|
-
* });
|
|
342
|
-
* ```
|
|
343
|
-
*/
|
|
344
|
-
async analyze(trace, options = {}) {
|
|
345
|
-
if (!initialized) {
|
|
346
|
-
throw new Error("ThinkHive SDK not initialized. Call init() first.");
|
|
347
|
-
}
|
|
348
|
-
const payload = {
|
|
349
|
-
trace: {
|
|
350
|
-
userMessage: trace.userMessage,
|
|
351
|
-
agentResponse: trace.agentResponse,
|
|
352
|
-
userIntent: trace.userIntent,
|
|
353
|
-
outcome: trace.outcome || 'success',
|
|
354
|
-
duration: trace.duration,
|
|
355
|
-
sessionId: trace.sessionId,
|
|
356
|
-
conversationHistory: trace.conversationHistory,
|
|
357
|
-
metadata: trace.metadata,
|
|
358
|
-
},
|
|
359
|
-
spans: trace.spans,
|
|
360
|
-
businessContext: trace.businessContext,
|
|
361
|
-
options: {
|
|
362
|
-
tier: options.tier,
|
|
363
|
-
includeRagEvaluation: options.includeRagEvaluation ?? true,
|
|
364
|
-
includeHallucinationCheck: options.includeHallucinationCheck ?? true,
|
|
365
|
-
},
|
|
366
|
-
};
|
|
367
|
-
if (options.waitForResult === false && options.webhookUrl) {
|
|
368
|
-
// Async analysis with webhook
|
|
369
|
-
return apiRequest('/explainer/analyze-async', {
|
|
370
|
-
method: 'POST',
|
|
371
|
-
body: { ...payload, webhookUrl: options.webhookUrl },
|
|
372
|
-
});
|
|
373
|
-
}
|
|
374
|
-
return apiRequest('/explainer/analyze', {
|
|
375
|
-
method: 'POST',
|
|
376
|
-
body: payload,
|
|
377
|
-
});
|
|
378
|
-
},
|
|
379
|
-
/**
|
|
380
|
-
* Batch analyze multiple traces
|
|
381
|
-
*
|
|
382
|
-
* @example
|
|
383
|
-
* ```typescript
|
|
384
|
-
* const results = await explainer.analyzeBatch([
|
|
385
|
-
* { userMessage: 'Q1', agentResponse: 'A1' },
|
|
386
|
-
* { userMessage: 'Q2', agentResponse: 'A2' },
|
|
387
|
-
* ]);
|
|
388
|
-
* ```
|
|
302
|
+
* Analyze a trace (v2 format)
|
|
303
|
+
* @deprecated Use runs.create() + claims.getRunAnalysis() instead
|
|
389
304
|
*/
|
|
390
|
-
async
|
|
391
|
-
|
|
392
|
-
throw new Error("ThinkHive SDK not initialized. Call init() first.");
|
|
393
|
-
}
|
|
394
|
-
return apiRequest('/explainer/analyze-batch', {
|
|
305
|
+
async analyze(traceData, options = {}) {
|
|
306
|
+
return (0, client_1.apiRequestWithData)('/explainer/analyze', {
|
|
395
307
|
method: 'POST',
|
|
396
308
|
body: {
|
|
397
|
-
|
|
398
|
-
userMessage:
|
|
399
|
-
agentResponse:
|
|
400
|
-
userIntent:
|
|
401
|
-
outcome:
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
309
|
+
trace: {
|
|
310
|
+
userMessage: traceData.userMessage,
|
|
311
|
+
agentResponse: traceData.agentResponse,
|
|
312
|
+
userIntent: traceData.userIntent,
|
|
313
|
+
outcome: traceData.outcome || 'success',
|
|
314
|
+
duration: traceData.duration,
|
|
315
|
+
sessionId: traceData.sessionId,
|
|
316
|
+
conversationHistory: traceData.conversationHistory,
|
|
317
|
+
metadata: traceData.metadata,
|
|
318
|
+
},
|
|
319
|
+
spans: traceData.spans,
|
|
320
|
+
businessContext: traceData.businessContext,
|
|
321
|
+
options: {
|
|
322
|
+
tier: options.tier,
|
|
323
|
+
includeRagEvaluation: options.includeRagEvaluation ?? true,
|
|
324
|
+
includeHallucinationCheck: options.includeHallucinationCheck ?? true,
|
|
325
|
+
},
|
|
407
326
|
},
|
|
327
|
+
apiVersion: 'v1',
|
|
408
328
|
});
|
|
409
329
|
},
|
|
410
330
|
/**
|
|
411
331
|
* Get a previously analyzed trace
|
|
332
|
+
* @deprecated
|
|
412
333
|
*/
|
|
413
334
|
async get(traceId) {
|
|
414
|
-
|
|
415
|
-
throw new Error("ThinkHive SDK not initialized. Call init() first.");
|
|
416
|
-
}
|
|
417
|
-
return apiRequest(`/explainer/${traceId}`);
|
|
335
|
+
return (0, client_1.apiRequestWithData)(`/explainer/${traceId}`, { apiVersion: 'v1' });
|
|
418
336
|
},
|
|
419
337
|
/**
|
|
420
338
|
* Search traces semantically
|
|
421
|
-
*
|
|
422
|
-
* @example
|
|
423
|
-
* ```typescript
|
|
424
|
-
* const results = await explainer.search({
|
|
425
|
-
* query: 'order refund issues',
|
|
426
|
-
* filters: { outcome: 'failure' },
|
|
427
|
-
* limit: 10,
|
|
428
|
-
* });
|
|
429
|
-
* ```
|
|
339
|
+
* @deprecated
|
|
430
340
|
*/
|
|
431
341
|
async search(params) {
|
|
432
|
-
|
|
433
|
-
throw new Error("ThinkHive SDK not initialized. Call init() first.");
|
|
434
|
-
}
|
|
435
|
-
return apiRequest('/explainer/search', {
|
|
342
|
+
return (0, client_1.apiRequestWithData)('/explainer/search', {
|
|
436
343
|
method: 'POST',
|
|
437
344
|
body: params,
|
|
345
|
+
apiVersion: 'v1',
|
|
438
346
|
});
|
|
439
347
|
},
|
|
440
348
|
};
|
|
441
349
|
// ============================================================================
|
|
442
|
-
// FEEDBACK CLIENT
|
|
443
|
-
// ============================================================================
|
|
444
|
-
/**
|
|
445
|
-
* Feedback API for improving analysis quality
|
|
446
|
-
*/
|
|
447
|
-
exports.feedback = {
|
|
448
|
-
/**
|
|
449
|
-
* Submit feedback for a trace
|
|
450
|
-
*
|
|
451
|
-
* @example
|
|
452
|
-
* ```typescript
|
|
453
|
-
* await feedback.submit({
|
|
454
|
-
* traceId: 'trace_123',
|
|
455
|
-
* rating: 5,
|
|
456
|
-
* wasHelpful: true,
|
|
457
|
-
* });
|
|
458
|
-
* ```
|
|
459
|
-
*/
|
|
460
|
-
async submit(options) {
|
|
461
|
-
if (!initialized) {
|
|
462
|
-
throw new Error("ThinkHive SDK not initialized. Call init() first.");
|
|
463
|
-
}
|
|
464
|
-
return apiRequest('/feedback', {
|
|
465
|
-
method: 'POST',
|
|
466
|
-
body: options,
|
|
467
|
-
});
|
|
468
|
-
},
|
|
469
|
-
};
|
|
470
|
-
// ============================================================================
|
|
471
|
-
// QUALITY METRICS CLIENT
|
|
472
|
-
// ============================================================================
|
|
473
|
-
/**
|
|
474
|
-
* Quality metrics API for RAG evaluation and hallucination detection
|
|
475
|
-
*/
|
|
476
|
-
exports.quality = {
|
|
477
|
-
/**
|
|
478
|
-
* Get RAG evaluation scores for a trace
|
|
479
|
-
*/
|
|
480
|
-
async getRagScores(traceId) {
|
|
481
|
-
if (!initialized) {
|
|
482
|
-
throw new Error("ThinkHive SDK not initialized. Call init() first.");
|
|
483
|
-
}
|
|
484
|
-
return apiRequest(`/quality/rag-scores/${traceId}`);
|
|
485
|
-
},
|
|
486
|
-
/**
|
|
487
|
-
* Get hallucination report for a trace
|
|
488
|
-
*/
|
|
489
|
-
async getHallucinationReport(traceId) {
|
|
490
|
-
if (!initialized) {
|
|
491
|
-
throw new Error("ThinkHive SDK not initialized. Call init() first.");
|
|
492
|
-
}
|
|
493
|
-
return apiRequest(`/quality/hallucination-report/${traceId}`);
|
|
494
|
-
},
|
|
495
|
-
/**
|
|
496
|
-
* Evaluate RAG quality for custom input
|
|
497
|
-
*/
|
|
498
|
-
async evaluateRag(input) {
|
|
499
|
-
if (!initialized) {
|
|
500
|
-
throw new Error("ThinkHive SDK not initialized. Call init() first.");
|
|
501
|
-
}
|
|
502
|
-
return apiRequest('/quality/evaluate-rag', {
|
|
503
|
-
method: 'POST',
|
|
504
|
-
body: input,
|
|
505
|
-
});
|
|
506
|
-
},
|
|
507
|
-
};
|
|
508
|
-
// ============================================================================
|
|
509
|
-
// ROI ANALYTICS CLIENT
|
|
510
|
-
// ============================================================================
|
|
511
|
-
/**
|
|
512
|
-
* ROI analytics API for business impact tracking
|
|
513
|
-
*/
|
|
514
|
-
exports.analytics = {
|
|
515
|
-
/**
|
|
516
|
-
* Get ROI summary for the account
|
|
517
|
-
*/
|
|
518
|
-
async getRoiSummary() {
|
|
519
|
-
if (!initialized) {
|
|
520
|
-
throw new Error("ThinkHive SDK not initialized. Call init() first.");
|
|
521
|
-
}
|
|
522
|
-
return apiRequest('/analytics/roi/summary');
|
|
523
|
-
},
|
|
524
|
-
/**
|
|
525
|
-
* Get ROI by agent
|
|
526
|
-
*/
|
|
527
|
-
async getRoiByAgent(agentId) {
|
|
528
|
-
if (!initialized) {
|
|
529
|
-
throw new Error("ThinkHive SDK not initialized. Call init() first.");
|
|
530
|
-
}
|
|
531
|
-
return apiRequest(`/analytics/roi/by-agent/${agentId}`);
|
|
532
|
-
},
|
|
533
|
-
/**
|
|
534
|
-
* Get correlation analysis
|
|
535
|
-
*/
|
|
536
|
-
async getCorrelations() {
|
|
537
|
-
if (!initialized) {
|
|
538
|
-
throw new Error("ThinkHive SDK not initialized. Call init() first.");
|
|
539
|
-
}
|
|
540
|
-
return apiRequest('/analytics/correlations');
|
|
541
|
-
},
|
|
542
|
-
};
|
|
543
|
-
// ============================================================================
|
|
544
350
|
// AUTO-INSTRUMENTATION
|
|
545
351
|
// ============================================================================
|
|
546
|
-
/**
|
|
547
|
-
* Setup auto-instrumentation for AI frameworks
|
|
548
|
-
*/
|
|
549
352
|
function setupAutoInstrumentation(frameworks) {
|
|
550
|
-
|
|
551
|
-
console.log(`Setting up auto-instrumentation for: ${frameworks.join(', ')}`);
|
|
552
|
-
}
|
|
553
|
-
// Note: Full auto-instrumentation requires framework-specific patches
|
|
554
|
-
// This is a placeholder for the instrumentation setup
|
|
555
|
-
// In production, use @opentelemetry/instrumentation-* packages
|
|
353
|
+
(0, config_1.debugLog)(`Setting up auto-instrumentation for: ${frameworks.join(', ')}`);
|
|
556
354
|
for (const framework of frameworks) {
|
|
557
355
|
try {
|
|
558
356
|
switch (framework) {
|
|
559
357
|
case 'openai':
|
|
560
|
-
|
|
358
|
+
case 'openai-assistants':
|
|
359
|
+
(0, config_1.debugLog)('OpenAI instrumentation ready (use instrumentOpenAIClient)');
|
|
561
360
|
break;
|
|
562
361
|
case 'langchain':
|
|
563
|
-
|
|
362
|
+
case 'langgraph':
|
|
363
|
+
(0, config_1.debugLog)('LangChain/LangGraph instrumentation ready (use ThinkHiveCallbackHandler)');
|
|
564
364
|
break;
|
|
565
365
|
case 'anthropic':
|
|
566
|
-
|
|
366
|
+
(0, config_1.debugLog)('Anthropic instrumentation ready');
|
|
567
367
|
break;
|
|
568
368
|
case 'llamaindex':
|
|
569
|
-
|
|
369
|
+
(0, config_1.debugLog)('LlamaIndex instrumentation ready');
|
|
370
|
+
break;
|
|
371
|
+
case 'n8n':
|
|
372
|
+
(0, config_1.debugLog)('n8n instrumentation ready');
|
|
373
|
+
break;
|
|
374
|
+
case 'voiceflow':
|
|
375
|
+
(0, config_1.debugLog)('Voiceflow instrumentation ready');
|
|
570
376
|
break;
|
|
571
377
|
}
|
|
572
378
|
}
|
|
573
379
|
catch (error) {
|
|
574
|
-
|
|
575
|
-
console.warn(`Failed to instrument ${framework}:`, error);
|
|
576
|
-
}
|
|
380
|
+
(0, config_1.debugLog)(`Failed to setup ${framework} instrumentation:`, error);
|
|
577
381
|
}
|
|
578
382
|
}
|
|
579
383
|
}
|
|
580
|
-
|
|
581
|
-
// Placeholder - would patch OpenAI client
|
|
582
|
-
if (config.debug) {
|
|
583
|
-
console.log('OpenAI instrumentation ready');
|
|
584
|
-
}
|
|
585
|
-
}
|
|
586
|
-
function instrumentLangChain() {
|
|
587
|
-
// Placeholder - would use LangChain callbacks
|
|
588
|
-
if (config.debug) {
|
|
589
|
-
console.log('LangChain instrumentation ready');
|
|
590
|
-
}
|
|
591
|
-
}
|
|
592
|
-
function instrumentAnthropic() {
|
|
593
|
-
// Placeholder - would patch Anthropic client
|
|
594
|
-
if (config.debug) {
|
|
595
|
-
console.log('Anthropic instrumentation ready');
|
|
596
|
-
}
|
|
597
|
-
}
|
|
598
|
-
function instrumentLlamaIndex() {
|
|
599
|
-
// Placeholder - would use LlamaIndex callbacks
|
|
600
|
-
if (config.debug) {
|
|
601
|
-
console.log('LlamaIndex instrumentation ready');
|
|
602
|
-
}
|
|
603
|
-
}
|
|
604
|
-
// ============================================================================
|
|
605
|
-
// CONVENIENCE FUNCTIONS
|
|
606
|
-
// ============================================================================
|
|
607
|
-
/**
|
|
608
|
-
* Create a trace and analyze it in one call
|
|
609
|
-
*
|
|
610
|
-
* @example
|
|
611
|
-
* ```typescript
|
|
612
|
-
* const { trace, analysis } = await createAndAnalyze({
|
|
613
|
-
* userMessage: 'Help me track my order',
|
|
614
|
-
* agentResponse: 'Your order is on the way...',
|
|
615
|
-
* });
|
|
616
|
-
* ```
|
|
617
|
-
*/
|
|
618
|
-
async function createAndAnalyze(traceData, options = {}) {
|
|
619
|
-
const analysis = await exports.explainer.analyze(traceData, options);
|
|
620
|
-
return { trace: traceData, analysis };
|
|
621
|
-
}
|
|
622
|
-
// ============================================================================
|
|
623
|
-
// EXPORTS
|
|
624
|
-
// ============================================================================
|
|
384
|
+
// Default export for convenience
|
|
625
385
|
exports.default = {
|
|
626
386
|
init,
|
|
627
387
|
getTracer,
|
|
628
|
-
|
|
388
|
+
shutdown,
|
|
389
|
+
isInitialized: config_1.isInitialized,
|
|
390
|
+
// Tracing
|
|
629
391
|
traceLLM,
|
|
630
392
|
traceRetrieval,
|
|
631
393
|
traceTool,
|
|
632
394
|
traceChain,
|
|
395
|
+
// API clients
|
|
396
|
+
runs: runs_1.runs,
|
|
397
|
+
claims: claims_1.claims,
|
|
398
|
+
calibration: calibration_1.calibration,
|
|
399
|
+
linking: ticket_linking_1.linking,
|
|
400
|
+
customerContext: customer_context_1.customerContext,
|
|
401
|
+
// V2 compatibility
|
|
633
402
|
explainer: exports.explainer,
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
403
|
+
// Helpers
|
|
404
|
+
generateZendeskMarker: ticket_linking_1.generateZendeskMarker,
|
|
405
|
+
parseZendeskMarker: ticket_linking_1.parseZendeskMarker,
|
|
406
|
+
linkRunToTicket: ticket_linking_1.linkRunToTicket,
|
|
407
|
+
createRunWithContext: runs_1.createRunWithContext,
|
|
408
|
+
// Utilities
|
|
409
|
+
isFact: claims_1.isFact,
|
|
410
|
+
isInference: claims_1.isInference,
|
|
411
|
+
calculateBrierScore: calibration_1.calculateBrierScore,
|
|
412
|
+
isWellCalibrated: calibration_1.isWellCalibrated,
|
|
638
413
|
};
|
|
639
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive TypeScript SDK\n * OpenTelemetry-based observability for AI agents with Explainer integration\n *\n * @version 2.0.0\n */\n\nimport { trace, context, SpanStatusCode, Span as OTelSpan } from \"@opentelemetry/api\";\nimport { OTLPTraceExporter } from \"@opentelemetry/exporter-trace-otlp-proto\";\nimport { Resource } from \"@opentelemetry/resources\";\nimport { NodeTracerProvider } from \"@opentelemetry/sdk-trace-node\";\nimport { BatchSpanProcessor } from \"@opentelemetry/sdk-trace-base\";\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface InitOptions {\n  /** ThinkHive API key (starts with th_) */\n  apiKey?: string;\n  /** Agent ID for legacy authentication */\n  agentId?: string;\n  /** ThinkHive API endpoint */\n  endpoint?: string;\n  /** Service name for traces */\n  serviceName?: string;\n  /** Enable auto-instrumentation */\n  autoInstrument?: boolean;\n  /** Frameworks to auto-instrument */\n  frameworks?: Array<'langchain' | 'openai' | 'anthropic' | 'llamaindex'>;\n  /** Enable debug logging */\n  debug?: boolean;\n}\n\nexport interface TraceOptions {\n  /** User's message/query */\n  userMessage: string;\n  /** Agent's response */\n  agentResponse: string;\n  /** User's detected intent */\n  userIntent?: string;\n  /** Outcome: success, failure, partial_success */\n  outcome?: 'success' | 'failure' | 'partial_success';\n  /** Duration in milliseconds */\n  duration?: number;\n  /** Session ID for conversation tracking */\n  sessionId?: string;\n  /** Conversation history */\n  conversationHistory?: Array<{ role: string; content: string }>;\n  /** Span data for detailed analysis */\n  spans?: SpanData[];\n  /** Business context for ROI calculation */\n  businessContext?: BusinessContext;\n  /** Custom metadata */\n  metadata?: Record<string, unknown>;\n}\n\nexport interface SpanData {\n  id?: string;\n  name: string;\n  type: 'llm' | 'tool' | 'retrieval' | 'embedding' | 'chain' | 'custom';\n  startTime?: Date;\n  endTime?: Date;\n  durationMs?: number;\n  status?: 'ok' | 'error' | 'timeout';\n  error?: string;\n  input?: unknown;\n  output?: unknown;\n  // LLM-specific\n  model?: string;\n  provider?: string;\n  promptTokens?: number;\n  completionTokens?: number;\n  // Tool-specific\n  toolName?: string;\n  toolParameters?: Record<string, unknown>;\n  // Retrieval-specific\n  query?: string;\n  documentCount?: number;\n  topScore?: number;\n  sources?: string[];\n  // Children\n  children?: SpanData[];\n}\n\nexport interface BusinessContext {\n  /** Customer ID */\n  customerId?: string;\n  /** Transaction value in dollars */\n  transactionValue?: number;\n  /** Priority level */\n  priority?: 'low' | 'medium' | 'high' | 'critical';\n  /** Department */\n  department?: string;\n  /** Industry vertical */\n  industry?: string;\n  /** Custom fields */\n  custom?: Record<string, unknown>;\n}\n\nexport interface ExplainabilityResult {\n  traceId: string;\n  explainabilityId: string;\n  summary: string;\n  outcome: {\n    verdict: 'success' | 'partial_success' | 'failure';\n    confidence: number;\n    reasoning: string;\n  };\n  businessImpact: {\n    impactScore: number;\n    customerSatisfaction: number;\n    revenueRisk: string;\n  };\n  recommendations: Array<{\n    priority: string;\n    category: string;\n    action: string;\n    expectedImpact: string;\n  }>;\n  ragEvaluation?: {\n    groundedness: number;\n    faithfulness: number;\n    answerRelevance: number;\n  };\n  hallucinationReport?: {\n    detected: boolean;\n    types: string[];\n    severity: string;\n  };\n  processingTimeMs: number;\n}\n\nexport interface AnalyzeOptions {\n  /** Force a specific analysis tier */\n  tier?: 'rule_based' | 'fast_llm' | 'full_llm' | 'deep';\n  /** Include RAG evaluation */\n  includeRagEvaluation?: boolean;\n  /** Include hallucination detection */\n  includeHallucinationCheck?: boolean;\n  /** Wait for analysis to complete (sync mode) */\n  waitForResult?: boolean;\n  /** Webhook URL for async notification */\n  webhookUrl?: string;\n}\n\nexport interface FeedbackOptions {\n  /** Trace ID to provide feedback for */\n  traceId: string;\n  /** User rating (1-5) */\n  rating?: number;\n  /** Was the response helpful */\n  wasHelpful?: boolean;\n  /** Specific issues encountered */\n  issues?: Array<'slow_response' | 'incorrect' | 'unhelpful' | 'hallucination' | 'off_topic' | 'other'>;\n  /** Free-form comment */\n  comment?: string;\n}\n\n// ============================================================================\n// GLOBAL STATE\n// ============================================================================\n\nlet tracer: ReturnType<typeof trace.getTracer> | null = null;\nlet initialized = false;\nlet config: Required<InitOptions>;\n\nconst DEFAULT_ENDPOINT = \"https://thinkhivemind-h25z7pvd3q-uc.a.run.app\";\n\n// ============================================================================\n// HTTP CLIENT\n// ============================================================================\n\nasync function apiRequest<T>(\n  path: string,\n  options: {\n    method?: 'GET' | 'POST' | 'PUT' | 'DELETE';\n    body?: unknown;\n    headers?: Record<string, string>;\n  } = {}\n): Promise<T> {\n  const { method = 'GET', body, headers = {} } = options;\n\n  const url = `${config.endpoint}/api/v1${path}`;\n\n  const requestHeaders: Record<string, string> = {\n    'Content-Type': 'application/json',\n    ...headers,\n  };\n\n  if (config.apiKey) {\n    requestHeaders['Authorization'] = `Bearer ${config.apiKey}`;\n  } else if (config.agentId) {\n    requestHeaders['X-Agent-ID'] = config.agentId;\n  }\n\n  const response = await fetch(url, {\n    method,\n    headers: requestHeaders,\n    body: body ? JSON.stringify(body) : undefined,\n  });\n\n  if (!response.ok) {\n    const error = await response.text();\n    throw new Error(`ThinkHive API error: ${response.status} - ${error}`);\n  }\n\n  return response.json() as Promise<T>;\n}\n\n// ============================================================================\n// INITIALIZATION\n// ============================================================================\n\n/**\n * Initialize ThinkHive SDK\n *\n * @example\n * ```typescript\n * import { init } from '@thinkhive/sdk';\n *\n * init({\n *   apiKey: 'th_your_api_key',\n *   serviceName: 'my-ai-agent',\n *   autoInstrument: true,\n *   frameworks: ['langchain', 'openai'],\n * });\n * ```\n */\nexport function init(options: InitOptions = {}): void {\n  if (initialized) {\n    if (options.debug) {\n      console.log('ThinkHive SDK already initialized');\n    }\n    return;\n  }\n\n  const apiKey = options.apiKey || process.env.THINKHIVE_API_KEY;\n  const agentId = options.agentId || process.env.THINKHIVE_AGENT_ID;\n\n  if (!apiKey && !agentId) {\n    throw new Error(\"Either apiKey or agentId must be provided (or set THINKHIVE_API_KEY env var)\");\n  }\n\n  config = {\n    apiKey: apiKey || '',\n    agentId: agentId || '',\n    endpoint: options.endpoint || process.env.THINKHIVE_ENDPOINT || DEFAULT_ENDPOINT,\n    serviceName: options.serviceName || process.env.THINKHIVE_SERVICE_NAME || 'my-ai-agent',\n    autoInstrument: options.autoInstrument ?? false,\n    frameworks: options.frameworks || ['langchain', 'openai'],\n    debug: options.debug ?? false,\n  };\n\n  // Configure OTLP exporter\n  const exporterHeaders: Record<string, string> = {};\n  if (config.apiKey) {\n    exporterHeaders[\"Authorization\"] = `Bearer ${config.apiKey}`;\n  } else if (config.agentId) {\n    exporterHeaders[\"X-Agent-ID\"] = config.agentId;\n  }\n\n  const exporter = new OTLPTraceExporter({\n    url: `${config.endpoint}/v1/traces`,\n    headers: exporterHeaders,\n  });\n\n  // Create OpenTelemetry resource\n  const resource = Resource.default().merge(\n    new Resource({\n      \"service.name\": config.serviceName,\n      \"thinkhive.sdk.version\": \"2.0.0\",\n      \"thinkhive.sdk.language\": \"typescript\",\n    })\n  );\n\n  // Create provider with span processor\n  const provider = new NodeTracerProvider({\n    resource,\n    spanProcessors: [new BatchSpanProcessor(exporter)],\n  });\n\n  // Register provider\n  provider.register();\n\n  // Get tracer\n  tracer = trace.getTracer(\"thinkhive\", \"2.0.0\");\n  initialized = true;\n\n  if (config.debug) {\n    console.log(`✅ ThinkHive SDK initialized`);\n    console.log(`   Endpoint: ${config.endpoint}`);\n    console.log(`   Service: ${config.serviceName}`);\n    console.log(`   Auto-instrument: ${config.autoInstrument}`);\n  }\n\n  // Setup auto-instrumentation if enabled\n  if (config.autoInstrument) {\n    setupAutoInstrumentation(config.frameworks);\n  }\n}\n\n/**\n * Get the global tracer\n */\nexport function getTracer() {\n  if (!initialized || !tracer) {\n    throw new Error(\"ThinkHive SDK not initialized. Call init() first.\");\n  }\n  return tracer;\n}\n\n/**\n * Check if SDK is initialized\n */\nexport function isInitialized(): boolean {\n  return initialized;\n}\n\n// ============================================================================\n// TRACING FUNCTIONS\n// ============================================================================\n\n/**\n * Trace an LLM call\n *\n * @example\n * ```typescript\n * const response = await traceLLM({\n *   name: 'chat_completion',\n *   modelName: 'gpt-4',\n *   provider: 'openai',\n * }, async () => {\n *   return await openai.chat.completions.create({ ... });\n * });\n * ```\n */\nexport function traceLLM<T>(\n  options: {\n    name: string;\n    modelName?: string;\n    provider?: string;\n    input?: unknown;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.name,\n    {\n      attributes: {\n        \"openinference.span.kind\": \"LLM\",\n        \"llm.model_name\": options.modelName,\n        \"llm.provider\": options.provider,\n        \"input.value\": options.input ? JSON.stringify(options.input).substring(0, 10000) : undefined,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        span.setAttribute(\"output.value\", JSON.stringify(result).substring(0, 10000));\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute(\"duration_ms\", Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n/**\n * Trace a retrieval operation\n *\n * @example\n * ```typescript\n * const docs = await traceRetrieval({\n *   name: 'vector_search',\n *   query: 'What is the return policy?',\n * }, async () => {\n *   return await vectorStore.similaritySearch(query, 5);\n * });\n * ```\n */\nexport function traceRetrieval<T>(\n  options: {\n    name: string;\n    query?: string;\n    topK?: number;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.name,\n    {\n      attributes: {\n        \"openinference.span.kind\": \"RETRIEVER\",\n        \"retrieval.query\": options.query,\n        \"retrieval.top_k\": options.topK,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n\n        // Try to extract document count from result\n        if (Array.isArray(result)) {\n          span.setAttribute(\"retrieval.document_count\", result.length);\n        }\n\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute(\"duration_ms\", Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n/**\n * Trace a tool call\n *\n * @example\n * ```typescript\n * const result = await traceTool({\n *   name: 'search_orders',\n *   toolName: 'OrderLookup',\n *   parameters: { orderId: '12345' },\n * }, async () => {\n *   return await orderService.lookup('12345');\n * });\n * ```\n */\nexport function traceTool<T>(\n  options: {\n    name: string;\n    toolName?: string;\n    parameters?: Record<string, unknown>;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.toolName || options.name,\n    {\n      attributes: {\n        \"openinference.span.kind\": \"TOOL\",\n        \"tool.name\": options.toolName || options.name,\n        \"tool.parameters\": options.parameters ? JSON.stringify(options.parameters) : undefined,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        span.setAttribute(\"tool.output\", JSON.stringify(result).substring(0, 10000));\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute(\"duration_ms\", Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n/**\n * Trace a chain/workflow\n *\n * @example\n * ```typescript\n * const result = await traceChain({\n *   name: 'customer_support_chain',\n * }, async () => {\n *   // Multiple LLM calls, tools, etc.\n * });\n * ```\n */\nexport function traceChain<T>(\n  options: {\n    name: string;\n    input?: unknown;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.name,\n    {\n      attributes: {\n        \"openinference.span.kind\": \"CHAIN\",\n        \"input.value\": options.input ? JSON.stringify(options.input).substring(0, 10000) : undefined,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        span.setAttribute(\"output.value\", JSON.stringify(result).substring(0, 10000));\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute(\"duration_ms\", Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n// ============================================================================\n// EXPLAINER CLIENT\n// ============================================================================\n\n/**\n * Explainer API client for trace analysis\n */\nexport const explainer = {\n  /**\n   * Analyze a trace and get explainability insights\n   *\n   * @example\n   * ```typescript\n   * const result = await explainer.analyze({\n   *   userMessage: 'Help me with my order #12345',\n   *   agentResponse: 'I found your order...',\n   *   outcome: 'success',\n   *   spans: [\n   *     { name: 'order_lookup', type: 'tool', durationMs: 150 },\n   *     { name: 'gpt-4', type: 'llm', durationMs: 2500, model: 'gpt-4' },\n   *   ],\n   * });\n   * ```\n   */\n  async analyze(\n    trace: TraceOptions,\n    options: AnalyzeOptions = {}\n  ): Promise<ExplainabilityResult> {\n    if (!initialized) {\n      throw new Error(\"ThinkHive SDK not initialized. Call init() first.\");\n    }\n\n    const payload = {\n      trace: {\n        userMessage: trace.userMessage,\n        agentResponse: trace.agentResponse,\n        userIntent: trace.userIntent,\n        outcome: trace.outcome || 'success',\n        duration: trace.duration,\n        sessionId: trace.sessionId,\n        conversationHistory: trace.conversationHistory,\n        metadata: trace.metadata,\n      },\n      spans: trace.spans,\n      businessContext: trace.businessContext,\n      options: {\n        tier: options.tier,\n        includeRagEvaluation: options.includeRagEvaluation ?? true,\n        includeHallucinationCheck: options.includeHallucinationCheck ?? true,\n      },\n    };\n\n    if (options.waitForResult === false && options.webhookUrl) {\n      // Async analysis with webhook\n      return apiRequest<ExplainabilityResult>('/explainer/analyze-async', {\n        method: 'POST',\n        body: { ...payload, webhookUrl: options.webhookUrl },\n      });\n    }\n\n    return apiRequest<ExplainabilityResult>('/explainer/analyze', {\n      method: 'POST',\n      body: payload,\n    });\n  },\n\n  /**\n   * Batch analyze multiple traces\n   *\n   * @example\n   * ```typescript\n   * const results = await explainer.analyzeBatch([\n   *   { userMessage: 'Q1', agentResponse: 'A1' },\n   *   { userMessage: 'Q2', agentResponse: 'A2' },\n   * ]);\n   * ```\n   */\n  async analyzeBatch(\n    traces: TraceOptions[],\n    options: AnalyzeOptions = {}\n  ): Promise<{\n    results: ExplainabilityResult[];\n    summary: {\n      total: number;\n      successCount: number;\n      failureCount: number;\n      averageProcessingTime: number;\n    };\n  }> {\n    if (!initialized) {\n      throw new Error(\"ThinkHive SDK not initialized. Call init() first.\");\n    }\n\n    return apiRequest('/explainer/analyze-batch', {\n      method: 'POST',\n      body: {\n        traces: traces.map(t => ({\n          userMessage: t.userMessage,\n          agentResponse: t.agentResponse,\n          userIntent: t.userIntent,\n          outcome: t.outcome || 'success',\n          spans: t.spans,\n          businessContext: t.businessContext,\n          metadata: t.metadata,\n        })),\n        options,\n      },\n    });\n  },\n\n  /**\n   * Get a previously analyzed trace\n   */\n  async get(traceId: string): Promise<ExplainabilityResult> {\n    if (!initialized) {\n      throw new Error(\"ThinkHive SDK not initialized. Call init() first.\");\n    }\n\n    return apiRequest<ExplainabilityResult>(`/explainer/${traceId}`);\n  },\n\n  /**\n   * Search traces semantically\n   *\n   * @example\n   * ```typescript\n   * const results = await explainer.search({\n   *   query: 'order refund issues',\n   *   filters: { outcome: 'failure' },\n   *   limit: 10,\n   * });\n   * ```\n   */\n  async search(params: {\n    query: string;\n    filters?: {\n      outcome?: 'success' | 'failure' | 'partial_success';\n      minImpactScore?: number;\n      dateRange?: { from: Date; to: Date };\n    };\n    limit?: number;\n  }): Promise<{\n    results: Array<ExplainabilityResult & { similarity: number }>;\n    total: number;\n  }> {\n    if (!initialized) {\n      throw new Error(\"ThinkHive SDK not initialized. Call init() first.\");\n    }\n\n    return apiRequest('/explainer/search', {\n      method: 'POST',\n      body: params,\n    });\n  },\n};\n\n// ============================================================================\n// FEEDBACK CLIENT\n// ============================================================================\n\n/**\n * Feedback API for improving analysis quality\n */\nexport const feedback = {\n  /**\n   * Submit feedback for a trace\n   *\n   * @example\n   * ```typescript\n   * await feedback.submit({\n   *   traceId: 'trace_123',\n   *   rating: 5,\n   *   wasHelpful: true,\n   * });\n   * ```\n   */\n  async submit(options: FeedbackOptions): Promise<{ success: boolean }> {\n    if (!initialized) {\n      throw new Error(\"ThinkHive SDK not initialized. Call init() first.\");\n    }\n\n    return apiRequest('/feedback', {\n      method: 'POST',\n      body: options,\n    });\n  },\n};\n\n// ============================================================================\n// QUALITY METRICS CLIENT\n// ============================================================================\n\n/**\n * Quality metrics API for RAG evaluation and hallucination detection\n */\nexport const quality = {\n  /**\n   * Get RAG evaluation scores for a trace\n   */\n  async getRagScores(traceId: string): Promise<{\n    contextRelevance: number;\n    contextPrecision: number;\n    contextRecall: number;\n    groundedness: number;\n    faithfulness: number;\n    answerRelevance: number;\n    citationAccuracy: number;\n    citationCompleteness: number;\n    overallGrade: string;\n  }> {\n    if (!initialized) {\n      throw new Error(\"ThinkHive SDK not initialized. Call init() first.\");\n    }\n\n    return apiRequest(`/quality/rag-scores/${traceId}`);\n  },\n\n  /**\n   * Get hallucination report for a trace\n   */\n  async getHallucinationReport(traceId: string): Promise<{\n    hasHallucinations: boolean;\n    severity: 'none' | 'low' | 'medium' | 'high';\n    confidence: number;\n    detectedTypes: Array<{\n      type: string;\n      description: string;\n      evidence: string;\n      severity: string;\n    }>;\n  }> {\n    if (!initialized) {\n      throw new Error(\"ThinkHive SDK not initialized. Call init() first.\");\n    }\n\n    return apiRequest(`/quality/hallucination-report/${traceId}`);\n  },\n\n  /**\n   * Evaluate RAG quality for custom input\n   */\n  async evaluateRag(input: {\n    query: string;\n    response: string;\n    contexts: Array<{ content: string; source?: string; score?: number }>;\n  }): Promise<{\n    scores: Record<string, number>;\n    grade: string;\n    groundedSpans: string[];\n    ungroundedSpans: string[];\n  }> {\n    if (!initialized) {\n      throw new Error(\"ThinkHive SDK not initialized. Call init() first.\");\n    }\n\n    return apiRequest('/quality/evaluate-rag', {\n      method: 'POST',\n      body: input,\n    });\n  },\n};\n\n// ============================================================================\n// ROI ANALYTICS CLIENT\n// ============================================================================\n\n/**\n * ROI analytics API for business impact tracking\n */\nexport const analytics = {\n  /**\n   * Get ROI summary for the account\n   */\n  async getRoiSummary(): Promise<{\n    totalRevenueSaved: number;\n    supportCostReduction: number;\n    averageResolutionTime: number;\n    customerSatisfaction: number;\n    trends: Array<{\n      date: string;\n      revenueSaved: number;\n      tracesAnalyzed: number;\n    }>;\n  }> {\n    if (!initialized) {\n      throw new Error(\"ThinkHive SDK not initialized. Call init() first.\");\n    }\n\n    return apiRequest('/analytics/roi/summary');\n  },\n\n  /**\n   * Get ROI by agent\n   */\n  async getRoiByAgent(agentId: string): Promise<{\n    agentId: string;\n    revenueSaved: number;\n    tracesAnalyzed: number;\n    successRate: number;\n    topIssues: Array<{ issue: string; count: number; impact: number }>;\n  }> {\n    if (!initialized) {\n      throw new Error(\"ThinkHive SDK not initialized. Call init() first.\");\n    }\n\n    return apiRequest(`/analytics/roi/by-agent/${agentId}`);\n  },\n\n  /**\n   * Get correlation analysis\n   */\n  async getCorrelations(): Promise<{\n    correlations: Array<{\n      type: string;\n      coefficient: number;\n      description: string;\n      actionableInsight: string;\n    }>;\n  }> {\n    if (!initialized) {\n      throw new Error(\"ThinkHive SDK not initialized. Call init() first.\");\n    }\n\n    return apiRequest('/analytics/correlations');\n  },\n};\n\n// ============================================================================\n// AUTO-INSTRUMENTATION\n// ============================================================================\n\n/**\n * Setup auto-instrumentation for AI frameworks\n */\nfunction setupAutoInstrumentation(\n  frameworks: Array<'langchain' | 'openai' | 'anthropic' | 'llamaindex'>\n): void {\n  if (config.debug) {\n    console.log(`Setting up auto-instrumentation for: ${frameworks.join(', ')}`);\n  }\n\n  // Note: Full auto-instrumentation requires framework-specific patches\n  // This is a placeholder for the instrumentation setup\n  // In production, use @opentelemetry/instrumentation-* packages\n\n  for (const framework of frameworks) {\n    try {\n      switch (framework) {\n        case 'openai':\n          instrumentOpenAI();\n          break;\n        case 'langchain':\n          instrumentLangChain();\n          break;\n        case 'anthropic':\n          instrumentAnthropic();\n          break;\n        case 'llamaindex':\n          instrumentLlamaIndex();\n          break;\n      }\n    } catch (error) {\n      if (config.debug) {\n        console.warn(`Failed to instrument ${framework}:`, error);\n      }\n    }\n  }\n}\n\nfunction instrumentOpenAI(): void {\n  // Placeholder - would patch OpenAI client\n  if (config.debug) {\n    console.log('OpenAI instrumentation ready');\n  }\n}\n\nfunction instrumentLangChain(): void {\n  // Placeholder - would use LangChain callbacks\n  if (config.debug) {\n    console.log('LangChain instrumentation ready');\n  }\n}\n\nfunction instrumentAnthropic(): void {\n  // Placeholder - would patch Anthropic client\n  if (config.debug) {\n    console.log('Anthropic instrumentation ready');\n  }\n}\n\nfunction instrumentLlamaIndex(): void {\n  // Placeholder - would use LlamaIndex callbacks\n  if (config.debug) {\n    console.log('LlamaIndex instrumentation ready');\n  }\n}\n\n// ============================================================================\n// CONVENIENCE FUNCTIONS\n// ============================================================================\n\n/**\n * Create a trace and analyze it in one call\n *\n * @example\n * ```typescript\n * const { trace, analysis } = await createAndAnalyze({\n *   userMessage: 'Help me track my order',\n *   agentResponse: 'Your order is on the way...',\n * });\n * ```\n */\nexport async function createAndAnalyze(\n  traceData: TraceOptions,\n  options: AnalyzeOptions = {}\n): Promise<{\n  trace: TraceOptions;\n  analysis: ExplainabilityResult;\n}> {\n  const analysis = await explainer.analyze(traceData, options);\n  return { trace: traceData, analysis };\n}\n\n// ============================================================================\n// EXPORTS\n// ============================================================================\n\nexport default {\n  init,\n  getTracer,\n  isInitialized,\n  traceLLM,\n  traceRetrieval,\n  traceTool,\n  traceChain,\n  explainer,\n  feedback,\n  quality,\n  analytics,\n  createAndAnalyze,\n};\n"]}
|
|
414
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.0.0\n *\n * Run-centric AI agent observability platform with:\n * - Facts vs Inferences (claims API)\n * - Deterministic ticket linking (7 methods)\n * - Customer context snapshots (time-series)\n * - Calibrated predictions (Brier scores)\n *\n * @version 3.0.0\n * @license MIT\n */\n\nimport { trace, context, SpanStatusCode } from '@opentelemetry/api';\nimport { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-proto';\nimport { Resource } from '@opentelemetry/resources';\nimport { NodeTracerProvider } from '@opentelemetry/sdk-trace-node';\nimport { BatchSpanProcessor } from '@opentelemetry/sdk-trace-base';\n\n// Core\nimport {\n  initConfig,\n  getConfig,\n  isInitialized,\n  resetConfig,\n  debugLog,\n  SDK_VERSION,\n  DEFAULT_ENDPOINT,\n} from './core/config';\nimport { apiRequest, apiRequestWithData, ThinkHiveApiError, ThinkHiveValidationError } from './core/client';\n\n// API clients\nimport { runs, createRunWithContext, toOpenAIMessages, fromOpenAIMessages } from './api/runs';\nimport {\n  claims,\n  isFact,\n  isInference,\n  isComputed,\n  getHighConfidenceClaims,\n  groupClaimsByType,\n  groupClaimsByCategory,\n} from './api/claims';\nimport {\n  calibration,\n  calculateBrierScore,\n  calculateECE,\n  isWellCalibrated,\n  getCalibrationQuality,\n} from './api/calibration';\n\n// Integrations\nimport {\n  linking,\n  generateZendeskMarker,\n  parseZendeskMarker,\n  hasZendeskMarker,\n  removeZendeskMarker,\n  linkRunToTicket,\n  linkRunToZendeskTicket,\n  getBestLinkMethod,\n  LINK_METHOD_CONFIDENCE,\n} from './integrations/ticket-linking';\nimport {\n  customerContext,\n  captureCustomerContext,\n  getContextAsOf,\n  toContextSnapshot,\n  calculateArrChange,\n  calculateHealthTrend,\n} from './integrations/customer-context';\n\n// Re-export types\nexport type {\n  InitOptions,\n  Framework,\n  RunOptions,\n  RunOutcome,\n  ConversationMessage,\n  CustomerContextSnapshot,\n  TicketLinkingOptions,\n  LinkMethod,\n  TraceOptions,\n  SpanData,\n  BusinessContext,\n  Claim,\n  ClaimType,\n  ClaimCategory,\n  ConfidenceCalibration,\n  EvidenceReference,\n  AnalysisResult,\n  CalibrationStatus,\n  CalibrationBucket,\n  PredictionType,\n  RoiConfig,\n  RoiSummary,\n  ExplainabilityResult,\n  ApiResponse,\n  PaginatedResponse,\n  RunResponse,\n} from './core/types';\n\n// ============================================================================\n// GLOBAL STATE\n// ============================================================================\n\nlet tracer: ReturnType<typeof trace.getTracer> | null = null;\nlet provider: NodeTracerProvider | null = null;\n\n// ============================================================================\n// INITIALIZATION\n// ============================================================================\n\n/**\n * Initialize ThinkHive SDK v3\n *\n * @example\n * ```typescript\n * import { init } from '@thinkhive/sdk';\n *\n * init({\n *   apiKey: 'th_your_api_key',\n *   serviceName: 'my-ai-agent',\n *   autoInstrument: true,\n *   frameworks: ['langchain', 'openai'],\n * });\n * ```\n */\nexport function init(options: import('./core/types').InitOptions = {}): void {\n  if (isInitialized()) {\n    debugLog('ThinkHive SDK already initialized');\n    return;\n  }\n\n  const config = initConfig(options);\n\n  // Configure OTLP exporter\n  const exporterHeaders: Record<string, string> = {};\n  if (config.apiKey) {\n    exporterHeaders['Authorization'] = `Bearer ${config.apiKey}`;\n  } else if (config.agentId) {\n    exporterHeaders['X-Agent-ID'] = config.agentId;\n  }\n\n  const exporter = new OTLPTraceExporter({\n    url: `${config.endpoint}/v1/traces`,\n    headers: exporterHeaders,\n  });\n\n  // Create OpenTelemetry resource\n  const resource = Resource.default().merge(\n    new Resource({\n      'service.name': config.serviceName,\n      'thinkhive.sdk.version': SDK_VERSION,\n      'thinkhive.sdk.language': 'typescript',\n      'thinkhive.api.version': config.apiVersion,\n    })\n  );\n\n  // Create provider with span processor\n  provider = new NodeTracerProvider({\n    resource,\n    spanProcessors: [new BatchSpanProcessor(exporter)],\n  });\n\n  // Register provider\n  provider.register();\n\n  // Get tracer\n  tracer = trace.getTracer('thinkhive', SDK_VERSION);\n\n  if (config.debug) {\n    console.log(`✅ ThinkHive SDK v${SDK_VERSION} initialized`);\n    console.log(`   Endpoint: ${config.endpoint}`);\n    console.log(`   Service: ${config.serviceName}`);\n    console.log(`   API Version: ${config.apiVersion}`);\n    console.log(`   Auto-instrument: ${config.autoInstrument}`);\n  }\n\n  // Setup auto-instrumentation if enabled\n  if (config.autoInstrument) {\n    setupAutoInstrumentation(config.frameworks);\n  }\n}\n\n/**\n * Get the global tracer\n */\nexport function getTracer() {\n  if (!tracer) {\n    throw new Error('ThinkHive SDK not initialized. Call init() first.');\n  }\n  return tracer;\n}\n\n/**\n * Shutdown the SDK and flush pending spans\n */\nexport async function shutdown(): Promise<void> {\n  if (provider) {\n    await provider.shutdown();\n    provider = null;\n  }\n  tracer = null;\n  resetConfig();\n  debugLog('ThinkHive SDK shutdown complete');\n}\n\n// ============================================================================\n// TRACING FUNCTIONS\n// ============================================================================\n\n/**\n * Trace an LLM call\n */\nexport function traceLLM<T>(\n  options: {\n    name: string;\n    modelName?: string;\n    provider?: string;\n    input?: unknown;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.name,\n    {\n      attributes: {\n        'openinference.span.kind': 'LLM',\n        'llm.model_name': options.modelName,\n        'llm.provider': options.provider,\n        'input.value': options.input ? JSON.stringify(options.input).substring(0, 10000) : undefined,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        span.setAttribute('output.value', JSON.stringify(result).substring(0, 10000));\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute('duration_ms', Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n/**\n * Trace a retrieval operation\n */\nexport function traceRetrieval<T>(\n  options: {\n    name: string;\n    query?: string;\n    topK?: number;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.name,\n    {\n      attributes: {\n        'openinference.span.kind': 'RETRIEVER',\n        'retrieval.query': options.query,\n        'retrieval.top_k': options.topK,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        if (Array.isArray(result)) {\n          span.setAttribute('retrieval.document_count', result.length);\n        }\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute('duration_ms', Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n/**\n * Trace a tool call\n */\nexport function traceTool<T>(\n  options: {\n    name: string;\n    toolName?: string;\n    parameters?: Record<string, unknown>;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.toolName || options.name,\n    {\n      attributes: {\n        'openinference.span.kind': 'TOOL',\n        'tool.name': options.toolName || options.name,\n        'tool.parameters': options.parameters ? JSON.stringify(options.parameters) : undefined,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        span.setAttribute('tool.output', JSON.stringify(result).substring(0, 10000));\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute('duration_ms', Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n/**\n * Trace a chain/workflow\n */\nexport function traceChain<T>(\n  options: {\n    name: string;\n    input?: unknown;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.name,\n    {\n      attributes: {\n        'openinference.span.kind': 'CHAIN',\n        'input.value': options.input ? JSON.stringify(options.input).substring(0, 10000) : undefined,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        span.setAttribute('output.value', JSON.stringify(result).substring(0, 10000));\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute('duration_ms', Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n// ============================================================================\n// V2 COMPATIBILITY - EXPLAINER CLIENT\n// ============================================================================\n\n/**\n * Explainer API client (v2 compatibility)\n * @deprecated Use runs and claims APIs instead\n */\nexport const explainer = {\n  /**\n   * Analyze a trace (v2 format)\n   * @deprecated Use runs.create() + claims.getRunAnalysis() instead\n   */\n  async analyze(\n    traceData: import('./core/types').TraceOptions,\n    options: {\n      tier?: string;\n      includeRagEvaluation?: boolean;\n      includeHallucinationCheck?: boolean;\n      waitForResult?: boolean;\n      webhookUrl?: string;\n    } = {}\n  ): Promise<import('./core/types').ExplainabilityResult> {\n    return apiRequestWithData('/explainer/analyze', {\n      method: 'POST',\n      body: {\n        trace: {\n          userMessage: traceData.userMessage,\n          agentResponse: traceData.agentResponse,\n          userIntent: traceData.userIntent,\n          outcome: traceData.outcome || 'success',\n          duration: traceData.duration,\n          sessionId: traceData.sessionId,\n          conversationHistory: traceData.conversationHistory,\n          metadata: traceData.metadata,\n        },\n        spans: traceData.spans,\n        businessContext: traceData.businessContext,\n        options: {\n          tier: options.tier,\n          includeRagEvaluation: options.includeRagEvaluation ?? true,\n          includeHallucinationCheck: options.includeHallucinationCheck ?? true,\n        },\n      },\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Get a previously analyzed trace\n   * @deprecated\n   */\n  async get(traceId: string): Promise<import('./core/types').ExplainabilityResult> {\n    return apiRequestWithData(`/explainer/${traceId}`, { apiVersion: 'v1' });\n  },\n\n  /**\n   * Search traces semantically\n   * @deprecated\n   */\n  async search(params: {\n    query: string;\n    filters?: {\n      outcome?: string;\n      minImpactScore?: number;\n      dateRange?: { from: Date; to: Date };\n    };\n    limit?: number;\n  }): Promise<{\n    results: Array<import('./core/types').ExplainabilityResult & { similarity: number }>;\n    total: number;\n  }> {\n    return apiRequestWithData('/explainer/search', {\n      method: 'POST',\n      body: params,\n      apiVersion: 'v1',\n    });\n  },\n};\n\n// ============================================================================\n// AUTO-INSTRUMENTATION\n// ============================================================================\n\nfunction setupAutoInstrumentation(\n  frameworks: import('./core/types').Framework[]\n): void {\n  debugLog(`Setting up auto-instrumentation for: ${frameworks.join(', ')}`);\n\n  for (const framework of frameworks) {\n    try {\n      switch (framework) {\n        case 'openai':\n        case 'openai-assistants':\n          debugLog('OpenAI instrumentation ready (use instrumentOpenAIClient)');\n          break;\n        case 'langchain':\n        case 'langgraph':\n          debugLog('LangChain/LangGraph instrumentation ready (use ThinkHiveCallbackHandler)');\n          break;\n        case 'anthropic':\n          debugLog('Anthropic instrumentation ready');\n          break;\n        case 'llamaindex':\n          debugLog('LlamaIndex instrumentation ready');\n          break;\n        case 'n8n':\n          debugLog('n8n instrumentation ready');\n          break;\n        case 'voiceflow':\n          debugLog('Voiceflow instrumentation ready');\n          break;\n      }\n    } catch (error) {\n      debugLog(`Failed to setup ${framework} instrumentation:`, error);\n    }\n  }\n}\n\n// ============================================================================\n// RE-EXPORTS (non-duplicated)\n// ============================================================================\n\n// Re-export from config (not yet exported)\nexport { isInitialized, SDK_VERSION, DEFAULT_ENDPOINT };\n\n// Re-export API clients (v3)\nexport {\n  runs,\n  claims,\n  calibration,\n  linking,\n  customerContext,\n};\n\n// Re-export helper functions\nexport {\n  // Runs helpers\n  createRunWithContext,\n  toOpenAIMessages,\n  fromOpenAIMessages,\n  // Claims helpers\n  isFact,\n  isInference,\n  isComputed,\n  getHighConfidenceClaims,\n  groupClaimsByType,\n  groupClaimsByCategory,\n  // Calibration helpers\n  calculateBrierScore,\n  calculateECE,\n  isWellCalibrated,\n  getCalibrationQuality,\n  // Linking helpers\n  generateZendeskMarker,\n  parseZendeskMarker,\n  hasZendeskMarker,\n  removeZendeskMarker,\n  linkRunToTicket,\n  linkRunToZendeskTicket,\n  getBestLinkMethod,\n  LINK_METHOD_CONFIDENCE,\n  // Customer context helpers\n  captureCustomerContext,\n  getContextAsOf,\n  toContextSnapshot,\n  calculateArrChange,\n  calculateHealthTrend,\n};\n\n// Re-export errors\nexport { ThinkHiveApiError, ThinkHiveValidationError };\n\n// Default export for convenience\nexport default {\n  init,\n  getTracer,\n  shutdown,\n  isInitialized,\n  // Tracing\n  traceLLM,\n  traceRetrieval,\n  traceTool,\n  traceChain,\n  // API clients\n  runs,\n  claims,\n  calibration,\n  linking,\n  customerContext,\n  // V2 compatibility\n  explainer,\n  // Helpers\n  generateZendeskMarker,\n  parseZendeskMarker,\n  linkRunToTicket,\n  createRunWithContext,\n  // Utilities\n  isFact,\n  isInference,\n  calculateBrierScore,\n  isWellCalibrated,\n};\n"]}
|