@thinkhive/sdk 3.1.1 → 4.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 +83 -12
- package/README.md +279 -128
- package/dist/api/agents.d.ts +169 -0
- package/dist/api/agents.js +185 -0
- package/dist/api/apiKeys.d.ts +252 -0
- package/dist/api/apiKeys.js +298 -0
- package/dist/api/business-metrics.d.ts +188 -0
- package/dist/api/business-metrics.js +213 -0
- package/dist/api/calibration.d.ts +0 -62
- package/dist/api/calibration.js +5 -48
- package/dist/api/claims.js +10 -7
- package/dist/api/conversation-eval.d.ts +200 -0
- package/dist/api/conversation-eval.js +235 -0
- package/dist/api/deterministic-graders.d.ts +205 -0
- package/dist/api/deterministic-graders.js +191 -0
- package/dist/api/eval-health.d.ts +250 -0
- package/dist/api/eval-health.js +224 -0
- package/dist/api/human-review.d.ts +275 -0
- package/dist/api/human-review.js +236 -0
- package/dist/api/nondeterminism.d.ts +300 -0
- package/dist/api/nondeterminism.js +250 -0
- package/dist/api/quality-metrics.d.ts +303 -0
- package/dist/api/quality-metrics.js +198 -0
- package/dist/api/roi-analytics.d.ts +263 -0
- package/dist/api/roi-analytics.js +204 -0
- package/dist/api/runs.js +12 -6
- package/dist/api/transcript-patterns.d.ts +204 -0
- package/dist/api/transcript-patterns.js +227 -0
- package/dist/core/client.d.ts +83 -9
- package/dist/core/client.js +229 -34
- package/dist/core/config.d.ts +2 -3
- package/dist/core/config.js +3 -4
- package/dist/core/types.d.ts +57 -4
- package/dist/core/types.js +1 -1
- package/dist/index.d.ts +429 -76
- package/dist/index.js +262 -42
- package/package.json +2 -2
package/dist/index.js
CHANGED
|
@@ -12,7 +12,9 @@
|
|
|
12
12
|
* @license MIT
|
|
13
13
|
*/
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.
|
|
15
|
+
exports.requiredPassRateForPassAtK = exports.calculatePassToK = exports.calculatePassAtK = 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.businessMetrics = exports.qualityMetrics = exports.roiAnalytics = exports.agents = exports.apiKeys = exports.transcriptPatterns = exports.conversationEval = exports.deterministicGraders = exports.evalHealth = exports.nondeterminism = exports.humanReview = exports.customerContext = exports.linking = exports.calibration = exports.claims = exports.runs = exports.DEFAULT_ENDPOINT = exports.SDK_VERSION = exports.isInitialized = exports.analyzer = exports.issues = void 0;
|
|
16
|
+
exports.getStatusMessage = exports.isMetricStale = exports.awaitingExternalData = exports.needsMoreTraces = exports.isMetricReady = exports.getGradeColor = exports.formatQualityScore = exports.getQualityRecommendations = exports.isHallucinationRiskAcceptable = exports.passesQualityThreshold = exports.getROIQuality = exports.formatCurrency = exports.calculateAutomationSavings = exports.calculateRevenueAtRisk = exports.canAccessAgent = exports.getTimeUntilExpiry = exports.isApiKeyValid = exports.isApiKeyExpired = exports.hasPermission = exports.sortMatchesBySeverity = exports.needsAttention = exports.getRecommendations = exports.getCategoryDistribution = exports.hasEscalationRequest = exports.hasFrustrationSignals = exports.hasPiiExposure = exports.getCriticalInsights = exports.getMatchesByCategory = exports.isHighRisk = exports.analyzeConversationTrend = exports.getProblematicTurns = exports.getAggregator = exports.aggregateMajority = exports.aggregateFinalTurn = exports.aggregateWeighted = exports.aggregateAverage = exports.aggregateWorst = exports.calculateAverageScore = exports.getFailedRules = exports.allRulesPassed = exports.createJsonSchemaRule = exports.createLengthRule = exports.createContainsRule = exports.createRegexRule = exports.getSaturationRecommendation = exports.isSaturated = exports.getHealthSeverityLevel = exports.hasHealthIssue = exports.getReliabilityRecommendation = exports.isReliableEvaluation = void 0;
|
|
17
|
+
exports.IpWhitelistError = exports.RateLimitError = exports.AgentScopeError = exports.PermissionDeniedError = exports.ThinkHiveValidationError = exports.ThinkHiveApiError = exports.ThinkHiveError = exports.getTrendEmoji = exports.formatMetricValue = exports.getTraceProgress = void 0;
|
|
16
18
|
exports.init = init;
|
|
17
19
|
exports.getTracer = getTracer;
|
|
18
20
|
exports.shutdown = shutdown;
|
|
@@ -31,8 +33,13 @@ Object.defineProperty(exports, "isInitialized", { enumerable: true, get: functio
|
|
|
31
33
|
Object.defineProperty(exports, "SDK_VERSION", { enumerable: true, get: function () { return config_1.SDK_VERSION; } });
|
|
32
34
|
Object.defineProperty(exports, "DEFAULT_ENDPOINT", { enumerable: true, get: function () { return config_1.DEFAULT_ENDPOINT; } });
|
|
33
35
|
const client_1 = require("./core/client");
|
|
36
|
+
Object.defineProperty(exports, "ThinkHiveError", { enumerable: true, get: function () { return client_1.ThinkHiveError; } });
|
|
34
37
|
Object.defineProperty(exports, "ThinkHiveApiError", { enumerable: true, get: function () { return client_1.ThinkHiveApiError; } });
|
|
35
38
|
Object.defineProperty(exports, "ThinkHiveValidationError", { enumerable: true, get: function () { return client_1.ThinkHiveValidationError; } });
|
|
39
|
+
Object.defineProperty(exports, "PermissionDeniedError", { enumerable: true, get: function () { return client_1.PermissionDeniedError; } });
|
|
40
|
+
Object.defineProperty(exports, "AgentScopeError", { enumerable: true, get: function () { return client_1.AgentScopeError; } });
|
|
41
|
+
Object.defineProperty(exports, "RateLimitError", { enumerable: true, get: function () { return client_1.RateLimitError; } });
|
|
42
|
+
Object.defineProperty(exports, "IpWhitelistError", { enumerable: true, get: function () { return client_1.IpWhitelistError; } });
|
|
36
43
|
// API clients
|
|
37
44
|
const runs_1 = require("./api/runs");
|
|
38
45
|
Object.defineProperty(exports, "runs", { enumerable: true, get: function () { return runs_1.runs; } });
|
|
@@ -53,6 +60,90 @@ Object.defineProperty(exports, "calculateBrierScore", { enumerable: true, get: f
|
|
|
53
60
|
Object.defineProperty(exports, "calculateECE", { enumerable: true, get: function () { return calibration_1.calculateECE; } });
|
|
54
61
|
Object.defineProperty(exports, "isWellCalibrated", { enumerable: true, get: function () { return calibration_1.isWellCalibrated; } });
|
|
55
62
|
Object.defineProperty(exports, "getCalibrationQuality", { enumerable: true, get: function () { return calibration_1.getCalibrationQuality; } });
|
|
63
|
+
// New Evaluation APIs
|
|
64
|
+
const human_review_1 = require("./api/human-review");
|
|
65
|
+
Object.defineProperty(exports, "humanReview", { enumerable: true, get: function () { return human_review_1.humanReview; } });
|
|
66
|
+
const nondeterminism_1 = require("./api/nondeterminism");
|
|
67
|
+
Object.defineProperty(exports, "nondeterminism", { enumerable: true, get: function () { return nondeterminism_1.nondeterminism; } });
|
|
68
|
+
Object.defineProperty(exports, "calculatePassAtK", { enumerable: true, get: function () { return nondeterminism_1.calculatePassAtK; } });
|
|
69
|
+
Object.defineProperty(exports, "calculatePassToK", { enumerable: true, get: function () { return nondeterminism_1.calculatePassToK; } });
|
|
70
|
+
Object.defineProperty(exports, "requiredPassRateForPassAtK", { enumerable: true, get: function () { return nondeterminism_1.requiredPassRateForPassAtK; } });
|
|
71
|
+
Object.defineProperty(exports, "isReliableEvaluation", { enumerable: true, get: function () { return nondeterminism_1.isReliableEvaluation; } });
|
|
72
|
+
Object.defineProperty(exports, "getReliabilityRecommendation", { enumerable: true, get: function () { return nondeterminism_1.getReliabilityRecommendation; } });
|
|
73
|
+
const eval_health_1 = require("./api/eval-health");
|
|
74
|
+
Object.defineProperty(exports, "evalHealth", { enumerable: true, get: function () { return eval_health_1.evalHealth; } });
|
|
75
|
+
Object.defineProperty(exports, "hasHealthIssue", { enumerable: true, get: function () { return eval_health_1.hasHealthIssue; } });
|
|
76
|
+
Object.defineProperty(exports, "getHealthSeverityLevel", { enumerable: true, get: function () { return eval_health_1.getSeverityLevel; } });
|
|
77
|
+
Object.defineProperty(exports, "isSaturated", { enumerable: true, get: function () { return eval_health_1.isSaturated; } });
|
|
78
|
+
Object.defineProperty(exports, "getSaturationRecommendation", { enumerable: true, get: function () { return eval_health_1.getSaturationRecommendation; } });
|
|
79
|
+
const deterministic_graders_1 = require("./api/deterministic-graders");
|
|
80
|
+
Object.defineProperty(exports, "deterministicGraders", { enumerable: true, get: function () { return deterministic_graders_1.deterministicGraders; } });
|
|
81
|
+
Object.defineProperty(exports, "createRegexRule", { enumerable: true, get: function () { return deterministic_graders_1.createRegexRule; } });
|
|
82
|
+
Object.defineProperty(exports, "createContainsRule", { enumerable: true, get: function () { return deterministic_graders_1.createContainsRule; } });
|
|
83
|
+
Object.defineProperty(exports, "createLengthRule", { enumerable: true, get: function () { return deterministic_graders_1.createLengthRule; } });
|
|
84
|
+
Object.defineProperty(exports, "createJsonSchemaRule", { enumerable: true, get: function () { return deterministic_graders_1.createJsonSchemaRule; } });
|
|
85
|
+
Object.defineProperty(exports, "allRulesPassed", { enumerable: true, get: function () { return deterministic_graders_1.allRulesPassed; } });
|
|
86
|
+
Object.defineProperty(exports, "getFailedRules", { enumerable: true, get: function () { return deterministic_graders_1.getFailedRules; } });
|
|
87
|
+
Object.defineProperty(exports, "calculateAverageScore", { enumerable: true, get: function () { return deterministic_graders_1.calculateAverageScore; } });
|
|
88
|
+
const conversation_eval_1 = require("./api/conversation-eval");
|
|
89
|
+
Object.defineProperty(exports, "conversationEval", { enumerable: true, get: function () { return conversation_eval_1.conversationEval; } });
|
|
90
|
+
Object.defineProperty(exports, "aggregateWorst", { enumerable: true, get: function () { return conversation_eval_1.aggregateWorst; } });
|
|
91
|
+
Object.defineProperty(exports, "aggregateAverage", { enumerable: true, get: function () { return conversation_eval_1.aggregateAverage; } });
|
|
92
|
+
Object.defineProperty(exports, "aggregateWeighted", { enumerable: true, get: function () { return conversation_eval_1.aggregateWeighted; } });
|
|
93
|
+
Object.defineProperty(exports, "aggregateFinalTurn", { enumerable: true, get: function () { return conversation_eval_1.aggregateFinalTurn; } });
|
|
94
|
+
Object.defineProperty(exports, "aggregateMajority", { enumerable: true, get: function () { return conversation_eval_1.aggregateMajority; } });
|
|
95
|
+
Object.defineProperty(exports, "getAggregator", { enumerable: true, get: function () { return conversation_eval_1.getAggregator; } });
|
|
96
|
+
Object.defineProperty(exports, "getProblematicTurns", { enumerable: true, get: function () { return conversation_eval_1.getProblematicTurns; } });
|
|
97
|
+
Object.defineProperty(exports, "analyzeConversationTrend", { enumerable: true, get: function () { return conversation_eval_1.analyzeConversationTrend; } });
|
|
98
|
+
const transcript_patterns_1 = require("./api/transcript-patterns");
|
|
99
|
+
Object.defineProperty(exports, "transcriptPatterns", { enumerable: true, get: function () { return transcript_patterns_1.transcriptPatterns; } });
|
|
100
|
+
Object.defineProperty(exports, "isHighRisk", { enumerable: true, get: function () { return transcript_patterns_1.isHighRisk; } });
|
|
101
|
+
Object.defineProperty(exports, "getMatchesByCategory", { enumerable: true, get: function () { return transcript_patterns_1.getMatchesByCategory; } });
|
|
102
|
+
Object.defineProperty(exports, "getCriticalInsights", { enumerable: true, get: function () { return transcript_patterns_1.getCriticalInsights; } });
|
|
103
|
+
Object.defineProperty(exports, "hasPiiExposure", { enumerable: true, get: function () { return transcript_patterns_1.hasPiiExposure; } });
|
|
104
|
+
Object.defineProperty(exports, "hasFrustrationSignals", { enumerable: true, get: function () { return transcript_patterns_1.hasFrustrationSignals; } });
|
|
105
|
+
Object.defineProperty(exports, "hasEscalationRequest", { enumerable: true, get: function () { return transcript_patterns_1.hasEscalationRequest; } });
|
|
106
|
+
Object.defineProperty(exports, "getCategoryDistribution", { enumerable: true, get: function () { return transcript_patterns_1.getCategoryDistribution; } });
|
|
107
|
+
Object.defineProperty(exports, "getRecommendations", { enumerable: true, get: function () { return transcript_patterns_1.getRecommendations; } });
|
|
108
|
+
Object.defineProperty(exports, "needsAttention", { enumerable: true, get: function () { return transcript_patterns_1.needsAttention; } });
|
|
109
|
+
Object.defineProperty(exports, "sortMatchesBySeverity", { enumerable: true, get: function () { return transcript_patterns_1.sortMatchesBySeverity; } });
|
|
110
|
+
// Agents Management
|
|
111
|
+
const agents_1 = require("./api/agents");
|
|
112
|
+
Object.defineProperty(exports, "agents", { enumerable: true, get: function () { return agents_1.agents; } });
|
|
113
|
+
// API Key Management (Phase 2 Security)
|
|
114
|
+
const apiKeys_1 = require("./api/apiKeys");
|
|
115
|
+
Object.defineProperty(exports, "apiKeys", { enumerable: true, get: function () { return apiKeys_1.apiKeys; } });
|
|
116
|
+
Object.defineProperty(exports, "hasPermission", { enumerable: true, get: function () { return apiKeys_1.hasPermission; } });
|
|
117
|
+
Object.defineProperty(exports, "isApiKeyExpired", { enumerable: true, get: function () { return apiKeys_1.isExpired; } });
|
|
118
|
+
Object.defineProperty(exports, "isApiKeyValid", { enumerable: true, get: function () { return apiKeys_1.isValid; } });
|
|
119
|
+
Object.defineProperty(exports, "getTimeUntilExpiry", { enumerable: true, get: function () { return apiKeys_1.getTimeUntilExpiry; } });
|
|
120
|
+
Object.defineProperty(exports, "canAccessAgent", { enumerable: true, get: function () { return apiKeys_1.canAccessAgent; } });
|
|
121
|
+
// ROI Analytics API
|
|
122
|
+
const roi_analytics_1 = require("./api/roi-analytics");
|
|
123
|
+
Object.defineProperty(exports, "roiAnalytics", { enumerable: true, get: function () { return roi_analytics_1.roiAnalytics; } });
|
|
124
|
+
Object.defineProperty(exports, "calculateRevenueAtRisk", { enumerable: true, get: function () { return roi_analytics_1.calculateRevenueAtRisk; } });
|
|
125
|
+
Object.defineProperty(exports, "calculateAutomationSavings", { enumerable: true, get: function () { return roi_analytics_1.calculateAutomationSavings; } });
|
|
126
|
+
Object.defineProperty(exports, "formatCurrency", { enumerable: true, get: function () { return roi_analytics_1.formatCurrency; } });
|
|
127
|
+
Object.defineProperty(exports, "getROIQuality", { enumerable: true, get: function () { return roi_analytics_1.getROIQuality; } });
|
|
128
|
+
// Business Metrics API
|
|
129
|
+
const business_metrics_1 = require("./api/business-metrics");
|
|
130
|
+
Object.defineProperty(exports, "businessMetrics", { enumerable: true, get: function () { return business_metrics_1.businessMetrics; } });
|
|
131
|
+
Object.defineProperty(exports, "isMetricReady", { enumerable: true, get: function () { return business_metrics_1.isMetricReady; } });
|
|
132
|
+
Object.defineProperty(exports, "needsMoreTraces", { enumerable: true, get: function () { return business_metrics_1.needsMoreTraces; } });
|
|
133
|
+
Object.defineProperty(exports, "awaitingExternalData", { enumerable: true, get: function () { return business_metrics_1.awaitingExternalData; } });
|
|
134
|
+
Object.defineProperty(exports, "isMetricStale", { enumerable: true, get: function () { return business_metrics_1.isMetricStale; } });
|
|
135
|
+
Object.defineProperty(exports, "getStatusMessage", { enumerable: true, get: function () { return business_metrics_1.getStatusMessage; } });
|
|
136
|
+
Object.defineProperty(exports, "getTraceProgress", { enumerable: true, get: function () { return business_metrics_1.getTraceProgress; } });
|
|
137
|
+
Object.defineProperty(exports, "formatMetricValue", { enumerable: true, get: function () { return business_metrics_1.formatMetricValue; } });
|
|
138
|
+
Object.defineProperty(exports, "getTrendEmoji", { enumerable: true, get: function () { return business_metrics_1.getTrendEmoji; } });
|
|
139
|
+
// Quality Metrics API
|
|
140
|
+
const quality_metrics_1 = require("./api/quality-metrics");
|
|
141
|
+
Object.defineProperty(exports, "qualityMetrics", { enumerable: true, get: function () { return quality_metrics_1.qualityMetrics; } });
|
|
142
|
+
Object.defineProperty(exports, "passesQualityThreshold", { enumerable: true, get: function () { return quality_metrics_1.passesQualityThreshold; } });
|
|
143
|
+
Object.defineProperty(exports, "isHallucinationRiskAcceptable", { enumerable: true, get: function () { return quality_metrics_1.isHallucinationRiskAcceptable; } });
|
|
144
|
+
Object.defineProperty(exports, "getQualityRecommendations", { enumerable: true, get: function () { return quality_metrics_1.getQualityRecommendations; } });
|
|
145
|
+
Object.defineProperty(exports, "formatQualityScore", { enumerable: true, get: function () { return quality_metrics_1.formatQualityScore; } });
|
|
146
|
+
Object.defineProperty(exports, "getGradeColor", { enumerable: true, get: function () { return quality_metrics_1.getGradeColor; } });
|
|
56
147
|
// Integrations
|
|
57
148
|
const ticket_linking_1 = require("./integrations/ticket-linking");
|
|
58
149
|
Object.defineProperty(exports, "linking", { enumerable: true, get: function () { return ticket_linking_1.linking; } });
|
|
@@ -105,11 +196,12 @@ function init(options = {}) {
|
|
|
105
196
|
if (config.apiKey) {
|
|
106
197
|
exporterHeaders['Authorization'] = `Bearer ${config.apiKey}`;
|
|
107
198
|
}
|
|
108
|
-
else
|
|
109
|
-
|
|
199
|
+
else {
|
|
200
|
+
throw new Error('OTLP tracing requires an API key. Agent ID alone is not sufficient for OTLP ingestion. ' +
|
|
201
|
+
'Provide apiKey in init() or set the THINKHIVE_API_KEY environment variable.');
|
|
110
202
|
}
|
|
111
203
|
const exporter = new exporter_trace_otlp_proto_1.OTLPTraceExporter({
|
|
112
|
-
url:
|
|
204
|
+
url: config.endpoint,
|
|
113
205
|
headers: exporterHeaders,
|
|
114
206
|
});
|
|
115
207
|
// Create OpenTelemetry resource
|
|
@@ -117,7 +209,6 @@ function init(options = {}) {
|
|
|
117
209
|
'service.name': config.serviceName,
|
|
118
210
|
'thinkhive.sdk.version': config_1.SDK_VERSION,
|
|
119
211
|
'thinkhive.sdk.language': 'typescript',
|
|
120
|
-
'thinkhive.api.version': config.apiVersion,
|
|
121
212
|
}));
|
|
122
213
|
// Create provider with span processor
|
|
123
214
|
provider = new sdk_trace_node_1.NodeTracerProvider({
|
|
@@ -132,7 +223,6 @@ function init(options = {}) {
|
|
|
132
223
|
console.log(`✅ ThinkHive SDK v${config_1.SDK_VERSION} initialized`);
|
|
133
224
|
console.log(` Endpoint: ${config.endpoint}`);
|
|
134
225
|
console.log(` Service: ${config.serviceName}`);
|
|
135
|
-
console.log(` API Version: ${config.apiVersion}`);
|
|
136
226
|
console.log(` Auto-instrument: ${config.autoInstrument}`);
|
|
137
227
|
}
|
|
138
228
|
// Setup auto-instrumentation if enabled
|
|
@@ -291,59 +381,159 @@ function traceChain(options, fn) {
|
|
|
291
381
|
});
|
|
292
382
|
}
|
|
293
383
|
// ============================================================================
|
|
294
|
-
// V2
|
|
384
|
+
// V2 TERMINOLOGY - ISSUES API (replaces Cases)
|
|
385
|
+
// Per ITIL best practices, "Issues" is more customer-friendly than "Cases"
|
|
295
386
|
// ============================================================================
|
|
296
387
|
/**
|
|
297
|
-
*
|
|
298
|
-
*
|
|
388
|
+
* Issues API client
|
|
389
|
+
* This is the recommended API for managing clustered failure patterns
|
|
390
|
+
*
|
|
391
|
+
* @since 3.1.0
|
|
299
392
|
*/
|
|
300
|
-
exports.
|
|
393
|
+
exports.issues = {
|
|
394
|
+
/**
|
|
395
|
+
* List issues for an agent
|
|
396
|
+
*/
|
|
397
|
+
async list(agentId, options) {
|
|
398
|
+
const params = new URLSearchParams({ agentId });
|
|
399
|
+
if (options?.status)
|
|
400
|
+
params.set('status', options.status);
|
|
401
|
+
if (options?.startDate)
|
|
402
|
+
params.set('startDate', options.startDate.toISOString());
|
|
403
|
+
if (options?.endDate)
|
|
404
|
+
params.set('endDate', options.endDate.toISOString());
|
|
405
|
+
if (options?.limit)
|
|
406
|
+
params.set('limit', options.limit.toString());
|
|
407
|
+
if (options?.offset)
|
|
408
|
+
params.set('offset', options.offset.toString());
|
|
409
|
+
const response = await (0, client_1.apiRequestWithData)(`/issues?${params}`, { apiVersion: 'v2' });
|
|
410
|
+
return response.data || response;
|
|
411
|
+
},
|
|
301
412
|
/**
|
|
302
|
-
*
|
|
303
|
-
* @deprecated Use runs.create() + claims.getRunAnalysis() instead
|
|
413
|
+
* Get a single issue by ID
|
|
304
414
|
*/
|
|
305
|
-
async
|
|
306
|
-
|
|
415
|
+
async get(id) {
|
|
416
|
+
const response = await (0, client_1.apiRequestWithData)(`/issues/${id}`, { apiVersion: 'v2' });
|
|
417
|
+
return response.data || response;
|
|
418
|
+
},
|
|
419
|
+
/**
|
|
420
|
+
* Create a new issue
|
|
421
|
+
*/
|
|
422
|
+
async create(data) {
|
|
423
|
+
const response = await (0, client_1.apiRequestWithData)('/issues', {
|
|
424
|
+
method: 'POST',
|
|
425
|
+
body: data,
|
|
426
|
+
apiVersion: 'v2',
|
|
427
|
+
});
|
|
428
|
+
return response.data || response;
|
|
429
|
+
},
|
|
430
|
+
/**
|
|
431
|
+
* Update an issue
|
|
432
|
+
*/
|
|
433
|
+
async update(id, data) {
|
|
434
|
+
const response = await (0, client_1.apiRequestWithData)(`/issues/${id}`, {
|
|
435
|
+
method: 'PATCH',
|
|
436
|
+
body: data,
|
|
437
|
+
apiVersion: 'v2',
|
|
438
|
+
});
|
|
439
|
+
return response.data || response;
|
|
440
|
+
},
|
|
441
|
+
/**
|
|
442
|
+
* Get fixes for an issue
|
|
443
|
+
*/
|
|
444
|
+
async getFixes(issueId) {
|
|
445
|
+
const response = await (0, client_1.apiRequestWithData)(`/issues/${issueId}/fixes`, { apiVersion: 'v2' });
|
|
446
|
+
return response.data || response;
|
|
447
|
+
},
|
|
448
|
+
};
|
|
449
|
+
// ============================================================================
|
|
450
|
+
// V2 TERMINOLOGY - ANALYZER API (replaces Explainer user-facing)
|
|
451
|
+
// Per industry distinction: Analyzer = pattern detection/observation
|
|
452
|
+
// ============================================================================
|
|
453
|
+
/**
|
|
454
|
+
* Analyzer API client
|
|
455
|
+
* User-selected trace analysis with cost estimation and smart sampling
|
|
456
|
+
*
|
|
457
|
+
* Key improvements over v1 Explainer:
|
|
458
|
+
* - User-selected trace analysis (not automatic)
|
|
459
|
+
* - Cost estimation before execution
|
|
460
|
+
* - Smart sampling strategies
|
|
461
|
+
* - Root cause analysis by layer
|
|
462
|
+
* - Pattern aggregation across traces
|
|
463
|
+
*
|
|
464
|
+
* @since 3.1.0
|
|
465
|
+
*/
|
|
466
|
+
exports.analyzer = {
|
|
467
|
+
/**
|
|
468
|
+
* Analyze specific traces (user-selected)
|
|
469
|
+
*/
|
|
470
|
+
async analyze(options) {
|
|
471
|
+
const { traceIds, tier, includeRootCause, includeLayers } = options;
|
|
472
|
+
const response = await (0, client_1.apiRequestWithData)('/analyzer/analyze', {
|
|
307
473
|
method: 'POST',
|
|
308
474
|
body: {
|
|
309
|
-
|
|
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,
|
|
475
|
+
traceIds,
|
|
321
476
|
options: {
|
|
322
|
-
tier
|
|
323
|
-
|
|
324
|
-
|
|
477
|
+
tier,
|
|
478
|
+
includeRootCause,
|
|
479
|
+
includeLayers,
|
|
325
480
|
},
|
|
326
481
|
},
|
|
327
|
-
apiVersion: '
|
|
482
|
+
apiVersion: 'v2',
|
|
328
483
|
});
|
|
484
|
+
return response.data || response;
|
|
329
485
|
},
|
|
330
486
|
/**
|
|
331
|
-
*
|
|
332
|
-
|
|
487
|
+
* Analyze traces by time window
|
|
488
|
+
*/
|
|
489
|
+
async analyzeWindow(options) {
|
|
490
|
+
const response = await (0, client_1.apiRequestWithData)('/analyzer/analyze-window', {
|
|
491
|
+
method: 'POST',
|
|
492
|
+
body: {
|
|
493
|
+
...options,
|
|
494
|
+
startDate: options.startDate.toISOString(),
|
|
495
|
+
endDate: options.endDate.toISOString(),
|
|
496
|
+
},
|
|
497
|
+
apiVersion: 'v2',
|
|
498
|
+
});
|
|
499
|
+
return response.data || response;
|
|
500
|
+
},
|
|
501
|
+
/**
|
|
502
|
+
* Estimate cost before running analysis
|
|
503
|
+
*/
|
|
504
|
+
async estimateCost(options) {
|
|
505
|
+
const response = await (0, client_1.apiRequestWithData)('/analyzer/estimate-cost', {
|
|
506
|
+
method: 'POST',
|
|
507
|
+
body: {
|
|
508
|
+
...options,
|
|
509
|
+
startDate: options.startDate?.toISOString(),
|
|
510
|
+
endDate: options.endDate?.toISOString(),
|
|
511
|
+
},
|
|
512
|
+
apiVersion: 'v2',
|
|
513
|
+
});
|
|
514
|
+
return response.data || response;
|
|
515
|
+
},
|
|
516
|
+
/**
|
|
517
|
+
* Get analysis results for a specific trace
|
|
333
518
|
*/
|
|
334
519
|
async get(traceId) {
|
|
335
|
-
|
|
520
|
+
const response = await (0, client_1.apiRequestWithData)(`/analyzer/${traceId}`, { apiVersion: 'v2' });
|
|
521
|
+
return response.data || response;
|
|
336
522
|
},
|
|
337
523
|
/**
|
|
338
|
-
*
|
|
339
|
-
* @deprecated
|
|
524
|
+
* Aggregate insights across multiple analyzed traces
|
|
340
525
|
*/
|
|
341
|
-
async
|
|
342
|
-
|
|
526
|
+
async summarize(options) {
|
|
527
|
+
const response = await (0, client_1.apiRequestWithData)('/analyzer/summarize', {
|
|
343
528
|
method: 'POST',
|
|
344
|
-
body:
|
|
345
|
-
|
|
529
|
+
body: {
|
|
530
|
+
...options,
|
|
531
|
+
startDate: options.startDate?.toISOString(),
|
|
532
|
+
endDate: options.endDate?.toISOString(),
|
|
533
|
+
},
|
|
534
|
+
apiVersion: 'v2',
|
|
346
535
|
});
|
|
536
|
+
return response.data || response;
|
|
347
537
|
},
|
|
348
538
|
};
|
|
349
539
|
// ============================================================================
|
|
@@ -398,8 +588,24 @@ exports.default = {
|
|
|
398
588
|
calibration: calibration_1.calibration,
|
|
399
589
|
linking: ticket_linking_1.linking,
|
|
400
590
|
customerContext: customer_context_1.customerContext,
|
|
401
|
-
//
|
|
402
|
-
|
|
591
|
+
// Evaluation APIs
|
|
592
|
+
humanReview: human_review_1.humanReview,
|
|
593
|
+
nondeterminism: nondeterminism_1.nondeterminism,
|
|
594
|
+
evalHealth: eval_health_1.evalHealth,
|
|
595
|
+
deterministicGraders: deterministic_graders_1.deterministicGraders,
|
|
596
|
+
conversationEval: conversation_eval_1.conversationEval,
|
|
597
|
+
transcriptPatterns: transcript_patterns_1.transcriptPatterns,
|
|
598
|
+
// API Key Management (Phase 2 Security)
|
|
599
|
+
apiKeys: apiKeys_1.apiKeys,
|
|
600
|
+
// Agents Management
|
|
601
|
+
agents: agents_1.agents,
|
|
602
|
+
// Issues and Analyzer APIs
|
|
603
|
+
issues: exports.issues,
|
|
604
|
+
analyzer: exports.analyzer,
|
|
605
|
+
// ROI Analytics, Quality Metrics, and Business Metrics
|
|
606
|
+
roiAnalytics: roi_analytics_1.roiAnalytics,
|
|
607
|
+
qualityMetrics: quality_metrics_1.qualityMetrics,
|
|
608
|
+
businessMetrics: business_metrics_1.businessMetrics,
|
|
403
609
|
// Helpers
|
|
404
610
|
generateZendeskMarker: ticket_linking_1.generateZendeskMarker,
|
|
405
611
|
parseZendeskMarker: ticket_linking_1.parseZendeskMarker,
|
|
@@ -410,5 +616,19 @@ exports.default = {
|
|
|
410
616
|
isInference: claims_1.isInference,
|
|
411
617
|
calculateBrierScore: calibration_1.calculateBrierScore,
|
|
412
618
|
isWellCalibrated: calibration_1.isWellCalibrated,
|
|
619
|
+
calculatePassAtK: nondeterminism_1.calculatePassAtK,
|
|
620
|
+
isReliableEvaluation: nondeterminism_1.isReliableEvaluation,
|
|
621
|
+
isHighRisk: transcript_patterns_1.isHighRisk,
|
|
622
|
+
needsAttention: transcript_patterns_1.needsAttention,
|
|
623
|
+
// ROI helpers
|
|
624
|
+
calculateRevenueAtRisk: roi_analytics_1.calculateRevenueAtRisk,
|
|
625
|
+
formatCurrency: roi_analytics_1.formatCurrency,
|
|
626
|
+
// Quality helpers
|
|
627
|
+
passesQualityThreshold: quality_metrics_1.passesQualityThreshold,
|
|
628
|
+
isHallucinationRiskAcceptable: quality_metrics_1.isHallucinationRiskAcceptable,
|
|
629
|
+
// Business Metrics helpers
|
|
630
|
+
isMetricReady: business_metrics_1.isMetricReady,
|
|
631
|
+
needsMoreTraces: business_metrics_1.needsMoreTraces,
|
|
632
|
+
getStatusMessage: business_metrics_1.getStatusMessage,
|
|
413
633
|
};
|
|
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"]}
|
|
634
|
+
//# 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 {\n  apiRequestWithData,\n  ThinkHiveError,\n  ThinkHiveApiError,\n  ThinkHiveValidationError,\n  PermissionDeniedError,\n  AgentScopeError,\n  RateLimitError,\n  IpWhitelistError,\n} 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// New Evaluation APIs\nimport { humanReview } from './api/human-review';\nimport {\n  nondeterminism,\n  calculatePassAtK,\n  calculatePassToK,\n  requiredPassRateForPassAtK,\n  isReliableEvaluation,\n  getReliabilityRecommendation,\n} from './api/nondeterminism';\nimport {\n  evalHealth,\n  hasHealthIssue,\n  getSeverityLevel as getHealthSeverityLevel,\n  isSaturated,\n  getSaturationRecommendation,\n} from './api/eval-health';\nimport {\n  deterministicGraders,\n  createRegexRule,\n  createContainsRule,\n  createLengthRule,\n  createJsonSchemaRule,\n  allRulesPassed,\n  getFailedRules,\n  calculateAverageScore,\n} from './api/deterministic-graders';\nimport {\n  conversationEval,\n  aggregateWorst,\n  aggregateAverage,\n  aggregateWeighted,\n  aggregateFinalTurn,\n  aggregateMajority,\n  getAggregator,\n  getProblematicTurns,\n  analyzeConversationTrend,\n} from './api/conversation-eval';\nimport {\n  transcriptPatterns,\n  isHighRisk,\n  getMatchesByCategory,\n  getCriticalInsights,\n  hasPiiExposure,\n  hasFrustrationSignals,\n  hasEscalationRequest,\n  getCategoryDistribution,\n  getRecommendations,\n  needsAttention,\n  sortMatchesBySeverity,\n} from './api/transcript-patterns';\n\n// Agents Management\nimport {\n  agents,\n} from './api/agents';\n\n// API Key Management (Phase 2 Security)\nimport {\n  apiKeys,\n  hasPermission,\n  isExpired as isApiKeyExpired,\n  isValid as isApiKeyValid,\n  getTimeUntilExpiry,\n  canAccessAgent,\n} from './api/apiKeys';\n\n// ROI Analytics API\nimport {\n  roiAnalytics,\n  calculateRevenueAtRisk,\n  calculateAutomationSavings,\n  formatCurrency,\n  getROIQuality,\n} from './api/roi-analytics';\n\n// Business Metrics API\nimport {\n  businessMetrics,\n  isMetricReady,\n  needsMoreTraces,\n  awaitingExternalData,\n  isMetricStale,\n  getStatusMessage,\n  getTraceProgress,\n  formatMetricValue,\n  getTrendEmoji,\n} from './api/business-metrics';\n\n// Quality Metrics API\nimport {\n  qualityMetrics,\n  passesQualityThreshold,\n  isHallucinationRiskAcceptable,\n  getQualityRecommendations,\n  formatQualityScore,\n  getGradeColor,\n} from './api/quality-metrics';\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  TraceCustomFlag,\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// Re-export evaluation types\nexport type {\n  HumanReviewStatus,\n  HumanReviewType,\n  HumanReviewQueueItem,\n  CalibrationSet,\n  ReviewerCalibration,\n  QueueStats,\n} from './api/human-review';\n\nexport type {\n  NondeterminismRunType,\n  NondeterminismRunStatus,\n  NondeterminismRun,\n  NondeterminismSample,\n  TraceAnalysis,\n  CriterionAnalysis,\n  RunSummary,\n} from './api/nondeterminism';\n\nexport type {\n  SaturationType,\n  HealthStatus,\n  RegressionSeverity,\n  EvalHealthSnapshot,\n  EvalRegression,\n  HealthReport,\n} from './api/eval-health';\n\nexport type {\n  RuleType,\n  DeterministicEvalResult,\n  RuleResult,\n  RuleTypeInfo,\n  RuleTemplate,\n} from './api/deterministic-graders';\n\nexport type {\n  AggregateMethod,\n  SessionTrace,\n  TurnEvaluation,\n  ConversationEvalResult,\n  AggregationMethodInfo,\n} from './api/conversation-eval';\n\nexport type {\n  PatternCategory,\n  PatternOutcome,\n  PatternSeverity,\n  PatternMatch,\n  PatternInsight,\n  AnalysisResult as PatternAnalysisResult,\n  PatternCategoryInfo,\n  BuiltInPattern,\n} from './api/transcript-patterns';\n\n// Re-export API Key types (Phase 2 Security)\nexport type {\n  ApiKeyPermissions,\n  ScopeType,\n  Environment,\n  CreateApiKeyOptions,\n  ApiKey,\n  CreateApiKeyResult,\n} from './api/apiKeys';\n\n// Re-export ROI Analytics types\nexport type {\n  IndustryConfig,\n  CustomIndustryConfig,\n  ROIMetrics,\n  BusinessImpact,\n  ROISummary,\n  TrendDataPoint,\n  Correlation,\n  PatternCluster,\n  CorrelationAnalysis,\n} from './api/roi-analytics';\n\n// Re-export Quality Metrics types\nexport type {\n  RetrievedContext,\n  GroundTruthContext,\n  GroundedSpan,\n  UngroundedSpan,\n  CitationMap,\n  RAGEvaluation,\n  RAGEvidence,\n  HallucinationInstance,\n  HallucinationReport,\n  GroundednessResult,\n  BatchEvaluationResult,\n  BatchEvaluationSummary,\n} from './api/quality-metrics';\n\n// Re-export Business Metrics types\nexport type {\n  MetricTrend,\n  MetricStatus,\n  CurrentMetricResponse,\n  MetricHistoryPoint,\n  MetricHistorySummary,\n  MetricHistoryResponse,\n  RecordMetricOptions,\n  RecordMetricResponse,\n} from './api/business-metrics';\n\n// Re-export Agent types\nexport type {\n  Agent,\n  CreateAgentOptions,\n  UpdateAgentOptions,\n  AgentConfig,\n  UpdateAgentConfigOptions,\n  DeleteAgentOptions,\n  CascadeImpact,\n} from './api/agents';\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 {\n    throw new Error(\n      'OTLP tracing requires an API key. Agent ID alone is not sufficient for OTLP ingestion. ' +\n      'Provide apiKey in init() or set the THINKHIVE_API_KEY environment variable.'\n    );\n  }\n\n  const exporter = new OTLPTraceExporter({\n    url: config.endpoint,\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    })\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(`   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 TERMINOLOGY - ISSUES API (replaces Cases)\n// Per ITIL best practices, \"Issues\" is more customer-friendly than \"Cases\"\n// ============================================================================\n\n/**\n * Issues API client\n * This is the recommended API for managing clustered failure patterns\n *\n * @since 3.1.0\n */\nexport const issues = {\n  /**\n   * List issues for an agent\n   */\n  async list(agentId: string, options?: {\n    status?: string;\n    startDate?: Date;\n    endDate?: Date;\n    limit?: number;\n    offset?: number;\n  }): Promise<any[]> {\n    const params = new URLSearchParams({ agentId });\n    if (options?.status) params.set('status', options.status);\n    if (options?.startDate) params.set('startDate', options.startDate.toISOString());\n    if (options?.endDate) params.set('endDate', options.endDate.toISOString());\n    if (options?.limit) params.set('limit', options.limit.toString());\n    if (options?.offset) params.set('offset', options.offset.toString());\n\n    const response = await apiRequestWithData(`/issues?${params}`, { apiVersion: 'v2' });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Get a single issue by ID\n   */\n  async get(id: string): Promise<any> {\n    const response = await apiRequestWithData(`/issues/${id}`, { apiVersion: 'v2' });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Create a new issue\n   */\n  async create(data: {\n    agentId: string;\n    title: string;\n    description?: string;\n    type: string;\n    severity?: string;\n    pattern?: string;\n    exampleTraceIds?: string[];\n  }): Promise<any> {\n    const response = await apiRequestWithData('/issues', {\n      method: 'POST',\n      body: data,\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Update an issue\n   */\n  async update(id: string, data: {\n    title?: string;\n    description?: string;\n    status?: string;\n    severity?: string;\n    assignedTo?: string;\n    resolutionNotes?: string;\n  }): Promise<any> {\n    const response = await apiRequestWithData(`/issues/${id}`, {\n      method: 'PATCH',\n      body: data,\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Get fixes for an issue\n   */\n  async getFixes(issueId: string): Promise<any[]> {\n    const response = await apiRequestWithData(`/issues/${issueId}/fixes`, { apiVersion: 'v2' });\n    return (response as any).data || response;\n  },\n};\n\n\n// ============================================================================\n// V2 TERMINOLOGY - ANALYZER API (replaces Explainer user-facing)\n// Per industry distinction: Analyzer = pattern detection/observation\n// ============================================================================\n\n/**\n * Analyzer API client\n * User-selected trace analysis with cost estimation and smart sampling\n *\n * Key improvements over v1 Explainer:\n * - User-selected trace analysis (not automatic)\n * - Cost estimation before execution\n * - Smart sampling strategies\n * - Root cause analysis by layer\n * - Pattern aggregation across traces\n *\n * @since 3.1.0\n */\nexport const analyzer = {\n  /**\n   * Analyze specific traces (user-selected)\n   */\n  async analyze(options: {\n    traceIds: string[];\n    tier?: 'fast' | 'standard' | 'deep';\n    includeRootCause?: boolean;\n    includeLayers?: boolean;\n  }): Promise<any> {\n    const { traceIds, tier, includeRootCause, includeLayers } = options;\n    const response = await apiRequestWithData('/analyzer/analyze', {\n      method: 'POST',\n      body: {\n        traceIds,\n        options: {\n          tier,\n          includeRootCause,\n          includeLayers,\n        },\n      },\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Analyze traces by time window\n   */\n  async analyzeWindow(options: {\n    agentId: string;\n    startDate: Date;\n    endDate: Date;\n    filters?: {\n      outcomes?: ('failure' | 'error' | 'success')[];\n      minSeverity?: 'low' | 'medium' | 'high' | 'critical';\n    };\n    sampling?: {\n      strategy: 'all' | 'failures_only' | 'smart' | 'random';\n      samplePercent?: number;\n    };\n  }): Promise<any> {\n    const response = await apiRequestWithData('/analyzer/analyze-window', {\n      method: 'POST',\n      body: {\n        ...options,\n        startDate: options.startDate.toISOString(),\n        endDate: options.endDate.toISOString(),\n      },\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Estimate cost before running analysis\n   */\n  async estimateCost(options: {\n    traceIds?: string[];\n    agentId?: string;\n    startDate?: Date;\n    endDate?: Date;\n    tier: 'fast' | 'standard' | 'deep';\n  }): Promise<{\n    estimatedTraces: number;\n    estimatedTokens: number;\n    estimatedCost: number;\n    estimatedCredits: number;\n    tier: string;\n    note: string;\n  }> {\n    const response = await apiRequestWithData('/analyzer/estimate-cost', {\n      method: 'POST',\n      body: {\n        ...options,\n        startDate: options.startDate?.toISOString(),\n        endDate: options.endDate?.toISOString(),\n      },\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Get analysis results for a specific trace\n   */\n  async get(traceId: string): Promise<any> {\n    const response = await apiRequestWithData(`/analyzer/${traceId}`, { apiVersion: 'v2' });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Aggregate insights across multiple analyzed traces\n   */\n  async summarize(options: {\n    analysisIds?: string[];\n    agentId?: string;\n    startDate?: Date;\n    endDate?: Date;\n  }): Promise<any> {\n    const response = await apiRequestWithData('/analyzer/summarize', {\n      method: 'POST',\n      body: {\n        ...options,\n        startDate: options.startDate?.toISOString(),\n        endDate: options.endDate?.toISOString(),\n      },\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\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  // New evaluation APIs\n  humanReview,\n  nondeterminism,\n  evalHealth,\n  deterministicGraders,\n  conversationEval,\n  transcriptPatterns,\n  // API Key Management (Phase 2 Security)\n  apiKeys,\n  // Agents Management\n  agents,\n  // ROI Analytics, Quality Metrics, and Business Metrics\n  roiAnalytics,\n  qualityMetrics,\n  businessMetrics,\n};\n\n// Note: issues and analyzer are already exported via 'export const' above\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  // Non-determinism helpers\n  calculatePassAtK,\n  calculatePassToK,\n  requiredPassRateForPassAtK,\n  isReliableEvaluation,\n  getReliabilityRecommendation,\n  // Eval health helpers\n  hasHealthIssue,\n  getHealthSeverityLevel,\n  isSaturated,\n  getSaturationRecommendation,\n  // Deterministic graders helpers\n  createRegexRule,\n  createContainsRule,\n  createLengthRule,\n  createJsonSchemaRule,\n  allRulesPassed,\n  getFailedRules,\n  calculateAverageScore,\n  // Conversation eval helpers\n  aggregateWorst,\n  aggregateAverage,\n  aggregateWeighted,\n  aggregateFinalTurn,\n  aggregateMajority,\n  getAggregator,\n  getProblematicTurns,\n  analyzeConversationTrend,\n  // Transcript patterns helpers\n  isHighRisk,\n  getMatchesByCategory,\n  getCriticalInsights,\n  hasPiiExposure,\n  hasFrustrationSignals,\n  hasEscalationRequest,\n  getCategoryDistribution,\n  getRecommendations,\n  needsAttention,\n  sortMatchesBySeverity,\n  // API Key helpers\n  hasPermission,\n  isApiKeyExpired,\n  isApiKeyValid,\n  getTimeUntilExpiry,\n  canAccessAgent,\n  // ROI Analytics helpers\n  calculateRevenueAtRisk,\n  calculateAutomationSavings,\n  formatCurrency,\n  getROIQuality,\n  // Quality Metrics helpers\n  passesQualityThreshold,\n  isHallucinationRiskAcceptable,\n  getQualityRecommendations,\n  formatQualityScore,\n  getGradeColor,\n  // Business Metrics helpers\n  isMetricReady,\n  needsMoreTraces,\n  awaitingExternalData,\n  isMetricStale,\n  getStatusMessage,\n  getTraceProgress,\n  formatMetricValue,\n  getTrendEmoji,\n};\n\n// Re-export errors (including new security errors)\nexport {\n  ThinkHiveError,\n  ThinkHiveApiError,\n  ThinkHiveValidationError,\n  PermissionDeniedError,\n  AgentScopeError,\n  RateLimitError,\n  IpWhitelistError,\n};\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  // Evaluation APIs\n  humanReview,\n  nondeterminism,\n  evalHealth,\n  deterministicGraders,\n  conversationEval,\n  transcriptPatterns,\n  // API Key Management (Phase 2 Security)\n  apiKeys,\n  // Agents Management\n  agents,\n  // Issues and Analyzer APIs\n  issues,\n  analyzer,\n  // ROI Analytics, Quality Metrics, and Business Metrics\n  roiAnalytics,\n  qualityMetrics,\n  businessMetrics,\n  // Helpers\n  generateZendeskMarker,\n  parseZendeskMarker,\n  linkRunToTicket,\n  createRunWithContext,\n  // Utilities\n  isFact,\n  isInference,\n  calculateBrierScore,\n  isWellCalibrated,\n  calculatePassAtK,\n  isReliableEvaluation,\n  isHighRisk,\n  needsAttention,\n  // ROI helpers\n  calculateRevenueAtRisk,\n  formatCurrency,\n  // Quality helpers\n  passesQualityThreshold,\n  isHallucinationRiskAcceptable,\n  // Business Metrics helpers\n  isMetricReady,\n  needsMoreTraces,\n  getStatusMessage,\n};\n"]}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@thinkhive/sdk",
|
|
3
|
-
"version": "
|
|
4
|
-
"description": "ThinkHive SDK
|
|
3
|
+
"version": "4.0.0",
|
|
4
|
+
"description": "ThinkHive SDK v4.0 - AI agent observability with business metrics, ROI analytics, and 25+ trace format support",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
7
7
|
"exports": {
|