@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,200 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ThinkHive SDK v3.0 - Runs API
|
|
3
|
+
*
|
|
4
|
+
* Run-centric API for creating and managing runs (the atomic unit in v3)
|
|
5
|
+
*/
|
|
6
|
+
import type { RunOptions, RunResponse, CustomerContextSnapshot, ConversationMessage, RunOutcome } from '../core/types';
|
|
7
|
+
/**
|
|
8
|
+
* List runs query options
|
|
9
|
+
*/
|
|
10
|
+
export interface ListRunsOptions {
|
|
11
|
+
agentId?: string;
|
|
12
|
+
ticketId?: string;
|
|
13
|
+
customerAccountId?: string;
|
|
14
|
+
outcome?: RunOutcome;
|
|
15
|
+
startedAfter?: string | Date;
|
|
16
|
+
startedBefore?: string | Date;
|
|
17
|
+
limit?: number;
|
|
18
|
+
offset?: number;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Run stats response
|
|
22
|
+
*/
|
|
23
|
+
export interface RunStats {
|
|
24
|
+
agentId: string;
|
|
25
|
+
period: {
|
|
26
|
+
from: string;
|
|
27
|
+
to: string;
|
|
28
|
+
};
|
|
29
|
+
totalRuns: number;
|
|
30
|
+
outcomeBreakdown: Record<RunOutcome, number>;
|
|
31
|
+
avgDurationMs: number;
|
|
32
|
+
linkedTickets: number;
|
|
33
|
+
unlinkedRuns: number;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Runs API client for v3 run-centric operations
|
|
37
|
+
*/
|
|
38
|
+
export declare const runs: {
|
|
39
|
+
/**
|
|
40
|
+
* Create a new run
|
|
41
|
+
*
|
|
42
|
+
* @example
|
|
43
|
+
* ```typescript
|
|
44
|
+
* const run = await runs.create({
|
|
45
|
+
* agentId: 'agent_123',
|
|
46
|
+
* conversationMessages: [
|
|
47
|
+
* { role: 'user', content: 'Help me with my order' },
|
|
48
|
+
* { role: 'assistant', content: 'I can help with that...' },
|
|
49
|
+
* ],
|
|
50
|
+
* outcome: 'resolved',
|
|
51
|
+
* customerContext: {
|
|
52
|
+
* arr: 50000,
|
|
53
|
+
* healthScore: 85,
|
|
54
|
+
* segment: 'enterprise',
|
|
55
|
+
* },
|
|
56
|
+
* });
|
|
57
|
+
* ```
|
|
58
|
+
*/
|
|
59
|
+
create(options: RunOptions): Promise<RunResponse>;
|
|
60
|
+
/**
|
|
61
|
+
* Get a run by ID
|
|
62
|
+
*
|
|
63
|
+
* @example
|
|
64
|
+
* ```typescript
|
|
65
|
+
* const run = await runs.get('run_abc123');
|
|
66
|
+
* ```
|
|
67
|
+
*/
|
|
68
|
+
get(runId: string): Promise<RunResponse>;
|
|
69
|
+
/**
|
|
70
|
+
* List runs with filters
|
|
71
|
+
*
|
|
72
|
+
* @example
|
|
73
|
+
* ```typescript
|
|
74
|
+
* const { items, hasMore } = await runs.list({
|
|
75
|
+
* agentId: 'agent_123',
|
|
76
|
+
* outcome: 'failed',
|
|
77
|
+
* limit: 20,
|
|
78
|
+
* });
|
|
79
|
+
* ```
|
|
80
|
+
*/
|
|
81
|
+
list(options?: ListRunsOptions): Promise<{
|
|
82
|
+
items: RunResponse[];
|
|
83
|
+
limit: number;
|
|
84
|
+
offset: number;
|
|
85
|
+
hasMore: boolean;
|
|
86
|
+
}>;
|
|
87
|
+
/**
|
|
88
|
+
* Update a run
|
|
89
|
+
*
|
|
90
|
+
* @example
|
|
91
|
+
* ```typescript
|
|
92
|
+
* await runs.update('run_abc123', {
|
|
93
|
+
* outcome: 'resolved',
|
|
94
|
+
* outcomeReason: 'Customer confirmed issue resolved',
|
|
95
|
+
* });
|
|
96
|
+
* ```
|
|
97
|
+
*/
|
|
98
|
+
update(runId: string, updates: Partial<Pick<RunOptions, "outcome" | "outcomeReason" | "endedAt" | "metadata">>): Promise<RunResponse>;
|
|
99
|
+
/**
|
|
100
|
+
* Delete a run
|
|
101
|
+
*
|
|
102
|
+
* @example
|
|
103
|
+
* ```typescript
|
|
104
|
+
* await runs.delete('run_abc123');
|
|
105
|
+
* ```
|
|
106
|
+
*/
|
|
107
|
+
delete(runId: string): Promise<void>;
|
|
108
|
+
/**
|
|
109
|
+
* Create multiple runs in batch
|
|
110
|
+
*
|
|
111
|
+
* @example
|
|
112
|
+
* ```typescript
|
|
113
|
+
* const { created, failed } = await runs.batch([
|
|
114
|
+
* { agentId: 'agent_1', conversationMessages: [...] },
|
|
115
|
+
* { agentId: 'agent_1', conversationMessages: [...] },
|
|
116
|
+
* ]);
|
|
117
|
+
* ```
|
|
118
|
+
*/
|
|
119
|
+
batch(runsData: RunOptions[]): Promise<{
|
|
120
|
+
created: RunResponse[];
|
|
121
|
+
failed: Array<{
|
|
122
|
+
index: number;
|
|
123
|
+
error: string;
|
|
124
|
+
}>;
|
|
125
|
+
}>;
|
|
126
|
+
/**
|
|
127
|
+
* Get run statistics for an agent
|
|
128
|
+
*
|
|
129
|
+
* @example
|
|
130
|
+
* ```typescript
|
|
131
|
+
* const stats = await runs.stats('agent_123', {
|
|
132
|
+
* from: '2024-01-01',
|
|
133
|
+
* to: '2024-01-31',
|
|
134
|
+
* });
|
|
135
|
+
* ```
|
|
136
|
+
*/
|
|
137
|
+
stats(agentId: string, options?: {
|
|
138
|
+
from?: string | Date;
|
|
139
|
+
to?: string | Date;
|
|
140
|
+
}): Promise<RunStats>;
|
|
141
|
+
/**
|
|
142
|
+
* Get traces for a run
|
|
143
|
+
*
|
|
144
|
+
* @example
|
|
145
|
+
* ```typescript
|
|
146
|
+
* const traces = await runs.getTraces('run_abc123');
|
|
147
|
+
* ```
|
|
148
|
+
*/
|
|
149
|
+
getTraces(runId: string): Promise<unknown[]>;
|
|
150
|
+
/**
|
|
151
|
+
* Add a trace to a run
|
|
152
|
+
*
|
|
153
|
+
* @example
|
|
154
|
+
* ```typescript
|
|
155
|
+
* await runs.addTrace('run_abc123', {
|
|
156
|
+
* spans: [...],
|
|
157
|
+
* timestamp: new Date().toISOString(),
|
|
158
|
+
* });
|
|
159
|
+
* ```
|
|
160
|
+
*/
|
|
161
|
+
addTrace(runId: string, traceData: {
|
|
162
|
+
spans?: unknown[];
|
|
163
|
+
timestamp?: string;
|
|
164
|
+
metadata?: Record<string, unknown>;
|
|
165
|
+
}): Promise<{
|
|
166
|
+
traceId: string;
|
|
167
|
+
}>;
|
|
168
|
+
};
|
|
169
|
+
/**
|
|
170
|
+
* Create a run with customer context snapshot
|
|
171
|
+
*
|
|
172
|
+
* @example
|
|
173
|
+
* ```typescript
|
|
174
|
+
* const run = await createRunWithContext({
|
|
175
|
+
* agentId: 'agent_123',
|
|
176
|
+
* conversationMessages: [...],
|
|
177
|
+
* customerContext: {
|
|
178
|
+
* arr: 100000,
|
|
179
|
+
* healthScore: 92,
|
|
180
|
+
* },
|
|
181
|
+
* });
|
|
182
|
+
* ```
|
|
183
|
+
*/
|
|
184
|
+
export declare function createRunWithContext(options: RunOptions & {
|
|
185
|
+
customerContext: CustomerContextSnapshot;
|
|
186
|
+
}): Promise<RunResponse>;
|
|
187
|
+
/**
|
|
188
|
+
* Convert conversation messages to OpenAI format
|
|
189
|
+
*/
|
|
190
|
+
export declare function toOpenAIMessages(messages: ConversationMessage[]): Array<{
|
|
191
|
+
role: string;
|
|
192
|
+
content: string;
|
|
193
|
+
}>;
|
|
194
|
+
/**
|
|
195
|
+
* Convert OpenAI format messages to ThinkHive format
|
|
196
|
+
*/
|
|
197
|
+
export declare function fromOpenAIMessages(messages: Array<{
|
|
198
|
+
role: string;
|
|
199
|
+
content: string;
|
|
200
|
+
}>): ConversationMessage[];
|
package/dist/api/runs.js
ADDED
|
@@ -0,0 +1,262 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ThinkHive SDK v3.0 - Runs API
|
|
4
|
+
*
|
|
5
|
+
* Run-centric API for creating and managing runs (the atomic unit in v3)
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.runs = void 0;
|
|
9
|
+
exports.createRunWithContext = createRunWithContext;
|
|
10
|
+
exports.toOpenAIMessages = toOpenAIMessages;
|
|
11
|
+
exports.fromOpenAIMessages = fromOpenAIMessages;
|
|
12
|
+
const client_1 = require("../core/client");
|
|
13
|
+
/**
|
|
14
|
+
* Runs API client for v3 run-centric operations
|
|
15
|
+
*/
|
|
16
|
+
exports.runs = {
|
|
17
|
+
/**
|
|
18
|
+
* Create a new run
|
|
19
|
+
*
|
|
20
|
+
* @example
|
|
21
|
+
* ```typescript
|
|
22
|
+
* const run = await runs.create({
|
|
23
|
+
* agentId: 'agent_123',
|
|
24
|
+
* conversationMessages: [
|
|
25
|
+
* { role: 'user', content: 'Help me with my order' },
|
|
26
|
+
* { role: 'assistant', content: 'I can help with that...' },
|
|
27
|
+
* ],
|
|
28
|
+
* outcome: 'resolved',
|
|
29
|
+
* customerContext: {
|
|
30
|
+
* arr: 50000,
|
|
31
|
+
* healthScore: 85,
|
|
32
|
+
* segment: 'enterprise',
|
|
33
|
+
* },
|
|
34
|
+
* });
|
|
35
|
+
* ```
|
|
36
|
+
*/
|
|
37
|
+
async create(options) {
|
|
38
|
+
const startedAt = options.startedAt
|
|
39
|
+
? new Date(options.startedAt).toISOString()
|
|
40
|
+
: new Date().toISOString();
|
|
41
|
+
const payload = {
|
|
42
|
+
agentId: options.agentId,
|
|
43
|
+
startedAt,
|
|
44
|
+
endedAt: options.endedAt
|
|
45
|
+
? new Date(options.endedAt).toISOString()
|
|
46
|
+
: undefined,
|
|
47
|
+
outcome: options.outcome,
|
|
48
|
+
outcomeReason: options.outcomeReason,
|
|
49
|
+
conversationMessages: options.conversationMessages,
|
|
50
|
+
modelId: options.modelId,
|
|
51
|
+
promptVersion: options.promptVersion,
|
|
52
|
+
sessionId: options.sessionId,
|
|
53
|
+
customerContext: options.customerContext,
|
|
54
|
+
metadata: options.metadata,
|
|
55
|
+
};
|
|
56
|
+
return (0, client_1.apiRequestWithData)('/runs', {
|
|
57
|
+
method: 'POST',
|
|
58
|
+
body: payload,
|
|
59
|
+
});
|
|
60
|
+
},
|
|
61
|
+
/**
|
|
62
|
+
* Get a run by ID
|
|
63
|
+
*
|
|
64
|
+
* @example
|
|
65
|
+
* ```typescript
|
|
66
|
+
* const run = await runs.get('run_abc123');
|
|
67
|
+
* ```
|
|
68
|
+
*/
|
|
69
|
+
async get(runId) {
|
|
70
|
+
return (0, client_1.apiRequestWithData)(`/runs/${runId}`);
|
|
71
|
+
},
|
|
72
|
+
/**
|
|
73
|
+
* List runs with filters
|
|
74
|
+
*
|
|
75
|
+
* @example
|
|
76
|
+
* ```typescript
|
|
77
|
+
* const { items, hasMore } = await runs.list({
|
|
78
|
+
* agentId: 'agent_123',
|
|
79
|
+
* outcome: 'failed',
|
|
80
|
+
* limit: 20,
|
|
81
|
+
* });
|
|
82
|
+
* ```
|
|
83
|
+
*/
|
|
84
|
+
async list(options = {}) {
|
|
85
|
+
const params = new URLSearchParams();
|
|
86
|
+
if (options.agentId)
|
|
87
|
+
params.set('agentId', options.agentId);
|
|
88
|
+
if (options.ticketId)
|
|
89
|
+
params.set('ticketId', options.ticketId);
|
|
90
|
+
if (options.customerAccountId)
|
|
91
|
+
params.set('customerAccountId', options.customerAccountId);
|
|
92
|
+
if (options.outcome)
|
|
93
|
+
params.set('outcome', options.outcome);
|
|
94
|
+
if (options.startedAfter) {
|
|
95
|
+
params.set('startedAfter', new Date(options.startedAfter).toISOString());
|
|
96
|
+
}
|
|
97
|
+
if (options.startedBefore) {
|
|
98
|
+
params.set('startedBefore', new Date(options.startedBefore).toISOString());
|
|
99
|
+
}
|
|
100
|
+
if (options.limit)
|
|
101
|
+
params.set('limit', String(options.limit));
|
|
102
|
+
if (options.offset)
|
|
103
|
+
params.set('offset', String(options.offset));
|
|
104
|
+
const response = await (0, client_1.apiRequest)(`/runs?${params.toString()}`);
|
|
105
|
+
return response.data;
|
|
106
|
+
},
|
|
107
|
+
/**
|
|
108
|
+
* Update a run
|
|
109
|
+
*
|
|
110
|
+
* @example
|
|
111
|
+
* ```typescript
|
|
112
|
+
* await runs.update('run_abc123', {
|
|
113
|
+
* outcome: 'resolved',
|
|
114
|
+
* outcomeReason: 'Customer confirmed issue resolved',
|
|
115
|
+
* });
|
|
116
|
+
* ```
|
|
117
|
+
*/
|
|
118
|
+
async update(runId, updates) {
|
|
119
|
+
return (0, client_1.apiRequestWithData)(`/runs/${runId}`, {
|
|
120
|
+
method: 'PUT',
|
|
121
|
+
body: updates,
|
|
122
|
+
});
|
|
123
|
+
},
|
|
124
|
+
/**
|
|
125
|
+
* Delete a run
|
|
126
|
+
*
|
|
127
|
+
* @example
|
|
128
|
+
* ```typescript
|
|
129
|
+
* await runs.delete('run_abc123');
|
|
130
|
+
* ```
|
|
131
|
+
*/
|
|
132
|
+
async delete(runId) {
|
|
133
|
+
await (0, client_1.apiRequest)(`/runs/${runId}`, { method: 'DELETE' });
|
|
134
|
+
},
|
|
135
|
+
/**
|
|
136
|
+
* Create multiple runs in batch
|
|
137
|
+
*
|
|
138
|
+
* @example
|
|
139
|
+
* ```typescript
|
|
140
|
+
* const { created, failed } = await runs.batch([
|
|
141
|
+
* { agentId: 'agent_1', conversationMessages: [...] },
|
|
142
|
+
* { agentId: 'agent_1', conversationMessages: [...] },
|
|
143
|
+
* ]);
|
|
144
|
+
* ```
|
|
145
|
+
*/
|
|
146
|
+
async batch(runsData) {
|
|
147
|
+
const payload = runsData.map((r) => ({
|
|
148
|
+
agentId: r.agentId,
|
|
149
|
+
startedAt: r.startedAt
|
|
150
|
+
? new Date(r.startedAt).toISOString()
|
|
151
|
+
: new Date().toISOString(),
|
|
152
|
+
endedAt: r.endedAt ? new Date(r.endedAt).toISOString() : undefined,
|
|
153
|
+
outcome: r.outcome,
|
|
154
|
+
outcomeReason: r.outcomeReason,
|
|
155
|
+
conversationMessages: r.conversationMessages,
|
|
156
|
+
modelId: r.modelId,
|
|
157
|
+
promptVersion: r.promptVersion,
|
|
158
|
+
sessionId: r.sessionId,
|
|
159
|
+
customerContext: r.customerContext,
|
|
160
|
+
metadata: r.metadata,
|
|
161
|
+
}));
|
|
162
|
+
return (0, client_1.apiRequestWithData)('/runs/batch', {
|
|
163
|
+
method: 'POST',
|
|
164
|
+
body: { runs: payload },
|
|
165
|
+
});
|
|
166
|
+
},
|
|
167
|
+
/**
|
|
168
|
+
* Get run statistics for an agent
|
|
169
|
+
*
|
|
170
|
+
* @example
|
|
171
|
+
* ```typescript
|
|
172
|
+
* const stats = await runs.stats('agent_123', {
|
|
173
|
+
* from: '2024-01-01',
|
|
174
|
+
* to: '2024-01-31',
|
|
175
|
+
* });
|
|
176
|
+
* ```
|
|
177
|
+
*/
|
|
178
|
+
async stats(agentId, options = {}) {
|
|
179
|
+
const params = new URLSearchParams();
|
|
180
|
+
if (options.from)
|
|
181
|
+
params.set('from', new Date(options.from).toISOString());
|
|
182
|
+
if (options.to)
|
|
183
|
+
params.set('to', new Date(options.to).toISOString());
|
|
184
|
+
return (0, client_1.apiRequestWithData)(`/runs/stats/${agentId}?${params.toString()}`);
|
|
185
|
+
},
|
|
186
|
+
/**
|
|
187
|
+
* Get traces for a run
|
|
188
|
+
*
|
|
189
|
+
* @example
|
|
190
|
+
* ```typescript
|
|
191
|
+
* const traces = await runs.getTraces('run_abc123');
|
|
192
|
+
* ```
|
|
193
|
+
*/
|
|
194
|
+
async getTraces(runId) {
|
|
195
|
+
return (0, client_1.apiRequestWithData)(`/runs/${runId}/traces`);
|
|
196
|
+
},
|
|
197
|
+
/**
|
|
198
|
+
* Add a trace to a run
|
|
199
|
+
*
|
|
200
|
+
* @example
|
|
201
|
+
* ```typescript
|
|
202
|
+
* await runs.addTrace('run_abc123', {
|
|
203
|
+
* spans: [...],
|
|
204
|
+
* timestamp: new Date().toISOString(),
|
|
205
|
+
* });
|
|
206
|
+
* ```
|
|
207
|
+
*/
|
|
208
|
+
async addTrace(runId, traceData) {
|
|
209
|
+
return (0, client_1.apiRequestWithData)(`/runs/${runId}/traces`, {
|
|
210
|
+
method: 'POST',
|
|
211
|
+
body: traceData,
|
|
212
|
+
});
|
|
213
|
+
},
|
|
214
|
+
};
|
|
215
|
+
// ============================================================================
|
|
216
|
+
// HELPER FUNCTIONS
|
|
217
|
+
// ============================================================================
|
|
218
|
+
/**
|
|
219
|
+
* Create a run with customer context snapshot
|
|
220
|
+
*
|
|
221
|
+
* @example
|
|
222
|
+
* ```typescript
|
|
223
|
+
* const run = await createRunWithContext({
|
|
224
|
+
* agentId: 'agent_123',
|
|
225
|
+
* conversationMessages: [...],
|
|
226
|
+
* customerContext: {
|
|
227
|
+
* arr: 100000,
|
|
228
|
+
* healthScore: 92,
|
|
229
|
+
* },
|
|
230
|
+
* });
|
|
231
|
+
* ```
|
|
232
|
+
*/
|
|
233
|
+
async function createRunWithContext(options) {
|
|
234
|
+
// Ensure capturedAt is set
|
|
235
|
+
const customerContext = {
|
|
236
|
+
...options.customerContext,
|
|
237
|
+
capturedAt: options.customerContext.capturedAt || new Date().toISOString(),
|
|
238
|
+
};
|
|
239
|
+
return exports.runs.create({
|
|
240
|
+
...options,
|
|
241
|
+
customerContext,
|
|
242
|
+
});
|
|
243
|
+
}
|
|
244
|
+
/**
|
|
245
|
+
* Convert conversation messages to OpenAI format
|
|
246
|
+
*/
|
|
247
|
+
function toOpenAIMessages(messages) {
|
|
248
|
+
return messages.map((m) => ({
|
|
249
|
+
role: m.role,
|
|
250
|
+
content: m.content,
|
|
251
|
+
}));
|
|
252
|
+
}
|
|
253
|
+
/**
|
|
254
|
+
* Convert OpenAI format messages to ThinkHive format
|
|
255
|
+
*/
|
|
256
|
+
function fromOpenAIMessages(messages) {
|
|
257
|
+
return messages.map((m) => ({
|
|
258
|
+
role: m.role,
|
|
259
|
+
content: m.content,
|
|
260
|
+
}));
|
|
261
|
+
}
|
|
262
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runs.js","sourceRoot":"","sources":["../../src/api/runs.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Runs API\n *\n * Run-centric API for creating and managing runs (the atomic unit in v3)\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\nimport type {\n  RunOptions,\n  RunResponse,\n  ApiResponse,\n  PaginatedResponse,\n  CustomerContextSnapshot,\n  ConversationMessage,\n  RunOutcome,\n} from '../core/types';\n\n// ============================================================================\n// RUNS API CLIENT\n// ============================================================================\n\n/**\n * List runs query options\n */\nexport interface ListRunsOptions {\n  agentId?: string;\n  ticketId?: string;\n  customerAccountId?: string;\n  outcome?: RunOutcome;\n  startedAfter?: string | Date;\n  startedBefore?: string | Date;\n  limit?: number;\n  offset?: number;\n}\n\n/**\n * Run stats response\n */\nexport interface RunStats {\n  agentId: string;\n  period: { from: string; to: string };\n  totalRuns: number;\n  outcomeBreakdown: Record<RunOutcome, number>;\n  avgDurationMs: number;\n  linkedTickets: number;\n  unlinkedRuns: number;\n}\n\n/**\n * Runs API client for v3 run-centric operations\n */\nexport const runs = {\n  /**\n   * Create a new run\n   *\n   * @example\n   * ```typescript\n   * const run = await runs.create({\n   *   agentId: 'agent_123',\n   *   conversationMessages: [\n   *     { role: 'user', content: 'Help me with my order' },\n   *     { role: 'assistant', content: 'I can help with that...' },\n   *   ],\n   *   outcome: 'resolved',\n   *   customerContext: {\n   *     arr: 50000,\n   *     healthScore: 85,\n   *     segment: 'enterprise',\n   *   },\n   * });\n   * ```\n   */\n  async create(options: RunOptions): Promise<RunResponse> {\n    const startedAt = options.startedAt\n      ? new Date(options.startedAt).toISOString()\n      : new Date().toISOString();\n\n    const payload = {\n      agentId: options.agentId,\n      startedAt,\n      endedAt: options.endedAt\n        ? new Date(options.endedAt).toISOString()\n        : undefined,\n      outcome: options.outcome,\n      outcomeReason: options.outcomeReason,\n      conversationMessages: options.conversationMessages,\n      modelId: options.modelId,\n      promptVersion: options.promptVersion,\n      sessionId: options.sessionId,\n      customerContext: options.customerContext,\n      metadata: options.metadata,\n    };\n\n    return apiRequestWithData<RunResponse>('/runs', {\n      method: 'POST',\n      body: payload,\n    });\n  },\n\n  /**\n   * Get a run by ID\n   *\n   * @example\n   * ```typescript\n   * const run = await runs.get('run_abc123');\n   * ```\n   */\n  async get(runId: string): Promise<RunResponse> {\n    return apiRequestWithData<RunResponse>(`/runs/${runId}`);\n  },\n\n  /**\n   * List runs with filters\n   *\n   * @example\n   * ```typescript\n   * const { items, hasMore } = await runs.list({\n   *   agentId: 'agent_123',\n   *   outcome: 'failed',\n   *   limit: 20,\n   * });\n   * ```\n   */\n  async list(\n    options: ListRunsOptions = {}\n  ): Promise<{ items: RunResponse[]; limit: number; offset: number; hasMore: boolean }> {\n    const params = new URLSearchParams();\n    if (options.agentId) params.set('agentId', options.agentId);\n    if (options.ticketId) params.set('ticketId', options.ticketId);\n    if (options.customerAccountId) params.set('customerAccountId', options.customerAccountId);\n    if (options.outcome) params.set('outcome', options.outcome);\n    if (options.startedAfter) {\n      params.set('startedAfter', new Date(options.startedAfter).toISOString());\n    }\n    if (options.startedBefore) {\n      params.set('startedBefore', new Date(options.startedBefore).toISOString());\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<PaginatedResponse<RunResponse>>(\n      `/runs?${params.toString()}`\n    );\n    return response.data;\n  },\n\n  /**\n   * Update a run\n   *\n   * @example\n   * ```typescript\n   * await runs.update('run_abc123', {\n   *   outcome: 'resolved',\n   *   outcomeReason: 'Customer confirmed issue resolved',\n   * });\n   * ```\n   */\n  async update(\n    runId: string,\n    updates: Partial<Pick<RunOptions, 'outcome' | 'outcomeReason' | 'endedAt' | 'metadata'>>\n  ): Promise<RunResponse> {\n    return apiRequestWithData<RunResponse>(`/runs/${runId}`, {\n      method: 'PUT',\n      body: updates,\n    });\n  },\n\n  /**\n   * Delete a run\n   *\n   * @example\n   * ```typescript\n   * await runs.delete('run_abc123');\n   * ```\n   */\n  async delete(runId: string): Promise<void> {\n    await apiRequest(`/runs/${runId}`, { method: 'DELETE' });\n  },\n\n  /**\n   * Create multiple runs in batch\n   *\n   * @example\n   * ```typescript\n   * const { created, failed } = await runs.batch([\n   *   { agentId: 'agent_1', conversationMessages: [...] },\n   *   { agentId: 'agent_1', conversationMessages: [...] },\n   * ]);\n   * ```\n   */\n  async batch(\n    runsData: RunOptions[]\n  ): Promise<{ created: RunResponse[]; failed: Array<{ index: number; error: string }> }> {\n    const payload = runsData.map((r) => ({\n      agentId: r.agentId,\n      startedAt: r.startedAt\n        ? new Date(r.startedAt).toISOString()\n        : new Date().toISOString(),\n      endedAt: r.endedAt ? new Date(r.endedAt).toISOString() : undefined,\n      outcome: r.outcome,\n      outcomeReason: r.outcomeReason,\n      conversationMessages: r.conversationMessages,\n      modelId: r.modelId,\n      promptVersion: r.promptVersion,\n      sessionId: r.sessionId,\n      customerContext: r.customerContext,\n      metadata: r.metadata,\n    }));\n\n    return apiRequestWithData('/runs/batch', {\n      method: 'POST',\n      body: { runs: payload },\n    });\n  },\n\n  /**\n   * Get run statistics for an agent\n   *\n   * @example\n   * ```typescript\n   * const stats = await runs.stats('agent_123', {\n   *   from: '2024-01-01',\n   *   to: '2024-01-31',\n   * });\n   * ```\n   */\n  async stats(\n    agentId: string,\n    options: { from?: string | Date; to?: string | Date } = {}\n  ): Promise<RunStats> {\n    const params = new URLSearchParams();\n    if (options.from) params.set('from', new Date(options.from).toISOString());\n    if (options.to) params.set('to', new Date(options.to).toISOString());\n\n    return apiRequestWithData<RunStats>(\n      `/runs/stats/${agentId}?${params.toString()}`\n    );\n  },\n\n  /**\n   * Get traces for a run\n   *\n   * @example\n   * ```typescript\n   * const traces = await runs.getTraces('run_abc123');\n   * ```\n   */\n  async getTraces(runId: string): Promise<unknown[]> {\n    return apiRequestWithData<unknown[]>(`/runs/${runId}/traces`);\n  },\n\n  /**\n   * Add a trace to a run\n   *\n   * @example\n   * ```typescript\n   * await runs.addTrace('run_abc123', {\n   *   spans: [...],\n   *   timestamp: new Date().toISOString(),\n   * });\n   * ```\n   */\n  async addTrace(\n    runId: string,\n    traceData: { spans?: unknown[]; timestamp?: string; metadata?: Record<string, unknown> }\n  ): Promise<{ traceId: string }> {\n    return apiRequestWithData(`/runs/${runId}/traces`, {\n      method: 'POST',\n      body: traceData,\n    });\n  },\n};\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Create a run with customer context snapshot\n *\n * @example\n * ```typescript\n * const run = await createRunWithContext({\n *   agentId: 'agent_123',\n *   conversationMessages: [...],\n *   customerContext: {\n *     arr: 100000,\n *     healthScore: 92,\n *   },\n * });\n * ```\n */\nexport async function createRunWithContext(\n  options: RunOptions & { customerContext: CustomerContextSnapshot }\n): Promise<RunResponse> {\n  // Ensure capturedAt is set\n  const customerContext: CustomerContextSnapshot = {\n    ...options.customerContext,\n    capturedAt: options.customerContext.capturedAt || new Date().toISOString(),\n  };\n\n  return runs.create({\n    ...options,\n    customerContext,\n  });\n}\n\n/**\n * Convert conversation messages to OpenAI format\n */\nexport function toOpenAIMessages(\n  messages: ConversationMessage[]\n): Array<{ role: string; content: string }> {\n  return messages.map((m) => ({\n    role: m.role,\n    content: m.content,\n  }));\n}\n\n/**\n * Convert OpenAI format messages to ThinkHive format\n */\nexport function fromOpenAIMessages(\n  messages: Array<{ role: string; content: string }>\n): ConversationMessage[] {\n  return messages.map((m) => ({\n    role: m.role as ConversationMessage['role'],\n    content: m.content,\n  }));\n}\n"]}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ThinkHive SDK v3.0 - HTTP Client
|
|
3
|
+
*
|
|
4
|
+
* Centralized HTTP client with authentication and error handling
|
|
5
|
+
*/
|
|
6
|
+
export interface RequestOptions {
|
|
7
|
+
method?: 'GET' | 'POST' | 'PUT' | 'DELETE';
|
|
8
|
+
body?: unknown;
|
|
9
|
+
headers?: Record<string, string>;
|
|
10
|
+
/** Override API version for this request */
|
|
11
|
+
apiVersion?: 'v1' | 'v3';
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Make an authenticated API request
|
|
15
|
+
*/
|
|
16
|
+
export declare function apiRequest<T>(path: string, options?: RequestOptions): Promise<T>;
|
|
17
|
+
/**
|
|
18
|
+
* Make an API request and extract data from response wrapper
|
|
19
|
+
*/
|
|
20
|
+
export declare function apiRequestWithData<T>(path: string, options?: RequestOptions): Promise<T>;
|
|
21
|
+
export declare class ThinkHiveApiError extends Error {
|
|
22
|
+
readonly statusCode: number;
|
|
23
|
+
readonly code?: string | undefined;
|
|
24
|
+
constructor(message: string, statusCode: number, code?: string | undefined);
|
|
25
|
+
}
|
|
26
|
+
export declare class ThinkHiveValidationError extends Error {
|
|
27
|
+
readonly field?: string | undefined;
|
|
28
|
+
constructor(message: string, field?: string | undefined);
|
|
29
|
+
}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ThinkHive SDK v3.0 - HTTP Client
|
|
4
|
+
*
|
|
5
|
+
* Centralized HTTP client with authentication and error handling
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.ThinkHiveValidationError = exports.ThinkHiveApiError = void 0;
|
|
9
|
+
exports.apiRequest = apiRequest;
|
|
10
|
+
exports.apiRequestWithData = apiRequestWithData;
|
|
11
|
+
const config_1 = require("./config");
|
|
12
|
+
/**
|
|
13
|
+
* Make an authenticated API request
|
|
14
|
+
*/
|
|
15
|
+
async function apiRequest(path, options = {}) {
|
|
16
|
+
const config = (0, config_1.getConfig)();
|
|
17
|
+
const { method = 'GET', body, headers = {}, apiVersion } = options;
|
|
18
|
+
const version = apiVersion || config.apiVersion;
|
|
19
|
+
const url = `${config.endpoint}/api/${version}${path}`;
|
|
20
|
+
const requestHeaders = {
|
|
21
|
+
'Content-Type': 'application/json',
|
|
22
|
+
'X-SDK-Version': '3.0.0',
|
|
23
|
+
...headers,
|
|
24
|
+
};
|
|
25
|
+
if (config.apiKey) {
|
|
26
|
+
requestHeaders['Authorization'] = `Bearer ${config.apiKey}`;
|
|
27
|
+
}
|
|
28
|
+
else if (config.agentId) {
|
|
29
|
+
requestHeaders['X-Agent-ID'] = config.agentId;
|
|
30
|
+
}
|
|
31
|
+
(0, config_1.debugLog)(`${method} ${url}`);
|
|
32
|
+
const response = await fetch(url, {
|
|
33
|
+
method,
|
|
34
|
+
headers: requestHeaders,
|
|
35
|
+
body: body ? JSON.stringify(body) : undefined,
|
|
36
|
+
});
|
|
37
|
+
// Handle deprecation warnings
|
|
38
|
+
if (response.headers.has('Deprecation')) {
|
|
39
|
+
const sunset = response.headers.get('Sunset');
|
|
40
|
+
const link = response.headers.get('Link');
|
|
41
|
+
console.warn(`[ThinkHive] Deprecation warning: This endpoint is deprecated.` +
|
|
42
|
+
(sunset ? ` Sunset: ${sunset}` : '') +
|
|
43
|
+
(link ? ` Successor: ${link}` : ''));
|
|
44
|
+
}
|
|
45
|
+
if (!response.ok) {
|
|
46
|
+
const errorText = await response.text();
|
|
47
|
+
let errorData = {};
|
|
48
|
+
try {
|
|
49
|
+
errorData = JSON.parse(errorText);
|
|
50
|
+
}
|
|
51
|
+
catch {
|
|
52
|
+
errorData = { message: errorText };
|
|
53
|
+
}
|
|
54
|
+
const error = new ThinkHiveApiError(errorData.message || `HTTP ${response.status}`, response.status, errorData.code);
|
|
55
|
+
throw error;
|
|
56
|
+
}
|
|
57
|
+
return response.json();
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Make an API request and extract data from response wrapper
|
|
61
|
+
*/
|
|
62
|
+
async function apiRequestWithData(path, options = {}) {
|
|
63
|
+
const response = await apiRequest(path, options);
|
|
64
|
+
if (!response.success) {
|
|
65
|
+
throw new ThinkHiveApiError(response.error?.message || 'Unknown error', 500, response.error?.code);
|
|
66
|
+
}
|
|
67
|
+
return response.data;
|
|
68
|
+
}
|
|
69
|
+
// ============================================================================
|
|
70
|
+
// ERRORS
|
|
71
|
+
// ============================================================================
|
|
72
|
+
class ThinkHiveApiError extends Error {
|
|
73
|
+
constructor(message, statusCode, code) {
|
|
74
|
+
super(message);
|
|
75
|
+
this.statusCode = statusCode;
|
|
76
|
+
this.code = code;
|
|
77
|
+
this.name = 'ThinkHiveApiError';
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
exports.ThinkHiveApiError = ThinkHiveApiError;
|
|
81
|
+
class ThinkHiveValidationError extends Error {
|
|
82
|
+
constructor(message, field) {
|
|
83
|
+
super(message);
|
|
84
|
+
this.field = field;
|
|
85
|
+
this.name = 'ThinkHiveValidationError';
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
exports.ThinkHiveValidationError = ThinkHiveValidationError;
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/core/client.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.0 - HTTP Client\n *\n * Centralized HTTP client with authentication and error handling\n */\n\nimport { getConfig, debugLog } from './config';\nimport type { ApiResponse } from './types';\n\n// ============================================================================\n// HTTP CLIENT\n// ============================================================================\n\nexport interface RequestOptions {\n  method?: 'GET' | 'POST' | 'PUT' | 'DELETE';\n  body?: unknown;\n  headers?: Record<string, string>;\n  /** Override API version for this request */\n  apiVersion?: 'v1' | 'v3';\n}\n\n/**\n * Make an authenticated API request\n */\nexport async function apiRequest<T>(\n  path: string,\n  options: RequestOptions = {}\n): Promise<T> {\n  const config = getConfig();\n  const { method = 'GET', body, headers = {}, apiVersion } = options;\n\n  const version = apiVersion || config.apiVersion;\n  const url = `${config.endpoint}/api/${version}${path}`;\n\n  const requestHeaders: Record<string, string> = {\n    'Content-Type': 'application/json',\n    'X-SDK-Version': '3.0.0',\n    ...headers,\n  };\n\n  if (config.apiKey) {\n    requestHeaders['Authorization'] = `Bearer ${config.apiKey}`;\n  } else if (config.agentId) {\n    requestHeaders['X-Agent-ID'] = config.agentId;\n  }\n\n  debugLog(`${method} ${url}`);\n\n  const response = await fetch(url, {\n    method,\n    headers: requestHeaders,\n    body: body ? JSON.stringify(body) : undefined,\n  });\n\n  // Handle deprecation warnings\n  if (response.headers.has('Deprecation')) {\n    const sunset = response.headers.get('Sunset');\n    const link = response.headers.get('Link');\n    console.warn(\n      `[ThinkHive] Deprecation warning: This endpoint is deprecated.` +\n        (sunset ? ` Sunset: ${sunset}` : '') +\n        (link ? ` Successor: ${link}` : '')\n    );\n  }\n\n  if (!response.ok) {\n    const errorText = await response.text();\n    let errorData: { message?: string; code?: string } = {};\n    try {\n      errorData = JSON.parse(errorText);\n    } catch {\n      errorData = { message: errorText };\n    }\n\n    const error = new ThinkHiveApiError(\n      errorData.message || `HTTP ${response.status}`,\n      response.status,\n      errorData.code\n    );\n    throw error;\n  }\n\n  return response.json() as Promise<T>;\n}\n\n/**\n * Make an API request and extract data from response wrapper\n */\nexport async function apiRequestWithData<T>(\n  path: string,\n  options: RequestOptions = {}\n): Promise<T> {\n  const response = await apiRequest<ApiResponse<T>>(path, options);\n  if (!response.success) {\n    throw new ThinkHiveApiError(\n      response.error?.message || 'Unknown error',\n      500,\n      response.error?.code\n    );\n  }\n  return response.data as T;\n}\n\n// ============================================================================\n// ERRORS\n// ============================================================================\n\nexport class ThinkHiveApiError extends Error {\n  constructor(\n    message: string,\n    public readonly statusCode: number,\n    public readonly code?: string\n  ) {\n    super(message);\n    this.name = 'ThinkHiveApiError';\n  }\n}\n\nexport class ThinkHiveValidationError extends Error {\n  constructor(\n    message: string,\n    public readonly field?: string\n  ) {\n    super(message);\n    this.name = 'ThinkHiveValidationError';\n  }\n}\n"]}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ThinkHive SDK v3.0 - Configuration
|
|
3
|
+
*/
|
|
4
|
+
import type { InitOptions, Framework } from './types';
|
|
5
|
+
export declare const SDK_VERSION = "3.0.0";
|
|
6
|
+
export declare const DEFAULT_ENDPOINT = "https://thinkhivemind-h25z7pvd3q-uc.a.run.app";
|
|
7
|
+
export declare const DEFAULT_SERVICE_NAME = "my-ai-agent";
|
|
8
|
+
export interface ResolvedConfig {
|
|
9
|
+
apiKey: string;
|
|
10
|
+
agentId: string;
|
|
11
|
+
endpoint: string;
|
|
12
|
+
serviceName: string;
|
|
13
|
+
autoInstrument: boolean;
|
|
14
|
+
frameworks: Framework[];
|
|
15
|
+
debug: boolean;
|
|
16
|
+
apiVersion: 'v1' | 'v3';
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Initialize configuration from options
|
|
20
|
+
*/
|
|
21
|
+
export declare function initConfig(options?: InitOptions): ResolvedConfig;
|
|
22
|
+
/**
|
|
23
|
+
* Get current configuration
|
|
24
|
+
* @throws if not initialized
|
|
25
|
+
*/
|
|
26
|
+
export declare function getConfig(): ResolvedConfig;
|
|
27
|
+
/**
|
|
28
|
+
* Check if SDK is initialized
|
|
29
|
+
*/
|
|
30
|
+
export declare function isInitialized(): boolean;
|
|
31
|
+
/**
|
|
32
|
+
* Reset configuration (for testing)
|
|
33
|
+
*/
|
|
34
|
+
export declare function resetConfig(): void;
|
|
35
|
+
/**
|
|
36
|
+
* Debug log helper
|
|
37
|
+
*/
|
|
38
|
+
export declare function debugLog(...args: unknown[]): void;
|