@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
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ThinkHive SDK v3.2 - Business Metrics API
|
|
4
|
+
*
|
|
5
|
+
* Industry-driven business metrics with historical tracking and external data support
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.businessMetrics = void 0;
|
|
9
|
+
exports.isMetricReady = isMetricReady;
|
|
10
|
+
exports.needsMoreTraces = needsMoreTraces;
|
|
11
|
+
exports.awaitingExternalData = awaitingExternalData;
|
|
12
|
+
exports.isMetricStale = isMetricStale;
|
|
13
|
+
exports.getStatusMessage = getStatusMessage;
|
|
14
|
+
exports.getTraceProgress = getTraceProgress;
|
|
15
|
+
exports.formatMetricValue = formatMetricValue;
|
|
16
|
+
exports.getTrendEmoji = getTrendEmoji;
|
|
17
|
+
const client_1 = require("../core/client");
|
|
18
|
+
// ============================================================================
|
|
19
|
+
// BUSINESS METRICS API CLIENT
|
|
20
|
+
// ============================================================================
|
|
21
|
+
/**
|
|
22
|
+
* Business Metrics API client for industry-driven metrics with historical tracking
|
|
23
|
+
*/
|
|
24
|
+
exports.businessMetrics = {
|
|
25
|
+
/**
|
|
26
|
+
* Get current metric value with status information
|
|
27
|
+
*
|
|
28
|
+
* @example
|
|
29
|
+
* ```typescript
|
|
30
|
+
* const metric = await businessMetrics.current('agent_123', 'Deflection Rate');
|
|
31
|
+
* console.log(`${metric.metricName}: ${metric.valueFormatted}`);
|
|
32
|
+
*
|
|
33
|
+
* if (metric.status === 'insufficient_data') {
|
|
34
|
+
* console.log(`Need ${metric.minTraceThreshold - metric.traceCount} more traces`);
|
|
35
|
+
* }
|
|
36
|
+
* ```
|
|
37
|
+
*/
|
|
38
|
+
async current(agentId, metricName) {
|
|
39
|
+
const params = new URLSearchParams();
|
|
40
|
+
if (metricName) {
|
|
41
|
+
params.set('metricName', metricName);
|
|
42
|
+
}
|
|
43
|
+
const queryString = params.toString();
|
|
44
|
+
const url = `/agents/${agentId}/metrics/current${queryString ? `?${queryString}` : ''}`;
|
|
45
|
+
return (0, client_1.apiRequestWithData)(url, { apiVersion: 'v3' });
|
|
46
|
+
},
|
|
47
|
+
/**
|
|
48
|
+
* Get historical metric data for graphing
|
|
49
|
+
*
|
|
50
|
+
* @example
|
|
51
|
+
* ```typescript
|
|
52
|
+
* const history = await businessMetrics.history('agent_123', 'Deflection Rate', {
|
|
53
|
+
* startDate: new Date(Date.now() - 30 * 24 * 60 * 60 * 1000),
|
|
54
|
+
* endDate: new Date(),
|
|
55
|
+
* granularity: 'daily',
|
|
56
|
+
* });
|
|
57
|
+
*
|
|
58
|
+
* console.log(`${history.dataPoints.length} data points`);
|
|
59
|
+
* console.log(`Change: ${history.summary.changePercent}%`);
|
|
60
|
+
* ```
|
|
61
|
+
*/
|
|
62
|
+
async history(agentId, metricName, options = {}) {
|
|
63
|
+
const params = new URLSearchParams();
|
|
64
|
+
params.set('metricName', metricName);
|
|
65
|
+
if (options.startDate) {
|
|
66
|
+
params.set('startDate', new Date(options.startDate).toISOString());
|
|
67
|
+
}
|
|
68
|
+
if (options.endDate) {
|
|
69
|
+
params.set('endDate', new Date(options.endDate).toISOString());
|
|
70
|
+
}
|
|
71
|
+
if (options.granularity) {
|
|
72
|
+
params.set('granularity', options.granularity);
|
|
73
|
+
}
|
|
74
|
+
return (0, client_1.apiRequestWithData)(`/agents/${agentId}/metrics/history?${params.toString()}`, { apiVersion: 'v3' });
|
|
75
|
+
},
|
|
76
|
+
/**
|
|
77
|
+
* Record an external metric value
|
|
78
|
+
*
|
|
79
|
+
* Use this to ingest metrics from external data sources (CRM, surveys, billing, etc.)
|
|
80
|
+
*
|
|
81
|
+
* @example
|
|
82
|
+
* ```typescript
|
|
83
|
+
* // Record CSAT score from survey system
|
|
84
|
+
* await businessMetrics.record('agent_123', {
|
|
85
|
+
* metricName: 'CSAT/NPS',
|
|
86
|
+
* value: 4.5,
|
|
87
|
+
* unit: 'score',
|
|
88
|
+
* periodStart: '2024-01-01T00:00:00Z',
|
|
89
|
+
* periodEnd: '2024-01-07T23:59:59Z',
|
|
90
|
+
* source: 'survey_system',
|
|
91
|
+
* sourceDetails: { surveyId: 'survey_456', responseCount: 150 },
|
|
92
|
+
* });
|
|
93
|
+
* ```
|
|
94
|
+
*/
|
|
95
|
+
async record(agentId, options) {
|
|
96
|
+
const body = {
|
|
97
|
+
metricName: options.metricName,
|
|
98
|
+
value: options.value,
|
|
99
|
+
unit: options.unit,
|
|
100
|
+
periodStart: new Date(options.periodStart).toISOString(),
|
|
101
|
+
periodEnd: new Date(options.periodEnd).toISOString(),
|
|
102
|
+
source: options.source || 'api',
|
|
103
|
+
sourceDetails: options.sourceDetails,
|
|
104
|
+
};
|
|
105
|
+
const response = await (0, client_1.apiRequest)(`/agents/${agentId}/metrics/values`, {
|
|
106
|
+
method: 'POST',
|
|
107
|
+
body,
|
|
108
|
+
apiVersion: 'v3',
|
|
109
|
+
});
|
|
110
|
+
return response.data;
|
|
111
|
+
},
|
|
112
|
+
/**
|
|
113
|
+
* Batch record multiple external metric values
|
|
114
|
+
*
|
|
115
|
+
* @example
|
|
116
|
+
* ```typescript
|
|
117
|
+
* await businessMetrics.recordBatch('agent_123', [
|
|
118
|
+
* { metricName: 'CSAT/NPS', value: 4.5, ... },
|
|
119
|
+
* { metricName: 'Hours Saved', value: 120, ... },
|
|
120
|
+
* ]);
|
|
121
|
+
* ```
|
|
122
|
+
*/
|
|
123
|
+
async recordBatch(agentId, metrics) {
|
|
124
|
+
const results = await Promise.all(metrics.map((metric) => this.record(agentId, metric)));
|
|
125
|
+
return results;
|
|
126
|
+
},
|
|
127
|
+
};
|
|
128
|
+
// ============================================================================
|
|
129
|
+
// HELPER FUNCTIONS
|
|
130
|
+
// ============================================================================
|
|
131
|
+
/**
|
|
132
|
+
* Check if a metric is ready to display
|
|
133
|
+
*/
|
|
134
|
+
function isMetricReady(metric) {
|
|
135
|
+
return metric.status === 'ready';
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Check if a metric needs more trace data
|
|
139
|
+
*/
|
|
140
|
+
function needsMoreTraces(metric) {
|
|
141
|
+
return metric.status === 'insufficient_data';
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Check if a metric is waiting for external data
|
|
145
|
+
*/
|
|
146
|
+
function awaitingExternalData(metric) {
|
|
147
|
+
return metric.status === 'awaiting_external';
|
|
148
|
+
}
|
|
149
|
+
/**
|
|
150
|
+
* Check if metric data is stale
|
|
151
|
+
*/
|
|
152
|
+
function isMetricStale(metric) {
|
|
153
|
+
return metric.status === 'stale';
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* Get human-readable status message
|
|
157
|
+
*/
|
|
158
|
+
function getStatusMessage(metric) {
|
|
159
|
+
switch (metric.status) {
|
|
160
|
+
case 'ready':
|
|
161
|
+
return 'Metric is up to date';
|
|
162
|
+
case 'insufficient_data':
|
|
163
|
+
return metric.statusMessage ||
|
|
164
|
+
`Need ${(metric.minTraceThreshold || 50) - (metric.traceCount || 0)} more traces`;
|
|
165
|
+
case 'awaiting_external':
|
|
166
|
+
return metric.statusMessage || 'Waiting for external data source';
|
|
167
|
+
case 'stale':
|
|
168
|
+
return metric.statusMessage || 'Data may be outdated';
|
|
169
|
+
default:
|
|
170
|
+
return 'Unknown status';
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Calculate progress toward minimum trace threshold
|
|
175
|
+
*/
|
|
176
|
+
function getTraceProgress(metric) {
|
|
177
|
+
if (metric.status !== 'insufficient_data')
|
|
178
|
+
return 100;
|
|
179
|
+
return metric.progressPercent || 0;
|
|
180
|
+
}
|
|
181
|
+
/**
|
|
182
|
+
* Format metric value for display based on unit
|
|
183
|
+
*/
|
|
184
|
+
function formatMetricValue(value, unit) {
|
|
185
|
+
switch (unit) {
|
|
186
|
+
case '%':
|
|
187
|
+
return `${Math.round(value * 10) / 10}%`;
|
|
188
|
+
case '$':
|
|
189
|
+
return new Intl.NumberFormat('en-US', {
|
|
190
|
+
style: 'currency',
|
|
191
|
+
currency: 'USD',
|
|
192
|
+
}).format(value);
|
|
193
|
+
case 's':
|
|
194
|
+
return value < 60 ? `${Math.round(value)}s` : `${Math.round(value / 60)}m`;
|
|
195
|
+
case 'hrs':
|
|
196
|
+
return `${Math.round(value * 10) / 10} hrs`;
|
|
197
|
+
case 'score':
|
|
198
|
+
return value.toFixed(1);
|
|
199
|
+
default:
|
|
200
|
+
return String(Math.round(value * 100) / 100);
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
/**
|
|
204
|
+
* Get trend direction as emoji
|
|
205
|
+
*/
|
|
206
|
+
function getTrendEmoji(trend) {
|
|
207
|
+
if (trend.direction === 'up')
|
|
208
|
+
return trend.isPositive ? '📈' : '📉';
|
|
209
|
+
if (trend.direction === 'down')
|
|
210
|
+
return trend.isPositive ? '📈' : '📉';
|
|
211
|
+
return '➡️';
|
|
212
|
+
}
|
|
213
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"business-metrics.js","sourceRoot":"","sources":["../../src/api/business-metrics.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.2 - Business Metrics API\n *\n * Industry-driven business metrics with historical tracking and external data support\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\nimport type { ApiResponse } from '../core/types';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\n/**\n * Metric trend information\n */\nexport interface MetricTrend {\n  direction: 'up' | 'down' | 'stable';\n  value: number;\n  isPositive: boolean;\n}\n\n/**\n * Current metric status\n */\nexport type MetricStatus = 'ready' | 'insufficient_data' | 'awaiting_external' | 'stale';\n\n/**\n * Current metric response from the API\n */\nexport interface CurrentMetricResponse {\n  metricName: string;\n  metricType: 'trace_calculated' | 'external';\n  value: number | null;\n  valueFormatted: string;\n  unit?: string;\n  status: MetricStatus;\n  statusMessage?: string;\n  trend?: MetricTrend;\n  traceCount?: number;\n  minTraceThreshold?: number;\n  progressPercent?: number;\n  lastExternalUpdate?: string;\n}\n\n/**\n * Historical data point\n */\nexport interface MetricHistoryPoint {\n  periodStart: string;\n  periodEnd: string;\n  value: number;\n  valueFormatted?: string;\n  source: string;\n  traceCount?: number;\n}\n\n/**\n * Historical summary statistics\n */\nexport interface MetricHistorySummary {\n  current: number | null;\n  previous: number | null;\n  changePercent: number | null;\n  isPositive: boolean;\n  dataPointCount: number;\n}\n\n/**\n * Full history response\n */\nexport interface MetricHistoryResponse {\n  metricName: string;\n  unit: string;\n  higherIsBetter: boolean;\n  dataPoints: MetricHistoryPoint[];\n  summary: MetricHistorySummary;\n}\n\n/**\n * Options for recording external metric values\n */\nexport interface RecordMetricOptions {\n  metricName: string;\n  value: number;\n  unit?: string;\n  periodStart: string | Date;\n  periodEnd: string | Date;\n  source?: string;\n  sourceDetails?: Record<string, unknown>;\n}\n\n/**\n * Response from recording a metric value\n */\nexport interface RecordMetricResponse {\n  success: boolean;\n  id: string;\n  recordedAt: string;\n}\n\n// ============================================================================\n// BUSINESS METRICS API CLIENT\n// ============================================================================\n\n/**\n * Business Metrics API client for industry-driven metrics with historical tracking\n */\nexport const businessMetrics = {\n  /**\n   * Get current metric value with status information\n   *\n   * @example\n   * ```typescript\n   * const metric = await businessMetrics.current('agent_123', 'Deflection Rate');\n   * console.log(`${metric.metricName}: ${metric.valueFormatted}`);\n   *\n   * if (metric.status === 'insufficient_data') {\n   *   console.log(`Need ${metric.minTraceThreshold - metric.traceCount} more traces`);\n   * }\n   * ```\n   */\n  async current(\n    agentId: string,\n    metricName?: string\n  ): Promise<CurrentMetricResponse> {\n    const params = new URLSearchParams();\n    if (metricName) {\n      params.set('metricName', metricName);\n    }\n\n    const queryString = params.toString();\n    const url = `/agents/${agentId}/metrics/current${queryString ? `?${queryString}` : ''}`;\n\n    return apiRequestWithData<CurrentMetricResponse>(url, { apiVersion: 'v3' });\n  },\n\n  /**\n   * Get historical metric data for graphing\n   *\n   * @example\n   * ```typescript\n   * const history = await businessMetrics.history('agent_123', 'Deflection Rate', {\n   *   startDate: new Date(Date.now() - 30 * 24 * 60 * 60 * 1000),\n   *   endDate: new Date(),\n   *   granularity: 'daily',\n   * });\n   *\n   * console.log(`${history.dataPoints.length} data points`);\n   * console.log(`Change: ${history.summary.changePercent}%`);\n   * ```\n   */\n  async history(\n    agentId: string,\n    metricName: string,\n    options: {\n      startDate?: string | Date;\n      endDate?: string | Date;\n      granularity?: 'hourly' | 'daily' | 'weekly' | 'monthly';\n    } = {}\n  ): Promise<MetricHistoryResponse> {\n    const params = new URLSearchParams();\n    params.set('metricName', metricName);\n\n    if (options.startDate) {\n      params.set('startDate', new Date(options.startDate).toISOString());\n    }\n    if (options.endDate) {\n      params.set('endDate', new Date(options.endDate).toISOString());\n    }\n    if (options.granularity) {\n      params.set('granularity', options.granularity);\n    }\n\n    return apiRequestWithData<MetricHistoryResponse>(\n      `/agents/${agentId}/metrics/history?${params.toString()}`,\n      { apiVersion: 'v3' }\n    );\n  },\n\n  /**\n   * Record an external metric value\n   *\n   * Use this to ingest metrics from external data sources (CRM, surveys, billing, etc.)\n   *\n   * @example\n   * ```typescript\n   * // Record CSAT score from survey system\n   * await businessMetrics.record('agent_123', {\n   *   metricName: 'CSAT/NPS',\n   *   value: 4.5,\n   *   unit: 'score',\n   *   periodStart: '2024-01-01T00:00:00Z',\n   *   periodEnd: '2024-01-07T23:59:59Z',\n   *   source: 'survey_system',\n   *   sourceDetails: { surveyId: 'survey_456', responseCount: 150 },\n   * });\n   * ```\n   */\n  async record(\n    agentId: string,\n    options: RecordMetricOptions\n  ): Promise<RecordMetricResponse> {\n    const body = {\n      metricName: options.metricName,\n      value: options.value,\n      unit: options.unit,\n      periodStart: new Date(options.periodStart).toISOString(),\n      periodEnd: new Date(options.periodEnd).toISOString(),\n      source: options.source || 'api',\n      sourceDetails: options.sourceDetails,\n    };\n\n    const response = await apiRequest<ApiResponse<RecordMetricResponse>>(\n      `/agents/${agentId}/metrics/values`,\n      {\n        method: 'POST',\n        body,\n        apiVersion: 'v3',\n      }\n    );\n\n    return response.data!;\n  },\n\n  /**\n   * Batch record multiple external metric values\n   *\n   * @example\n   * ```typescript\n   * await businessMetrics.recordBatch('agent_123', [\n   *   { metricName: 'CSAT/NPS', value: 4.5, ... },\n   *   { metricName: 'Hours Saved', value: 120, ... },\n   * ]);\n   * ```\n   */\n  async recordBatch(\n    agentId: string,\n    metrics: RecordMetricOptions[]\n  ): Promise<RecordMetricResponse[]> {\n    const results = await Promise.all(\n      metrics.map((metric) => this.record(agentId, metric))\n    );\n    return results;\n  },\n};\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Check if a metric is ready to display\n */\nexport function isMetricReady(metric: CurrentMetricResponse): boolean {\n  return metric.status === 'ready';\n}\n\n/**\n * Check if a metric needs more trace data\n */\nexport function needsMoreTraces(metric: CurrentMetricResponse): boolean {\n  return metric.status === 'insufficient_data';\n}\n\n/**\n * Check if a metric is waiting for external data\n */\nexport function awaitingExternalData(metric: CurrentMetricResponse): boolean {\n  return metric.status === 'awaiting_external';\n}\n\n/**\n * Check if metric data is stale\n */\nexport function isMetricStale(metric: CurrentMetricResponse): boolean {\n  return metric.status === 'stale';\n}\n\n/**\n * Get human-readable status message\n */\nexport function getStatusMessage(metric: CurrentMetricResponse): string {\n  switch (metric.status) {\n    case 'ready':\n      return 'Metric is up to date';\n    case 'insufficient_data':\n      return metric.statusMessage ||\n        `Need ${(metric.minTraceThreshold || 50) - (metric.traceCount || 0)} more traces`;\n    case 'awaiting_external':\n      return metric.statusMessage || 'Waiting for external data source';\n    case 'stale':\n      return metric.statusMessage || 'Data may be outdated';\n    default:\n      return 'Unknown status';\n  }\n}\n\n/**\n * Calculate progress toward minimum trace threshold\n */\nexport function getTraceProgress(metric: CurrentMetricResponse): number {\n  if (metric.status !== 'insufficient_data') return 100;\n  return metric.progressPercent || 0;\n}\n\n/**\n * Format metric value for display based on unit\n */\nexport function formatMetricValue(value: number, unit: string): string {\n  switch (unit) {\n    case '%':\n      return `${Math.round(value * 10) / 10}%`;\n    case '$':\n      return new Intl.NumberFormat('en-US', {\n        style: 'currency',\n        currency: 'USD',\n      }).format(value);\n    case 's':\n      return value < 60 ? `${Math.round(value)}s` : `${Math.round(value / 60)}m`;\n    case 'hrs':\n      return `${Math.round(value * 10) / 10} hrs`;\n    case 'score':\n      return value.toFixed(1);\n    default:\n      return String(Math.round(value * 100) / 100);\n  }\n}\n\n/**\n * Get trend direction as emoji\n */\nexport function getTrendEmoji(trend: MetricTrend): string {\n  if (trend.direction === 'up') return trend.isPositive ? '📈' : '📉';\n  if (trend.direction === 'down') return trend.isPositive ? '📈' : '📉';\n  return '➡️';\n}\n"]}
|
|
@@ -4,23 +4,6 @@
|
|
|
4
4
|
* Prediction accuracy tracking with Brier scores and calibration metrics
|
|
5
5
|
*/
|
|
6
6
|
import type { CalibrationStatus, CalibrationBucket, PredictionType } from '../core/types';
|
|
7
|
-
/**
|
|
8
|
-
* Record outcome input
|
|
9
|
-
*/
|
|
10
|
-
export interface RecordOutcomeInput {
|
|
11
|
-
/** Run ID the prediction was made for */
|
|
12
|
-
runId: string;
|
|
13
|
-
/** Type of prediction */
|
|
14
|
-
predictionType: PredictionType;
|
|
15
|
-
/** The predicted value (0-1 for probabilities) */
|
|
16
|
-
predictedValue: number;
|
|
17
|
-
/** The actual outcome (0 or 1 for binary, or actual value) */
|
|
18
|
-
actualOutcome: number;
|
|
19
|
-
/** When the prediction was made */
|
|
20
|
-
predictedAt?: string;
|
|
21
|
-
/** When the outcome was observed */
|
|
22
|
-
observedAt?: string;
|
|
23
|
-
}
|
|
24
7
|
/**
|
|
25
8
|
* Calibration metrics
|
|
26
9
|
*/
|
|
@@ -69,33 +52,6 @@ export declare const calibration: {
|
|
|
69
52
|
* ```
|
|
70
53
|
*/
|
|
71
54
|
allMetrics(agentId: string): Promise<CalibrationMetrics[]>;
|
|
72
|
-
/**
|
|
73
|
-
* Record a prediction outcome for calibration tracking
|
|
74
|
-
*
|
|
75
|
-
* @example
|
|
76
|
-
* ```typescript
|
|
77
|
-
* // Record a churn prediction outcome
|
|
78
|
-
* await calibration.recordOutcome({
|
|
79
|
-
* runId: 'run_abc123',
|
|
80
|
-
* predictionType: 'churn_risk',
|
|
81
|
-
* predictedValue: 0.7, // We predicted 70% churn risk
|
|
82
|
-
* actualOutcome: 1, // Customer did churn
|
|
83
|
-
* });
|
|
84
|
-
*
|
|
85
|
-
* // Record a resolution time prediction
|
|
86
|
-
* await calibration.recordOutcome({
|
|
87
|
-
* runId: 'run_abc123',
|
|
88
|
-
* predictionType: 'resolution_time',
|
|
89
|
-
* predictedValue: 15, // Predicted 15 minutes
|
|
90
|
-
* actualOutcome: 22, // Actual was 22 minutes
|
|
91
|
-
* });
|
|
92
|
-
* ```
|
|
93
|
-
*/
|
|
94
|
-
recordOutcome(input: RecordOutcomeInput): Promise<{
|
|
95
|
-
recorded: boolean;
|
|
96
|
-
brierContribution: number;
|
|
97
|
-
message: string;
|
|
98
|
-
}>;
|
|
99
55
|
/**
|
|
100
56
|
* Trigger recalibration for an agent
|
|
101
57
|
*
|
|
@@ -119,24 +75,6 @@ export declare const calibration: {
|
|
|
119
75
|
}>;
|
|
120
76
|
newMetrics: CalibrationMetrics[];
|
|
121
77
|
}>;
|
|
122
|
-
/**
|
|
123
|
-
* Get reliability diagram data for visualization
|
|
124
|
-
*
|
|
125
|
-
* @example
|
|
126
|
-
* ```typescript
|
|
127
|
-
* const diagram = await calibration.reliabilityDiagram('agent_123', 'outcome');
|
|
128
|
-
* // Use diagram.buckets to plot predicted vs actual probabilities
|
|
129
|
-
* ```
|
|
130
|
-
*/
|
|
131
|
-
reliabilityDiagram(agentId: string, predictionType: PredictionType): Promise<{
|
|
132
|
-
agentId: string;
|
|
133
|
-
predictionType: PredictionType;
|
|
134
|
-
buckets: CalibrationBucket[];
|
|
135
|
-
perfectCalibrationLine: Array<{
|
|
136
|
-
x: number;
|
|
137
|
-
y: number;
|
|
138
|
-
}>;
|
|
139
|
-
}>;
|
|
140
78
|
};
|
|
141
79
|
/**
|
|
142
80
|
* Calculate Brier score from predictions and outcomes
|
package/dist/api/calibration.js
CHANGED
|
@@ -27,7 +27,7 @@ exports.calibration = {
|
|
|
27
27
|
* ```
|
|
28
28
|
*/
|
|
29
29
|
async status(agentId, predictionType) {
|
|
30
|
-
return (0, client_1.apiRequestWithData)(`/calibration
|
|
30
|
+
return (0, client_1.apiRequestWithData)(`/calibration/${agentId}/status?predictionType=${predictionType}`, { apiVersion: 'v3' });
|
|
31
31
|
},
|
|
32
32
|
/**
|
|
33
33
|
* Get all calibration metrics for an agent
|
|
@@ -41,39 +41,7 @@ exports.calibration = {
|
|
|
41
41
|
* ```
|
|
42
42
|
*/
|
|
43
43
|
async allMetrics(agentId) {
|
|
44
|
-
return (0, client_1.apiRequestWithData)(`/calibration
|
|
45
|
-
},
|
|
46
|
-
/**
|
|
47
|
-
* Record a prediction outcome for calibration tracking
|
|
48
|
-
*
|
|
49
|
-
* @example
|
|
50
|
-
* ```typescript
|
|
51
|
-
* // Record a churn prediction outcome
|
|
52
|
-
* await calibration.recordOutcome({
|
|
53
|
-
* runId: 'run_abc123',
|
|
54
|
-
* predictionType: 'churn_risk',
|
|
55
|
-
* predictedValue: 0.7, // We predicted 70% churn risk
|
|
56
|
-
* actualOutcome: 1, // Customer did churn
|
|
57
|
-
* });
|
|
58
|
-
*
|
|
59
|
-
* // Record a resolution time prediction
|
|
60
|
-
* await calibration.recordOutcome({
|
|
61
|
-
* runId: 'run_abc123',
|
|
62
|
-
* predictionType: 'resolution_time',
|
|
63
|
-
* predictedValue: 15, // Predicted 15 minutes
|
|
64
|
-
* actualOutcome: 22, // Actual was 22 minutes
|
|
65
|
-
* });
|
|
66
|
-
* ```
|
|
67
|
-
*/
|
|
68
|
-
async recordOutcome(input) {
|
|
69
|
-
return (0, client_1.apiRequestWithData)('/calibration/record', {
|
|
70
|
-
method: 'POST',
|
|
71
|
-
body: {
|
|
72
|
-
...input,
|
|
73
|
-
predictedAt: input.predictedAt || new Date().toISOString(),
|
|
74
|
-
observedAt: input.observedAt || new Date().toISOString(),
|
|
75
|
-
},
|
|
76
|
-
});
|
|
44
|
+
return (0, client_1.apiRequestWithData)(`/calibration/${agentId}/metrics`, { apiVersion: 'v3' });
|
|
77
45
|
},
|
|
78
46
|
/**
|
|
79
47
|
* Trigger recalibration for an agent
|
|
@@ -87,23 +55,12 @@ exports.calibration = {
|
|
|
87
55
|
* ```
|
|
88
56
|
*/
|
|
89
57
|
async retrain(agentId, options = {}) {
|
|
90
|
-
return (0, client_1.apiRequestWithData)(`/calibration
|
|
58
|
+
return (0, client_1.apiRequestWithData)(`/calibration/${agentId}/retrain`, {
|
|
91
59
|
method: 'POST',
|
|
92
60
|
body: options,
|
|
61
|
+
apiVersion: 'v3',
|
|
93
62
|
});
|
|
94
63
|
},
|
|
95
|
-
/**
|
|
96
|
-
* Get reliability diagram data for visualization
|
|
97
|
-
*
|
|
98
|
-
* @example
|
|
99
|
-
* ```typescript
|
|
100
|
-
* const diagram = await calibration.reliabilityDiagram('agent_123', 'outcome');
|
|
101
|
-
* // Use diagram.buckets to plot predicted vs actual probabilities
|
|
102
|
-
* ```
|
|
103
|
-
*/
|
|
104
|
-
async reliabilityDiagram(agentId, predictionType) {
|
|
105
|
-
return (0, client_1.apiRequestWithData)(`/calibration/diagram/${agentId}?predictionType=${predictionType}`);
|
|
106
|
-
},
|
|
107
64
|
};
|
|
108
65
|
// ============================================================================
|
|
109
66
|
// HELPER FUNCTIONS
|
|
@@ -173,4 +130,4 @@ function getCalibrationQuality(brierScore) {
|
|
|
173
130
|
function formatBrierScore(score) {
|
|
174
131
|
return score.toFixed(4);
|
|
175
132
|
}
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calibration.js","sourceRoot":"","sources":["../../src/api/calibration.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Calibration API\n *\n * Prediction accuracy tracking with Brier scores and calibration metrics\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\nimport type {\n  CalibrationStatus,\n  CalibrationBucket,\n  PredictionType,\n  ApiResponse,\n} from '../core/types';\n\n// ============================================================================\n// CALIBRATION API CLIENT\n// ============================================================================\n\n/**\n * Record outcome input\n */\nexport interface RecordOutcomeInput {\n  /** Run ID the prediction was made for */\n  runId: string;\n  /** Type of prediction */\n  predictionType: PredictionType;\n  /** The predicted value (0-1 for probabilities) */\n  predictedValue: number;\n  /** The actual outcome (0 or 1 for binary, or actual value) */\n  actualOutcome: number;\n  /** When the prediction was made */\n  predictedAt?: string;\n  /** When the outcome was observed */\n  observedAt?: string;\n}\n\n/**\n * Calibration metrics\n */\nexport interface CalibrationMetrics {\n  agentId: string;\n  predictionType: PredictionType;\n  /** Brier score (lower is better, <0.1 is good) */\n  brierScore: number;\n  /** Expected Calibration Error */\n  ece: number;\n  /** Maximum Calibration Error */\n  mce: number;\n  /** Sample count */\n  sampleCount: number;\n  /** Is the model well-calibrated */\n  isCalibrated: boolean;\n  /** Reliability diagram data */\n  reliabilityDiagram: CalibrationBucket[];\n  /** Last updated */\n  lastUpdated: string;\n}\n\n/**\n * Calibration API client for prediction accuracy tracking\n */\nexport const calibration = {\n  /**\n   * Get calibration status for an agent\n   *\n   * @example\n   * ```typescript\n   * const status = await calibration.status('agent_123', 'churn_risk');\n   * console.log(`Brier score: ${status.brierScore}`);\n   * console.log(`Is calibrated: ${status.isCalibrated}`);\n   * ```\n   */\n  async status(\n    agentId: string,\n    predictionType: PredictionType\n  ): Promise<CalibrationStatus> {\n    return apiRequestWithData<CalibrationStatus>(\n      `/calibration/status/${agentId}?predictionType=${predictionType}`\n    );\n  },\n\n  /**\n   * Get all calibration metrics for an agent\n   *\n   * @example\n   * ```typescript\n   * const metrics = await calibration.allMetrics('agent_123');\n   * for (const m of metrics) {\n   *   console.log(`${m.predictionType}: Brier=${m.brierScore}`);\n   * }\n   * ```\n   */\n  async allMetrics(agentId: string): Promise<CalibrationMetrics[]> {\n    return apiRequestWithData<CalibrationMetrics[]>(\n      `/calibration/metrics/${agentId}`\n    );\n  },\n\n  /**\n   * Record a prediction outcome for calibration tracking\n   *\n   * @example\n   * ```typescript\n   * // Record a churn prediction outcome\n   * await calibration.recordOutcome({\n   *   runId: 'run_abc123',\n   *   predictionType: 'churn_risk',\n   *   predictedValue: 0.7,  // We predicted 70% churn risk\n   *   actualOutcome: 1,     // Customer did churn\n   * });\n   *\n   * // Record a resolution time prediction\n   * await calibration.recordOutcome({\n   *   runId: 'run_abc123',\n   *   predictionType: 'resolution_time',\n   *   predictedValue: 15,   // Predicted 15 minutes\n   *   actualOutcome: 22,    // Actual was 22 minutes\n   * });\n   * ```\n   */\n  async recordOutcome(input: RecordOutcomeInput): Promise<{\n    recorded: boolean;\n    brierContribution: number;\n    message: string;\n  }> {\n    return apiRequestWithData('/calibration/record', {\n      method: 'POST',\n      body: {\n        ...input,\n        predictedAt: input.predictedAt || new Date().toISOString(),\n        observedAt: input.observedAt || new Date().toISOString(),\n      },\n    });\n  },\n\n  /**\n   * Trigger recalibration for an agent\n   *\n   * @example\n   * ```typescript\n   * const result = await calibration.retrain('agent_123', {\n   *   predictionTypes: ['churn_risk', 'escalation_risk'],\n   * });\n   * console.log(`Retrained: ${result.success}`);\n   * ```\n   */\n  async retrain(\n    agentId: string,\n    options: {\n      predictionTypes?: PredictionType[];\n      minSamples?: number;\n    } = {}\n  ): Promise<{\n    success: boolean;\n    retrainedTypes: PredictionType[];\n    skippedTypes: Array<{ type: PredictionType; reason: string }>;\n    newMetrics: CalibrationMetrics[];\n  }> {\n    return apiRequestWithData(`/calibration/retrain/${agentId}`, {\n      method: 'POST',\n      body: options,\n    });\n  },\n\n  /**\n   * Get reliability diagram data for visualization\n   *\n   * @example\n   * ```typescript\n   * const diagram = await calibration.reliabilityDiagram('agent_123', 'outcome');\n   * // Use diagram.buckets to plot predicted vs actual probabilities\n   * ```\n   */\n  async reliabilityDiagram(\n    agentId: string,\n    predictionType: PredictionType\n  ): Promise<{\n    agentId: string;\n    predictionType: PredictionType;\n    buckets: CalibrationBucket[];\n    perfectCalibrationLine: Array<{ x: number; y: number }>;\n  }> {\n    return apiRequestWithData(\n      `/calibration/diagram/${agentId}?predictionType=${predictionType}`\n    );\n  },\n};\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Calculate Brier score from predictions and outcomes\n * Lower is better, <0.1 is considered good\n */\nexport function calculateBrierScore(\n  predictions: Array<{ predicted: number; actual: number }>\n): number {\n  if (predictions.length === 0) return 0;\n\n  const sum = predictions.reduce((acc, { predicted, actual }) => {\n    return acc + Math.pow(predicted - actual, 2);\n  }, 0);\n\n  return sum / predictions.length;\n}\n\n/**\n * Calculate Expected Calibration Error (ECE)\n * Measures how well-calibrated predictions are across confidence buckets\n */\nexport function calculateECE(\n  predictions: Array<{ predicted: number; actual: number }>,\n  numBuckets: number = 10\n): number {\n  if (predictions.length === 0) return 0;\n\n  const buckets: Array<{ predictions: number[]; actuals: number[] }> = [];\n  for (let i = 0; i < numBuckets; i++) {\n    buckets.push({ predictions: [], actuals: [] });\n  }\n\n  // Assign predictions to buckets\n  for (const { predicted, actual } of predictions) {\n    const bucketIndex = Math.min(\n      Math.floor(predicted * numBuckets),\n      numBuckets - 1\n    );\n    buckets[bucketIndex].predictions.push(predicted);\n    buckets[bucketIndex].actuals.push(actual);\n  }\n\n  // Calculate ECE\n  let ece = 0;\n  for (const bucket of buckets) {\n    if (bucket.predictions.length === 0) continue;\n\n    const avgPredicted =\n      bucket.predictions.reduce((a, b) => a + b, 0) / bucket.predictions.length;\n    const avgActual =\n      bucket.actuals.reduce((a, b) => a + b, 0) / bucket.actuals.length;\n    const weight = bucket.predictions.length / predictions.length;\n\n    ece += weight * Math.abs(avgPredicted - avgActual);\n  }\n\n  return ece;\n}\n\n/**\n * Check if a model is well-calibrated based on Brier score\n */\nexport function isWellCalibrated(brierScore: number): boolean {\n  return brierScore < 0.1;\n}\n\n/**\n * Get calibration quality label\n */\nexport function getCalibrationQuality(\n  brierScore: number\n): 'excellent' | 'good' | 'fair' | 'poor' {\n  if (brierScore < 0.05) return 'excellent';\n  if (brierScore < 0.1) return 'good';\n  if (brierScore < 0.2) return 'fair';\n  return 'poor';\n}\n\n/**\n * Format Brier score for display\n */\nexport function formatBrierScore(score: number): string {\n  return score.toFixed(4);\n}\n"]}
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calibration.js","sourceRoot":"","sources":["../../src/api/calibration.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Calibration API\n *\n * Prediction accuracy tracking with Brier scores and calibration metrics\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\nimport type {\n  CalibrationStatus,\n  CalibrationBucket,\n  PredictionType,\n  ApiResponse,\n} from '../core/types';\n\n// ============================================================================\n// CALIBRATION API CLIENT\n// ============================================================================\n\n/**\n * Calibration metrics\n */\nexport interface CalibrationMetrics {\n  agentId: string;\n  predictionType: PredictionType;\n  /** Brier score (lower is better, <0.1 is good) */\n  brierScore: number;\n  /** Expected Calibration Error */\n  ece: number;\n  /** Maximum Calibration Error */\n  mce: number;\n  /** Sample count */\n  sampleCount: number;\n  /** Is the model well-calibrated */\n  isCalibrated: boolean;\n  /** Reliability diagram data */\n  reliabilityDiagram: CalibrationBucket[];\n  /** Last updated */\n  lastUpdated: string;\n}\n\n/**\n * Calibration API client for prediction accuracy tracking\n */\nexport const calibration = {\n  /**\n   * Get calibration status for an agent\n   *\n   * @example\n   * ```typescript\n   * const status = await calibration.status('agent_123', 'churn_risk');\n   * console.log(`Brier score: ${status.brierScore}`);\n   * console.log(`Is calibrated: ${status.isCalibrated}`);\n   * ```\n   */\n  async status(\n    agentId: string,\n    predictionType: PredictionType\n  ): Promise<CalibrationStatus> {\n    return apiRequestWithData<CalibrationStatus>(\n      `/calibration/${agentId}/status?predictionType=${predictionType}`,\n      { apiVersion: 'v3' }\n    );\n  },\n\n  /**\n   * Get all calibration metrics for an agent\n   *\n   * @example\n   * ```typescript\n   * const metrics = await calibration.allMetrics('agent_123');\n   * for (const m of metrics) {\n   *   console.log(`${m.predictionType}: Brier=${m.brierScore}`);\n   * }\n   * ```\n   */\n  async allMetrics(agentId: string): Promise<CalibrationMetrics[]> {\n    return apiRequestWithData<CalibrationMetrics[]>(\n      `/calibration/${agentId}/metrics`,\n      { apiVersion: 'v3' }\n    );\n  },\n\n  /**\n   * Trigger recalibration for an agent\n   *\n   * @example\n   * ```typescript\n   * const result = await calibration.retrain('agent_123', {\n   *   predictionTypes: ['churn_risk', 'escalation_risk'],\n   * });\n   * console.log(`Retrained: ${result.success}`);\n   * ```\n   */\n  async retrain(\n    agentId: string,\n    options: {\n      predictionTypes?: PredictionType[];\n      minSamples?: number;\n    } = {}\n  ): Promise<{\n    success: boolean;\n    retrainedTypes: PredictionType[];\n    skippedTypes: Array<{ type: PredictionType; reason: string }>;\n    newMetrics: CalibrationMetrics[];\n  }> {\n    return apiRequestWithData(`/calibration/${agentId}/retrain`, {\n      method: 'POST',\n      body: options,\n      apiVersion: 'v3',\n    });\n  },\n\n};\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Calculate Brier score from predictions and outcomes\n * Lower is better, <0.1 is considered good\n */\nexport function calculateBrierScore(\n  predictions: Array<{ predicted: number; actual: number }>\n): number {\n  if (predictions.length === 0) return 0;\n\n  const sum = predictions.reduce((acc, { predicted, actual }) => {\n    return acc + Math.pow(predicted - actual, 2);\n  }, 0);\n\n  return sum / predictions.length;\n}\n\n/**\n * Calculate Expected Calibration Error (ECE)\n * Measures how well-calibrated predictions are across confidence buckets\n */\nexport function calculateECE(\n  predictions: Array<{ predicted: number; actual: number }>,\n  numBuckets: number = 10\n): number {\n  if (predictions.length === 0) return 0;\n\n  const buckets: Array<{ predictions: number[]; actuals: number[] }> = [];\n  for (let i = 0; i < numBuckets; i++) {\n    buckets.push({ predictions: [], actuals: [] });\n  }\n\n  // Assign predictions to buckets\n  for (const { predicted, actual } of predictions) {\n    const bucketIndex = Math.min(\n      Math.floor(predicted * numBuckets),\n      numBuckets - 1\n    );\n    buckets[bucketIndex].predictions.push(predicted);\n    buckets[bucketIndex].actuals.push(actual);\n  }\n\n  // Calculate ECE\n  let ece = 0;\n  for (const bucket of buckets) {\n    if (bucket.predictions.length === 0) continue;\n\n    const avgPredicted =\n      bucket.predictions.reduce((a, b) => a + b, 0) / bucket.predictions.length;\n    const avgActual =\n      bucket.actuals.reduce((a, b) => a + b, 0) / bucket.actuals.length;\n    const weight = bucket.predictions.length / predictions.length;\n\n    ece += weight * Math.abs(avgPredicted - avgActual);\n  }\n\n  return ece;\n}\n\n/**\n * Check if a model is well-calibrated based on Brier score\n */\nexport function isWellCalibrated(brierScore: number): boolean {\n  return brierScore < 0.1;\n}\n\n/**\n * Get calibration quality label\n */\nexport function getCalibrationQuality(\n  brierScore: number\n): 'excellent' | 'good' | 'fair' | 'poor' {\n  if (brierScore < 0.05) return 'excellent';\n  if (brierScore < 0.1) return 'good';\n  if (brierScore < 0.2) return 'fair';\n  return 'poor';\n}\n\n/**\n * Format Brier score for display\n */\nexport function formatBrierScore(score: number): string {\n  return score.toFixed(4);\n}\n"]}
|
package/dist/api/claims.js
CHANGED
|
@@ -49,6 +49,7 @@ exports.claims = {
|
|
|
49
49
|
return (0, client_1.apiRequestWithData)('/analyses', {
|
|
50
50
|
method: 'POST',
|
|
51
51
|
body: options,
|
|
52
|
+
apiVersion: 'v3',
|
|
52
53
|
});
|
|
53
54
|
},
|
|
54
55
|
/**
|
|
@@ -60,7 +61,7 @@ exports.claims = {
|
|
|
60
61
|
* ```
|
|
61
62
|
*/
|
|
62
63
|
async getAnalysis(analysisId) {
|
|
63
|
-
return (0, client_1.apiRequestWithData)(`/analyses/${analysisId}
|
|
64
|
+
return (0, client_1.apiRequestWithData)(`/analyses/${analysisId}`, { apiVersion: 'v3' });
|
|
64
65
|
},
|
|
65
66
|
/**
|
|
66
67
|
* Get current analysis for a run
|
|
@@ -71,7 +72,7 @@ exports.claims = {
|
|
|
71
72
|
* ```
|
|
72
73
|
*/
|
|
73
74
|
async getRunAnalysis(runId) {
|
|
74
|
-
return (0, client_1.apiRequestWithData)(`/runs/${runId}/analysis
|
|
75
|
+
return (0, client_1.apiRequestWithData)(`/runs/${runId}/analysis`, { apiVersion: 'v3' });
|
|
75
76
|
},
|
|
76
77
|
/**
|
|
77
78
|
* Get analysis history for a run
|
|
@@ -82,7 +83,7 @@ exports.claims = {
|
|
|
82
83
|
* ```
|
|
83
84
|
*/
|
|
84
85
|
async getAnalysisHistory(runId) {
|
|
85
|
-
return (0, client_1.apiRequestWithData)(`/runs/${runId}/analyses
|
|
86
|
+
return (0, client_1.apiRequestWithData)(`/runs/${runId}/analyses`, { apiVersion: 'v3' });
|
|
86
87
|
},
|
|
87
88
|
/**
|
|
88
89
|
* Supersede an analysis with a new one
|
|
@@ -103,6 +104,7 @@ exports.claims = {
|
|
|
103
104
|
return (0, client_1.apiRequestWithData)(`/analyses/${analysisId}/supersede`, {
|
|
104
105
|
method: 'POST',
|
|
105
106
|
body: options,
|
|
107
|
+
apiVersion: 'v3',
|
|
106
108
|
});
|
|
107
109
|
},
|
|
108
110
|
/**
|
|
@@ -143,7 +145,7 @@ exports.claims = {
|
|
|
143
145
|
params.set('limit', String(options.limit));
|
|
144
146
|
if (options.offset)
|
|
145
147
|
params.set('offset', String(options.offset));
|
|
146
|
-
const response = await (0, client_1.apiRequest)(`/claims?${params.toString()}
|
|
148
|
+
const response = await (0, client_1.apiRequest)(`/claims?${params.toString()}`, { apiVersion: 'v3' });
|
|
147
149
|
return response.data;
|
|
148
150
|
},
|
|
149
151
|
/**
|
|
@@ -155,7 +157,7 @@ exports.claims = {
|
|
|
155
157
|
* ```
|
|
156
158
|
*/
|
|
157
159
|
async get(claimId) {
|
|
158
|
-
return (0, client_1.apiRequestWithData)(`/claims/${claimId}
|
|
160
|
+
return (0, client_1.apiRequestWithData)(`/claims/${claimId}`, { apiVersion: 'v3' });
|
|
159
161
|
},
|
|
160
162
|
/**
|
|
161
163
|
* Verify or reject a claim (human feedback)
|
|
@@ -179,6 +181,7 @@ exports.claims = {
|
|
|
179
181
|
return (0, client_1.apiRequestWithData)(`/claims/${claimId}/verify`, {
|
|
180
182
|
method: 'POST',
|
|
181
183
|
body: options,
|
|
184
|
+
apiVersion: 'v3',
|
|
182
185
|
});
|
|
183
186
|
},
|
|
184
187
|
/**
|
|
@@ -201,7 +204,7 @@ exports.claims = {
|
|
|
201
204
|
params.set('runId', options.runId);
|
|
202
205
|
if (options.analysisIds)
|
|
203
206
|
params.set('analysisIds', options.analysisIds.join(','));
|
|
204
|
-
return (0, client_1.apiRequestWithData)(`/claims/summary?${params.toString()}
|
|
207
|
+
return (0, client_1.apiRequestWithData)(`/claims/summary?${params.toString()}`, { apiVersion: 'v3' });
|
|
205
208
|
},
|
|
206
209
|
};
|
|
207
210
|
// ============================================================================
|
|
@@ -259,4 +262,4 @@ function groupClaimsByCategory(claimsList) {
|
|
|
259
262
|
}
|
|
260
263
|
return groups;
|
|
261
264
|
}
|
|
262
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"claims.js","sourceRoot":"","sources":["../../src/api/claims.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Claims API\n *\n * Facts vs Inferences API for accessing analysis claims\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\nimport type {\n  Claim,\n  ClaimType,\n  ClaimCategory,\n  AnalysisResult,\n  ApiResponse,\n  PaginatedResponse,\n  EvidenceReference,\n} from '../core/types';\n\n// ============================================================================\n// CLAIMS API CLIENT\n// ============================================================================\n\n/**\n * List claims query options\n */\nexport interface ListClaimsOptions {\n  runId?: string;\n  analysisId?: string;\n  claimType?: ClaimType;\n  claimCategory?: ClaimCategory;\n  minConfidence?: number;\n  humanVerified?: boolean;\n  limit?: number;\n  offset?: number;\n}\n\n/**\n * Create analysis options\n */\nexport interface CreateAnalysisOptions {\n  runId: string;\n  modelUsed?: string;\n  outcomeVerdict: 'success' | 'partial_success' | 'failure';\n  outcomeConfidence?: number;\n  rootCauseCategory?: string;\n  rootCauseConfidence?: number;\n  claims?: CreateClaimInput[];\n}\n\nexport interface CreateClaimInput {\n  claimType: ClaimType;\n  claimCategory: ClaimCategory;\n  claimText: string;\n  confidence: number;\n  confidenceCalibration?: 'calibrated' | 'uncalibrated' | 'needs_more_data';\n  evidence?: EvidenceReference[];\n  isExplainable?: boolean;\n  probabilityValue?: number;\n}\n\n/**\n * Facts vs inferences summary\n */\nexport interface FactsVsInferencesSummary {\n  analysisIds: string[];\n  totalClaims: number;\n  observed: {\n    count: number;\n    avgConfidence: number;\n    categories: Record<string, number>;\n  };\n  inferred: {\n    count: number;\n    avgConfidence: number;\n    categories: Record<string, number>;\n  };\n  computed: {\n    count: number;\n    avgConfidence: number;\n    categories: Record<string, number>;\n  };\n  humanVerifiedCount: number;\n  humanRejectedCount: number;\n}\n\n/**\n * Claims API client for facts vs inferences management\n */\nexport const claims = {\n  /**\n   * Create a new analysis for a run\n   *\n   * @example\n   * ```typescript\n   * const analysis = await claims.createAnalysis({\n   *   runId: 'run_abc123',\n   *   outcomeVerdict: 'failure',\n   *   outcomeConfidence: 0.85,\n   *   rootCauseCategory: 'retrieval_failure',\n   *   claims: [\n   *     {\n   *       claimType: 'observed',\n   *       claimCategory: 'root_cause',\n   *       claimText: 'Vector search returned 0 results',\n   *       confidence: 1.0,\n   *       evidence: [{ type: 'span', referenceId: 'span_123', relevance: 'direct', confidence: 1.0 }],\n   *     },\n   *     {\n   *       claimType: 'inferred',\n   *       claimCategory: 'churn_risk',\n   *       claimText: 'High churn risk due to repeated failures',\n   *       confidence: 0.7,\n   *     },\n   *   ],\n   * });\n   * ```\n   */\n  async createAnalysis(options: CreateAnalysisOptions): Promise<AnalysisResult> {\n    return apiRequestWithData<AnalysisResult>('/analyses', {\n      method: 'POST',\n      body: options,\n    });\n  },\n\n  /**\n   * Get an analysis by ID\n   *\n   * @example\n   * ```typescript\n   * const analysis = await claims.getAnalysis('analysis_abc123');\n   * ```\n   */\n  async getAnalysis(analysisId: string): Promise<AnalysisResult> {\n    return apiRequestWithData<AnalysisResult>(`/analyses/${analysisId}`);\n  },\n\n  /**\n   * Get current analysis for a run\n   *\n   * @example\n   * ```typescript\n   * const analysis = await claims.getRunAnalysis('run_abc123');\n   * ```\n   */\n  async getRunAnalysis(runId: string): Promise<AnalysisResult> {\n    return apiRequestWithData<AnalysisResult>(`/runs/${runId}/analysis`);\n  },\n\n  /**\n   * Get analysis history for a run\n   *\n   * @example\n   * ```typescript\n   * const history = await claims.getAnalysisHistory('run_abc123');\n   * ```\n   */\n  async getAnalysisHistory(runId: string): Promise<{\n    runId: string;\n    analyses: Array<{\n      id: string;\n      analysisVersion: string;\n      modelUsed: string;\n      outcomeVerdict: string;\n      isCurrent: boolean;\n      supersededBy?: string;\n      supersessionReason?: string;\n      analyzedAt: string;\n    }>;\n  }> {\n    return apiRequestWithData(`/runs/${runId}/analyses`);\n  },\n\n  /**\n   * Supersede an analysis with a new one\n   *\n   * @example\n   * ```typescript\n   * const newAnalysis = await claims.supersedeAnalysis('analysis_old', {\n   *   reason: 'Improved model accuracy',\n   *   newAnalysis: {\n   *     outcomeVerdict: 'success',\n   *     outcomeConfidence: 0.95,\n   *     claims: [...],\n   *   },\n   * });\n   * ```\n   */\n  async supersedeAnalysis(\n    analysisId: string,\n    options: {\n      reason: string;\n      newAnalysis: Omit<CreateAnalysisOptions, 'runId'>;\n    }\n  ): Promise<{ supersededAnalysisId: string; newAnalysis: AnalysisResult }> {\n    return apiRequestWithData(`/analyses/${analysisId}/supersede`, {\n      method: 'POST',\n      body: options,\n    });\n  },\n\n  /**\n   * List claims with filters\n   *\n   * @example\n   * ```typescript\n   * // Get all inferred claims with high confidence\n   * const { claims } = await claims.list({\n   *   claimType: 'inferred',\n   *   minConfidence: 0.8,\n   * });\n   *\n   * // Get all churn risk claims for a run\n   * const { claims } = await claims.list({\n   *   runId: 'run_abc123',\n   *   claimCategory: 'churn_risk',\n   * });\n   * ```\n   */\n  async list(\n    options: ListClaimsOptions = {}\n  ): Promise<{ claims: Claim[]; limit: number; offset: number; hasMore: boolean }> {\n    const params = new URLSearchParams();\n    if (options.runId) params.set('runId', options.runId);\n    if (options.analysisId) params.set('analysisId', options.analysisId);\n    if (options.claimType) params.set('claimType', options.claimType);\n    if (options.claimCategory) params.set('claimCategory', options.claimCategory);\n    if (options.minConfidence !== undefined) {\n      params.set('minConfidence', String(options.minConfidence));\n    }\n    if (options.humanVerified !== undefined) {\n      params.set('humanVerified', String(options.humanVerified));\n    }\n    if (options.limit) params.set('limit', String(options.limit));\n    if (options.offset) params.set('offset', String(options.offset));\n\n    const response = await apiRequest<ApiResponse<{ claims: Claim[]; limit: number; offset: number; hasMore: boolean }>>(\n      `/claims?${params.toString()}`\n    );\n    return response.data!;\n  },\n\n  /**\n   * Get a claim by ID\n   *\n   * @example\n   * ```typescript\n   * const claim = await claims.get('claim_abc123');\n   * ```\n   */\n  async get(claimId: string): Promise<Claim> {\n    return apiRequestWithData<Claim>(`/claims/${claimId}`);\n  },\n\n  /**\n   * Verify or reject a claim (human feedback)\n   *\n   * @example\n   * ```typescript\n   * // Confirm a claim\n   * await claims.verify('claim_abc123', {\n   *   verdict: 'confirmed',\n   *   notes: 'Verified against ticket history',\n   * });\n   *\n   * // Reject a claim\n   * await claims.verify('claim_abc123', {\n   *   verdict: 'rejected',\n   *   notes: 'Customer context was missing',\n   * });\n   * ```\n   */\n  async verify(\n    claimId: string,\n    options: {\n      verdict: 'confirmed' | 'rejected' | 'modified';\n      notes?: string;\n      modifiedText?: string;\n    }\n  ): Promise<{ claimId: string; verdict: string; message: string }> {\n    return apiRequestWithData(`/claims/${claimId}/verify`, {\n      method: 'POST',\n      body: options,\n    });\n  },\n\n  /**\n   * Get facts vs inferences summary\n   *\n   * @example\n   * ```typescript\n   * // Summary for a specific run\n   * const summary = await claims.summary({ runId: 'run_abc123' });\n   *\n   * // Summary for multiple analyses\n   * const summary = await claims.summary({\n   *   analysisIds: ['analysis_1', 'analysis_2'],\n   * });\n   * ```\n   */\n  async summary(\n    options: { runId?: string; analysisIds?: string[] } = {}\n  ): Promise<FactsVsInferencesSummary> {\n    const params = new URLSearchParams();\n    if (options.runId) params.set('runId', options.runId);\n    if (options.analysisIds) params.set('analysisIds', options.analysisIds.join(','));\n\n    return apiRequestWithData<FactsVsInferencesSummary>(\n      `/claims/summary?${params.toString()}`\n    );\n  },\n};\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Check if a claim is a fact (observed)\n */\nexport function isFact(claim: Claim): boolean {\n  return claim.claimType === 'observed';\n}\n\n/**\n * Check if a claim is an inference\n */\nexport function isInference(claim: Claim): boolean {\n  return claim.claimType === 'inferred';\n}\n\n/**\n * Check if a claim is computed\n */\nexport function isComputed(claim: Claim): boolean {\n  return claim.claimType === 'computed';\n}\n\n/**\n * Get high confidence claims (>= threshold)\n */\nexport function getHighConfidenceClaims(\n  claimsList: Claim[],\n  threshold: number = 0.8\n): Claim[] {\n  return claimsList.filter((c) => c.confidence >= threshold);\n}\n\n/**\n * Group claims by type\n */\nexport function groupClaimsByType(\n  claimsList: Claim[]\n): Record<ClaimType, Claim[]> {\n  return {\n    observed: claimsList.filter((c) => c.claimType === 'observed'),\n    inferred: claimsList.filter((c) => c.claimType === 'inferred'),\n    computed: claimsList.filter((c) => c.claimType === 'computed'),\n  };\n}\n\n/**\n * Group claims by category\n */\nexport function groupClaimsByCategory(\n  claimsList: Claim[]\n): Record<ClaimCategory, Claim[]> {\n  const groups: Record<ClaimCategory, Claim[]> = {\n    outcome: [],\n    root_cause: [],\n    customer_impact: [],\n    churn_risk: [],\n    revenue_impact: [],\n    quality: [],\n    other: [],\n  };\n\n  for (const claim of claimsList) {\n    groups[claim.claimCategory].push(claim);\n  }\n\n  return groups;\n}\n"]}
|
|
265
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"claims.js","sourceRoot":"","sources":["../../src/api/claims.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Claims API\n *\n * Facts vs Inferences API for accessing analysis claims\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\nimport type {\n  Claim,\n  ClaimType,\n  ClaimCategory,\n  AnalysisResult,\n  ApiResponse,\n  PaginatedResponse,\n  EvidenceReference,\n} from '../core/types';\n\n// ============================================================================\n// CLAIMS API CLIENT\n// ============================================================================\n\n/**\n * List claims query options\n */\nexport interface ListClaimsOptions {\n  runId?: string;\n  analysisId?: string;\n  claimType?: ClaimType;\n  claimCategory?: ClaimCategory;\n  minConfidence?: number;\n  humanVerified?: boolean;\n  limit?: number;\n  offset?: number;\n}\n\n/**\n * Create analysis options\n */\nexport interface CreateAnalysisOptions {\n  runId: string;\n  modelUsed?: string;\n  outcomeVerdict: 'success' | 'partial_success' | 'failure';\n  outcomeConfidence?: number;\n  rootCauseCategory?: string;\n  rootCauseConfidence?: number;\n  claims?: CreateClaimInput[];\n}\n\nexport interface CreateClaimInput {\n  claimType: ClaimType;\n  claimCategory: ClaimCategory;\n  claimText: string;\n  confidence: number;\n  confidenceCalibration?: 'calibrated' | 'uncalibrated' | 'needs_more_data';\n  evidence?: EvidenceReference[];\n  isExplainable?: boolean;\n  probabilityValue?: number;\n}\n\n/**\n * Facts vs inferences summary\n */\nexport interface FactsVsInferencesSummary {\n  analysisIds: string[];\n  totalClaims: number;\n  observed: {\n    count: number;\n    avgConfidence: number;\n    categories: Record<string, number>;\n  };\n  inferred: {\n    count: number;\n    avgConfidence: number;\n    categories: Record<string, number>;\n  };\n  computed: {\n    count: number;\n    avgConfidence: number;\n    categories: Record<string, number>;\n  };\n  humanVerifiedCount: number;\n  humanRejectedCount: number;\n}\n\n/**\n * Claims API client for facts vs inferences management\n */\nexport const claims = {\n  /**\n   * Create a new analysis for a run\n   *\n   * @example\n   * ```typescript\n   * const analysis = await claims.createAnalysis({\n   *   runId: 'run_abc123',\n   *   outcomeVerdict: 'failure',\n   *   outcomeConfidence: 0.85,\n   *   rootCauseCategory: 'retrieval_failure',\n   *   claims: [\n   *     {\n   *       claimType: 'observed',\n   *       claimCategory: 'root_cause',\n   *       claimText: 'Vector search returned 0 results',\n   *       confidence: 1.0,\n   *       evidence: [{ type: 'span', referenceId: 'span_123', relevance: 'direct', confidence: 1.0 }],\n   *     },\n   *     {\n   *       claimType: 'inferred',\n   *       claimCategory: 'churn_risk',\n   *       claimText: 'High churn risk due to repeated failures',\n   *       confidence: 0.7,\n   *     },\n   *   ],\n   * });\n   * ```\n   */\n  async createAnalysis(options: CreateAnalysisOptions): Promise<AnalysisResult> {\n    return apiRequestWithData<AnalysisResult>('/analyses', {\n      method: 'POST',\n      body: options,\n      apiVersion: 'v3',\n    });\n  },\n\n  /**\n   * Get an analysis by ID\n   *\n   * @example\n   * ```typescript\n   * const analysis = await claims.getAnalysis('analysis_abc123');\n   * ```\n   */\n  async getAnalysis(analysisId: string): Promise<AnalysisResult> {\n    return apiRequestWithData<AnalysisResult>(`/analyses/${analysisId}`, { apiVersion: 'v3' });\n  },\n\n  /**\n   * Get current analysis for a run\n   *\n   * @example\n   * ```typescript\n   * const analysis = await claims.getRunAnalysis('run_abc123');\n   * ```\n   */\n  async getRunAnalysis(runId: string): Promise<AnalysisResult> {\n    return apiRequestWithData<AnalysisResult>(`/runs/${runId}/analysis`, { apiVersion: 'v3' });\n  },\n\n  /**\n   * Get analysis history for a run\n   *\n   * @example\n   * ```typescript\n   * const history = await claims.getAnalysisHistory('run_abc123');\n   * ```\n   */\n  async getAnalysisHistory(runId: string): Promise<{\n    runId: string;\n    analyses: Array<{\n      id: string;\n      analysisVersion: string;\n      modelUsed: string;\n      outcomeVerdict: string;\n      isCurrent: boolean;\n      supersededBy?: string;\n      supersessionReason?: string;\n      analyzedAt: string;\n    }>;\n  }> {\n    return apiRequestWithData(`/runs/${runId}/analyses`, { apiVersion: 'v3' });\n  },\n\n  /**\n   * Supersede an analysis with a new one\n   *\n   * @example\n   * ```typescript\n   * const newAnalysis = await claims.supersedeAnalysis('analysis_old', {\n   *   reason: 'Improved model accuracy',\n   *   newAnalysis: {\n   *     outcomeVerdict: 'success',\n   *     outcomeConfidence: 0.95,\n   *     claims: [...],\n   *   },\n   * });\n   * ```\n   */\n  async supersedeAnalysis(\n    analysisId: string,\n    options: {\n      reason: string;\n      newAnalysis: Omit<CreateAnalysisOptions, 'runId'>;\n    }\n  ): Promise<{ supersededAnalysisId: string; newAnalysis: AnalysisResult }> {\n    return apiRequestWithData(`/analyses/${analysisId}/supersede`, {\n      method: 'POST',\n      body: options,\n      apiVersion: 'v3',\n    });\n  },\n\n  /**\n   * List claims with filters\n   *\n   * @example\n   * ```typescript\n   * // Get all inferred claims with high confidence\n   * const { claims } = await claims.list({\n   *   claimType: 'inferred',\n   *   minConfidence: 0.8,\n   * });\n   *\n   * // Get all churn risk claims for a run\n   * const { claims } = await claims.list({\n   *   runId: 'run_abc123',\n   *   claimCategory: 'churn_risk',\n   * });\n   * ```\n   */\n  async list(\n    options: ListClaimsOptions = {}\n  ): Promise<{ claims: Claim[]; limit: number; offset: number; hasMore: boolean }> {\n    const params = new URLSearchParams();\n    if (options.runId) params.set('runId', options.runId);\n    if (options.analysisId) params.set('analysisId', options.analysisId);\n    if (options.claimType) params.set('claimType', options.claimType);\n    if (options.claimCategory) params.set('claimCategory', options.claimCategory);\n    if (options.minConfidence !== undefined) {\n      params.set('minConfidence', String(options.minConfidence));\n    }\n    if (options.humanVerified !== undefined) {\n      params.set('humanVerified', String(options.humanVerified));\n    }\n    if (options.limit) params.set('limit', String(options.limit));\n    if (options.offset) params.set('offset', String(options.offset));\n\n    const response = await apiRequest<ApiResponse<{ claims: Claim[]; limit: number; offset: number; hasMore: boolean }>>(\n      `/claims?${params.toString()}`,\n      { apiVersion: 'v3' }\n    );\n    return response.data!;\n  },\n\n  /**\n   * Get a claim by ID\n   *\n   * @example\n   * ```typescript\n   * const claim = await claims.get('claim_abc123');\n   * ```\n   */\n  async get(claimId: string): Promise<Claim> {\n    return apiRequestWithData<Claim>(`/claims/${claimId}`, { apiVersion: 'v3' });\n  },\n\n  /**\n   * Verify or reject a claim (human feedback)\n   *\n   * @example\n   * ```typescript\n   * // Confirm a claim\n   * await claims.verify('claim_abc123', {\n   *   verdict: 'confirmed',\n   *   notes: 'Verified against ticket history',\n   * });\n   *\n   * // Reject a claim\n   * await claims.verify('claim_abc123', {\n   *   verdict: 'rejected',\n   *   notes: 'Customer context was missing',\n   * });\n   * ```\n   */\n  async verify(\n    claimId: string,\n    options: {\n      verdict: 'confirmed' | 'rejected' | 'modified';\n      notes?: string;\n      modifiedText?: string;\n    }\n  ): Promise<{ claimId: string; verdict: string; message: string }> {\n    return apiRequestWithData(`/claims/${claimId}/verify`, {\n      method: 'POST',\n      body: options,\n      apiVersion: 'v3',\n    });\n  },\n\n  /**\n   * Get facts vs inferences summary\n   *\n   * @example\n   * ```typescript\n   * // Summary for a specific run\n   * const summary = await claims.summary({ runId: 'run_abc123' });\n   *\n   * // Summary for multiple analyses\n   * const summary = await claims.summary({\n   *   analysisIds: ['analysis_1', 'analysis_2'],\n   * });\n   * ```\n   */\n  async summary(\n    options: { runId?: string; analysisIds?: string[] } = {}\n  ): Promise<FactsVsInferencesSummary> {\n    const params = new URLSearchParams();\n    if (options.runId) params.set('runId', options.runId);\n    if (options.analysisIds) params.set('analysisIds', options.analysisIds.join(','));\n\n    return apiRequestWithData<FactsVsInferencesSummary>(\n      `/claims/summary?${params.toString()}`,\n      { apiVersion: 'v3' }\n    );\n  },\n};\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Check if a claim is a fact (observed)\n */\nexport function isFact(claim: Claim): boolean {\n  return claim.claimType === 'observed';\n}\n\n/**\n * Check if a claim is an inference\n */\nexport function isInference(claim: Claim): boolean {\n  return claim.claimType === 'inferred';\n}\n\n/**\n * Check if a claim is computed\n */\nexport function isComputed(claim: Claim): boolean {\n  return claim.claimType === 'computed';\n}\n\n/**\n * Get high confidence claims (>= threshold)\n */\nexport function getHighConfidenceClaims(\n  claimsList: Claim[],\n  threshold: number = 0.8\n): Claim[] {\n  return claimsList.filter((c) => c.confidence >= threshold);\n}\n\n/**\n * Group claims by type\n */\nexport function groupClaimsByType(\n  claimsList: Claim[]\n): Record<ClaimType, Claim[]> {\n  return {\n    observed: claimsList.filter((c) => c.claimType === 'observed'),\n    inferred: claimsList.filter((c) => c.claimType === 'inferred'),\n    computed: claimsList.filter((c) => c.claimType === 'computed'),\n  };\n}\n\n/**\n * Group claims by category\n */\nexport function groupClaimsByCategory(\n  claimsList: Claim[]\n): Record<ClaimCategory, Claim[]> {\n  const groups: Record<ClaimCategory, Claim[]> = {\n    outcome: [],\n    root_cause: [],\n    customer_impact: [],\n    churn_risk: [],\n    revenue_impact: [],\n    quality: [],\n    other: [],\n  };\n\n  for (const claim of claimsList) {\n    groups[claim.claimCategory].push(claim);\n  }\n\n  return groups;\n}\n"]}
|