@thinkhive/sdk 2.0.1 → 3.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/MIGRATION.md +274 -0
- package/README.md +7 -22
- package/dist/api/calibration.d.ts +168 -0
- package/dist/api/calibration.js +176 -0
- package/dist/api/claims.d.ts +262 -0
- package/dist/api/claims.js +262 -0
- package/dist/api/runs.d.ts +200 -0
- package/dist/api/runs.js +262 -0
- package/dist/core/client.d.ts +29 -0
- package/dist/core/client.js +89 -0
- package/dist/core/config.d.ts +38 -0
- package/dist/core/config.js +76 -0
- package/dist/core/types.d.ts +354 -0
- package/dist/core/types.js +8 -0
- package/dist/index.d.ts +222 -512
- package/dist/index.js +169 -394
- package/dist/instrumentation/langchain.d.ts +194 -0
- package/dist/instrumentation/langchain.js +429 -0
- package/dist/instrumentation/openai.d.ts +141 -0
- package/dist/instrumentation/openai.js +279 -0
- package/dist/integrations/customer-context.d.ts +203 -0
- package/dist/integrations/customer-context.js +274 -0
- package/dist/integrations/ticket-linking.d.ts +217 -0
- package/dist/integrations/ticket-linking.js +259 -0
- package/package.json +61 -9
|
@@ -0,0 +1,262 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ThinkHive SDK v3.0 - Claims API
|
|
3
|
+
*
|
|
4
|
+
* Facts vs Inferences API for accessing analysis claims
|
|
5
|
+
*/
|
|
6
|
+
import type { Claim, ClaimType, ClaimCategory, AnalysisResult, EvidenceReference } from '../core/types';
|
|
7
|
+
/**
|
|
8
|
+
* List claims query options
|
|
9
|
+
*/
|
|
10
|
+
export interface ListClaimsOptions {
|
|
11
|
+
runId?: string;
|
|
12
|
+
analysisId?: string;
|
|
13
|
+
claimType?: ClaimType;
|
|
14
|
+
claimCategory?: ClaimCategory;
|
|
15
|
+
minConfidence?: number;
|
|
16
|
+
humanVerified?: boolean;
|
|
17
|
+
limit?: number;
|
|
18
|
+
offset?: number;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Create analysis options
|
|
22
|
+
*/
|
|
23
|
+
export interface CreateAnalysisOptions {
|
|
24
|
+
runId: string;
|
|
25
|
+
modelUsed?: string;
|
|
26
|
+
outcomeVerdict: 'success' | 'partial_success' | 'failure';
|
|
27
|
+
outcomeConfidence?: number;
|
|
28
|
+
rootCauseCategory?: string;
|
|
29
|
+
rootCauseConfidence?: number;
|
|
30
|
+
claims?: CreateClaimInput[];
|
|
31
|
+
}
|
|
32
|
+
export interface CreateClaimInput {
|
|
33
|
+
claimType: ClaimType;
|
|
34
|
+
claimCategory: ClaimCategory;
|
|
35
|
+
claimText: string;
|
|
36
|
+
confidence: number;
|
|
37
|
+
confidenceCalibration?: 'calibrated' | 'uncalibrated' | 'needs_more_data';
|
|
38
|
+
evidence?: EvidenceReference[];
|
|
39
|
+
isExplainable?: boolean;
|
|
40
|
+
probabilityValue?: number;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Facts vs inferences summary
|
|
44
|
+
*/
|
|
45
|
+
export interface FactsVsInferencesSummary {
|
|
46
|
+
analysisIds: string[];
|
|
47
|
+
totalClaims: number;
|
|
48
|
+
observed: {
|
|
49
|
+
count: number;
|
|
50
|
+
avgConfidence: number;
|
|
51
|
+
categories: Record<string, number>;
|
|
52
|
+
};
|
|
53
|
+
inferred: {
|
|
54
|
+
count: number;
|
|
55
|
+
avgConfidence: number;
|
|
56
|
+
categories: Record<string, number>;
|
|
57
|
+
};
|
|
58
|
+
computed: {
|
|
59
|
+
count: number;
|
|
60
|
+
avgConfidence: number;
|
|
61
|
+
categories: Record<string, number>;
|
|
62
|
+
};
|
|
63
|
+
humanVerifiedCount: number;
|
|
64
|
+
humanRejectedCount: number;
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Claims API client for facts vs inferences management
|
|
68
|
+
*/
|
|
69
|
+
export declare const claims: {
|
|
70
|
+
/**
|
|
71
|
+
* Create a new analysis for a run
|
|
72
|
+
*
|
|
73
|
+
* @example
|
|
74
|
+
* ```typescript
|
|
75
|
+
* const analysis = await claims.createAnalysis({
|
|
76
|
+
* runId: 'run_abc123',
|
|
77
|
+
* outcomeVerdict: 'failure',
|
|
78
|
+
* outcomeConfidence: 0.85,
|
|
79
|
+
* rootCauseCategory: 'retrieval_failure',
|
|
80
|
+
* claims: [
|
|
81
|
+
* {
|
|
82
|
+
* claimType: 'observed',
|
|
83
|
+
* claimCategory: 'root_cause',
|
|
84
|
+
* claimText: 'Vector search returned 0 results',
|
|
85
|
+
* confidence: 1.0,
|
|
86
|
+
* evidence: [{ type: 'span', referenceId: 'span_123', relevance: 'direct', confidence: 1.0 }],
|
|
87
|
+
* },
|
|
88
|
+
* {
|
|
89
|
+
* claimType: 'inferred',
|
|
90
|
+
* claimCategory: 'churn_risk',
|
|
91
|
+
* claimText: 'High churn risk due to repeated failures',
|
|
92
|
+
* confidence: 0.7,
|
|
93
|
+
* },
|
|
94
|
+
* ],
|
|
95
|
+
* });
|
|
96
|
+
* ```
|
|
97
|
+
*/
|
|
98
|
+
createAnalysis(options: CreateAnalysisOptions): Promise<AnalysisResult>;
|
|
99
|
+
/**
|
|
100
|
+
* Get an analysis by ID
|
|
101
|
+
*
|
|
102
|
+
* @example
|
|
103
|
+
* ```typescript
|
|
104
|
+
* const analysis = await claims.getAnalysis('analysis_abc123');
|
|
105
|
+
* ```
|
|
106
|
+
*/
|
|
107
|
+
getAnalysis(analysisId: string): Promise<AnalysisResult>;
|
|
108
|
+
/**
|
|
109
|
+
* Get current analysis for a run
|
|
110
|
+
*
|
|
111
|
+
* @example
|
|
112
|
+
* ```typescript
|
|
113
|
+
* const analysis = await claims.getRunAnalysis('run_abc123');
|
|
114
|
+
* ```
|
|
115
|
+
*/
|
|
116
|
+
getRunAnalysis(runId: string): Promise<AnalysisResult>;
|
|
117
|
+
/**
|
|
118
|
+
* Get analysis history for a run
|
|
119
|
+
*
|
|
120
|
+
* @example
|
|
121
|
+
* ```typescript
|
|
122
|
+
* const history = await claims.getAnalysisHistory('run_abc123');
|
|
123
|
+
* ```
|
|
124
|
+
*/
|
|
125
|
+
getAnalysisHistory(runId: string): Promise<{
|
|
126
|
+
runId: string;
|
|
127
|
+
analyses: Array<{
|
|
128
|
+
id: string;
|
|
129
|
+
analysisVersion: string;
|
|
130
|
+
modelUsed: string;
|
|
131
|
+
outcomeVerdict: string;
|
|
132
|
+
isCurrent: boolean;
|
|
133
|
+
supersededBy?: string;
|
|
134
|
+
supersessionReason?: string;
|
|
135
|
+
analyzedAt: string;
|
|
136
|
+
}>;
|
|
137
|
+
}>;
|
|
138
|
+
/**
|
|
139
|
+
* Supersede an analysis with a new one
|
|
140
|
+
*
|
|
141
|
+
* @example
|
|
142
|
+
* ```typescript
|
|
143
|
+
* const newAnalysis = await claims.supersedeAnalysis('analysis_old', {
|
|
144
|
+
* reason: 'Improved model accuracy',
|
|
145
|
+
* newAnalysis: {
|
|
146
|
+
* outcomeVerdict: 'success',
|
|
147
|
+
* outcomeConfidence: 0.95,
|
|
148
|
+
* claims: [...],
|
|
149
|
+
* },
|
|
150
|
+
* });
|
|
151
|
+
* ```
|
|
152
|
+
*/
|
|
153
|
+
supersedeAnalysis(analysisId: string, options: {
|
|
154
|
+
reason: string;
|
|
155
|
+
newAnalysis: Omit<CreateAnalysisOptions, "runId">;
|
|
156
|
+
}): Promise<{
|
|
157
|
+
supersededAnalysisId: string;
|
|
158
|
+
newAnalysis: AnalysisResult;
|
|
159
|
+
}>;
|
|
160
|
+
/**
|
|
161
|
+
* List claims with filters
|
|
162
|
+
*
|
|
163
|
+
* @example
|
|
164
|
+
* ```typescript
|
|
165
|
+
* // Get all inferred claims with high confidence
|
|
166
|
+
* const { claims } = await claims.list({
|
|
167
|
+
* claimType: 'inferred',
|
|
168
|
+
* minConfidence: 0.8,
|
|
169
|
+
* });
|
|
170
|
+
*
|
|
171
|
+
* // Get all churn risk claims for a run
|
|
172
|
+
* const { claims } = await claims.list({
|
|
173
|
+
* runId: 'run_abc123',
|
|
174
|
+
* claimCategory: 'churn_risk',
|
|
175
|
+
* });
|
|
176
|
+
* ```
|
|
177
|
+
*/
|
|
178
|
+
list(options?: ListClaimsOptions): Promise<{
|
|
179
|
+
claims: Claim[];
|
|
180
|
+
limit: number;
|
|
181
|
+
offset: number;
|
|
182
|
+
hasMore: boolean;
|
|
183
|
+
}>;
|
|
184
|
+
/**
|
|
185
|
+
* Get a claim by ID
|
|
186
|
+
*
|
|
187
|
+
* @example
|
|
188
|
+
* ```typescript
|
|
189
|
+
* const claim = await claims.get('claim_abc123');
|
|
190
|
+
* ```
|
|
191
|
+
*/
|
|
192
|
+
get(claimId: string): Promise<Claim>;
|
|
193
|
+
/**
|
|
194
|
+
* Verify or reject a claim (human feedback)
|
|
195
|
+
*
|
|
196
|
+
* @example
|
|
197
|
+
* ```typescript
|
|
198
|
+
* // Confirm a claim
|
|
199
|
+
* await claims.verify('claim_abc123', {
|
|
200
|
+
* verdict: 'confirmed',
|
|
201
|
+
* notes: 'Verified against ticket history',
|
|
202
|
+
* });
|
|
203
|
+
*
|
|
204
|
+
* // Reject a claim
|
|
205
|
+
* await claims.verify('claim_abc123', {
|
|
206
|
+
* verdict: 'rejected',
|
|
207
|
+
* notes: 'Customer context was missing',
|
|
208
|
+
* });
|
|
209
|
+
* ```
|
|
210
|
+
*/
|
|
211
|
+
verify(claimId: string, options: {
|
|
212
|
+
verdict: "confirmed" | "rejected" | "modified";
|
|
213
|
+
notes?: string;
|
|
214
|
+
modifiedText?: string;
|
|
215
|
+
}): Promise<{
|
|
216
|
+
claimId: string;
|
|
217
|
+
verdict: string;
|
|
218
|
+
message: string;
|
|
219
|
+
}>;
|
|
220
|
+
/**
|
|
221
|
+
* Get facts vs inferences summary
|
|
222
|
+
*
|
|
223
|
+
* @example
|
|
224
|
+
* ```typescript
|
|
225
|
+
* // Summary for a specific run
|
|
226
|
+
* const summary = await claims.summary({ runId: 'run_abc123' });
|
|
227
|
+
*
|
|
228
|
+
* // Summary for multiple analyses
|
|
229
|
+
* const summary = await claims.summary({
|
|
230
|
+
* analysisIds: ['analysis_1', 'analysis_2'],
|
|
231
|
+
* });
|
|
232
|
+
* ```
|
|
233
|
+
*/
|
|
234
|
+
summary(options?: {
|
|
235
|
+
runId?: string;
|
|
236
|
+
analysisIds?: string[];
|
|
237
|
+
}): Promise<FactsVsInferencesSummary>;
|
|
238
|
+
};
|
|
239
|
+
/**
|
|
240
|
+
* Check if a claim is a fact (observed)
|
|
241
|
+
*/
|
|
242
|
+
export declare function isFact(claim: Claim): boolean;
|
|
243
|
+
/**
|
|
244
|
+
* Check if a claim is an inference
|
|
245
|
+
*/
|
|
246
|
+
export declare function isInference(claim: Claim): boolean;
|
|
247
|
+
/**
|
|
248
|
+
* Check if a claim is computed
|
|
249
|
+
*/
|
|
250
|
+
export declare function isComputed(claim: Claim): boolean;
|
|
251
|
+
/**
|
|
252
|
+
* Get high confidence claims (>= threshold)
|
|
253
|
+
*/
|
|
254
|
+
export declare function getHighConfidenceClaims(claimsList: Claim[], threshold?: number): Claim[];
|
|
255
|
+
/**
|
|
256
|
+
* Group claims by type
|
|
257
|
+
*/
|
|
258
|
+
export declare function groupClaimsByType(claimsList: Claim[]): Record<ClaimType, Claim[]>;
|
|
259
|
+
/**
|
|
260
|
+
* Group claims by category
|
|
261
|
+
*/
|
|
262
|
+
export declare function groupClaimsByCategory(claimsList: Claim[]): Record<ClaimCategory, Claim[]>;
|
|
@@ -0,0 +1,262 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ThinkHive SDK v3.0 - Claims API
|
|
4
|
+
*
|
|
5
|
+
* Facts vs Inferences API for accessing analysis claims
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.claims = void 0;
|
|
9
|
+
exports.isFact = isFact;
|
|
10
|
+
exports.isInference = isInference;
|
|
11
|
+
exports.isComputed = isComputed;
|
|
12
|
+
exports.getHighConfidenceClaims = getHighConfidenceClaims;
|
|
13
|
+
exports.groupClaimsByType = groupClaimsByType;
|
|
14
|
+
exports.groupClaimsByCategory = groupClaimsByCategory;
|
|
15
|
+
const client_1 = require("../core/client");
|
|
16
|
+
/**
|
|
17
|
+
* Claims API client for facts vs inferences management
|
|
18
|
+
*/
|
|
19
|
+
exports.claims = {
|
|
20
|
+
/**
|
|
21
|
+
* Create a new analysis for a run
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* ```typescript
|
|
25
|
+
* const analysis = await claims.createAnalysis({
|
|
26
|
+
* runId: 'run_abc123',
|
|
27
|
+
* outcomeVerdict: 'failure',
|
|
28
|
+
* outcomeConfidence: 0.85,
|
|
29
|
+
* rootCauseCategory: 'retrieval_failure',
|
|
30
|
+
* claims: [
|
|
31
|
+
* {
|
|
32
|
+
* claimType: 'observed',
|
|
33
|
+
* claimCategory: 'root_cause',
|
|
34
|
+
* claimText: 'Vector search returned 0 results',
|
|
35
|
+
* confidence: 1.0,
|
|
36
|
+
* evidence: [{ type: 'span', referenceId: 'span_123', relevance: 'direct', confidence: 1.0 }],
|
|
37
|
+
* },
|
|
38
|
+
* {
|
|
39
|
+
* claimType: 'inferred',
|
|
40
|
+
* claimCategory: 'churn_risk',
|
|
41
|
+
* claimText: 'High churn risk due to repeated failures',
|
|
42
|
+
* confidence: 0.7,
|
|
43
|
+
* },
|
|
44
|
+
* ],
|
|
45
|
+
* });
|
|
46
|
+
* ```
|
|
47
|
+
*/
|
|
48
|
+
async createAnalysis(options) {
|
|
49
|
+
return (0, client_1.apiRequestWithData)('/analyses', {
|
|
50
|
+
method: 'POST',
|
|
51
|
+
body: options,
|
|
52
|
+
});
|
|
53
|
+
},
|
|
54
|
+
/**
|
|
55
|
+
* Get an analysis by ID
|
|
56
|
+
*
|
|
57
|
+
* @example
|
|
58
|
+
* ```typescript
|
|
59
|
+
* const analysis = await claims.getAnalysis('analysis_abc123');
|
|
60
|
+
* ```
|
|
61
|
+
*/
|
|
62
|
+
async getAnalysis(analysisId) {
|
|
63
|
+
return (0, client_1.apiRequestWithData)(`/analyses/${analysisId}`);
|
|
64
|
+
},
|
|
65
|
+
/**
|
|
66
|
+
* Get current analysis for a run
|
|
67
|
+
*
|
|
68
|
+
* @example
|
|
69
|
+
* ```typescript
|
|
70
|
+
* const analysis = await claims.getRunAnalysis('run_abc123');
|
|
71
|
+
* ```
|
|
72
|
+
*/
|
|
73
|
+
async getRunAnalysis(runId) {
|
|
74
|
+
return (0, client_1.apiRequestWithData)(`/runs/${runId}/analysis`);
|
|
75
|
+
},
|
|
76
|
+
/**
|
|
77
|
+
* Get analysis history for a run
|
|
78
|
+
*
|
|
79
|
+
* @example
|
|
80
|
+
* ```typescript
|
|
81
|
+
* const history = await claims.getAnalysisHistory('run_abc123');
|
|
82
|
+
* ```
|
|
83
|
+
*/
|
|
84
|
+
async getAnalysisHistory(runId) {
|
|
85
|
+
return (0, client_1.apiRequestWithData)(`/runs/${runId}/analyses`);
|
|
86
|
+
},
|
|
87
|
+
/**
|
|
88
|
+
* Supersede an analysis with a new one
|
|
89
|
+
*
|
|
90
|
+
* @example
|
|
91
|
+
* ```typescript
|
|
92
|
+
* const newAnalysis = await claims.supersedeAnalysis('analysis_old', {
|
|
93
|
+
* reason: 'Improved model accuracy',
|
|
94
|
+
* newAnalysis: {
|
|
95
|
+
* outcomeVerdict: 'success',
|
|
96
|
+
* outcomeConfidence: 0.95,
|
|
97
|
+
* claims: [...],
|
|
98
|
+
* },
|
|
99
|
+
* });
|
|
100
|
+
* ```
|
|
101
|
+
*/
|
|
102
|
+
async supersedeAnalysis(analysisId, options) {
|
|
103
|
+
return (0, client_1.apiRequestWithData)(`/analyses/${analysisId}/supersede`, {
|
|
104
|
+
method: 'POST',
|
|
105
|
+
body: options,
|
|
106
|
+
});
|
|
107
|
+
},
|
|
108
|
+
/**
|
|
109
|
+
* List claims with filters
|
|
110
|
+
*
|
|
111
|
+
* @example
|
|
112
|
+
* ```typescript
|
|
113
|
+
* // Get all inferred claims with high confidence
|
|
114
|
+
* const { claims } = await claims.list({
|
|
115
|
+
* claimType: 'inferred',
|
|
116
|
+
* minConfidence: 0.8,
|
|
117
|
+
* });
|
|
118
|
+
*
|
|
119
|
+
* // Get all churn risk claims for a run
|
|
120
|
+
* const { claims } = await claims.list({
|
|
121
|
+
* runId: 'run_abc123',
|
|
122
|
+
* claimCategory: 'churn_risk',
|
|
123
|
+
* });
|
|
124
|
+
* ```
|
|
125
|
+
*/
|
|
126
|
+
async list(options = {}) {
|
|
127
|
+
const params = new URLSearchParams();
|
|
128
|
+
if (options.runId)
|
|
129
|
+
params.set('runId', options.runId);
|
|
130
|
+
if (options.analysisId)
|
|
131
|
+
params.set('analysisId', options.analysisId);
|
|
132
|
+
if (options.claimType)
|
|
133
|
+
params.set('claimType', options.claimType);
|
|
134
|
+
if (options.claimCategory)
|
|
135
|
+
params.set('claimCategory', options.claimCategory);
|
|
136
|
+
if (options.minConfidence !== undefined) {
|
|
137
|
+
params.set('minConfidence', String(options.minConfidence));
|
|
138
|
+
}
|
|
139
|
+
if (options.humanVerified !== undefined) {
|
|
140
|
+
params.set('humanVerified', String(options.humanVerified));
|
|
141
|
+
}
|
|
142
|
+
if (options.limit)
|
|
143
|
+
params.set('limit', String(options.limit));
|
|
144
|
+
if (options.offset)
|
|
145
|
+
params.set('offset', String(options.offset));
|
|
146
|
+
const response = await (0, client_1.apiRequest)(`/claims?${params.toString()}`);
|
|
147
|
+
return response.data;
|
|
148
|
+
},
|
|
149
|
+
/**
|
|
150
|
+
* Get a claim by ID
|
|
151
|
+
*
|
|
152
|
+
* @example
|
|
153
|
+
* ```typescript
|
|
154
|
+
* const claim = await claims.get('claim_abc123');
|
|
155
|
+
* ```
|
|
156
|
+
*/
|
|
157
|
+
async get(claimId) {
|
|
158
|
+
return (0, client_1.apiRequestWithData)(`/claims/${claimId}`);
|
|
159
|
+
},
|
|
160
|
+
/**
|
|
161
|
+
* Verify or reject a claim (human feedback)
|
|
162
|
+
*
|
|
163
|
+
* @example
|
|
164
|
+
* ```typescript
|
|
165
|
+
* // Confirm a claim
|
|
166
|
+
* await claims.verify('claim_abc123', {
|
|
167
|
+
* verdict: 'confirmed',
|
|
168
|
+
* notes: 'Verified against ticket history',
|
|
169
|
+
* });
|
|
170
|
+
*
|
|
171
|
+
* // Reject a claim
|
|
172
|
+
* await claims.verify('claim_abc123', {
|
|
173
|
+
* verdict: 'rejected',
|
|
174
|
+
* notes: 'Customer context was missing',
|
|
175
|
+
* });
|
|
176
|
+
* ```
|
|
177
|
+
*/
|
|
178
|
+
async verify(claimId, options) {
|
|
179
|
+
return (0, client_1.apiRequestWithData)(`/claims/${claimId}/verify`, {
|
|
180
|
+
method: 'POST',
|
|
181
|
+
body: options,
|
|
182
|
+
});
|
|
183
|
+
},
|
|
184
|
+
/**
|
|
185
|
+
* Get facts vs inferences summary
|
|
186
|
+
*
|
|
187
|
+
* @example
|
|
188
|
+
* ```typescript
|
|
189
|
+
* // Summary for a specific run
|
|
190
|
+
* const summary = await claims.summary({ runId: 'run_abc123' });
|
|
191
|
+
*
|
|
192
|
+
* // Summary for multiple analyses
|
|
193
|
+
* const summary = await claims.summary({
|
|
194
|
+
* analysisIds: ['analysis_1', 'analysis_2'],
|
|
195
|
+
* });
|
|
196
|
+
* ```
|
|
197
|
+
*/
|
|
198
|
+
async summary(options = {}) {
|
|
199
|
+
const params = new URLSearchParams();
|
|
200
|
+
if (options.runId)
|
|
201
|
+
params.set('runId', options.runId);
|
|
202
|
+
if (options.analysisIds)
|
|
203
|
+
params.set('analysisIds', options.analysisIds.join(','));
|
|
204
|
+
return (0, client_1.apiRequestWithData)(`/claims/summary?${params.toString()}`);
|
|
205
|
+
},
|
|
206
|
+
};
|
|
207
|
+
// ============================================================================
|
|
208
|
+
// HELPER FUNCTIONS
|
|
209
|
+
// ============================================================================
|
|
210
|
+
/**
|
|
211
|
+
* Check if a claim is a fact (observed)
|
|
212
|
+
*/
|
|
213
|
+
function isFact(claim) {
|
|
214
|
+
return claim.claimType === 'observed';
|
|
215
|
+
}
|
|
216
|
+
/**
|
|
217
|
+
* Check if a claim is an inference
|
|
218
|
+
*/
|
|
219
|
+
function isInference(claim) {
|
|
220
|
+
return claim.claimType === 'inferred';
|
|
221
|
+
}
|
|
222
|
+
/**
|
|
223
|
+
* Check if a claim is computed
|
|
224
|
+
*/
|
|
225
|
+
function isComputed(claim) {
|
|
226
|
+
return claim.claimType === 'computed';
|
|
227
|
+
}
|
|
228
|
+
/**
|
|
229
|
+
* Get high confidence claims (>= threshold)
|
|
230
|
+
*/
|
|
231
|
+
function getHighConfidenceClaims(claimsList, threshold = 0.8) {
|
|
232
|
+
return claimsList.filter((c) => c.confidence >= threshold);
|
|
233
|
+
}
|
|
234
|
+
/**
|
|
235
|
+
* Group claims by type
|
|
236
|
+
*/
|
|
237
|
+
function groupClaimsByType(claimsList) {
|
|
238
|
+
return {
|
|
239
|
+
observed: claimsList.filter((c) => c.claimType === 'observed'),
|
|
240
|
+
inferred: claimsList.filter((c) => c.claimType === 'inferred'),
|
|
241
|
+
computed: claimsList.filter((c) => c.claimType === 'computed'),
|
|
242
|
+
};
|
|
243
|
+
}
|
|
244
|
+
/**
|
|
245
|
+
* Group claims by category
|
|
246
|
+
*/
|
|
247
|
+
function groupClaimsByCategory(claimsList) {
|
|
248
|
+
const groups = {
|
|
249
|
+
outcome: [],
|
|
250
|
+
root_cause: [],
|
|
251
|
+
customer_impact: [],
|
|
252
|
+
churn_risk: [],
|
|
253
|
+
revenue_impact: [],
|
|
254
|
+
quality: [],
|
|
255
|
+
other: [],
|
|
256
|
+
};
|
|
257
|
+
for (const claim of claimsList) {
|
|
258
|
+
groups[claim.claimCategory].push(claim);
|
|
259
|
+
}
|
|
260
|
+
return groups;
|
|
261
|
+
}
|
|
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"]}
|