@thinkhive/sdk 2.0.0 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/MIGRATION.md +274 -0
- package/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,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ThinkHive SDK v3.0 - Configuration
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.DEFAULT_SERVICE_NAME = exports.DEFAULT_ENDPOINT = exports.SDK_VERSION = void 0;
|
|
7
|
+
exports.initConfig = initConfig;
|
|
8
|
+
exports.getConfig = getConfig;
|
|
9
|
+
exports.isInitialized = isInitialized;
|
|
10
|
+
exports.resetConfig = resetConfig;
|
|
11
|
+
exports.debugLog = debugLog;
|
|
12
|
+
// ============================================================================
|
|
13
|
+
// CONSTANTS
|
|
14
|
+
// ============================================================================
|
|
15
|
+
exports.SDK_VERSION = '3.0.0';
|
|
16
|
+
exports.DEFAULT_ENDPOINT = 'https://thinkhivemind-h25z7pvd3q-uc.a.run.app';
|
|
17
|
+
exports.DEFAULT_SERVICE_NAME = 'my-ai-agent';
|
|
18
|
+
let config = null;
|
|
19
|
+
let initialized = false;
|
|
20
|
+
// ============================================================================
|
|
21
|
+
// CONFIG FUNCTIONS
|
|
22
|
+
// ============================================================================
|
|
23
|
+
/**
|
|
24
|
+
* Initialize configuration from options
|
|
25
|
+
*/
|
|
26
|
+
function initConfig(options = {}) {
|
|
27
|
+
const apiKey = options.apiKey || process.env.THINKHIVE_API_KEY || '';
|
|
28
|
+
const agentId = options.agentId || process.env.THINKHIVE_AGENT_ID || '';
|
|
29
|
+
if (!apiKey && !agentId) {
|
|
30
|
+
throw new Error('Either apiKey or agentId must be provided (or set THINKHIVE_API_KEY env var)');
|
|
31
|
+
}
|
|
32
|
+
config = {
|
|
33
|
+
apiKey,
|
|
34
|
+
agentId,
|
|
35
|
+
endpoint: options.endpoint || process.env.THINKHIVE_ENDPOINT || exports.DEFAULT_ENDPOINT,
|
|
36
|
+
serviceName: options.serviceName || process.env.THINKHIVE_SERVICE_NAME || exports.DEFAULT_SERVICE_NAME,
|
|
37
|
+
autoInstrument: options.autoInstrument ?? false,
|
|
38
|
+
frameworks: options.frameworks || ['langchain', 'openai'],
|
|
39
|
+
debug: options.debug ?? false,
|
|
40
|
+
apiVersion: options.apiVersion ?? 'v3',
|
|
41
|
+
};
|
|
42
|
+
initialized = true;
|
|
43
|
+
return config;
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Get current configuration
|
|
47
|
+
* @throws if not initialized
|
|
48
|
+
*/
|
|
49
|
+
function getConfig() {
|
|
50
|
+
if (!config || !initialized) {
|
|
51
|
+
throw new Error('ThinkHive SDK not initialized. Call init() first.');
|
|
52
|
+
}
|
|
53
|
+
return config;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Check if SDK is initialized
|
|
57
|
+
*/
|
|
58
|
+
function isInitialized() {
|
|
59
|
+
return initialized;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Reset configuration (for testing)
|
|
63
|
+
*/
|
|
64
|
+
function resetConfig() {
|
|
65
|
+
config = null;
|
|
66
|
+
initialized = false;
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Debug log helper
|
|
70
|
+
*/
|
|
71
|
+
function debugLog(...args) {
|
|
72
|
+
if (config?.debug) {
|
|
73
|
+
console.log('[ThinkHive]', ...args);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvcmUvY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7R0FFRzs7O0FBcUNILGdDQXVCQztBQU1ELDhCQUtDO0FBS0Qsc0NBRUM7QUFLRCxrQ0FHQztBQUtELDRCQUlDO0FBM0ZELCtFQUErRTtBQUMvRSxZQUFZO0FBQ1osK0VBQStFO0FBRWxFLFFBQUEsV0FBVyxHQUFHLE9BQU8sQ0FBQztBQUN0QixRQUFBLGdCQUFnQixHQUFHLCtDQUErQyxDQUFDO0FBQ25FLFFBQUEsb0JBQW9CLEdBQUcsYUFBYSxDQUFDO0FBaUJsRCxJQUFJLE1BQU0sR0FBMEIsSUFBSSxDQUFDO0FBQ3pDLElBQUksV0FBVyxHQUFHLEtBQUssQ0FBQztBQUV4QiwrRUFBK0U7QUFDL0UsbUJBQW1CO0FBQ25CLCtFQUErRTtBQUUvRTs7R0FFRztBQUNILFNBQWdCLFVBQVUsQ0FBQyxVQUF1QixFQUFFO0lBQ2xELE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxNQUFNLElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsSUFBSSxFQUFFLENBQUM7SUFDckUsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLE9BQU8sSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQixJQUFJLEVBQUUsQ0FBQztJQUV4RSxJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDeEIsTUFBTSxJQUFJLEtBQUssQ0FDYiw4RUFBOEUsQ0FDL0UsQ0FBQztJQUNKLENBQUM7SUFFRCxNQUFNLEdBQUc7UUFDUCxNQUFNO1FBQ04sT0FBTztRQUNQLFFBQVEsRUFBRSxPQUFPLENBQUMsUUFBUSxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCLElBQUksd0JBQWdCO1FBQ2hGLFdBQVcsRUFBRSxPQUFPLENBQUMsV0FBVyxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsc0JBQXNCLElBQUksNEJBQW9CO1FBQzlGLGNBQWMsRUFBRSxPQUFPLENBQUMsY0FBYyxJQUFJLEtBQUs7UUFDL0MsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVLElBQUksQ0FBQyxXQUFXLEVBQUUsUUFBUSxDQUFDO1FBQ3pELEtBQUssRUFBRSxPQUFPLENBQUMsS0FBSyxJQUFJLEtBQUs7UUFDN0IsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVLElBQUksSUFBSTtLQUN2QyxDQUFDO0lBRUYsV0FBVyxHQUFHLElBQUksQ0FBQztJQUNuQixPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBRUQ7OztHQUdHO0FBQ0gsU0FBZ0IsU0FBUztJQUN2QixJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDNUIsTUFBTSxJQUFJLEtBQUssQ0FBQyxtREFBbUQsQ0FBQyxDQUFDO0lBQ3ZFLENBQUM7SUFDRCxPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixhQUFhO0lBQzNCLE9BQU8sV0FBVyxDQUFDO0FBQ3JCLENBQUM7QUFFRDs7R0FFRztBQUNILFNBQWdCLFdBQVc7SUFDekIsTUFBTSxHQUFHLElBQUksQ0FBQztJQUNkLFdBQVcsR0FBRyxLQUFLLENBQUM7QUFDdEIsQ0FBQztBQUVEOztHQUVHO0FBQ0gsU0FBZ0IsUUFBUSxDQUFDLEdBQUcsSUFBZTtJQUN6QyxJQUFJLE1BQU0sRUFBRSxLQUFLLEVBQUUsQ0FBQztRQUNsQixPQUFPLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxHQUFHLElBQUksQ0FBQyxDQUFDO0lBQ3RDLENBQUM7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBUaGlua0hpdmUgU0RLIHYzLjAgLSBDb25maWd1cmF0aW9uXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBJbml0T3B0aW9ucywgRnJhbWV3b3JrIH0gZnJvbSAnLi90eXBlcyc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIENPTlNUQU5UU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5leHBvcnQgY29uc3QgU0RLX1ZFUlNJT04gPSAnMy4wLjAnO1xuZXhwb3J0IGNvbnN0IERFRkFVTFRfRU5EUE9JTlQgPSAnaHR0cHM6Ly90aGlua2hpdmVtaW5kLWgyNXo3cHZkM3EtdWMuYS5ydW4uYXBwJztcbmV4cG9ydCBjb25zdCBERUZBVUxUX1NFUlZJQ0VfTkFNRSA9ICdteS1haS1hZ2VudCc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIEdMT0JBTCBDT05GSUcgU1RBVEVcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGludGVyZmFjZSBSZXNvbHZlZENvbmZpZyB7XG4gIGFwaUtleTogc3RyaW5nO1xuICBhZ2VudElkOiBzdHJpbmc7XG4gIGVuZHBvaW50OiBzdHJpbmc7XG4gIHNlcnZpY2VOYW1lOiBzdHJpbmc7XG4gIGF1dG9JbnN0cnVtZW50OiBib29sZWFuO1xuICBmcmFtZXdvcmtzOiBGcmFtZXdvcmtbXTtcbiAgZGVidWc6IGJvb2xlYW47XG4gIGFwaVZlcnNpb246ICd2MScgfCAndjMnO1xufVxuXG5sZXQgY29uZmlnOiBSZXNvbHZlZENvbmZpZyB8IG51bGwgPSBudWxsO1xubGV0IGluaXRpYWxpemVkID0gZmFsc2U7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIENPTkZJRyBGVU5DVElPTlNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBJbml0aWFsaXplIGNvbmZpZ3VyYXRpb24gZnJvbSBvcHRpb25zXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpbml0Q29uZmlnKG9wdGlvbnM6IEluaXRPcHRpb25zID0ge30pOiBSZXNvbHZlZENvbmZpZyB7XG4gIGNvbnN0IGFwaUtleSA9IG9wdGlvbnMuYXBpS2V5IHx8IHByb2Nlc3MuZW52LlRISU5LSElWRV9BUElfS0VZIHx8ICcnO1xuICBjb25zdCBhZ2VudElkID0gb3B0aW9ucy5hZ2VudElkIHx8IHByb2Nlc3MuZW52LlRISU5LSElWRV9BR0VOVF9JRCB8fCAnJztcblxuICBpZiAoIWFwaUtleSAmJiAhYWdlbnRJZCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICdFaXRoZXIgYXBpS2V5IG9yIGFnZW50SWQgbXVzdCBiZSBwcm92aWRlZCAob3Igc2V0IFRISU5LSElWRV9BUElfS0VZIGVudiB2YXIpJ1xuICAgICk7XG4gIH1cblxuICBjb25maWcgPSB7XG4gICAgYXBpS2V5LFxuICAgIGFnZW50SWQsXG4gICAgZW5kcG9pbnQ6IG9wdGlvbnMuZW5kcG9pbnQgfHwgcHJvY2Vzcy5lbnYuVEhJTktISVZFX0VORFBPSU5UIHx8IERFRkFVTFRfRU5EUE9JTlQsXG4gICAgc2VydmljZU5hbWU6IG9wdGlvbnMuc2VydmljZU5hbWUgfHwgcHJvY2Vzcy5lbnYuVEhJTktISVZFX1NFUlZJQ0VfTkFNRSB8fCBERUZBVUxUX1NFUlZJQ0VfTkFNRSxcbiAgICBhdXRvSW5zdHJ1bWVudDogb3B0aW9ucy5hdXRvSW5zdHJ1bWVudCA/PyBmYWxzZSxcbiAgICBmcmFtZXdvcmtzOiBvcHRpb25zLmZyYW1ld29ya3MgfHwgWydsYW5nY2hhaW4nLCAnb3BlbmFpJ10sXG4gICAgZGVidWc6IG9wdGlvbnMuZGVidWcgPz8gZmFsc2UsXG4gICAgYXBpVmVyc2lvbjogb3B0aW9ucy5hcGlWZXJzaW9uID8/ICd2MycsXG4gIH07XG5cbiAgaW5pdGlhbGl6ZWQgPSB0cnVlO1xuICByZXR1cm4gY29uZmlnO1xufVxuXG4vKipcbiAqIEdldCBjdXJyZW50IGNvbmZpZ3VyYXRpb25cbiAqIEB0aHJvd3MgaWYgbm90IGluaXRpYWxpemVkXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRDb25maWcoKTogUmVzb2x2ZWRDb25maWcge1xuICBpZiAoIWNvbmZpZyB8fCAhaW5pdGlhbGl6ZWQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1RoaW5rSGl2ZSBTREsgbm90IGluaXRpYWxpemVkLiBDYWxsIGluaXQoKSBmaXJzdC4nKTtcbiAgfVxuICByZXR1cm4gY29uZmlnO1xufVxuXG4vKipcbiAqIENoZWNrIGlmIFNESyBpcyBpbml0aWFsaXplZFxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNJbml0aWFsaXplZCgpOiBib29sZWFuIHtcbiAgcmV0dXJuIGluaXRpYWxpemVkO1xufVxuXG4vKipcbiAqIFJlc2V0IGNvbmZpZ3VyYXRpb24gKGZvciB0ZXN0aW5nKVxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVzZXRDb25maWcoKTogdm9pZCB7XG4gIGNvbmZpZyA9IG51bGw7XG4gIGluaXRpYWxpemVkID0gZmFsc2U7XG59XG5cbi8qKlxuICogRGVidWcgbG9nIGhlbHBlclxuICovXG5leHBvcnQgZnVuY3Rpb24gZGVidWdMb2coLi4uYXJnczogdW5rbm93bltdKTogdm9pZCB7XG4gIGlmIChjb25maWc/LmRlYnVnKSB7XG4gICAgY29uc29sZS5sb2coJ1tUaGlua0hpdmVdJywgLi4uYXJncyk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,354 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ThinkHive SDK v3.0 - Core Types
|
|
3
|
+
*
|
|
4
|
+
* Run-centric types with facts vs inferences and customer context snapshots
|
|
5
|
+
*/
|
|
6
|
+
export interface InitOptions {
|
|
7
|
+
/** ThinkHive API key (starts with th_) */
|
|
8
|
+
apiKey?: string;
|
|
9
|
+
/** Agent ID */
|
|
10
|
+
agentId?: string;
|
|
11
|
+
/** ThinkHive API endpoint */
|
|
12
|
+
endpoint?: string;
|
|
13
|
+
/** Service name for traces */
|
|
14
|
+
serviceName?: string;
|
|
15
|
+
/** Enable auto-instrumentation */
|
|
16
|
+
autoInstrument?: boolean;
|
|
17
|
+
/** Frameworks to auto-instrument */
|
|
18
|
+
frameworks?: Framework[];
|
|
19
|
+
/** Enable debug logging */
|
|
20
|
+
debug?: boolean;
|
|
21
|
+
/** API version (default: 'v3') */
|
|
22
|
+
apiVersion?: 'v1' | 'v3';
|
|
23
|
+
}
|
|
24
|
+
export type Framework = 'langchain' | 'langgraph' | 'openai' | 'openai-assistants' | 'anthropic' | 'llamaindex' | 'n8n' | 'voiceflow';
|
|
25
|
+
/**
|
|
26
|
+
* Options for creating a run (v3 atomic unit)
|
|
27
|
+
*/
|
|
28
|
+
export interface RunOptions {
|
|
29
|
+
/** Agent ID */
|
|
30
|
+
agentId: string;
|
|
31
|
+
/** When the run started */
|
|
32
|
+
startedAt?: string | Date;
|
|
33
|
+
/** When the run ended */
|
|
34
|
+
endedAt?: string | Date;
|
|
35
|
+
/** Run outcome */
|
|
36
|
+
outcome?: RunOutcome;
|
|
37
|
+
/** Reason for the outcome */
|
|
38
|
+
outcomeReason?: string;
|
|
39
|
+
/** Conversation messages */
|
|
40
|
+
conversationMessages: ConversationMessage[];
|
|
41
|
+
/** Model ID used */
|
|
42
|
+
modelId?: string;
|
|
43
|
+
/** Prompt version */
|
|
44
|
+
promptVersion?: string;
|
|
45
|
+
/** Session ID for conversation tracking */
|
|
46
|
+
sessionId?: string;
|
|
47
|
+
/** Customer context snapshot (ARR, health AS OF this run) */
|
|
48
|
+
customerContext?: CustomerContextSnapshot;
|
|
49
|
+
/** Ticket linking options */
|
|
50
|
+
ticketLinking?: TicketLinkingOptions;
|
|
51
|
+
/** Custom metadata */
|
|
52
|
+
metadata?: Record<string, unknown>;
|
|
53
|
+
}
|
|
54
|
+
export type RunOutcome = 'resolved' | 'escalated' | 'abandoned' | 'failed' | 'transferred' | 'pending';
|
|
55
|
+
export interface ConversationMessage {
|
|
56
|
+
role: 'user' | 'assistant' | 'system' | 'tool';
|
|
57
|
+
content: string;
|
|
58
|
+
timestamp?: string;
|
|
59
|
+
metadata?: Record<string, unknown>;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Customer context captured AS OF the run time (not current values)
|
|
63
|
+
*/
|
|
64
|
+
export interface CustomerContextSnapshot {
|
|
65
|
+
/** Customer account ID */
|
|
66
|
+
customerId?: string;
|
|
67
|
+
/** ARR at the time of the run (not current ARR) */
|
|
68
|
+
arr?: number;
|
|
69
|
+
/** Health score at the time of the run (0-100) */
|
|
70
|
+
healthScore?: number;
|
|
71
|
+
/** Customer segment (e.g., 'enterprise', 'mid-market', 'smb') */
|
|
72
|
+
segment?: string;
|
|
73
|
+
/** When this snapshot was captured */
|
|
74
|
+
capturedAt?: string;
|
|
75
|
+
/** Custom fields (will be validated against schema) */
|
|
76
|
+
customFields?: Record<string, unknown>;
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Options for deterministic ticket linking
|
|
80
|
+
*/
|
|
81
|
+
export interface TicketLinkingOptions {
|
|
82
|
+
/** Link method to use */
|
|
83
|
+
method: LinkMethod;
|
|
84
|
+
/** Ticket ID (for sdk_explicit method) */
|
|
85
|
+
ticketId?: string;
|
|
86
|
+
/** External ticket ID (e.g., Zendesk ticket ID) */
|
|
87
|
+
externalTicketId?: string;
|
|
88
|
+
/** Platform for external ticket */
|
|
89
|
+
platform?: 'zendesk' | 'intercom' | 'salesforce' | 'freshdesk';
|
|
90
|
+
/** Custom field name for linking */
|
|
91
|
+
customFieldName?: string;
|
|
92
|
+
/** Custom field value */
|
|
93
|
+
customFieldValue?: string;
|
|
94
|
+
}
|
|
95
|
+
export type LinkMethod = 'sdk_explicit' | 'zendesk_marker' | 'custom_field' | 'middleware_stamp' | 'session_match' | 'email_time_window' | 'manual';
|
|
96
|
+
/**
|
|
97
|
+
* Trace options (v2 format, converted to runs internally)
|
|
98
|
+
* @deprecated Use RunOptions instead
|
|
99
|
+
*/
|
|
100
|
+
export interface TraceOptions {
|
|
101
|
+
/** User's message/query */
|
|
102
|
+
userMessage: string;
|
|
103
|
+
/** Agent's response */
|
|
104
|
+
agentResponse: string;
|
|
105
|
+
/** User's detected intent */
|
|
106
|
+
userIntent?: string;
|
|
107
|
+
/** Outcome: success, failure, partial_success */
|
|
108
|
+
outcome?: 'success' | 'failure' | 'partial_success';
|
|
109
|
+
/** Duration in milliseconds */
|
|
110
|
+
duration?: number;
|
|
111
|
+
/** Session ID for conversation tracking */
|
|
112
|
+
sessionId?: string;
|
|
113
|
+
/** Conversation history */
|
|
114
|
+
conversationHistory?: Array<{
|
|
115
|
+
role: string;
|
|
116
|
+
content: string;
|
|
117
|
+
}>;
|
|
118
|
+
/** Span data for detailed analysis */
|
|
119
|
+
spans?: SpanData[];
|
|
120
|
+
/** Business context for ROI calculation */
|
|
121
|
+
businessContext?: BusinessContext;
|
|
122
|
+
/** Custom metadata */
|
|
123
|
+
metadata?: Record<string, unknown>;
|
|
124
|
+
}
|
|
125
|
+
export interface SpanData {
|
|
126
|
+
id?: string;
|
|
127
|
+
name: string;
|
|
128
|
+
type: 'llm' | 'tool' | 'retrieval' | 'embedding' | 'chain' | 'custom';
|
|
129
|
+
startTime?: Date;
|
|
130
|
+
endTime?: Date;
|
|
131
|
+
durationMs?: number;
|
|
132
|
+
status?: 'ok' | 'error' | 'timeout';
|
|
133
|
+
error?: string;
|
|
134
|
+
input?: unknown;
|
|
135
|
+
output?: unknown;
|
|
136
|
+
model?: string;
|
|
137
|
+
provider?: string;
|
|
138
|
+
promptTokens?: number;
|
|
139
|
+
completionTokens?: number;
|
|
140
|
+
toolName?: string;
|
|
141
|
+
toolParameters?: Record<string, unknown>;
|
|
142
|
+
query?: string;
|
|
143
|
+
documentCount?: number;
|
|
144
|
+
topScore?: number;
|
|
145
|
+
sources?: string[];
|
|
146
|
+
children?: SpanData[];
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* @deprecated Use CustomerContextSnapshot instead
|
|
150
|
+
*/
|
|
151
|
+
export interface BusinessContext {
|
|
152
|
+
/** Customer ID */
|
|
153
|
+
customerId?: string;
|
|
154
|
+
/** Transaction value in dollars */
|
|
155
|
+
transactionValue?: number;
|
|
156
|
+
/** Priority level */
|
|
157
|
+
priority?: 'low' | 'medium' | 'high' | 'critical';
|
|
158
|
+
/** Department */
|
|
159
|
+
department?: string;
|
|
160
|
+
/** Industry vertical */
|
|
161
|
+
industry?: string;
|
|
162
|
+
/** Custom fields */
|
|
163
|
+
custom?: Record<string, unknown>;
|
|
164
|
+
}
|
|
165
|
+
/**
|
|
166
|
+
* A claim about a run (fact vs inference)
|
|
167
|
+
*/
|
|
168
|
+
export interface Claim {
|
|
169
|
+
id: string;
|
|
170
|
+
analysisId: string;
|
|
171
|
+
/** Type of claim */
|
|
172
|
+
claimType: ClaimType;
|
|
173
|
+
/** Category of the claim */
|
|
174
|
+
claimCategory: ClaimCategory;
|
|
175
|
+
/** The claim text */
|
|
176
|
+
claimText: string;
|
|
177
|
+
/** Confidence in this claim (0-1) */
|
|
178
|
+
confidence: number;
|
|
179
|
+
/** How well calibrated is this confidence */
|
|
180
|
+
confidenceCalibration: ConfidenceCalibration;
|
|
181
|
+
/** Evidence supporting this claim */
|
|
182
|
+
evidence: EvidenceReference[];
|
|
183
|
+
/** Is this claim explainable to end users */
|
|
184
|
+
isExplainable: boolean;
|
|
185
|
+
/** Probability value for probability claims */
|
|
186
|
+
probabilityValue?: number;
|
|
187
|
+
/** Human-assigned verification status */
|
|
188
|
+
humanVerified?: boolean;
|
|
189
|
+
/** Human verification verdict */
|
|
190
|
+
humanVerdict?: 'confirmed' | 'rejected' | 'modified';
|
|
191
|
+
createdAt?: string;
|
|
192
|
+
}
|
|
193
|
+
export type ClaimType = 'observed' | 'inferred' | 'computed';
|
|
194
|
+
export type ClaimCategory = 'outcome' | 'root_cause' | 'customer_impact' | 'churn_risk' | 'revenue_impact' | 'quality' | 'other';
|
|
195
|
+
export type ConfidenceCalibration = 'calibrated' | 'uncalibrated' | 'needs_more_data';
|
|
196
|
+
export interface EvidenceReference {
|
|
197
|
+
/** Type of evidence */
|
|
198
|
+
type: 'span' | 'message' | 'tool_call' | 'external' | 'computed';
|
|
199
|
+
/** ID of the referenced item */
|
|
200
|
+
referenceId: string;
|
|
201
|
+
/** How relevant is this evidence */
|
|
202
|
+
relevance: string;
|
|
203
|
+
/** Confidence in this evidence */
|
|
204
|
+
confidence: number;
|
|
205
|
+
}
|
|
206
|
+
export interface AnalysisResult {
|
|
207
|
+
id: string;
|
|
208
|
+
runId: string;
|
|
209
|
+
analysisVersion: string;
|
|
210
|
+
modelUsed: string;
|
|
211
|
+
/** Overall outcome verdict */
|
|
212
|
+
outcomeVerdict: 'success' | 'partial_success' | 'failure';
|
|
213
|
+
/** Confidence in the verdict (0-1) */
|
|
214
|
+
outcomeConfidence: number;
|
|
215
|
+
/** Root cause category if failure */
|
|
216
|
+
rootCauseCategory?: string;
|
|
217
|
+
/** Confidence in root cause (0-1) */
|
|
218
|
+
rootCauseConfidence?: number;
|
|
219
|
+
/** Is this the current analysis */
|
|
220
|
+
isCurrent: boolean;
|
|
221
|
+
/** ID of analysis that superseded this one */
|
|
222
|
+
supersededBy?: string;
|
|
223
|
+
/** Claims from this analysis */
|
|
224
|
+
claims: Claim[];
|
|
225
|
+
analyzedAt?: string;
|
|
226
|
+
createdAt?: string;
|
|
227
|
+
}
|
|
228
|
+
export interface CalibrationStatus {
|
|
229
|
+
agentId: string;
|
|
230
|
+
predictionType: PredictionType;
|
|
231
|
+
/** Brier score (lower is better, <0.1 is good) */
|
|
232
|
+
brierScore: number;
|
|
233
|
+
/** Expected Calibration Error */
|
|
234
|
+
ece: number;
|
|
235
|
+
/** Sample count */
|
|
236
|
+
sampleCount: number;
|
|
237
|
+
/** Is the model well-calibrated */
|
|
238
|
+
isCalibrated: boolean;
|
|
239
|
+
/** Calibration by confidence bucket */
|
|
240
|
+
buckets: CalibrationBucket[];
|
|
241
|
+
lastUpdated?: string;
|
|
242
|
+
}
|
|
243
|
+
export type PredictionType = 'outcome' | 'churn_risk' | 'escalation_risk' | 'resolution_time' | 'customer_satisfaction';
|
|
244
|
+
export interface CalibrationBucket {
|
|
245
|
+
bucketStart: number;
|
|
246
|
+
bucketEnd: number;
|
|
247
|
+
predictedProbability: number;
|
|
248
|
+
actualFrequency: number;
|
|
249
|
+
sampleCount: number;
|
|
250
|
+
}
|
|
251
|
+
export interface RoiConfig {
|
|
252
|
+
/** Cost per support ticket deflected */
|
|
253
|
+
ticketDeflectionValue: number;
|
|
254
|
+
/** Cost per escalation */
|
|
255
|
+
escalationCost: number;
|
|
256
|
+
/** Cost per hour of agent time */
|
|
257
|
+
agentHourlyCost: number;
|
|
258
|
+
/** Average resolution time (minutes) */
|
|
259
|
+
avgResolutionMinutes: number;
|
|
260
|
+
/** CSAT impact multiplier */
|
|
261
|
+
csatImpactMultiplier: number;
|
|
262
|
+
}
|
|
263
|
+
export interface RoiSummary {
|
|
264
|
+
period: {
|
|
265
|
+
from: string;
|
|
266
|
+
to: string;
|
|
267
|
+
};
|
|
268
|
+
/** Total estimated savings */
|
|
269
|
+
totalSavings: number;
|
|
270
|
+
/** Breakdown by category */
|
|
271
|
+
breakdown: {
|
|
272
|
+
ticketDeflection: number;
|
|
273
|
+
escalationPrevention: number;
|
|
274
|
+
timeToResolution: number;
|
|
275
|
+
churnPrevention: number;
|
|
276
|
+
};
|
|
277
|
+
/** Confidence in these estimates */
|
|
278
|
+
confidence: 'low' | 'medium' | 'high';
|
|
279
|
+
/** Methodology used */
|
|
280
|
+
methodology: string;
|
|
281
|
+
}
|
|
282
|
+
/**
|
|
283
|
+
* @deprecated Use AnalysisResult instead
|
|
284
|
+
*/
|
|
285
|
+
export interface ExplainabilityResult {
|
|
286
|
+
traceId: string;
|
|
287
|
+
explainabilityId: string;
|
|
288
|
+
summary: string;
|
|
289
|
+
outcome: {
|
|
290
|
+
verdict: 'success' | 'partial_success' | 'failure';
|
|
291
|
+
confidence: number;
|
|
292
|
+
reasoning: string;
|
|
293
|
+
};
|
|
294
|
+
businessImpact: {
|
|
295
|
+
impactScore: number;
|
|
296
|
+
customerSatisfaction: number;
|
|
297
|
+
revenueRisk: string;
|
|
298
|
+
};
|
|
299
|
+
recommendations: Array<{
|
|
300
|
+
priority: string;
|
|
301
|
+
category: string;
|
|
302
|
+
action: string;
|
|
303
|
+
expectedImpact: string;
|
|
304
|
+
}>;
|
|
305
|
+
ragEvaluation?: {
|
|
306
|
+
groundedness: number;
|
|
307
|
+
faithfulness: number;
|
|
308
|
+
answerRelevance: number;
|
|
309
|
+
};
|
|
310
|
+
hallucinationReport?: {
|
|
311
|
+
detected: boolean;
|
|
312
|
+
types: string[];
|
|
313
|
+
severity: string;
|
|
314
|
+
};
|
|
315
|
+
processingTimeMs: number;
|
|
316
|
+
}
|
|
317
|
+
export interface ApiResponse<T> {
|
|
318
|
+
success: boolean;
|
|
319
|
+
data?: T;
|
|
320
|
+
error?: {
|
|
321
|
+
code: string;
|
|
322
|
+
message: string;
|
|
323
|
+
details?: unknown;
|
|
324
|
+
};
|
|
325
|
+
}
|
|
326
|
+
export interface PaginatedResponse<T> {
|
|
327
|
+
success: boolean;
|
|
328
|
+
data: {
|
|
329
|
+
items: T[];
|
|
330
|
+
limit: number;
|
|
331
|
+
offset: number;
|
|
332
|
+
hasMore: boolean;
|
|
333
|
+
};
|
|
334
|
+
}
|
|
335
|
+
export interface RunResponse {
|
|
336
|
+
id: string;
|
|
337
|
+
companyId: string;
|
|
338
|
+
agentId: string;
|
|
339
|
+
ticketId?: string;
|
|
340
|
+
customerAccountId?: string;
|
|
341
|
+
sessionId?: string;
|
|
342
|
+
startedAt: string;
|
|
343
|
+
endedAt?: string;
|
|
344
|
+
durationMs?: number;
|
|
345
|
+
outcome?: RunOutcome;
|
|
346
|
+
outcomeReason?: string;
|
|
347
|
+
conversationMessages: ConversationMessage[];
|
|
348
|
+
modelId?: string;
|
|
349
|
+
promptVersion?: string;
|
|
350
|
+
customerContextSnapshot?: CustomerContextSnapshot;
|
|
351
|
+
zendeskMarker?: string;
|
|
352
|
+
createdAt: string;
|
|
353
|
+
updatedAt: string;
|
|
354
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ThinkHive SDK v3.0 - Core Types
|
|
4
|
+
*
|
|
5
|
+
* Run-centric types with facts vs inferences and customer context snapshots
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/core/types.ts"],"names":[],"mappings":";AAAA;;;;GAIG","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Core Types\n *\n * Run-centric types with facts vs inferences and customer context snapshots\n */\n\n// ============================================================================\n// INIT OPTIONS\n// ============================================================================\n\nexport interface InitOptions {\n  /** ThinkHive API key (starts with th_) */\n  apiKey?: string;\n  /** Agent ID */\n  agentId?: string;\n  /** ThinkHive API endpoint */\n  endpoint?: string;\n  /** Service name for traces */\n  serviceName?: string;\n  /** Enable auto-instrumentation */\n  autoInstrument?: boolean;\n  /** Frameworks to auto-instrument */\n  frameworks?: Framework[];\n  /** Enable debug logging */\n  debug?: boolean;\n  /** API version (default: 'v3') */\n  apiVersion?: 'v1' | 'v3';\n}\n\nexport type Framework =\n  | 'langchain'\n  | 'langgraph'\n  | 'openai'\n  | 'openai-assistants'\n  | 'anthropic'\n  | 'llamaindex'\n  | 'n8n'\n  | 'voiceflow';\n\n// ============================================================================\n// RUN OPTIONS (v3)\n// ============================================================================\n\n/**\n * Options for creating a run (v3 atomic unit)\n */\nexport interface RunOptions {\n  /** Agent ID */\n  agentId: string;\n  /** When the run started */\n  startedAt?: string | Date;\n  /** When the run ended */\n  endedAt?: string | Date;\n  /** Run outcome */\n  outcome?: RunOutcome;\n  /** Reason for the outcome */\n  outcomeReason?: string;\n  /** Conversation messages */\n  conversationMessages: ConversationMessage[];\n  /** Model ID used */\n  modelId?: string;\n  /** Prompt version */\n  promptVersion?: string;\n  /** Session ID for conversation tracking */\n  sessionId?: string;\n  /** Customer context snapshot (ARR, health AS OF this run) */\n  customerContext?: CustomerContextSnapshot;\n  /** Ticket linking options */\n  ticketLinking?: TicketLinkingOptions;\n  /** Custom metadata */\n  metadata?: Record<string, unknown>;\n}\n\nexport type RunOutcome =\n  | 'resolved'\n  | 'escalated'\n  | 'abandoned'\n  | 'failed'\n  | 'transferred'\n  | 'pending';\n\nexport interface ConversationMessage {\n  role: 'user' | 'assistant' | 'system' | 'tool';\n  content: string;\n  timestamp?: string;\n  metadata?: Record<string, unknown>;\n}\n\n// ============================================================================\n// CUSTOMER CONTEXT SNAPSHOT (v3)\n// ============================================================================\n\n/**\n * Customer context captured AS OF the run time (not current values)\n */\nexport interface CustomerContextSnapshot {\n  /** Customer account ID */\n  customerId?: string;\n  /** ARR at the time of the run (not current ARR) */\n  arr?: number;\n  /** Health score at the time of the run (0-100) */\n  healthScore?: number;\n  /** Customer segment (e.g., 'enterprise', 'mid-market', 'smb') */\n  segment?: string;\n  /** When this snapshot was captured */\n  capturedAt?: string;\n  /** Custom fields (will be validated against schema) */\n  customFields?: Record<string, unknown>;\n}\n\n// ============================================================================\n// TICKET LINKING (v3)\n// ============================================================================\n\n/**\n * Options for deterministic ticket linking\n */\nexport interface TicketLinkingOptions {\n  /** Link method to use */\n  method: LinkMethod;\n  /** Ticket ID (for sdk_explicit method) */\n  ticketId?: string;\n  /** External ticket ID (e.g., Zendesk ticket ID) */\n  externalTicketId?: string;\n  /** Platform for external ticket */\n  platform?: 'zendesk' | 'intercom' | 'salesforce' | 'freshdesk';\n  /** Custom field name for linking */\n  customFieldName?: string;\n  /** Custom field value */\n  customFieldValue?: string;\n}\n\nexport type LinkMethod =\n  | 'sdk_explicit'      // Direct SDK call with ticket ID (confidence: 1.0)\n  | 'zendesk_marker'    // Embedded THID marker in response (confidence: 1.0)\n  | 'custom_field'      // Zendesk custom field (confidence: 1.0)\n  | 'middleware_stamp'  // Middleware-injected trace ID (confidence: 0.98)\n  | 'session_match'     // Session ID correlation (confidence: 0.95)\n  | 'email_time_window' // Email + 15min window (confidence: 0.6)\n  | 'manual';           // Human-assigned (confidence: 1.0)\n\n// ============================================================================\n// TRACE OPTIONS (v2 compatibility)\n// ============================================================================\n\n/**\n * Trace options (v2 format, converted to runs internally)\n * @deprecated Use RunOptions instead\n */\nexport interface TraceOptions {\n  /** User's message/query */\n  userMessage: string;\n  /** Agent's response */\n  agentResponse: string;\n  /** User's detected intent */\n  userIntent?: string;\n  /** Outcome: success, failure, partial_success */\n  outcome?: 'success' | 'failure' | 'partial_success';\n  /** Duration in milliseconds */\n  duration?: number;\n  /** Session ID for conversation tracking */\n  sessionId?: string;\n  /** Conversation history */\n  conversationHistory?: Array<{ role: string; content: string }>;\n  /** Span data for detailed analysis */\n  spans?: SpanData[];\n  /** Business context for ROI calculation */\n  businessContext?: BusinessContext;\n  /** Custom metadata */\n  metadata?: Record<string, unknown>;\n}\n\nexport interface SpanData {\n  id?: string;\n  name: string;\n  type: 'llm' | 'tool' | 'retrieval' | 'embedding' | 'chain' | 'custom';\n  startTime?: Date;\n  endTime?: Date;\n  durationMs?: number;\n  status?: 'ok' | 'error' | 'timeout';\n  error?: string;\n  input?: unknown;\n  output?: unknown;\n  // LLM-specific\n  model?: string;\n  provider?: string;\n  promptTokens?: number;\n  completionTokens?: number;\n  // Tool-specific\n  toolName?: string;\n  toolParameters?: Record<string, unknown>;\n  // Retrieval-specific\n  query?: string;\n  documentCount?: number;\n  topScore?: number;\n  sources?: string[];\n  // Children\n  children?: SpanData[];\n}\n\n/**\n * @deprecated Use CustomerContextSnapshot instead\n */\nexport interface BusinessContext {\n  /** Customer ID */\n  customerId?: string;\n  /** Transaction value in dollars */\n  transactionValue?: number;\n  /** Priority level */\n  priority?: 'low' | 'medium' | 'high' | 'critical';\n  /** Department */\n  department?: string;\n  /** Industry vertical */\n  industry?: string;\n  /** Custom fields */\n  custom?: Record<string, unknown>;\n}\n\n// ============================================================================\n// CLAIM TYPES (v3)\n// ============================================================================\n\n/**\n * A claim about a run (fact vs inference)\n */\nexport interface Claim {\n  id: string;\n  analysisId: string;\n  /** Type of claim */\n  claimType: ClaimType;\n  /** Category of the claim */\n  claimCategory: ClaimCategory;\n  /** The claim text */\n  claimText: string;\n  /** Confidence in this claim (0-1) */\n  confidence: number;\n  /** How well calibrated is this confidence */\n  confidenceCalibration: ConfidenceCalibration;\n  /** Evidence supporting this claim */\n  evidence: EvidenceReference[];\n  /** Is this claim explainable to end users */\n  isExplainable: boolean;\n  /** Probability value for probability claims */\n  probabilityValue?: number;\n  /** Human-assigned verification status */\n  humanVerified?: boolean;\n  /** Human verification verdict */\n  humanVerdict?: 'confirmed' | 'rejected' | 'modified';\n  createdAt?: string;\n}\n\nexport type ClaimType = 'observed' | 'inferred' | 'computed';\nexport type ClaimCategory =\n  | 'outcome'\n  | 'root_cause'\n  | 'customer_impact'\n  | 'churn_risk'\n  | 'revenue_impact'\n  | 'quality'\n  | 'other';\nexport type ConfidenceCalibration = 'calibrated' | 'uncalibrated' | 'needs_more_data';\n\nexport interface EvidenceReference {\n  /** Type of evidence */\n  type: 'span' | 'message' | 'tool_call' | 'external' | 'computed';\n  /** ID of the referenced item */\n  referenceId: string;\n  /** How relevant is this evidence */\n  relevance: string;\n  /** Confidence in this evidence */\n  confidence: number;\n}\n\n// ============================================================================\n// ANALYSIS RESULT (v3)\n// ============================================================================\n\nexport interface AnalysisResult {\n  id: string;\n  runId: string;\n  analysisVersion: string;\n  modelUsed: string;\n  /** Overall outcome verdict */\n  outcomeVerdict: 'success' | 'partial_success' | 'failure';\n  /** Confidence in the verdict (0-1) */\n  outcomeConfidence: number;\n  /** Root cause category if failure */\n  rootCauseCategory?: string;\n  /** Confidence in root cause (0-1) */\n  rootCauseConfidence?: number;\n  /** Is this the current analysis */\n  isCurrent: boolean;\n  /** ID of analysis that superseded this one */\n  supersededBy?: string;\n  /** Claims from this analysis */\n  claims: Claim[];\n  analyzedAt?: string;\n  createdAt?: string;\n}\n\n// ============================================================================\n// CALIBRATION TYPES (v3)\n// ============================================================================\n\nexport interface CalibrationStatus {\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  /** Sample count */\n  sampleCount: number;\n  /** Is the model well-calibrated */\n  isCalibrated: boolean;\n  /** Calibration by confidence bucket */\n  buckets: CalibrationBucket[];\n  lastUpdated?: string;\n}\n\nexport type PredictionType =\n  | 'outcome'\n  | 'churn_risk'\n  | 'escalation_risk'\n  | 'resolution_time'\n  | 'customer_satisfaction';\n\nexport interface CalibrationBucket {\n  bucketStart: number;\n  bucketEnd: number;\n  predictedProbability: number;\n  actualFrequency: number;\n  sampleCount: number;\n}\n\n// ============================================================================\n// ROI TYPES (v3)\n// ============================================================================\n\nexport interface RoiConfig {\n  /** Cost per support ticket deflected */\n  ticketDeflectionValue: number;\n  /** Cost per escalation */\n  escalationCost: number;\n  /** Cost per hour of agent time */\n  agentHourlyCost: number;\n  /** Average resolution time (minutes) */\n  avgResolutionMinutes: number;\n  /** CSAT impact multiplier */\n  csatImpactMultiplier: number;\n}\n\nexport interface RoiSummary {\n  period: { from: string; to: string };\n  /** Total estimated savings */\n  totalSavings: number;\n  /** Breakdown by category */\n  breakdown: {\n    ticketDeflection: number;\n    escalationPrevention: number;\n    timeToResolution: number;\n    churnPrevention: number;\n  };\n  /** Confidence in these estimates */\n  confidence: 'low' | 'medium' | 'high';\n  /** Methodology used */\n  methodology: string;\n}\n\n// ============================================================================\n// EXPLAINABILITY RESULT (v2 compatibility)\n// ============================================================================\n\n/**\n * @deprecated Use AnalysisResult instead\n */\nexport interface ExplainabilityResult {\n  traceId: string;\n  explainabilityId: string;\n  summary: string;\n  outcome: {\n    verdict: 'success' | 'partial_success' | 'failure';\n    confidence: number;\n    reasoning: string;\n  };\n  businessImpact: {\n    impactScore: number;\n    customerSatisfaction: number;\n    revenueRisk: string;\n  };\n  recommendations: Array<{\n    priority: string;\n    category: string;\n    action: string;\n    expectedImpact: string;\n  }>;\n  ragEvaluation?: {\n    groundedness: number;\n    faithfulness: number;\n    answerRelevance: number;\n  };\n  hallucinationReport?: {\n    detected: boolean;\n    types: string[];\n    severity: string;\n  };\n  processingTimeMs: number;\n}\n\n// ============================================================================\n// API RESPONSE TYPES\n// ============================================================================\n\nexport interface ApiResponse<T> {\n  success: boolean;\n  data?: T;\n  error?: {\n    code: string;\n    message: string;\n    details?: unknown;\n  };\n}\n\nexport interface PaginatedResponse<T> {\n  success: boolean;\n  data: {\n    items: T[];\n    limit: number;\n    offset: number;\n    hasMore: boolean;\n  };\n}\n\nexport interface RunResponse {\n  id: string;\n  companyId: string;\n  agentId: string;\n  ticketId?: string;\n  customerAccountId?: string;\n  sessionId?: string;\n  startedAt: string;\n  endedAt?: string;\n  durationMs?: number;\n  outcome?: RunOutcome;\n  outcomeReason?: string;\n  conversationMessages: ConversationMessage[];\n  modelId?: string;\n  promptVersion?: string;\n  customerContextSnapshot?: CustomerContextSnapshot;\n  zendeskMarker?: string;\n  createdAt: string;\n  updatedAt: string;\n}\n"]}
|