@thinkhive/sdk 4.2.2 → 4.2.4
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/README.md +50 -5
- package/dist/api/calibration.d.ts +19 -4
- package/dist/api/calibration.js +44 -6
- package/dist/api/claims.d.ts +24 -4
- package/dist/api/claims.js +16 -7
- package/dist/api/conversation-eval.d.ts +7 -8
- package/dist/api/conversation-eval.js +30 -17
- package/dist/api/deterministic-graders.d.ts +37 -28
- package/dist/api/deterministic-graders.js +25 -22
- package/dist/api/llm-costs.d.ts +2 -0
- package/dist/api/llm-costs.js +5 -1
- package/dist/api/nondeterminism.d.ts +16 -8
- package/dist/api/nondeterminism.js +43 -11
- package/dist/api/notifications.d.ts +2 -0
- package/dist/api/notifications.js +5 -1
- package/dist/api/quality-metrics.d.ts +11 -0
- package/dist/api/quality-metrics.js +5 -1
- package/dist/api/signals.d.ts +2 -0
- package/dist/api/signals.js +5 -1
- package/dist/core/client.d.ts +1 -1
- package/dist/core/client.js +10 -3
- package/dist/core/config.d.ts +1 -1
- package/dist/core/config.js +2 -2
- package/dist/guardrails.d.ts +2 -0
- package/dist/guardrails.js +5 -1
- package/dist/index.d.ts +20 -1
- package/dist/index.js +2 -2
- package/dist/integrations/customer-context.d.ts +2 -0
- package/dist/integrations/customer-context.js +5 -1
- package/package.json +12 -12
package/dist/core/config.d.ts
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
* ThinkHive SDK v3.0 - Configuration
|
|
3
3
|
*/
|
|
4
4
|
import type { InitOptions, Framework } from './types';
|
|
5
|
-
export declare const SDK_VERSION = "4.
|
|
5
|
+
export declare const SDK_VERSION = "4.2.4";
|
|
6
6
|
export declare const DEFAULT_ENDPOINT = "https://app.thinkhive.ai";
|
|
7
7
|
export declare const DEFAULT_SERVICE_NAME = "my-ai-agent";
|
|
8
8
|
export interface ResolvedConfig {
|
package/dist/core/config.js
CHANGED
|
@@ -12,7 +12,7 @@ exports.debugLog = debugLog;
|
|
|
12
12
|
// ============================================================================
|
|
13
13
|
// CONSTANTS
|
|
14
14
|
// ============================================================================
|
|
15
|
-
exports.SDK_VERSION = '4.
|
|
15
|
+
exports.SDK_VERSION = '4.2.4';
|
|
16
16
|
exports.DEFAULT_ENDPOINT = 'https://app.thinkhive.ai';
|
|
17
17
|
exports.DEFAULT_SERVICE_NAME = 'my-ai-agent';
|
|
18
18
|
let config = null;
|
|
@@ -72,4 +72,4 @@ function debugLog(...args) {
|
|
|
72
72
|
console.log('[ThinkHive]', ...args);
|
|
73
73
|
}
|
|
74
74
|
}
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvcmUvY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7R0FFRzs7O0FBb0NILGdDQXNCQztBQU1ELDhCQUtDO0FBS0Qsc0NBRUM7QUFLRCxrQ0FHQztBQUtELDRCQUlDO0FBekZELCtFQUErRTtBQUMvRSxZQUFZO0FBQ1osK0VBQStFO0FBRWxFLFFBQUEsV0FBVyxHQUFHLE9BQU8sQ0FBQztBQUN0QixRQUFBLGdCQUFnQixHQUFHLDBCQUEwQixDQUFDO0FBQzlDLFFBQUEsb0JBQW9CLEdBQUcsYUFBYSxDQUFDO0FBZ0JsRCxJQUFJLE1BQU0sR0FBMEIsSUFBSSxDQUFDO0FBQ3pDLElBQUksV0FBVyxHQUFHLEtBQUssQ0FBQztBQUV4QiwrRUFBK0U7QUFDL0UsbUJBQW1CO0FBQ25CLCtFQUErRTtBQUUvRTs7R0FFRztBQUNILFNBQWdCLFVBQVUsQ0FBQyxVQUF1QixFQUFFO0lBQ2xELE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxNQUFNLElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsSUFBSSxFQUFFLENBQUM7SUFDckUsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLE9BQU8sSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQixJQUFJLEVBQUUsQ0FBQztJQUV4RSxJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDeEIsTUFBTSxJQUFJLEtBQUssQ0FDYiw4RUFBOEUsQ0FDL0UsQ0FBQztJQUNKLENBQUM7SUFFRCxNQUFNLEdBQUc7UUFDUCxNQUFNO1FBQ04sT0FBTztRQUNQLFFBQVEsRUFBRSxPQUFPLENBQUMsUUFBUSxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCLElBQUksd0JBQWdCO1FBQ2hGLFdBQVcsRUFBRSxPQUFPLENBQUMsV0FBVyxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsc0JBQXNCLElBQUksNEJBQW9CO1FBQzlGLGNBQWMsRUFBRSxPQUFPLENBQUMsY0FBYyxJQUFJLEtBQUs7UUFDL0MsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVLElBQUksQ0FBQyxXQUFXLEVBQUUsUUFBUSxDQUFDO1FBQ3pELEtBQUssRUFBRSxPQUFPLENBQUMsS0FBSyxJQUFJLEtBQUs7S0FDOUIsQ0FBQztJQUVGLFdBQVcsR0FBRyxJQUFJLENBQUM7SUFDbkIsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVEOzs7R0FHRztBQUNILFNBQWdCLFNBQVM7SUFDdkIsSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQzVCLE1BQU0sSUFBSSxLQUFLLENBQUMsbURBQW1ELENBQUMsQ0FBQztJQUN2RSxDQUFDO0lBQ0QsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVEOztHQUVHO0FBQ0gsU0FBZ0IsYUFBYTtJQUMzQixPQUFPLFdBQVcsQ0FBQztBQUNyQixDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixXQUFXO0lBQ3pCLE1BQU0sR0FBRyxJQUFJLENBQUM7SUFDZCxXQUFXLEdBQUcsS0FBSyxDQUFDO0FBQ3RCLENBQUM7QUFFRDs7R0FFRztBQUNILFNBQWdCLFFBQVEsQ0FBQyxHQUFHLElBQWU7SUFDekMsSUFBSSxNQUFNLEVBQUUsS0FBSyxFQUFFLENBQUM7UUFDbEIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztJQUN0QyxDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVGhpbmtIaXZlIFNESyB2My4wIC0gQ29uZmlndXJhdGlvblxuICovXG5cbmltcG9ydCB0eXBlIHsgSW5pdE9wdGlvbnMsIEZyYW1ld29yayB9IGZyb20gJy4vdHlwZXMnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBDT05TVEFOVFNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGNvbnN0IFNES19WRVJTSU9OID0gJzQuMi40JztcbmV4cG9ydCBjb25zdCBERUZBVUxUX0VORFBPSU5UID0gJ2h0dHBzOi8vYXBwLnRoaW5raGl2ZS5haSc7XG5leHBvcnQgY29uc3QgREVGQVVMVF9TRVJWSUNFX05BTUUgPSAnbXktYWktYWdlbnQnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBHTE9CQUwgQ09ORklHIFNUQVRFXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb2x2ZWRDb25maWcge1xuICBhcGlLZXk6IHN0cmluZztcbiAgYWdlbnRJZDogc3RyaW5nO1xuICBlbmRwb2ludDogc3RyaW5nO1xuICBzZXJ2aWNlTmFtZTogc3RyaW5nO1xuICBhdXRvSW5zdHJ1bWVudDogYm9vbGVhbjtcbiAgZnJhbWV3b3JrczogRnJhbWV3b3JrW107XG4gIGRlYnVnOiBib29sZWFuO1xufVxuXG5sZXQgY29uZmlnOiBSZXNvbHZlZENvbmZpZyB8IG51bGwgPSBudWxsO1xubGV0IGluaXRpYWxpemVkID0gZmFsc2U7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIENPTkZJRyBGVU5DVElPTlNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBJbml0aWFsaXplIGNvbmZpZ3VyYXRpb24gZnJvbSBvcHRpb25zXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpbml0Q29uZmlnKG9wdGlvbnM6IEluaXRPcHRpb25zID0ge30pOiBSZXNvbHZlZENvbmZpZyB7XG4gIGNvbnN0IGFwaUtleSA9IG9wdGlvbnMuYXBpS2V5IHx8IHByb2Nlc3MuZW52LlRISU5LSElWRV9BUElfS0VZIHx8ICcnO1xuICBjb25zdCBhZ2VudElkID0gb3B0aW9ucy5hZ2VudElkIHx8IHByb2Nlc3MuZW52LlRISU5LSElWRV9BR0VOVF9JRCB8fCAnJztcblxuICBpZiAoIWFwaUtleSAmJiAhYWdlbnRJZCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICdFaXRoZXIgYXBpS2V5IG9yIGFnZW50SWQgbXVzdCBiZSBwcm92aWRlZCAob3Igc2V0IFRISU5LSElWRV9BUElfS0VZIGVudiB2YXIpJ1xuICAgICk7XG4gIH1cblxuICBjb25maWcgPSB7XG4gICAgYXBpS2V5LFxuICAgIGFnZW50SWQsXG4gICAgZW5kcG9pbnQ6IG9wdGlvbnMuZW5kcG9pbnQgfHwgcHJvY2Vzcy5lbnYuVEhJTktISVZFX0VORFBPSU5UIHx8IERFRkFVTFRfRU5EUE9JTlQsXG4gICAgc2VydmljZU5hbWU6IG9wdGlvbnMuc2VydmljZU5hbWUgfHwgcHJvY2Vzcy5lbnYuVEhJTktISVZFX1NFUlZJQ0VfTkFNRSB8fCBERUZBVUxUX1NFUlZJQ0VfTkFNRSxcbiAgICBhdXRvSW5zdHJ1bWVudDogb3B0aW9ucy5hdXRvSW5zdHJ1bWVudCA/PyBmYWxzZSxcbiAgICBmcmFtZXdvcmtzOiBvcHRpb25zLmZyYW1ld29ya3MgfHwgWydsYW5nY2hhaW4nLCAnb3BlbmFpJ10sXG4gICAgZGVidWc6IG9wdGlvbnMuZGVidWcgPz8gZmFsc2UsXG4gIH07XG5cbiAgaW5pdGlhbGl6ZWQgPSB0cnVlO1xuICByZXR1cm4gY29uZmlnO1xufVxuXG4vKipcbiAqIEdldCBjdXJyZW50IGNvbmZpZ3VyYXRpb25cbiAqIEB0aHJvd3MgaWYgbm90IGluaXRpYWxpemVkXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRDb25maWcoKTogUmVzb2x2ZWRDb25maWcge1xuICBpZiAoIWNvbmZpZyB8fCAhaW5pdGlhbGl6ZWQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1RoaW5rSGl2ZSBTREsgbm90IGluaXRpYWxpemVkLiBDYWxsIGluaXQoKSBmaXJzdC4nKTtcbiAgfVxuICByZXR1cm4gY29uZmlnO1xufVxuXG4vKipcbiAqIENoZWNrIGlmIFNESyBpcyBpbml0aWFsaXplZFxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNJbml0aWFsaXplZCgpOiBib29sZWFuIHtcbiAgcmV0dXJuIGluaXRpYWxpemVkO1xufVxuXG4vKipcbiAqIFJlc2V0IGNvbmZpZ3VyYXRpb24gKGZvciB0ZXN0aW5nKVxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVzZXRDb25maWcoKTogdm9pZCB7XG4gIGNvbmZpZyA9IG51bGw7XG4gIGluaXRpYWxpemVkID0gZmFsc2U7XG59XG5cbi8qKlxuICogRGVidWcgbG9nIGhlbHBlclxuICovXG5leHBvcnQgZnVuY3Rpb24gZGVidWdMb2coLi4uYXJnczogdW5rbm93bltdKTogdm9pZCB7XG4gIGlmIChjb25maWc/LmRlYnVnKSB7XG4gICAgY29uc29sZS5sb2coJ1tUaGlua0hpdmVdJywgLi4uYXJncyk7XG4gIH1cbn1cbiJdfQ==
|
package/dist/guardrails.d.ts
CHANGED
package/dist/guardrails.js
CHANGED
|
@@ -30,5 +30,9 @@ exports.guardrails = {
|
|
|
30
30
|
});
|
|
31
31
|
return result.scanners;
|
|
32
32
|
},
|
|
33
|
+
/** Alias for scan() */
|
|
34
|
+
async evaluate(request) {
|
|
35
|
+
return this.scan(request);
|
|
36
|
+
},
|
|
33
37
|
};
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3VhcmRyYWlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9ndWFyZHJhaWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7O0dBR0c7OztBQUVILDBDQUFtRDtBQW9EbkQ7OztHQUdHO0FBQ1UsUUFBQSxVQUFVLEdBQUc7SUFDeEI7O09BRUc7SUFDSCxLQUFLLENBQUMsSUFBSSxDQUFDLE9BQW9CO1FBQzdCLE9BQU8sSUFBQSwyQkFBa0IsRUFBZSxxQkFBcUIsRUFBRTtZQUM3RCxNQUFNLEVBQUUsTUFBTTtZQUNkLElBQUksRUFBRSxPQUFPO1lBQ2IsT0FBTyxFQUFFLElBQUk7U0FDZCxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxLQUFLLENBQUMsWUFBWTtRQUNoQixNQUFNLE1BQU0sR0FBRyxNQUFNLElBQUEsMkJBQWtCLEVBQTZELHlCQUF5QixFQUFFO1lBQzdILE9BQU8sRUFBRSxJQUFJO1NBQ2QsQ0FBQyxDQUFDO1FBQ0gsT0FBTyxNQUFNLENBQUMsUUFBUSxDQUFDO0lBQ3pCLENBQUM7SUFFRCx1QkFBdUI7SUFDdkIsS0FBSyxDQUFDLFFBQVEsQ0FBQyxPQUFvQjtRQUNqQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDNUIsQ0FBQztDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoaW5rSGl2ZSBHdWFyZHJhaWxzIFNESyBNb2R1bGVcbiAqIFJlYWwtdGltZSBjb250ZW50IHNjYW5uaW5nIHVzaW5nIGNlbnRyYWxpemVkIFNESyBjb25maWd1cmF0aW9uXG4gKi9cblxuaW1wb3J0IHsgYXBpUmVxdWVzdFdpdGhEYXRhIH0gZnJvbSAnLi9jb3JlL2NsaWVudCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2NhblJlcXVlc3Qge1xuICBpbnB1dD86IHN0cmluZztcbiAgb3V0cHV0Pzogc3RyaW5nO1xuICB0b29sQ2FsbD86IHsgbmFtZTogc3RyaW5nOyBhcmd1bWVudHM6IFJlY29yZDxzdHJpbmcsIHVua25vd24+IH07XG4gIHNjYW5uZXJzPzogc3RyaW5nW107XG4gIHBvbGljeUlkPzogc3RyaW5nO1xuICBjb25maWc/OiBSZWNvcmQ8c3RyaW5nLCBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPj47XG4gIG9wdGlvbnM/OiB7XG4gICAgdGltZW91dD86IG51bWJlcjtcbiAgICBmYWlsT3Blbj86IGJvb2xlYW47XG4gICAgc2hvcnRDaXJjdWl0PzogYm9vbGVhbjtcbiAgICByZXR1cm5SZWRhY3RlZD86IGJvb2xlYW47XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmluZGluZyB7XG4gIHR5cGU6IHN0cmluZztcbiAgdmFsdWU6IHN0cmluZztcbiAgc3RhcnQ6IG51bWJlcjtcbiAgZW5kOiBudW1iZXI7XG4gIGNvbmZpZGVuY2U6IG51bWJlcjtcbiAgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTY2FubmVyUmVzdWx0IHtcbiAgc2Nhbm5lcjogc3RyaW5nO1xuICBzdGF0dXM6ICdjb21wbGV0ZWQnIHwgJ3RpbWVvdXQnIHwgJ2Vycm9yJztcbiAgYWN0aW9uOiAncGFzcycgfCAnYmxvY2snIHwgJ3JlZGFjdCcgfCAnZmxhZyc7XG4gIGZpbmRpbmdzOiBGaW5kaW5nW107XG4gIGxhdGVuY3lNczogbnVtYmVyO1xuICBzYW5pdGl6ZWRDb250ZW50Pzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjYW5SZXNwb25zZSB7XG4gIGFjdGlvbjogJ3Bhc3MnIHwgJ2Jsb2NrJyB8ICdyZWRhY3QnIHwgJ2ZsYWcnO1xuICBhY3Rpb25SZWFzb24/OiBzdHJpbmc7XG4gIHJlZGFjdGVkSW5wdXQ/OiBzdHJpbmc7XG4gIHJlZGFjdGVkT3V0cHV0Pzogc3RyaW5nO1xuICByZXN1bHRzOiBSZWNvcmQ8c3RyaW5nLCBTY2FubmVyUmVzdWx0PjtcbiAgbWV0YWRhdGE6IHtcbiAgICBzY2FuSWQ6IHN0cmluZztcbiAgICB0b3RhbExhdGVuY3lNczogbnVtYmVyO1xuICAgIHNjYW5uZXJzRXhlY3V0ZWQ6IG51bWJlcjtcbiAgICBzY2FubmVyc0Jsb2NrZWQ6IG51bWJlcjtcbiAgICBzY2FubmVyc0ZsYWdnZWQ6IG51bWJlcjtcbiAgICBzY2FubmVyc1RpbWVkT3V0OiBudW1iZXI7XG4gICAgY2FjaGVkOiBib29sZWFuO1xuICB9O1xufVxuXG4vKipcbiAqIEd1YXJkcmFpbHMgQVBJIGNsaWVudFxuICogUmVhbC10aW1lIGNvbnRlbnQgc2Nhbm5pbmcgZm9yIFBJSSwgc2VjcmV0cywga2V5d29yZHMsIGFuZCBtb3JlXG4gKi9cbmV4cG9ydCBjb25zdCBndWFyZHJhaWxzID0ge1xuICAvKipcbiAgICogU2NhbiBjb250ZW50IGZvciBwb2xpY3kgdmlvbGF0aW9uc1xuICAgKi9cbiAgYXN5bmMgc2NhbihyZXF1ZXN0OiBTY2FuUmVxdWVzdCk6IFByb21pc2U8U2NhblJlc3BvbnNlPiB7XG4gICAgcmV0dXJuIGFwaVJlcXVlc3RXaXRoRGF0YTxTY2FuUmVzcG9uc2U+KCcvdjEvZ3VhcmRyYWlscy9zY2FuJywge1xuICAgICAgbWV0aG9kOiAnUE9TVCcsXG4gICAgICBib2R5OiByZXF1ZXN0LFxuICAgICAgcmF3UGF0aDogdHJ1ZSxcbiAgICB9KTtcbiAgfSxcblxuICAvKipcbiAgICogTGlzdCBhdmFpbGFibGUgc2Nhbm5lcnNcbiAgICovXG4gIGFzeW5jIGxpc3RTY2FubmVycygpOiBQcm9taXNlPEFycmF5PHsgbmFtZTogc3RyaW5nOyBkZXNjcmlwdGlvbjogc3RyaW5nIH0+PiB7XG4gICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgYXBpUmVxdWVzdFdpdGhEYXRhPHsgc2Nhbm5lcnM6IEFycmF5PHsgbmFtZTogc3RyaW5nOyBkZXNjcmlwdGlvbjogc3RyaW5nIH0+IH0+KCcvdjEvZ3VhcmRyYWlscy9zY2FubmVycycsIHtcbiAgICAgIHJhd1BhdGg6IHRydWUsXG4gICAgfSk7XG4gICAgcmV0dXJuIHJlc3VsdC5zY2FubmVycztcbiAgfSxcblxuICAvKiogQWxpYXMgZm9yIHNjYW4oKSAqL1xuICBhc3luYyBldmFsdWF0ZShyZXF1ZXN0OiBTY2FuUmVxdWVzdCk6IFByb21pc2U8U2NhblJlc3BvbnNlPiB7XG4gICAgcmV0dXJuIHRoaXMuc2NhbihyZXF1ZXN0KTtcbiAgfSxcbn07XG4iXX0=
|
package/dist/index.d.ts
CHANGED
|
@@ -396,6 +396,7 @@ declare const _default: {
|
|
|
396
396
|
}): Promise<import("./integrations/customer-context").CustomerMetricsSnapshot[]>;
|
|
397
397
|
getLatestSnapshot(customerId: string): Promise<import("./integrations/customer-context").CustomerMetricsSnapshot | null>;
|
|
398
398
|
getSnapshotAsOf(customerId: string, timestamp: string | Date): Promise<import("./integrations/customer-context").CustomerMetricsSnapshot | null>;
|
|
399
|
+
capture(customerId: string, metrics: Record<string, unknown>): Promise<import("./core/types").CustomerContextSnapshot>;
|
|
399
400
|
};
|
|
400
401
|
humanReview: {
|
|
401
402
|
getQueue(options?: import("./api/human-review").ListQueueOptions): Promise<import("./api/human-review").HumanReviewQueueItem[]>;
|
|
@@ -691,7 +692,11 @@ declare const _default: {
|
|
|
691
692
|
};
|
|
692
693
|
}>;
|
|
693
694
|
calculateV3(options: {
|
|
694
|
-
agentId
|
|
695
|
+
agentId
|
|
696
|
+
/**
|
|
697
|
+
* Trace an LLM call
|
|
698
|
+
*/
|
|
699
|
+
?: string;
|
|
695
700
|
startDate: string | Date;
|
|
696
701
|
endDate: string | Date;
|
|
697
702
|
configurationVersion?: number;
|
|
@@ -764,6 +769,16 @@ declare const _default: {
|
|
|
764
769
|
summary: import("./api/quality-metrics").BatchEvaluationSummary;
|
|
765
770
|
results: import("./api/quality-metrics").BatchEvaluationResult[];
|
|
766
771
|
}>;
|
|
772
|
+
evaluate(input: {
|
|
773
|
+
query: string;
|
|
774
|
+
response: string;
|
|
775
|
+
retrievedContexts: import("./api/quality-metrics").RetrievedContext[];
|
|
776
|
+
groundTruthContexts?: import("./api/quality-metrics").GroundTruthContext[];
|
|
777
|
+
citations?: string[];
|
|
778
|
+
}): Promise<{
|
|
779
|
+
evaluation: import("./api/quality-metrics").RAGEvaluation;
|
|
780
|
+
evidence: import("./api/quality-metrics").RAGEvidence;
|
|
781
|
+
}>;
|
|
767
782
|
};
|
|
768
783
|
businessMetrics: {
|
|
769
784
|
current(agentId: string, metricName?: string): Promise<import("./api/business-metrics").CurrentMetricResponse>;
|
|
@@ -794,6 +809,7 @@ declare const _default: {
|
|
|
794
809
|
create(name: string, group: string, detectionConfig: import("./api/signals").DetectionConfig, opts?: import("./api/signals").CreateSignalOptions): Promise<import("./api/signals").Signal>;
|
|
795
810
|
update(id: string, opts: import("./api/signals").UpdateSignalOptions): Promise<import("./api/signals").Signal>;
|
|
796
811
|
remove(id: string): Promise<void>;
|
|
812
|
+
delete(id: string): Promise<void>;
|
|
797
813
|
seedDefaults(): Promise<import("./api/signals").Signal[]>;
|
|
798
814
|
getStats(opts?: import("./api/signals").SignalStatsOptions): Promise<import("./api/signals").SignalStats[]>;
|
|
799
815
|
getTrends(opts?: import("./api/signals").SignalTrendsOptions): Promise<import("./api/signals").SignalTrendPoint[]>;
|
|
@@ -818,6 +834,7 @@ declare const _default: {
|
|
|
818
834
|
deleteRule(id: string): Promise<void>;
|
|
819
835
|
listNotifications(agentId: string, unreadOnly?: boolean): Promise<import("./api/notifications").Notification[]>;
|
|
820
836
|
markAsRead(id: string): Promise<import("./api/notifications").Notification>;
|
|
837
|
+
list(agentId: string, unreadOnly?: boolean): Promise<import("./api/notifications").Notification[]>;
|
|
821
838
|
};
|
|
822
839
|
documents: {
|
|
823
840
|
list(agentId: string): Promise<import("./api/documents").Document[]>;
|
|
@@ -849,6 +866,7 @@ declare const _default: {
|
|
|
849
866
|
getBreakdown(agentId: string, opts?: import("./api/llm-costs").CostQueryOptions): Promise<import("./api/llm-costs").AgentCostBreakdown>;
|
|
850
867
|
getSavings(): Promise<import("./api/llm-costs").CostSavings>;
|
|
851
868
|
getOptimizationStats(): Promise<import("./api/llm-costs").OptimizationStats>;
|
|
869
|
+
summary(opts?: import("./api/llm-costs").CostQueryOptions): Promise<import("./api/llm-costs").CostSummary>;
|
|
852
870
|
};
|
|
853
871
|
guardrails: {
|
|
854
872
|
scan(request: import("./guardrails").ScanRequest): Promise<import("./guardrails").ScanResponse>;
|
|
@@ -856,6 +874,7 @@ declare const _default: {
|
|
|
856
874
|
name: string;
|
|
857
875
|
description: string;
|
|
858
876
|
}>>;
|
|
877
|
+
evaluate(request: import("./guardrails").ScanRequest): Promise<import("./guardrails").ScanResponse>;
|
|
859
878
|
};
|
|
860
879
|
generateZendeskMarker: typeof generateZendeskMarker;
|
|
861
880
|
parseZendeskMarker: typeof parseZendeskMarker;
|
package/dist/index.js
CHANGED
|
@@ -237,7 +237,7 @@ function init(options = {}) {
|
|
|
237
237
|
headers: exporterHeaders,
|
|
238
238
|
});
|
|
239
239
|
// Create OpenTelemetry resource
|
|
240
|
-
const resource = resources_1.
|
|
240
|
+
const resource = (0, resources_1.defaultResource)().merge((0, resources_1.resourceFromAttributes)({
|
|
241
241
|
'service.name': config.serviceName,
|
|
242
242
|
'thinkhive.sdk.version': config_1.SDK_VERSION,
|
|
243
243
|
'thinkhive.sdk.language': 'typescript',
|
|
@@ -679,4 +679,4 @@ exports.default = {
|
|
|
679
679
|
// LLM Costs helpers
|
|
680
680
|
formatLLMCost: llm_costs_1.formatCost,
|
|
681
681
|
};
|
|
682
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v4.1.0\n *\n * Run-centric AI agent observability platform with:\n * - Facts vs Inferences (claims API)\n * - Deterministic ticket linking (7 methods)\n * - Customer context snapshots (time-series)\n * - Calibrated predictions (Brier scores)\n * - Configurable ROI calculation engine\n *\n * @version 4.1.0\n * @license MIT\n */\n\nimport { trace, context, SpanStatusCode } from '@opentelemetry/api';\nimport { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-proto';\nimport { Resource } from '@opentelemetry/resources';\nimport { NodeTracerProvider } from '@opentelemetry/sdk-trace-node';\nimport { BatchSpanProcessor } from '@opentelemetry/sdk-trace-base';\n\n// Core\nimport {\n  initConfig,\n  getConfig,\n  isInitialized,\n  resetConfig,\n  debugLog,\n  SDK_VERSION,\n  DEFAULT_ENDPOINT,\n} from './core/config';\nimport {\n  apiRequestWithData,\n  ThinkHiveError,\n  ThinkHiveApiError,\n  ThinkHiveValidationError,\n  PermissionDeniedError,\n  AgentScopeError,\n  RateLimitError,\n  IpWhitelistError,\n} from './core/client';\n\n// API clients\nimport { runs, createRunWithContext, toOpenAIMessages, fromOpenAIMessages } from './api/runs';\nimport {\n  claims,\n  isFact,\n  isInference,\n  isComputed,\n  getHighConfidenceClaims,\n  groupClaimsByType,\n  groupClaimsByCategory,\n} from './api/claims';\nimport {\n  calibration,\n  calculateBrierScore,\n  calculateECE,\n  isWellCalibrated,\n  getCalibrationQuality,\n} from './api/calibration';\n\n// New Evaluation APIs\nimport { humanReview } from './api/human-review';\nimport {\n  nondeterminism,\n  calculatePassAtK,\n  calculatePassToK,\n  requiredPassRateForPassAtK,\n  isReliableEvaluation,\n  getReliabilityRecommendation,\n} from './api/nondeterminism';\nimport {\n  evalHealth,\n  hasHealthIssue,\n  getSeverityLevel as getHealthSeverityLevel,\n  isSaturated,\n  getSaturationRecommendation,\n} from './api/eval-health';\nimport {\n  deterministicGraders,\n  createRegexRule,\n  createContainsRule,\n  createLengthRule,\n  createJsonSchemaRule,\n  allRulesPassed,\n  getFailedRules,\n  calculateAverageScore,\n} from './api/deterministic-graders';\nimport {\n  conversationEval,\n  aggregateWorst,\n  aggregateAverage,\n  aggregateWeighted,\n  aggregateFinalTurn,\n  aggregateMajority,\n  getAggregator,\n  getProblematicTurns,\n  analyzeConversationTrend,\n} from './api/conversation-eval';\nimport {\n  transcriptPatterns,\n  isHighRisk,\n  getMatchesByCategory,\n  getCriticalInsights,\n  hasPiiExposure,\n  hasFrustrationSignals,\n  hasEscalationRequest,\n  getCategoryDistribution,\n  getRecommendations,\n  needsAttention,\n  sortMatchesBySeverity,\n} from './api/transcript-patterns';\n\n// Agents Management\nimport {\n  agents,\n} from './api/agents';\n\n// Eval Runs\nimport { evalRuns } from './api/eval-runs';\n\n// Signals\nimport { signals } from './api/signals';\n\n// Notifications\nimport { notifications } from './api/notifications';\n\n// Documents\nimport { documents } from './api/documents';\n\n// Shadow Tests\nimport { shadowTests } from './api/shadow-tests';\n\n// Sessions\nimport { sessions } from './api/sessions';\n\n// Drift\nimport { drift, hasDrift, getDriftSeverity } from './api/drift';\n\n// LLM Costs\nimport { llmCosts, formatCost as formatLLMCost } from './api/llm-costs';\n\n// Guardrails\nimport { guardrails } from './guardrails';\n\n// API Key Management (Phase 2 Security)\nimport {\n  apiKeys,\n  hasPermission,\n  isExpired as isApiKeyExpired,\n  isValid as isApiKeyValid,\n  getTimeUntilExpiry,\n  canAccessAgent,\n} from './api/apiKeys';\n\n// ROI Analytics API\nimport {\n  roiAnalytics,\n  calculateRevenueAtRisk,\n  calculateAutomationSavings,\n  formatCurrency,\n  getROIQuality,\n} from './api/roi-analytics';\n\n// Business Metrics API\nimport {\n  businessMetrics,\n  isMetricReady,\n  needsMoreTraces,\n  awaitingExternalData,\n  isMetricStale,\n  getStatusMessage,\n  getTraceProgress,\n  formatMetricValue,\n  getTrendEmoji,\n} from './api/business-metrics';\n\n// Quality Metrics API\nimport {\n  qualityMetrics,\n  passesQualityThreshold,\n  isHallucinationRiskAcceptable,\n  getQualityRecommendations,\n  formatQualityScore,\n  getGradeColor,\n} from './api/quality-metrics';\n\n// Integrations\nimport {\n  linking,\n  generateZendeskMarker,\n  parseZendeskMarker,\n  hasZendeskMarker,\n  removeZendeskMarker,\n  linkRunToTicket,\n  linkRunToZendeskTicket,\n  getBestLinkMethod,\n  LINK_METHOD_CONFIDENCE,\n} from './integrations/ticket-linking';\nimport {\n  customerContext,\n  captureCustomerContext,\n  getContextAsOf,\n  toContextSnapshot,\n  calculateArrChange,\n  calculateHealthTrend,\n} from './integrations/customer-context';\n\n// Re-export types\nexport type {\n  InitOptions,\n  Framework,\n  RunOptions,\n  RunOutcome,\n  ConversationMessage,\n  CustomerContextSnapshot,\n  TicketLinkingOptions,\n  LinkMethod,\n  TraceOptions,\n  TraceCustomFlag,\n  SpanData,\n  BusinessContext,\n  Claim,\n  ClaimType,\n  ClaimCategory,\n  ConfidenceCalibration,\n  EvidenceReference,\n  AnalysisResult,\n  CalibrationStatus,\n  CalibrationBucket,\n  PredictionType,\n  RoiConfig,\n  RoiSummary,\n  ExplainabilityResult,\n  ApiResponse,\n  PaginatedResponse,\n  RunResponse,\n} from './core/types';\n\n// Re-export evaluation types\nexport type {\n  HumanReviewStatus,\n  HumanReviewType,\n  HumanReviewQueueItem,\n  CalibrationSet,\n  ReviewerCalibration,\n  QueueStats,\n} from './api/human-review';\n\nexport type {\n  NondeterminismRunType,\n  NondeterminismRunStatus,\n  NondeterminismRun,\n  NondeterminismSample,\n  TraceAnalysis,\n  CriterionAnalysis,\n  RunSummary,\n} from './api/nondeterminism';\n\nexport type {\n  SaturationType,\n  HealthStatus,\n  RegressionSeverity,\n  EvalHealthSnapshot,\n  EvalRegression,\n  HealthReport,\n} from './api/eval-health';\n\nexport type {\n  RuleType,\n  DeterministicEvalResult,\n  RuleResult,\n  RuleTypeInfo,\n  RuleTemplate,\n} from './api/deterministic-graders';\n\nexport type {\n  AggregateMethod,\n  SessionTrace,\n  TurnEvaluation,\n  ConversationEvalResult,\n  AggregationMethodInfo,\n} from './api/conversation-eval';\n\nexport type {\n  PatternCategory,\n  PatternOutcome,\n  PatternSeverity,\n  PatternMatch,\n  PatternInsight,\n  AnalysisResult as PatternAnalysisResult,\n  PatternCategoryInfo,\n  BuiltInPattern,\n} from './api/transcript-patterns';\n\n// Re-export API Key types (Phase 2 Security)\nexport type {\n  ApiKeyPermissions,\n  ScopeType,\n  Environment,\n  CreateApiKeyOptions,\n  ApiKey,\n  CreateApiKeyResult,\n} from './api/apiKeys';\n\n// Re-export ROI Analytics types\nexport type {\n  IndustryConfig,\n  CustomIndustryConfig,\n  ROIMetrics,\n  BusinessImpact,\n  ROISummary,\n  TrendDataPoint,\n  Correlation,\n  PatternCluster,\n  CorrelationAnalysis,\n} from './api/roi-analytics';\n\n// Re-export Quality Metrics types\nexport type {\n  RetrievedContext,\n  GroundTruthContext,\n  GroundedSpan,\n  UngroundedSpan,\n  CitationMap,\n  RAGEvaluation,\n  RAGEvidence,\n  HallucinationInstance,\n  HallucinationReport,\n  GroundednessResult,\n  BatchEvaluationResult,\n  BatchEvaluationSummary,\n} from './api/quality-metrics';\n\n// Re-export Business Metrics types\nexport type {\n  MetricTrend,\n  MetricStatus,\n  CurrentMetricResponse,\n  MetricHistoryPoint,\n  MetricHistorySummary,\n  MetricHistoryResponse,\n  RecordMetricOptions,\n  RecordMetricResponse,\n} from './api/business-metrics';\n\n// Re-export Agent types\nexport type {\n  Agent,\n  CreateAgentOptions,\n  UpdateAgentOptions,\n  AgentConfig,\n  UpdateAgentConfigOptions,\n  DeleteAgentOptions,\n  CascadeImpact,\n} from './api/agents';\n\n// Re-export Eval Runs types\nexport type {\n  CreateEvalRunOptions,\n  GetEvalRunResultsOptions,\n  ListEvalRunsOptions,\n  EstimateCostOptions,\n  GetTraceResultsOptions,\n  EvalRun,\n  EvalResult,\n  EvalCostEstimate,\n} from './api/eval-runs';\n\n// Re-export Signals types\nexport type {\n  DetectionConfig,\n  CreateSignalOptions,\n  UpdateSignalOptions,\n  ListSignalsOptions,\n  SignalStatsOptions,\n  SignalTrendsOptions,\n  SignalTracesOptions,\n  SignalEventsOptions,\n  Signal,\n  SignalStats,\n  SignalTrendPoint,\n  SignalEvent,\n} from './api/signals';\n\n// Re-export Notifications types\nexport type {\n  NotificationRule,\n  CreateNotificationRuleData,\n  UpdateNotificationRuleData,\n  Notification,\n} from './api/notifications';\n\n// Re-export Documents types\nexport type {\n  Document,\n  DocumentUploadResponse,\n} from './api/documents';\n\n// Re-export Shadow Tests types\nexport type {\n  CreateShadowTestData,\n  UpdateShadowTestData,\n  ShadowTest,\n} from './api/shadow-tests';\n\n// Re-export Sessions types\nexport type {\n  ListSessionsOptions,\n  Session,\n  SessionTrace as SessionTraceRecord,\n} from './api/sessions';\n\n// Re-export Drift types\nexport type {\n  DetectDriftOptions,\n  DriftReport,\n  DriftDimension,\n  DetectAllResult,\n} from './api/drift';\n\n// Re-export LLM Costs types\nexport type {\n  CostQueryOptions,\n  CostSummary,\n  CostBreakdownItem,\n  AgentCostBreakdown,\n  CostSavings,\n  OptimizationEntry,\n  OptimizationStats,\n  OptimizationRecommendation,\n} from './api/llm-costs';\n\n// ============================================================================\n// GLOBAL STATE\n// ============================================================================\n\nlet tracer: ReturnType<typeof trace.getTracer> | null = null;\nlet provider: NodeTracerProvider | null = null;\n\n// ============================================================================\n// INITIALIZATION\n// ============================================================================\n\n/**\n * Initialize ThinkHive SDK v3\n *\n * @example\n * ```typescript\n * import { init } from '@thinkhive/sdk';\n *\n * init({\n *   apiKey: 'th_your_api_key',\n *   serviceName: 'my-ai-agent',\n *   autoInstrument: true,\n *   frameworks: ['langchain', 'openai'],\n * });\n * ```\n */\nexport function init(options: import('./core/types').InitOptions = {}): void {\n  if (isInitialized()) {\n    debugLog('ThinkHive SDK already initialized');\n    return;\n  }\n\n  const config = initConfig(options);\n\n  // Configure OTLP exporter\n  const exporterHeaders: Record<string, string> = {};\n  if (config.apiKey) {\n    exporterHeaders['Authorization'] = `Bearer ${config.apiKey}`;\n  } else {\n    throw new Error(\n      'OTLP tracing requires an API key. Agent ID alone is not sufficient for OTLP ingestion. ' +\n      'Provide apiKey in init() or set the THINKHIVE_API_KEY environment variable.'\n    );\n  }\n\n  const otlpUrl = config.endpoint.replace(/\\/+$/, '') + '/v1/traces';\n  const exporter = new OTLPTraceExporter({\n    url: otlpUrl,\n    headers: exporterHeaders,\n  });\n\n  // Create OpenTelemetry resource\n  const resource = Resource.default().merge(\n    new Resource({\n      'service.name': config.serviceName,\n      'thinkhive.sdk.version': SDK_VERSION,\n      'thinkhive.sdk.language': 'typescript',\n    })\n  );\n\n  // Create provider with span processor\n  provider = new NodeTracerProvider({\n    resource,\n    spanProcessors: [new BatchSpanProcessor(exporter)],\n  });\n\n  // Register provider\n  provider.register();\n\n  // Get tracer\n  tracer = trace.getTracer('thinkhive', SDK_VERSION);\n\n  if (config.debug) {\n    console.log(`✅ ThinkHive SDK v${SDK_VERSION} initialized`);\n    console.log(`   Endpoint: ${config.endpoint}`);\n    console.log(`   Service: ${config.serviceName}`);\n    console.log(`   Auto-instrument: ${config.autoInstrument}`);\n  }\n\n  // Setup auto-instrumentation if enabled\n  if (config.autoInstrument) {\n    setupAutoInstrumentation(config.frameworks);\n  }\n}\n\n/**\n * Get the global tracer\n */\nexport function getTracer() {\n  if (!tracer) {\n    throw new Error('ThinkHive SDK not initialized. Call init() first.');\n  }\n  return tracer;\n}\n\n/**\n * Shutdown the SDK and flush pending spans\n */\nexport async function shutdown(): Promise<void> {\n  if (provider) {\n    await provider.shutdown();\n    provider = null;\n  }\n  tracer = null;\n  resetConfig();\n  debugLog('ThinkHive SDK shutdown complete');\n}\n\n// ============================================================================\n// TRACING FUNCTIONS\n// ============================================================================\n\n/**\n * Trace an LLM call\n */\nexport function traceLLM<T>(\n  options: {\n    name: string;\n    modelName?: string;\n    provider?: string;\n    input?: unknown;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.name,\n    {\n      attributes: {\n        'openinference.span.kind': 'LLM',\n        'llm.model_name': options.modelName,\n        'llm.provider': options.provider,\n        'input.value': options.input ? JSON.stringify(options.input).substring(0, 10000) : undefined,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        span.setAttribute('output.value', JSON.stringify(result).substring(0, 10000));\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute('duration_ms', Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n/**\n * Trace a retrieval operation\n */\nexport function traceRetrieval<T>(\n  options: {\n    name: string;\n    query?: string;\n    topK?: number;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.name,\n    {\n      attributes: {\n        'openinference.span.kind': 'RETRIEVER',\n        'retrieval.query': options.query,\n        'retrieval.top_k': options.topK,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        if (Array.isArray(result)) {\n          span.setAttribute('retrieval.document_count', result.length);\n        }\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute('duration_ms', Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n/**\n * Trace a tool call\n */\nexport function traceTool<T>(\n  options: {\n    name: string;\n    toolName?: string;\n    parameters?: Record<string, unknown>;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.toolName || options.name,\n    {\n      attributes: {\n        'openinference.span.kind': 'TOOL',\n        'tool.name': options.toolName || options.name,\n        'tool.parameters': options.parameters ? JSON.stringify(options.parameters) : undefined,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        span.setAttribute('tool.output', JSON.stringify(result).substring(0, 10000));\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute('duration_ms', Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n/**\n * Trace a chain/workflow\n */\nexport function traceChain<T>(\n  options: {\n    name: string;\n    input?: unknown;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.name,\n    {\n      attributes: {\n        'openinference.span.kind': 'CHAIN',\n        'input.value': options.input ? JSON.stringify(options.input).substring(0, 10000) : undefined,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        span.setAttribute('output.value', JSON.stringify(result).substring(0, 10000));\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute('duration_ms', Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n// ============================================================================\n// V2 TERMINOLOGY - ISSUES API (replaces Cases)\n// Per ITIL best practices, \"Issues\" is more customer-friendly than \"Cases\"\n// ============================================================================\n\n/**\n * Issues API client\n * This is the recommended API for managing clustered failure patterns\n *\n * @since 3.1.0\n */\nexport const issues = {\n  /**\n   * List issues for an agent\n   */\n  async list(agentId: string, options?: {\n    status?: string;\n    startDate?: Date;\n    endDate?: Date;\n    limit?: number;\n    offset?: number;\n  }): Promise<any[]> {\n    const params = new URLSearchParams({ agentId });\n    if (options?.status) params.set('status', options.status);\n    if (options?.startDate) params.set('startDate', options.startDate.toISOString());\n    if (options?.endDate) params.set('endDate', options.endDate.toISOString());\n    if (options?.limit) params.set('limit', options.limit.toString());\n    if (options?.offset) params.set('offset', options.offset.toString());\n\n    const response = await apiRequestWithData(`/issues?${params}`, { apiVersion: 'v2' });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Get a single issue by ID\n   */\n  async get(id: string): Promise<any> {\n    const response = await apiRequestWithData(`/issues/${id}`, { apiVersion: 'v2' });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Create a new issue\n   */\n  async create(data: {\n    agentId: string;\n    title: string;\n    description?: string;\n    type: string;\n    severity?: string;\n    pattern?: string;\n    exampleTraceIds?: string[];\n  }): Promise<any> {\n    const response = await apiRequestWithData('/issues', {\n      method: 'POST',\n      body: data,\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Update an issue\n   */\n  async update(id: string, data: {\n    title?: string;\n    description?: string;\n    status?: string;\n    severity?: string;\n    assignedTo?: string;\n    resolutionNotes?: string;\n  }): Promise<any> {\n    const response = await apiRequestWithData(`/issues/${id}`, {\n      method: 'PATCH',\n      body: data,\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Get fixes for an issue\n   */\n  async getFixes(issueId: string): Promise<any[]> {\n    const response = await apiRequestWithData(`/issues/${issueId}/fixes`, { apiVersion: 'v2' });\n    return (response as any).data || response;\n  },\n};\n\n\n// ============================================================================\n// V2 TERMINOLOGY - ANALYZER API (replaces Explainer user-facing)\n// Per industry distinction: Analyzer = pattern detection/observation\n// ============================================================================\n\n/**\n * Analyzer API client\n * User-selected trace analysis with cost estimation and smart sampling\n *\n * Key improvements over v1 Explainer:\n * - User-selected trace analysis (not automatic)\n * - Cost estimation before execution\n * - Smart sampling strategies\n * - Root cause analysis by layer\n * - Pattern aggregation across traces\n *\n * @since 3.1.0\n */\nexport const analyzer = {\n  /**\n   * Analyze specific traces (user-selected)\n   */\n  async analyze(options: {\n    traceIds: string[];\n    tier?: 'fast' | 'standard' | 'deep';\n    includeRootCause?: boolean;\n    includeLayers?: boolean;\n  }): Promise<any> {\n    const { traceIds, tier, includeRootCause, includeLayers } = options;\n    const response = await apiRequestWithData('/analyzer/analyze', {\n      method: 'POST',\n      body: {\n        traceIds,\n        options: {\n          tier,\n          includeRootCause,\n          includeLayers,\n        },\n      },\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Analyze traces by time window\n   */\n  async analyzeWindow(options: {\n    agentId: string;\n    startDate: Date;\n    endDate: Date;\n    filters?: {\n      outcomes?: ('failure' | 'error' | 'success')[];\n      minSeverity?: 'low' | 'medium' | 'high' | 'critical';\n    };\n    sampling?: {\n      strategy: 'all' | 'failures_only' | 'smart' | 'random';\n      samplePercent?: number;\n    };\n  }): Promise<any> {\n    const response = await apiRequestWithData('/analyzer/analyze-window', {\n      method: 'POST',\n      body: {\n        ...options,\n        startDate: options.startDate.toISOString(),\n        endDate: options.endDate.toISOString(),\n      },\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Estimate cost before running analysis\n   */\n  async estimateCost(options: {\n    traceIds?: string[];\n    agentId?: string;\n    startDate?: Date;\n    endDate?: Date;\n    tier: 'fast' | 'standard' | 'deep';\n  }): Promise<{\n    estimatedTraces: number;\n    estimatedTokens: number;\n    estimatedCost: number;\n    estimatedCredits: number;\n    tier: string;\n    note: string;\n  }> {\n    const response = await apiRequestWithData('/analyzer/estimate-cost', {\n      method: 'POST',\n      body: {\n        ...options,\n        startDate: options.startDate?.toISOString(),\n        endDate: options.endDate?.toISOString(),\n      },\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Get analysis results for a specific trace\n   */\n  async get(traceId: string): Promise<any> {\n    const response = await apiRequestWithData(`/analyzer/${traceId}`, { apiVersion: 'v2' });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Aggregate insights across multiple analyzed traces\n   */\n  async summarize(options: {\n    analysisIds?: string[];\n    agentId?: string;\n    startDate?: Date;\n    endDate?: Date;\n  }): Promise<any> {\n    const response = await apiRequestWithData('/analyzer/summarize', {\n      method: 'POST',\n      body: {\n        ...options,\n        startDate: options.startDate?.toISOString(),\n        endDate: options.endDate?.toISOString(),\n      },\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n};\n\n\n// ============================================================================\n// AUTO-INSTRUMENTATION\n// ============================================================================\n\nfunction setupAutoInstrumentation(\n  frameworks: import('./core/types').Framework[]\n): void {\n  debugLog(`Setting up auto-instrumentation for: ${frameworks.join(', ')}`);\n\n  for (const framework of frameworks) {\n    try {\n      switch (framework) {\n        case 'openai':\n        case 'openai-assistants':\n          debugLog('OpenAI instrumentation ready (use instrumentOpenAIClient)');\n          break;\n        case 'langchain':\n        case 'langgraph':\n          debugLog('LangChain/LangGraph instrumentation ready (use ThinkHiveCallbackHandler)');\n          break;\n        case 'anthropic':\n          debugLog('Anthropic instrumentation ready');\n          break;\n        case 'llamaindex':\n          debugLog('LlamaIndex instrumentation ready');\n          break;\n        case 'n8n':\n          debugLog('n8n instrumentation ready');\n          break;\n        case 'voiceflow':\n          debugLog('Voiceflow instrumentation ready');\n          break;\n      }\n    } catch (error) {\n      debugLog(`Failed to setup ${framework} instrumentation:`, error);\n    }\n  }\n}\n\n// ============================================================================\n// RE-EXPORTS (non-duplicated)\n// ============================================================================\n\n// Re-export from config (not yet exported)\nexport { isInitialized, SDK_VERSION, DEFAULT_ENDPOINT };\n\n// Re-export API clients (v3)\nexport {\n  runs,\n  claims,\n  calibration,\n  linking,\n  customerContext,\n  // New evaluation APIs\n  humanReview,\n  nondeterminism,\n  evalHealth,\n  deterministicGraders,\n  conversationEval,\n  transcriptPatterns,\n  // API Key Management (Phase 2 Security)\n  apiKeys,\n  // Agents Management\n  agents,\n  // ROI Analytics, Quality Metrics, and Business Metrics\n  roiAnalytics,\n  qualityMetrics,\n  businessMetrics,\n  // Eval Runs, Signals, Notifications, Documents, Shadow Tests, Sessions, Drift, LLM Costs\n  evalRuns,\n  signals,\n  notifications,\n  documents,\n  shadowTests,\n  sessions,\n  drift,\n  llmCosts,\n  // Guardrails\n  guardrails,\n};\n\n// Note: issues, analyzer, and guardrails are already exported via 'export const' above\n\n// Re-export helper functions\nexport {\n  // Runs helpers\n  createRunWithContext,\n  toOpenAIMessages,\n  fromOpenAIMessages,\n  // Claims helpers\n  isFact,\n  isInference,\n  isComputed,\n  getHighConfidenceClaims,\n  groupClaimsByType,\n  groupClaimsByCategory,\n  // Calibration helpers\n  calculateBrierScore,\n  calculateECE,\n  isWellCalibrated,\n  getCalibrationQuality,\n  // Linking helpers\n  generateZendeskMarker,\n  parseZendeskMarker,\n  hasZendeskMarker,\n  removeZendeskMarker,\n  linkRunToTicket,\n  linkRunToZendeskTicket,\n  getBestLinkMethod,\n  LINK_METHOD_CONFIDENCE,\n  // Customer context helpers\n  captureCustomerContext,\n  getContextAsOf,\n  toContextSnapshot,\n  calculateArrChange,\n  calculateHealthTrend,\n  // Non-determinism helpers\n  calculatePassAtK,\n  calculatePassToK,\n  requiredPassRateForPassAtK,\n  isReliableEvaluation,\n  getReliabilityRecommendation,\n  // Eval health helpers\n  hasHealthIssue,\n  getHealthSeverityLevel,\n  isSaturated,\n  getSaturationRecommendation,\n  // Deterministic graders helpers\n  createRegexRule,\n  createContainsRule,\n  createLengthRule,\n  createJsonSchemaRule,\n  allRulesPassed,\n  getFailedRules,\n  calculateAverageScore,\n  // Conversation eval helpers\n  aggregateWorst,\n  aggregateAverage,\n  aggregateWeighted,\n  aggregateFinalTurn,\n  aggregateMajority,\n  getAggregator,\n  getProblematicTurns,\n  analyzeConversationTrend,\n  // Transcript patterns helpers\n  isHighRisk,\n  getMatchesByCategory,\n  getCriticalInsights,\n  hasPiiExposure,\n  hasFrustrationSignals,\n  hasEscalationRequest,\n  getCategoryDistribution,\n  getRecommendations,\n  needsAttention,\n  sortMatchesBySeverity,\n  // API Key helpers\n  hasPermission,\n  isApiKeyExpired,\n  isApiKeyValid,\n  getTimeUntilExpiry,\n  canAccessAgent,\n  // ROI Analytics helpers\n  calculateRevenueAtRisk,\n  calculateAutomationSavings,\n  formatCurrency,\n  getROIQuality,\n  // Quality Metrics helpers\n  passesQualityThreshold,\n  isHallucinationRiskAcceptable,\n  getQualityRecommendations,\n  formatQualityScore,\n  getGradeColor,\n  // Business Metrics helpers\n  isMetricReady,\n  needsMoreTraces,\n  awaitingExternalData,\n  isMetricStale,\n  getStatusMessage,\n  getTraceProgress,\n  formatMetricValue,\n  getTrendEmoji,\n  // Drift helpers\n  hasDrift,\n  getDriftSeverity,\n  // LLM Costs helpers\n  formatLLMCost,\n};\n\n// Re-export Guardrails\nexport { type ScanRequest, type ScanResponse, type Finding, type ScannerResult } from './guardrails';\n\n// Re-export errors (including new security errors)\nexport {\n  ThinkHiveError,\n  ThinkHiveApiError,\n  ThinkHiveValidationError,\n  PermissionDeniedError,\n  AgentScopeError,\n  RateLimitError,\n  IpWhitelistError,\n};\n\n// Default export for convenience\nexport default {\n  init,\n  getTracer,\n  shutdown,\n  isInitialized,\n  // Tracing\n  traceLLM,\n  traceRetrieval,\n  traceTool,\n  traceChain,\n  // API clients\n  runs,\n  claims,\n  calibration,\n  linking,\n  customerContext,\n  // Evaluation APIs\n  humanReview,\n  nondeterminism,\n  evalHealth,\n  deterministicGraders,\n  conversationEval,\n  transcriptPatterns,\n  // API Key Management (Phase 2 Security)\n  apiKeys,\n  // Agents Management\n  agents,\n  // Issues and Analyzer APIs\n  issues,\n  analyzer,\n  // ROI Analytics, Quality Metrics, and Business Metrics\n  roiAnalytics,\n  qualityMetrics,\n  businessMetrics,\n  // Eval Runs, Signals, Notifications, Documents, Shadow Tests, Sessions, Drift, LLM Costs\n  evalRuns,\n  signals,\n  notifications,\n  documents,\n  shadowTests,\n  sessions,\n  drift,\n  llmCosts,\n  // Guardrails\n  guardrails,\n  // Helpers\n  generateZendeskMarker,\n  parseZendeskMarker,\n  linkRunToTicket,\n  createRunWithContext,\n  // Utilities\n  isFact,\n  isInference,\n  calculateBrierScore,\n  isWellCalibrated,\n  calculatePassAtK,\n  isReliableEvaluation,\n  isHighRisk,\n  needsAttention,\n  // ROI helpers\n  calculateRevenueAtRisk,\n  formatCurrency,\n  // Quality helpers\n  passesQualityThreshold,\n  isHallucinationRiskAcceptable,\n  // Business Metrics helpers\n  isMetricReady,\n  needsMoreTraces,\n  getStatusMessage,\n  // Drift helpers\n  hasDrift,\n  getDriftSeverity,\n  // LLM Costs helpers\n  formatLLMCost,\n};\n"]}
|
|
682
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v4.1.0\n *\n * Run-centric AI agent observability platform with:\n * - Facts vs Inferences (claims API)\n * - Deterministic ticket linking (7 methods)\n * - Customer context snapshots (time-series)\n * - Calibrated predictions (Brier scores)\n * - Configurable ROI calculation engine\n *\n * @version 4.1.0\n * @license MIT\n */\n\nimport { trace, context, SpanStatusCode } from '@opentelemetry/api';\nimport { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-proto';\nimport { resourceFromAttributes, defaultResource } from '@opentelemetry/resources';\nimport { NodeTracerProvider } from '@opentelemetry/sdk-trace-node';\nimport { BatchSpanProcessor } from '@opentelemetry/sdk-trace-base';\n\n// Core\nimport {\n  initConfig,\n  getConfig,\n  isInitialized,\n  resetConfig,\n  debugLog,\n  SDK_VERSION,\n  DEFAULT_ENDPOINT,\n} from './core/config';\nimport {\n  apiRequestWithData,\n  ThinkHiveError,\n  ThinkHiveApiError,\n  ThinkHiveValidationError,\n  PermissionDeniedError,\n  AgentScopeError,\n  RateLimitError,\n  IpWhitelistError,\n} from './core/client';\n\n// API clients\nimport { runs, createRunWithContext, toOpenAIMessages, fromOpenAIMessages } from './api/runs';\nimport {\n  claims,\n  isFact,\n  isInference,\n  isComputed,\n  getHighConfidenceClaims,\n  groupClaimsByType,\n  groupClaimsByCategory,\n} from './api/claims';\nimport {\n  calibration,\n  calculateBrierScore,\n  calculateECE,\n  isWellCalibrated,\n  getCalibrationQuality,\n} from './api/calibration';\n\n// New Evaluation APIs\nimport { humanReview } from './api/human-review';\nimport {\n  nondeterminism,\n  calculatePassAtK,\n  calculatePassToK,\n  requiredPassRateForPassAtK,\n  isReliableEvaluation,\n  getReliabilityRecommendation,\n} from './api/nondeterminism';\nimport {\n  evalHealth,\n  hasHealthIssue,\n  getSeverityLevel as getHealthSeverityLevel,\n  isSaturated,\n  getSaturationRecommendation,\n} from './api/eval-health';\nimport {\n  deterministicGraders,\n  createRegexRule,\n  createContainsRule,\n  createLengthRule,\n  createJsonSchemaRule,\n  allRulesPassed,\n  getFailedRules,\n  calculateAverageScore,\n} from './api/deterministic-graders';\nimport {\n  conversationEval,\n  aggregateWorst,\n  aggregateAverage,\n  aggregateWeighted,\n  aggregateFinalTurn,\n  aggregateMajority,\n  getAggregator,\n  getProblematicTurns,\n  analyzeConversationTrend,\n} from './api/conversation-eval';\nimport {\n  transcriptPatterns,\n  isHighRisk,\n  getMatchesByCategory,\n  getCriticalInsights,\n  hasPiiExposure,\n  hasFrustrationSignals,\n  hasEscalationRequest,\n  getCategoryDistribution,\n  getRecommendations,\n  needsAttention,\n  sortMatchesBySeverity,\n} from './api/transcript-patterns';\n\n// Agents Management\nimport {\n  agents,\n} from './api/agents';\n\n// Eval Runs\nimport { evalRuns } from './api/eval-runs';\n\n// Signals\nimport { signals } from './api/signals';\n\n// Notifications\nimport { notifications } from './api/notifications';\n\n// Documents\nimport { documents } from './api/documents';\n\n// Shadow Tests\nimport { shadowTests } from './api/shadow-tests';\n\n// Sessions\nimport { sessions } from './api/sessions';\n\n// Drift\nimport { drift, hasDrift, getDriftSeverity } from './api/drift';\n\n// LLM Costs\nimport { llmCosts, formatCost as formatLLMCost } from './api/llm-costs';\n\n// Guardrails\nimport { guardrails } from './guardrails';\n\n// API Key Management (Phase 2 Security)\nimport {\n  apiKeys,\n  hasPermission,\n  isExpired as isApiKeyExpired,\n  isValid as isApiKeyValid,\n  getTimeUntilExpiry,\n  canAccessAgent,\n} from './api/apiKeys';\n\n// ROI Analytics API\nimport {\n  roiAnalytics,\n  calculateRevenueAtRisk,\n  calculateAutomationSavings,\n  formatCurrency,\n  getROIQuality,\n} from './api/roi-analytics';\n\n// Business Metrics API\nimport {\n  businessMetrics,\n  isMetricReady,\n  needsMoreTraces,\n  awaitingExternalData,\n  isMetricStale,\n  getStatusMessage,\n  getTraceProgress,\n  formatMetricValue,\n  getTrendEmoji,\n} from './api/business-metrics';\n\n// Quality Metrics API\nimport {\n  qualityMetrics,\n  passesQualityThreshold,\n  isHallucinationRiskAcceptable,\n  getQualityRecommendations,\n  formatQualityScore,\n  getGradeColor,\n} from './api/quality-metrics';\n\n// Integrations\nimport {\n  linking,\n  generateZendeskMarker,\n  parseZendeskMarker,\n  hasZendeskMarker,\n  removeZendeskMarker,\n  linkRunToTicket,\n  linkRunToZendeskTicket,\n  getBestLinkMethod,\n  LINK_METHOD_CONFIDENCE,\n} from './integrations/ticket-linking';\nimport {\n  customerContext,\n  captureCustomerContext,\n  getContextAsOf,\n  toContextSnapshot,\n  calculateArrChange,\n  calculateHealthTrend,\n} from './integrations/customer-context';\n\n// Re-export types\nexport type {\n  InitOptions,\n  Framework,\n  RunOptions,\n  RunOutcome,\n  ConversationMessage,\n  CustomerContextSnapshot,\n  TicketLinkingOptions,\n  LinkMethod,\n  TraceOptions,\n  TraceCustomFlag,\n  SpanData,\n  BusinessContext,\n  Claim,\n  ClaimType,\n  ClaimCategory,\n  ConfidenceCalibration,\n  EvidenceReference,\n  AnalysisResult,\n  CalibrationStatus,\n  CalibrationBucket,\n  PredictionType,\n  RoiConfig,\n  RoiSummary,\n  ExplainabilityResult,\n  ApiResponse,\n  PaginatedResponse,\n  RunResponse,\n} from './core/types';\n\n// Re-export evaluation types\nexport type {\n  HumanReviewStatus,\n  HumanReviewType,\n  HumanReviewQueueItem,\n  CalibrationSet,\n  ReviewerCalibration,\n  QueueStats,\n} from './api/human-review';\n\nexport type {\n  NondeterminismRunType,\n  NondeterminismRunStatus,\n  NondeterminismRun,\n  NondeterminismSample,\n  TraceAnalysis,\n  CriterionAnalysis,\n  RunSummary,\n} from './api/nondeterminism';\n\nexport type {\n  SaturationType,\n  HealthStatus,\n  RegressionSeverity,\n  EvalHealthSnapshot,\n  EvalRegression,\n  HealthReport,\n} from './api/eval-health';\n\nexport type {\n  RuleType,\n  DeterministicEvalResult,\n  RuleResult,\n  RuleTypeInfo,\n  RuleTemplate,\n} from './api/deterministic-graders';\n\nexport type {\n  AggregateMethod,\n  SessionTrace,\n  TurnEvaluation,\n  ConversationEvalResult,\n  AggregationMethodInfo,\n} from './api/conversation-eval';\n\nexport type {\n  PatternCategory,\n  PatternOutcome,\n  PatternSeverity,\n  PatternMatch,\n  PatternInsight,\n  AnalysisResult as PatternAnalysisResult,\n  PatternCategoryInfo,\n  BuiltInPattern,\n} from './api/transcript-patterns';\n\n// Re-export API Key types (Phase 2 Security)\nexport type {\n  ApiKeyPermissions,\n  ScopeType,\n  Environment,\n  CreateApiKeyOptions,\n  ApiKey,\n  CreateApiKeyResult,\n} from './api/apiKeys';\n\n// Re-export ROI Analytics types\nexport type {\n  IndustryConfig,\n  CustomIndustryConfig,\n  ROIMetrics,\n  BusinessImpact,\n  ROISummary,\n  TrendDataPoint,\n  Correlation,\n  PatternCluster,\n  CorrelationAnalysis,\n} from './api/roi-analytics';\n\n// Re-export Quality Metrics types\nexport type {\n  RetrievedContext,\n  GroundTruthContext,\n  GroundedSpan,\n  UngroundedSpan,\n  CitationMap,\n  RAGEvaluation,\n  RAGEvidence,\n  HallucinationInstance,\n  HallucinationReport,\n  GroundednessResult,\n  BatchEvaluationResult,\n  BatchEvaluationSummary,\n} from './api/quality-metrics';\n\n// Re-export Business Metrics types\nexport type {\n  MetricTrend,\n  MetricStatus,\n  CurrentMetricResponse,\n  MetricHistoryPoint,\n  MetricHistorySummary,\n  MetricHistoryResponse,\n  RecordMetricOptions,\n  RecordMetricResponse,\n} from './api/business-metrics';\n\n// Re-export Agent types\nexport type {\n  Agent,\n  CreateAgentOptions,\n  UpdateAgentOptions,\n  AgentConfig,\n  UpdateAgentConfigOptions,\n  DeleteAgentOptions,\n  CascadeImpact,\n} from './api/agents';\n\n// Re-export Eval Runs types\nexport type {\n  CreateEvalRunOptions,\n  GetEvalRunResultsOptions,\n  ListEvalRunsOptions,\n  EstimateCostOptions,\n  GetTraceResultsOptions,\n  EvalRun,\n  EvalResult,\n  EvalCostEstimate,\n} from './api/eval-runs';\n\n// Re-export Signals types\nexport type {\n  DetectionConfig,\n  CreateSignalOptions,\n  UpdateSignalOptions,\n  ListSignalsOptions,\n  SignalStatsOptions,\n  SignalTrendsOptions,\n  SignalTracesOptions,\n  SignalEventsOptions,\n  Signal,\n  SignalStats,\n  SignalTrendPoint,\n  SignalEvent,\n} from './api/signals';\n\n// Re-export Notifications types\nexport type {\n  NotificationRule,\n  CreateNotificationRuleData,\n  UpdateNotificationRuleData,\n  Notification,\n} from './api/notifications';\n\n// Re-export Documents types\nexport type {\n  Document,\n  DocumentUploadResponse,\n} from './api/documents';\n\n// Re-export Shadow Tests types\nexport type {\n  CreateShadowTestData,\n  UpdateShadowTestData,\n  ShadowTest,\n} from './api/shadow-tests';\n\n// Re-export Sessions types\nexport type {\n  ListSessionsOptions,\n  Session,\n  SessionTrace as SessionTraceRecord,\n} from './api/sessions';\n\n// Re-export Drift types\nexport type {\n  DetectDriftOptions,\n  DriftReport,\n  DriftDimension,\n  DetectAllResult,\n} from './api/drift';\n\n// Re-export LLM Costs types\nexport type {\n  CostQueryOptions,\n  CostSummary,\n  CostBreakdownItem,\n  AgentCostBreakdown,\n  CostSavings,\n  OptimizationEntry,\n  OptimizationStats,\n  OptimizationRecommendation,\n} from './api/llm-costs';\n\n// ============================================================================\n// GLOBAL STATE\n// ============================================================================\n\nlet tracer: ReturnType<typeof trace.getTracer> | null = null;\nlet provider: NodeTracerProvider | null = null;\n\n// ============================================================================\n// INITIALIZATION\n// ============================================================================\n\n/**\n * Initialize ThinkHive SDK v3\n *\n * @example\n * ```typescript\n * import { init } from '@thinkhive/sdk';\n *\n * init({\n *   apiKey: 'th_your_api_key',\n *   serviceName: 'my-ai-agent',\n *   autoInstrument: true,\n *   frameworks: ['langchain', 'openai'],\n * });\n * ```\n */\nexport function init(options: import('./core/types').InitOptions = {}): void {\n  if (isInitialized()) {\n    debugLog('ThinkHive SDK already initialized');\n    return;\n  }\n\n  const config = initConfig(options);\n\n  // Configure OTLP exporter\n  const exporterHeaders: Record<string, string> = {};\n  if (config.apiKey) {\n    exporterHeaders['Authorization'] = `Bearer ${config.apiKey}`;\n  } else {\n    throw new Error(\n      'OTLP tracing requires an API key. Agent ID alone is not sufficient for OTLP ingestion. ' +\n      'Provide apiKey in init() or set the THINKHIVE_API_KEY environment variable.'\n    );\n  }\n\n  const otlpUrl = config.endpoint.replace(/\\/+$/, '') + '/v1/traces';\n  const exporter = new OTLPTraceExporter({\n    url: otlpUrl,\n    headers: exporterHeaders,\n  });\n\n  // Create OpenTelemetry resource\n  const resource = defaultResource().merge(\n    resourceFromAttributes({\n      'service.name': config.serviceName,\n      'thinkhive.sdk.version': SDK_VERSION,\n      'thinkhive.sdk.language': 'typescript',\n    })\n  );\n\n  // Create provider with span processor\n  provider = new NodeTracerProvider({\n    resource,\n    spanProcessors: [new BatchSpanProcessor(exporter)],\n  });\n\n  // Register provider\n  provider.register();\n\n  // Get tracer\n  tracer = trace.getTracer('thinkhive', SDK_VERSION);\n\n  if (config.debug) {\n    console.log(`✅ ThinkHive SDK v${SDK_VERSION} initialized`);\n    console.log(`   Endpoint: ${config.endpoint}`);\n    console.log(`   Service: ${config.serviceName}`);\n    console.log(`   Auto-instrument: ${config.autoInstrument}`);\n  }\n\n  // Setup auto-instrumentation if enabled\n  if (config.autoInstrument) {\n    setupAutoInstrumentation(config.frameworks);\n  }\n}\n\n/**\n * Get the global tracer\n */\nexport function getTracer() {\n  if (!tracer) {\n    throw new Error('ThinkHive SDK not initialized. Call init() first.');\n  }\n  return tracer;\n}\n\n/**\n * Shutdown the SDK and flush pending spans\n */\nexport async function shutdown(): Promise<void> {\n  if (provider) {\n    await provider.shutdown();\n    provider = null;\n  }\n  tracer = null;\n  resetConfig();\n  debugLog('ThinkHive SDK shutdown complete');\n}\n\n// ============================================================================\n// TRACING FUNCTIONS\n// ============================================================================\n\n/**\n * Trace an LLM call\n */\nexport function traceLLM<T>(\n  options: {\n    name: string;\n    modelName?: string;\n    provider?: string;\n    input?: unknown;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.name,\n    {\n      attributes: {\n        'openinference.span.kind': 'LLM',\n        'llm.model_name': options.modelName,\n        'llm.provider': options.provider,\n        'input.value': options.input ? JSON.stringify(options.input).substring(0, 10000) : undefined,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        span.setAttribute('output.value', JSON.stringify(result).substring(0, 10000));\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute('duration_ms', Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n/**\n * Trace a retrieval operation\n */\nexport function traceRetrieval<T>(\n  options: {\n    name: string;\n    query?: string;\n    topK?: number;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.name,\n    {\n      attributes: {\n        'openinference.span.kind': 'RETRIEVER',\n        'retrieval.query': options.query,\n        'retrieval.top_k': options.topK,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        if (Array.isArray(result)) {\n          span.setAttribute('retrieval.document_count', result.length);\n        }\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute('duration_ms', Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n/**\n * Trace a tool call\n */\nexport function traceTool<T>(\n  options: {\n    name: string;\n    toolName?: string;\n    parameters?: Record<string, unknown>;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.toolName || options.name,\n    {\n      attributes: {\n        'openinference.span.kind': 'TOOL',\n        'tool.name': options.toolName || options.name,\n        'tool.parameters': options.parameters ? JSON.stringify(options.parameters) : undefined,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        span.setAttribute('tool.output', JSON.stringify(result).substring(0, 10000));\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute('duration_ms', Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n/**\n * Trace a chain/workflow\n */\nexport function traceChain<T>(\n  options: {\n    name: string;\n    input?: unknown;\n  },\n  fn: () => Promise<T>\n): Promise<T> {\n  const t = getTracer();\n\n  return t.startActiveSpan(\n    options.name,\n    {\n      attributes: {\n        'openinference.span.kind': 'CHAIN',\n        'input.value': options.input ? JSON.stringify(options.input).substring(0, 10000) : undefined,\n      },\n    },\n    async (span) => {\n      const startTime = Date.now();\n      try {\n        const result = await fn();\n        span.setAttribute('output.value', JSON.stringify(result).substring(0, 10000));\n        span.setStatus({ code: SpanStatusCode.OK });\n        return result;\n      } catch (error: unknown) {\n        const message = error instanceof Error ? error.message : String(error);\n        span.setStatus({ code: SpanStatusCode.ERROR, message });\n        span.recordException(error as Error);\n        throw error;\n      } finally {\n        span.setAttribute('duration_ms', Date.now() - startTime);\n        span.end();\n      }\n    }\n  );\n}\n\n// ============================================================================\n// V2 TERMINOLOGY - ISSUES API (replaces Cases)\n// Per ITIL best practices, \"Issues\" is more customer-friendly than \"Cases\"\n// ============================================================================\n\n/**\n * Issues API client\n * This is the recommended API for managing clustered failure patterns\n *\n * @since 3.1.0\n */\nexport const issues = {\n  /**\n   * List issues for an agent\n   */\n  async list(agentId: string, options?: {\n    status?: string;\n    startDate?: Date;\n    endDate?: Date;\n    limit?: number;\n    offset?: number;\n  }): Promise<any[]> {\n    const params = new URLSearchParams({ agentId });\n    if (options?.status) params.set('status', options.status);\n    if (options?.startDate) params.set('startDate', options.startDate.toISOString());\n    if (options?.endDate) params.set('endDate', options.endDate.toISOString());\n    if (options?.limit) params.set('limit', options.limit.toString());\n    if (options?.offset) params.set('offset', options.offset.toString());\n\n    const response = await apiRequestWithData(`/issues?${params}`, { apiVersion: 'v2' });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Get a single issue by ID\n   */\n  async get(id: string): Promise<any> {\n    const response = await apiRequestWithData(`/issues/${id}`, { apiVersion: 'v2' });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Create a new issue\n   */\n  async create(data: {\n    agentId: string;\n    title: string;\n    description?: string;\n    type: string;\n    severity?: string;\n    pattern?: string;\n    exampleTraceIds?: string[];\n  }): Promise<any> {\n    const response = await apiRequestWithData('/issues', {\n      method: 'POST',\n      body: data,\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Update an issue\n   */\n  async update(id: string, data: {\n    title?: string;\n    description?: string;\n    status?: string;\n    severity?: string;\n    assignedTo?: string;\n    resolutionNotes?: string;\n  }): Promise<any> {\n    const response = await apiRequestWithData(`/issues/${id}`, {\n      method: 'PATCH',\n      body: data,\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Get fixes for an issue\n   */\n  async getFixes(issueId: string): Promise<any[]> {\n    const response = await apiRequestWithData(`/issues/${issueId}/fixes`, { apiVersion: 'v2' });\n    return (response as any).data || response;\n  },\n};\n\n\n// ============================================================================\n// V2 TERMINOLOGY - ANALYZER API (replaces Explainer user-facing)\n// Per industry distinction: Analyzer = pattern detection/observation\n// ============================================================================\n\n/**\n * Analyzer API client\n * User-selected trace analysis with cost estimation and smart sampling\n *\n * Key improvements over v1 Explainer:\n * - User-selected trace analysis (not automatic)\n * - Cost estimation before execution\n * - Smart sampling strategies\n * - Root cause analysis by layer\n * - Pattern aggregation across traces\n *\n * @since 3.1.0\n */\nexport const analyzer = {\n  /**\n   * Analyze specific traces (user-selected)\n   */\n  async analyze(options: {\n    traceIds: string[];\n    tier?: 'fast' | 'standard' | 'deep';\n    includeRootCause?: boolean;\n    includeLayers?: boolean;\n  }): Promise<any> {\n    const { traceIds, tier, includeRootCause, includeLayers } = options;\n    const response = await apiRequestWithData('/analyzer/analyze', {\n      method: 'POST',\n      body: {\n        traceIds,\n        options: {\n          tier,\n          includeRootCause,\n          includeLayers,\n        },\n      },\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Analyze traces by time window\n   */\n  async analyzeWindow(options: {\n    agentId: string;\n    startDate: Date;\n    endDate: Date;\n    filters?: {\n      outcomes?: ('failure' | 'error' | 'success')[];\n      minSeverity?: 'low' | 'medium' | 'high' | 'critical';\n    };\n    sampling?: {\n      strategy: 'all' | 'failures_only' | 'smart' | 'random';\n      samplePercent?: number;\n    };\n  }): Promise<any> {\n    const response = await apiRequestWithData('/analyzer/analyze-window', {\n      method: 'POST',\n      body: {\n        ...options,\n        startDate: options.startDate.toISOString(),\n        endDate: options.endDate.toISOString(),\n      },\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Estimate cost before running analysis\n   */\n  async estimateCost(options: {\n    traceIds?: string[];\n    agentId?: string;\n    startDate?: Date;\n    endDate?: Date;\n    tier: 'fast' | 'standard' | 'deep';\n  }): Promise<{\n    estimatedTraces: number;\n    estimatedTokens: number;\n    estimatedCost: number;\n    estimatedCredits: number;\n    tier: string;\n    note: string;\n  }> {\n    const response = await apiRequestWithData('/analyzer/estimate-cost', {\n      method: 'POST',\n      body: {\n        ...options,\n        startDate: options.startDate?.toISOString(),\n        endDate: options.endDate?.toISOString(),\n      },\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Get analysis results for a specific trace\n   */\n  async get(traceId: string): Promise<any> {\n    const response = await apiRequestWithData(`/analyzer/${traceId}`, { apiVersion: 'v2' });\n    return (response as any).data || response;\n  },\n\n  /**\n   * Aggregate insights across multiple analyzed traces\n   */\n  async summarize(options: {\n    analysisIds?: string[];\n    agentId?: string;\n    startDate?: Date;\n    endDate?: Date;\n  }): Promise<any> {\n    const response = await apiRequestWithData('/analyzer/summarize', {\n      method: 'POST',\n      body: {\n        ...options,\n        startDate: options.startDate?.toISOString(),\n        endDate: options.endDate?.toISOString(),\n      },\n      apiVersion: 'v2',\n    });\n    return (response as any).data || response;\n  },\n};\n\n\n// ============================================================================\n// AUTO-INSTRUMENTATION\n// ============================================================================\n\nfunction setupAutoInstrumentation(\n  frameworks: import('./core/types').Framework[]\n): void {\n  debugLog(`Setting up auto-instrumentation for: ${frameworks.join(', ')}`);\n\n  for (const framework of frameworks) {\n    try {\n      switch (framework) {\n        case 'openai':\n        case 'openai-assistants':\n          debugLog('OpenAI instrumentation ready (use instrumentOpenAIClient)');\n          break;\n        case 'langchain':\n        case 'langgraph':\n          debugLog('LangChain/LangGraph instrumentation ready (use ThinkHiveCallbackHandler)');\n          break;\n        case 'anthropic':\n          debugLog('Anthropic instrumentation ready');\n          break;\n        case 'llamaindex':\n          debugLog('LlamaIndex instrumentation ready');\n          break;\n        case 'n8n':\n          debugLog('n8n instrumentation ready');\n          break;\n        case 'voiceflow':\n          debugLog('Voiceflow instrumentation ready');\n          break;\n      }\n    } catch (error) {\n      debugLog(`Failed to setup ${framework} instrumentation:`, error);\n    }\n  }\n}\n\n// ============================================================================\n// RE-EXPORTS (non-duplicated)\n// ============================================================================\n\n// Re-export from config (not yet exported)\nexport { isInitialized, SDK_VERSION, DEFAULT_ENDPOINT };\n\n// Re-export API clients (v3)\nexport {\n  runs,\n  claims,\n  calibration,\n  linking,\n  customerContext,\n  // New evaluation APIs\n  humanReview,\n  nondeterminism,\n  evalHealth,\n  deterministicGraders,\n  conversationEval,\n  transcriptPatterns,\n  // API Key Management (Phase 2 Security)\n  apiKeys,\n  // Agents Management\n  agents,\n  // ROI Analytics, Quality Metrics, and Business Metrics\n  roiAnalytics,\n  qualityMetrics,\n  businessMetrics,\n  // Eval Runs, Signals, Notifications, Documents, Shadow Tests, Sessions, Drift, LLM Costs\n  evalRuns,\n  signals,\n  notifications,\n  documents,\n  shadowTests,\n  sessions,\n  drift,\n  llmCosts,\n  // Guardrails\n  guardrails,\n};\n\n// Note: issues, analyzer, and guardrails are already exported via 'export const' above\n\n// Re-export helper functions\nexport {\n  // Runs helpers\n  createRunWithContext,\n  toOpenAIMessages,\n  fromOpenAIMessages,\n  // Claims helpers\n  isFact,\n  isInference,\n  isComputed,\n  getHighConfidenceClaims,\n  groupClaimsByType,\n  groupClaimsByCategory,\n  // Calibration helpers\n  calculateBrierScore,\n  calculateECE,\n  isWellCalibrated,\n  getCalibrationQuality,\n  // Linking helpers\n  generateZendeskMarker,\n  parseZendeskMarker,\n  hasZendeskMarker,\n  removeZendeskMarker,\n  linkRunToTicket,\n  linkRunToZendeskTicket,\n  getBestLinkMethod,\n  LINK_METHOD_CONFIDENCE,\n  // Customer context helpers\n  captureCustomerContext,\n  getContextAsOf,\n  toContextSnapshot,\n  calculateArrChange,\n  calculateHealthTrend,\n  // Non-determinism helpers\n  calculatePassAtK,\n  calculatePassToK,\n  requiredPassRateForPassAtK,\n  isReliableEvaluation,\n  getReliabilityRecommendation,\n  // Eval health helpers\n  hasHealthIssue,\n  getHealthSeverityLevel,\n  isSaturated,\n  getSaturationRecommendation,\n  // Deterministic graders helpers\n  createRegexRule,\n  createContainsRule,\n  createLengthRule,\n  createJsonSchemaRule,\n  allRulesPassed,\n  getFailedRules,\n  calculateAverageScore,\n  // Conversation eval helpers\n  aggregateWorst,\n  aggregateAverage,\n  aggregateWeighted,\n  aggregateFinalTurn,\n  aggregateMajority,\n  getAggregator,\n  getProblematicTurns,\n  analyzeConversationTrend,\n  // Transcript patterns helpers\n  isHighRisk,\n  getMatchesByCategory,\n  getCriticalInsights,\n  hasPiiExposure,\n  hasFrustrationSignals,\n  hasEscalationRequest,\n  getCategoryDistribution,\n  getRecommendations,\n  needsAttention,\n  sortMatchesBySeverity,\n  // API Key helpers\n  hasPermission,\n  isApiKeyExpired,\n  isApiKeyValid,\n  getTimeUntilExpiry,\n  canAccessAgent,\n  // ROI Analytics helpers\n  calculateRevenueAtRisk,\n  calculateAutomationSavings,\n  formatCurrency,\n  getROIQuality,\n  // Quality Metrics helpers\n  passesQualityThreshold,\n  isHallucinationRiskAcceptable,\n  getQualityRecommendations,\n  formatQualityScore,\n  getGradeColor,\n  // Business Metrics helpers\n  isMetricReady,\n  needsMoreTraces,\n  awaitingExternalData,\n  isMetricStale,\n  getStatusMessage,\n  getTraceProgress,\n  formatMetricValue,\n  getTrendEmoji,\n  // Drift helpers\n  hasDrift,\n  getDriftSeverity,\n  // LLM Costs helpers\n  formatLLMCost,\n};\n\n// Re-export Guardrails\nexport { type ScanRequest, type ScanResponse, type Finding, type ScannerResult } from './guardrails';\n\n// Re-export errors (including new security errors)\nexport {\n  ThinkHiveError,\n  ThinkHiveApiError,\n  ThinkHiveValidationError,\n  PermissionDeniedError,\n  AgentScopeError,\n  RateLimitError,\n  IpWhitelistError,\n};\n\n// Default export for convenience\nexport default {\n  init,\n  getTracer,\n  shutdown,\n  isInitialized,\n  // Tracing\n  traceLLM,\n  traceRetrieval,\n  traceTool,\n  traceChain,\n  // API clients\n  runs,\n  claims,\n  calibration,\n  linking,\n  customerContext,\n  // Evaluation APIs\n  humanReview,\n  nondeterminism,\n  evalHealth,\n  deterministicGraders,\n  conversationEval,\n  transcriptPatterns,\n  // API Key Management (Phase 2 Security)\n  apiKeys,\n  // Agents Management\n  agents,\n  // Issues and Analyzer APIs\n  issues,\n  analyzer,\n  // ROI Analytics, Quality Metrics, and Business Metrics\n  roiAnalytics,\n  qualityMetrics,\n  businessMetrics,\n  // Eval Runs, Signals, Notifications, Documents, Shadow Tests, Sessions, Drift, LLM Costs\n  evalRuns,\n  signals,\n  notifications,\n  documents,\n  shadowTests,\n  sessions,\n  drift,\n  llmCosts,\n  // Guardrails\n  guardrails,\n  // Helpers\n  generateZendeskMarker,\n  parseZendeskMarker,\n  linkRunToTicket,\n  createRunWithContext,\n  // Utilities\n  isFact,\n  isInference,\n  calculateBrierScore,\n  isWellCalibrated,\n  calculatePassAtK,\n  isReliableEvaluation,\n  isHighRisk,\n  needsAttention,\n  // ROI helpers\n  calculateRevenueAtRisk,\n  formatCurrency,\n  // Quality helpers\n  passesQualityThreshold,\n  isHallucinationRiskAcceptable,\n  // Business Metrics helpers\n  isMetricReady,\n  needsMoreTraces,\n  getStatusMessage,\n  // Drift helpers\n  hasDrift,\n  getDriftSeverity,\n  // LLM Costs helpers\n  formatLLMCost,\n};\n"]}
|
|
@@ -151,6 +151,8 @@ export declare const customerContext: {
|
|
|
151
151
|
* ```
|
|
152
152
|
*/
|
|
153
153
|
getSnapshotAsOf(customerId: string, timestamp: string | Date): Promise<CustomerMetricsSnapshot | null>;
|
|
154
|
+
/** Alias for captureSnapshot() */
|
|
155
|
+
capture(customerId: string, metrics: Record<string, unknown>): Promise<CustomerContextSnapshot>;
|
|
154
156
|
};
|
|
155
157
|
/**
|
|
156
158
|
* Create a CustomerContextSnapshot from a metrics snapshot
|
|
@@ -173,6 +173,10 @@ exports.customerContext = {
|
|
|
173
173
|
throw error;
|
|
174
174
|
}
|
|
175
175
|
},
|
|
176
|
+
/** Alias for captureSnapshot() */
|
|
177
|
+
async capture(customerId, metrics) {
|
|
178
|
+
return this.captureSnapshot(customerId, metrics);
|
|
179
|
+
},
|
|
176
180
|
};
|
|
177
181
|
// ============================================================================
|
|
178
182
|
// HELPER FUNCTIONS
|
|
@@ -271,4 +275,4 @@ function calculateHealthTrend(snapshots) {
|
|
|
271
275
|
volatility,
|
|
272
276
|
};
|
|
273
277
|
}
|
|
274
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"customer-context.js","sourceRoot":"","sources":["../../src/integrations/customer-context.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Customer Context\n *\n * Time-series customer metrics snapshots\n * Captures ARR, health score, segment AS OF the run time (not current values)\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\nimport type { CustomerContextSnapshot } from '../core/types';\n\n// ============================================================================\n// CUSTOMER ACCOUNT TYPES\n// ============================================================================\n\nexport interface CustomerAccount {\n  id: string;\n  companyId: string;\n  externalId?: string;\n  externalSource?: 'salesforce' | 'hubspot' | 'zendesk' | 'intercom' | 'custom';\n  name: string;\n  domain?: string;\n  segment?: string;\n  industry?: string;\n  employeeCount?: number;\n  createdAt: string;\n  updatedAt: string;\n}\n\nexport interface CustomerMetricsSnapshot {\n  id: string;\n  customerAccountId: string;\n  arr?: number;\n  healthScore?: number;\n  nps?: number;\n  segment?: string;\n  churnRisk?: 'low' | 'medium' | 'high';\n  capturedAt: string;\n  source?: string;\n  createdAt: string;\n}\n\n// ============================================================================\n// CUSTOMER CONTEXT API\n// ============================================================================\n\n/**\n * Customer context API client for time-series metrics\n */\nexport const customerContext = {\n  /**\n   * Create a customer account\n   *\n   * @example\n   * ```typescript\n   * const account = await customerContext.createAccount({\n   *   name: 'Acme Corp',\n   *   externalId: 'sf_001234',\n   *   externalSource: 'salesforce',\n   *   segment: 'enterprise',\n   * });\n   * ```\n   */\n  async createAccount(input: {\n    name: string;\n    externalId?: string;\n    externalSource?: CustomerAccount['externalSource'];\n    domain?: string;\n    segment?: string;\n    industry?: string;\n    employeeCount?: number;\n  }): Promise<CustomerAccount> {\n    return apiRequestWithData<CustomerAccount>('/customers', {\n      method: 'POST',\n      body: input,\n    });\n  },\n\n  /**\n   * Get a customer account by ID\n   *\n   * @example\n   * ```typescript\n   * const account = await customerContext.getAccount('cust_abc123');\n   * ```\n   */\n  async getAccount(customerId: string): Promise<CustomerAccount> {\n    return apiRequestWithData<CustomerAccount>(`/customers/${customerId}`);\n  },\n\n  /**\n   * Get a customer account by external ID\n   *\n   * @example\n   * ```typescript\n   * const account = await customerContext.getAccountByExternalId(\n   *   'sf_001234',\n   *   'salesforce'\n   * );\n   * ```\n   */\n  async getAccountByExternalId(\n    externalId: string,\n    source: CustomerAccount['externalSource']\n  ): Promise<CustomerAccount | null> {\n    try {\n      return await apiRequestWithData<CustomerAccount>(\n        `/customers/external/${source}/${externalId}`\n      );\n    } catch (error) {\n      if ((error as any)?.statusCode === 404) {\n        return null;\n      }\n      throw error;\n    }\n  },\n\n  /**\n   * Capture a metrics snapshot for a customer\n   * This creates a point-in-time record of the customer's metrics\n   *\n   * @example\n   * ```typescript\n   * // Capture current metrics\n   * const snapshot = await customerContext.captureSnapshot('cust_abc123', {\n   *   arr: 120000,\n   *   healthScore: 85,\n   *   nps: 45,\n   *   segment: 'enterprise',\n   * });\n   *\n   * // Use this snapshot in a run\n   * const run = await runs.create({\n   *   agentId: 'agent_123',\n   *   customerContext: {\n   *     customerId: 'cust_abc123',\n   *     arr: snapshot.arr,\n   *     healthScore: snapshot.healthScore,\n   *     capturedAt: snapshot.capturedAt,\n   *   },\n   *   // ...\n   * });\n   * ```\n   */\n  async captureSnapshot(\n    customerId: string,\n    metrics: {\n      arr?: number;\n      healthScore?: number;\n      nps?: number;\n      segment?: string;\n      churnRisk?: 'low' | 'medium' | 'high';\n      source?: string;\n    }\n  ): Promise<CustomerMetricsSnapshot> {\n    return apiRequestWithData<CustomerMetricsSnapshot>(\n      `/customers/${customerId}/snapshots`,\n      {\n        method: 'POST',\n        body: {\n          ...metrics,\n          capturedAt: new Date().toISOString(),\n        },\n      }\n    );\n  },\n\n  /**\n   * Get metrics snapshots for a customer (time-series)\n   *\n   * @example\n   * ```typescript\n   * // Get last 30 days of snapshots\n   * const snapshots = await customerContext.getSnapshots('cust_abc123', {\n   *   from: new Date(Date.now() - 30 * 24 * 60 * 60 * 1000).toISOString(),\n   * });\n   * ```\n   */\n  async getSnapshots(\n    customerId: string,\n    options: {\n      from?: string;\n      to?: string;\n      limit?: number;\n    } = {}\n  ): Promise<CustomerMetricsSnapshot[]> {\n    const params = new URLSearchParams();\n    if (options.from) params.set('from', options.from);\n    if (options.to) params.set('to', options.to);\n    if (options.limit) params.set('limit', String(options.limit));\n\n    return apiRequestWithData<CustomerMetricsSnapshot[]>(\n      `/customers/${customerId}/snapshots?${params.toString()}`\n    );\n  },\n\n  /**\n   * Get the most recent snapshot for a customer\n   *\n   * @example\n   * ```typescript\n   * const latest = await customerContext.getLatestSnapshot('cust_abc123');\n   * ```\n   */\n  async getLatestSnapshot(\n    customerId: string\n  ): Promise<CustomerMetricsSnapshot | null> {\n    try {\n      return await apiRequestWithData<CustomerMetricsSnapshot>(\n        `/customers/${customerId}/snapshots/latest`\n      );\n    } catch (error) {\n      if ((error as any)?.statusCode === 404) {\n        return null;\n      }\n      throw error;\n    }\n  },\n\n  /**\n   * Get snapshot closest to a specific timestamp\n   * Useful for retroactive analysis\n   *\n   * @example\n   * ```typescript\n   * // Get metrics as of a specific date\n   * const snapshot = await customerContext.getSnapshotAsOf(\n   *   'cust_abc123',\n   *   '2024-01-15T10:00:00Z'\n   * );\n   * ```\n   */\n  async getSnapshotAsOf(\n    customerId: string,\n    timestamp: string | Date\n  ): Promise<CustomerMetricsSnapshot | null> {\n    const ts = new Date(timestamp).toISOString();\n    try {\n      return await apiRequestWithData<CustomerMetricsSnapshot>(\n        `/customers/${customerId}/snapshots/as-of?timestamp=${encodeURIComponent(ts)}`\n      );\n    } catch (error) {\n      if ((error as any)?.statusCode === 404) {\n        return null;\n      }\n      throw error;\n    }\n  },\n};\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Create a CustomerContextSnapshot from a metrics snapshot\n */\nexport function toContextSnapshot(\n  snapshot: CustomerMetricsSnapshot\n): CustomerContextSnapshot {\n  return {\n    customerId: snapshot.customerAccountId,\n    arr: snapshot.arr,\n    healthScore: snapshot.healthScore,\n    segment: snapshot.segment,\n    capturedAt: snapshot.capturedAt,\n  };\n}\n\n/**\n * Capture metrics and create context snapshot in one call\n *\n * @example\n * ```typescript\n * const context = await captureCustomerContext('cust_abc123', {\n *   arr: 100000,\n *   healthScore: 90,\n *   segment: 'enterprise',\n * });\n *\n * // Use in run\n * const run = await runs.create({\n *   agentId: 'agent_123',\n *   customerContext: context,\n *   // ...\n * });\n * ```\n */\nexport async function captureCustomerContext(\n  customerId: string,\n  metrics: {\n    arr?: number;\n    healthScore?: number;\n    segment?: string;\n  }\n): Promise<CustomerContextSnapshot> {\n  const snapshot = await customerContext.captureSnapshot(customerId, metrics);\n  return toContextSnapshot(snapshot);\n}\n\n/**\n * Get customer context as of a specific time\n */\nexport async function getContextAsOf(\n  customerId: string,\n  timestamp: string | Date\n): Promise<CustomerContextSnapshot | null> {\n  const snapshot = await customerContext.getSnapshotAsOf(customerId, timestamp);\n  return snapshot ? toContextSnapshot(snapshot) : null;\n}\n\n/**\n * Calculate ARR change between two snapshots\n */\nexport function calculateArrChange(\n  older: CustomerMetricsSnapshot,\n  newer: CustomerMetricsSnapshot\n): {\n  absolute: number;\n  percentage: number;\n  direction: 'increase' | 'decrease' | 'stable';\n} {\n  const oldArr = older.arr || 0;\n  const newArr = newer.arr || 0;\n  const absolute = newArr - oldArr;\n  const percentage = oldArr > 0 ? (absolute / oldArr) * 100 : 0;\n\n  return {\n    absolute,\n    percentage,\n    direction: absolute > 0 ? 'increase' : absolute < 0 ? 'decrease' : 'stable',\n  };\n}\n\n/**\n * Calculate health score trend\n */\nexport function calculateHealthTrend(\n  snapshots: CustomerMetricsSnapshot[]\n): {\n  currentScore: number | null;\n  avgScore: number | null;\n  trend: 'improving' | 'declining' | 'stable';\n  volatility: 'low' | 'medium' | 'high';\n} {\n  const scores = snapshots\n    .filter((s) => s.healthScore !== undefined && s.healthScore !== null)\n    .map((s) => s.healthScore!);\n\n  if (scores.length === 0) {\n    return {\n      currentScore: null,\n      avgScore: null,\n      trend: 'stable',\n      volatility: 'low',\n    };\n  }\n\n  const currentScore = scores[0];\n  const avgScore = scores.reduce((a, b) => a + b, 0) / scores.length;\n\n  // Calculate trend (simple linear regression direction)\n  let trend: 'improving' | 'declining' | 'stable' = 'stable';\n  if (scores.length >= 2) {\n    const recentAvg = scores.slice(0, Math.ceil(scores.length / 2)).reduce((a, b) => a + b, 0) / Math.ceil(scores.length / 2);\n    const olderAvg = scores.slice(Math.ceil(scores.length / 2)).reduce((a, b) => a + b, 0) / Math.floor(scores.length / 2);\n    if (recentAvg - olderAvg > 5) trend = 'improving';\n    else if (olderAvg - recentAvg > 5) trend = 'declining';\n  }\n\n  // Calculate volatility (standard deviation)\n  const variance = scores.reduce((acc, s) => acc + Math.pow(s - avgScore, 2), 0) / scores.length;\n  const stdDev = Math.sqrt(variance);\n  const volatility = stdDev < 5 ? 'low' : stdDev < 15 ? 'medium' : 'high';\n\n  return {\n    currentScore,\n    avgScore,\n    trend,\n    volatility,\n  };\n}\n"]}
|
|
278
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"customer-context.js","sourceRoot":"","sources":["../../src/integrations/customer-context.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;AAgQH,8CAUC;AAqBD,wDAUC;AAKD,wCAMC;AAKD,gDAkBC;AAKD,oDA4CC;AA1XD,2CAAgE;AAkChE,+EAA+E;AAC/E,uBAAuB;AACvB,+EAA+E;AAE/E;;GAEG;AACU,QAAA,eAAe,GAAG;IAC7B;;;;;;;;;;;;OAYG;IACH,KAAK,CAAC,aAAa,CAAC,KAQnB;QACC,OAAO,IAAA,2BAAkB,EAAkB,YAAY,EAAE;YACvD,MAAM,EAAE,MAAM;YACd,IAAI,EAAE,KAAK;SACZ,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,UAAU,CAAC,UAAkB;QACjC,OAAO,IAAA,2BAAkB,EAAkB,cAAc,UAAU,EAAE,CAAC,CAAC;IACzE,CAAC;IAED;;;;;;;;;;OAUG;IACH,KAAK,CAAC,sBAAsB,CAC1B,UAAkB,EAClB,MAAyC;QAEzC,IAAI,CAAC;YACH,OAAO,MAAM,IAAA,2BAAkB,EAC7B,uBAAuB,MAAM,IAAI,UAAU,EAAE,CAC9C,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAK,KAAa,EAAE,UAAU,KAAK,GAAG,EAAE,CAAC;gBACvC,OAAO,IAAI,CAAC;YACd,CAAC;YACD,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;OA0BG;IACH,KAAK,CAAC,eAAe,CACnB,UAAkB,EAClB,OAOC;QAED,OAAO,IAAA,2BAAkB,EACvB,cAAc,UAAU,YAAY,EACpC;YACE,MAAM,EAAE,MAAM;YACd,IAAI,EAAE;gBACJ,GAAG,OAAO;gBACV,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;aACrC;SACF,CACF,CAAC;IACJ,CAAC;IAED;;;;;;;;;;OAUG;IACH,KAAK,CAAC,YAAY,CAChB,UAAkB,EAClB,UAII,EAAE;QAEN,MAAM,MAAM,GAAG,IAAI,eAAe,EAAE,CAAC;QACrC,IAAI,OAAO,CAAC,IAAI;YAAE,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;QACnD,IAAI,OAAO,CAAC,EAAE;YAAE,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,EAAE,CAAC,CAAC;QAC7C,IAAI,OAAO,CAAC,KAAK;YAAE,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;QAE9D,OAAO,IAAA,2BAAkB,EACvB,cAAc,UAAU,cAAc,MAAM,CAAC,QAAQ,EAAE,EAAE,CAC1D,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,iBAAiB,CACrB,UAAkB;QAElB,IAAI,CAAC;YACH,OAAO,MAAM,IAAA,2BAAkB,EAC7B,cAAc,UAAU,mBAAmB,CAC5C,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAK,KAAa,EAAE,UAAU,KAAK,GAAG,EAAE,CAAC;gBACvC,OAAO,IAAI,CAAC;YACd,CAAC;YACD,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,KAAK,CAAC,eAAe,CACnB,UAAkB,EAClB,SAAwB;QAExB,MAAM,EAAE,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;QAC7C,IAAI,CAAC;YACH,OAAO,MAAM,IAAA,2BAAkB,EAC7B,cAAc,UAAU,8BAA8B,kBAAkB,CAAC,EAAE,CAAC,EAAE,CAC/E,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAK,KAAa,EAAE,UAAU,KAAK,GAAG,EAAE,CAAC;gBACvC,OAAO,IAAI,CAAC;YACd,CAAC;YACD,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAED,kCAAkC;IAClC,KAAK,CAAC,OAAO,CAAC,UAAkB,EAAE,OAAgC;QAChE,OAAO,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;IACnD,CAAC;CACF,CAAC;AAEF,+EAA+E;AAC/E,mBAAmB;AACnB,+EAA+E;AAE/E;;GAEG;AACH,SAAgB,iBAAiB,CAC/B,QAAiC;IAEjC,OAAO;QACL,UAAU,EAAE,QAAQ,CAAC,iBAAiB;QACtC,GAAG,EAAE,QAAQ,CAAC,GAAG;QACjB,WAAW,EAAE,QAAQ,CAAC,WAAW;QACjC,OAAO,EAAE,QAAQ,CAAC,OAAO;QACzB,UAAU,EAAE,QAAQ,CAAC,UAAU;KAChC,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;;;;;;;GAkBG;AACI,KAAK,UAAU,sBAAsB,CAC1C,UAAkB,EAClB,OAIC;IAED,MAAM,QAAQ,GAAG,MAAM,uBAAe,CAAC,eAAe,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;IAC5E,OAAO,iBAAiB,CAAC,QAAQ,CAAC,CAAC;AACrC,CAAC;AAED;;GAEG;AACI,KAAK,UAAU,cAAc,CAClC,UAAkB,EAClB,SAAwB;IAExB,MAAM,QAAQ,GAAG,MAAM,uBAAe,CAAC,eAAe,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;IAC9E,OAAO,QAAQ,CAAC,CAAC,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;AACvD,CAAC;AAED;;GAEG;AACH,SAAgB,kBAAkB,CAChC,KAA8B,EAC9B,KAA8B;IAM9B,MAAM,MAAM,GAAG,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;IAC9B,MAAM,MAAM,GAAG,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;IAC9B,MAAM,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAC;IACjC,MAAM,UAAU,GAAG,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,MAAM,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAE9D,OAAO;QACL,QAAQ;QACR,UAAU;QACV,SAAS,EAAE,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ;KAC5E,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,oBAAoB,CAClC,SAAoC;IAOpC,MAAM,MAAM,GAAG,SAAS;SACrB,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,SAAS,IAAI,CAAC,CAAC,WAAW,KAAK,IAAI,CAAC;SACpE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAY,CAAC,CAAC;IAE9B,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACxB,OAAO;YACL,YAAY,EAAE,IAAI;YAClB,QAAQ,EAAE,IAAI;YACd,KAAK,EAAE,QAAQ;YACf,UAAU,EAAE,KAAK;SAClB,CAAC;IACJ,CAAC;IAED,MAAM,YAAY,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;IAC/B,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC;IAEnE,uDAAuD;IACvD,IAAI,KAAK,GAAyC,QAAQ,CAAC;IAC3D,IAAI,MAAM,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;QACvB,MAAM,SAAS,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAC1H,MAAM,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACvH,IAAI,SAAS,GAAG,QAAQ,GAAG,CAAC;YAAE,KAAK,GAAG,WAAW,CAAC;aAC7C,IAAI,QAAQ,GAAG,SAAS,GAAG,CAAC;YAAE,KAAK,GAAG,WAAW,CAAC;IACzD,CAAC;IAED,4CAA4C;IAC5C,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC;IAC/F,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACnC,MAAM,UAAU,GAAG,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC;IAExE,OAAO;QACL,YAAY;QACZ,QAAQ;QACR,KAAK;QACL,UAAU;KACX,CAAC;AACJ,CAAC","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Customer Context\n *\n * Time-series customer metrics snapshots\n * Captures ARR, health score, segment AS OF the run time (not current values)\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\nimport type { CustomerContextSnapshot } from '../core/types';\n\n// ============================================================================\n// CUSTOMER ACCOUNT TYPES\n// ============================================================================\n\nexport interface CustomerAccount {\n  id: string;\n  companyId: string;\n  externalId?: string;\n  externalSource?: 'salesforce' | 'hubspot' | 'zendesk' | 'intercom' | 'custom';\n  name: string;\n  domain?: string;\n  segment?: string;\n  industry?: string;\n  employeeCount?: number;\n  createdAt: string;\n  updatedAt: string;\n}\n\nexport interface CustomerMetricsSnapshot {\n  id: string;\n  customerAccountId: string;\n  arr?: number;\n  healthScore?: number;\n  nps?: number;\n  segment?: string;\n  churnRisk?: 'low' | 'medium' | 'high';\n  capturedAt: string;\n  source?: string;\n  createdAt: string;\n}\n\n// ============================================================================\n// CUSTOMER CONTEXT API\n// ============================================================================\n\n/**\n * Customer context API client for time-series metrics\n */\nexport const customerContext = {\n  /**\n   * Create a customer account\n   *\n   * @example\n   * ```typescript\n   * const account = await customerContext.createAccount({\n   *   name: 'Acme Corp',\n   *   externalId: 'sf_001234',\n   *   externalSource: 'salesforce',\n   *   segment: 'enterprise',\n   * });\n   * ```\n   */\n  async createAccount(input: {\n    name: string;\n    externalId?: string;\n    externalSource?: CustomerAccount['externalSource'];\n    domain?: string;\n    segment?: string;\n    industry?: string;\n    employeeCount?: number;\n  }): Promise<CustomerAccount> {\n    return apiRequestWithData<CustomerAccount>('/customers', {\n      method: 'POST',\n      body: input,\n    });\n  },\n\n  /**\n   * Get a customer account by ID\n   *\n   * @example\n   * ```typescript\n   * const account = await customerContext.getAccount('cust_abc123');\n   * ```\n   */\n  async getAccount(customerId: string): Promise<CustomerAccount> {\n    return apiRequestWithData<CustomerAccount>(`/customers/${customerId}`);\n  },\n\n  /**\n   * Get a customer account by external ID\n   *\n   * @example\n   * ```typescript\n   * const account = await customerContext.getAccountByExternalId(\n   *   'sf_001234',\n   *   'salesforce'\n   * );\n   * ```\n   */\n  async getAccountByExternalId(\n    externalId: string,\n    source: CustomerAccount['externalSource']\n  ): Promise<CustomerAccount | null> {\n    try {\n      return await apiRequestWithData<CustomerAccount>(\n        `/customers/external/${source}/${externalId}`\n      );\n    } catch (error) {\n      if ((error as any)?.statusCode === 404) {\n        return null;\n      }\n      throw error;\n    }\n  },\n\n  /**\n   * Capture a metrics snapshot for a customer\n   * This creates a point-in-time record of the customer's metrics\n   *\n   * @example\n   * ```typescript\n   * // Capture current metrics\n   * const snapshot = await customerContext.captureSnapshot('cust_abc123', {\n   *   arr: 120000,\n   *   healthScore: 85,\n   *   nps: 45,\n   *   segment: 'enterprise',\n   * });\n   *\n   * // Use this snapshot in a run\n   * const run = await runs.create({\n   *   agentId: 'agent_123',\n   *   customerContext: {\n   *     customerId: 'cust_abc123',\n   *     arr: snapshot.arr,\n   *     healthScore: snapshot.healthScore,\n   *     capturedAt: snapshot.capturedAt,\n   *   },\n   *   // ...\n   * });\n   * ```\n   */\n  async captureSnapshot(\n    customerId: string,\n    metrics: {\n      arr?: number;\n      healthScore?: number;\n      nps?: number;\n      segment?: string;\n      churnRisk?: 'low' | 'medium' | 'high';\n      source?: string;\n    }\n  ): Promise<CustomerMetricsSnapshot> {\n    return apiRequestWithData<CustomerMetricsSnapshot>(\n      `/customers/${customerId}/snapshots`,\n      {\n        method: 'POST',\n        body: {\n          ...metrics,\n          capturedAt: new Date().toISOString(),\n        },\n      }\n    );\n  },\n\n  /**\n   * Get metrics snapshots for a customer (time-series)\n   *\n   * @example\n   * ```typescript\n   * // Get last 30 days of snapshots\n   * const snapshots = await customerContext.getSnapshots('cust_abc123', {\n   *   from: new Date(Date.now() - 30 * 24 * 60 * 60 * 1000).toISOString(),\n   * });\n   * ```\n   */\n  async getSnapshots(\n    customerId: string,\n    options: {\n      from?: string;\n      to?: string;\n      limit?: number;\n    } = {}\n  ): Promise<CustomerMetricsSnapshot[]> {\n    const params = new URLSearchParams();\n    if (options.from) params.set('from', options.from);\n    if (options.to) params.set('to', options.to);\n    if (options.limit) params.set('limit', String(options.limit));\n\n    return apiRequestWithData<CustomerMetricsSnapshot[]>(\n      `/customers/${customerId}/snapshots?${params.toString()}`\n    );\n  },\n\n  /**\n   * Get the most recent snapshot for a customer\n   *\n   * @example\n   * ```typescript\n   * const latest = await customerContext.getLatestSnapshot('cust_abc123');\n   * ```\n   */\n  async getLatestSnapshot(\n    customerId: string\n  ): Promise<CustomerMetricsSnapshot | null> {\n    try {\n      return await apiRequestWithData<CustomerMetricsSnapshot>(\n        `/customers/${customerId}/snapshots/latest`\n      );\n    } catch (error) {\n      if ((error as any)?.statusCode === 404) {\n        return null;\n      }\n      throw error;\n    }\n  },\n\n  /**\n   * Get snapshot closest to a specific timestamp\n   * Useful for retroactive analysis\n   *\n   * @example\n   * ```typescript\n   * // Get metrics as of a specific date\n   * const snapshot = await customerContext.getSnapshotAsOf(\n   *   'cust_abc123',\n   *   '2024-01-15T10:00:00Z'\n   * );\n   * ```\n   */\n  async getSnapshotAsOf(\n    customerId: string,\n    timestamp: string | Date\n  ): Promise<CustomerMetricsSnapshot | null> {\n    const ts = new Date(timestamp).toISOString();\n    try {\n      return await apiRequestWithData<CustomerMetricsSnapshot>(\n        `/customers/${customerId}/snapshots/as-of?timestamp=${encodeURIComponent(ts)}`\n      );\n    } catch (error) {\n      if ((error as any)?.statusCode === 404) {\n        return null;\n      }\n      throw error;\n    }\n  },\n\n  /** Alias for captureSnapshot() */\n  async capture(customerId: string, metrics: Record<string, unknown>): Promise<CustomerContextSnapshot> {\n    return this.captureSnapshot(customerId, metrics);\n  },\n};\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Create a CustomerContextSnapshot from a metrics snapshot\n */\nexport function toContextSnapshot(\n  snapshot: CustomerMetricsSnapshot\n): CustomerContextSnapshot {\n  return {\n    customerId: snapshot.customerAccountId,\n    arr: snapshot.arr,\n    healthScore: snapshot.healthScore,\n    segment: snapshot.segment,\n    capturedAt: snapshot.capturedAt,\n  };\n}\n\n/**\n * Capture metrics and create context snapshot in one call\n *\n * @example\n * ```typescript\n * const context = await captureCustomerContext('cust_abc123', {\n *   arr: 100000,\n *   healthScore: 90,\n *   segment: 'enterprise',\n * });\n *\n * // Use in run\n * const run = await runs.create({\n *   agentId: 'agent_123',\n *   customerContext: context,\n *   // ...\n * });\n * ```\n */\nexport async function captureCustomerContext(\n  customerId: string,\n  metrics: {\n    arr?: number;\n    healthScore?: number;\n    segment?: string;\n  }\n): Promise<CustomerContextSnapshot> {\n  const snapshot = await customerContext.captureSnapshot(customerId, metrics);\n  return toContextSnapshot(snapshot);\n}\n\n/**\n * Get customer context as of a specific time\n */\nexport async function getContextAsOf(\n  customerId: string,\n  timestamp: string | Date\n): Promise<CustomerContextSnapshot | null> {\n  const snapshot = await customerContext.getSnapshotAsOf(customerId, timestamp);\n  return snapshot ? toContextSnapshot(snapshot) : null;\n}\n\n/**\n * Calculate ARR change between two snapshots\n */\nexport function calculateArrChange(\n  older: CustomerMetricsSnapshot,\n  newer: CustomerMetricsSnapshot\n): {\n  absolute: number;\n  percentage: number;\n  direction: 'increase' | 'decrease' | 'stable';\n} {\n  const oldArr = older.arr || 0;\n  const newArr = newer.arr || 0;\n  const absolute = newArr - oldArr;\n  const percentage = oldArr > 0 ? (absolute / oldArr) * 100 : 0;\n\n  return {\n    absolute,\n    percentage,\n    direction: absolute > 0 ? 'increase' : absolute < 0 ? 'decrease' : 'stable',\n  };\n}\n\n/**\n * Calculate health score trend\n */\nexport function calculateHealthTrend(\n  snapshots: CustomerMetricsSnapshot[]\n): {\n  currentScore: number | null;\n  avgScore: number | null;\n  trend: 'improving' | 'declining' | 'stable';\n  volatility: 'low' | 'medium' | 'high';\n} {\n  const scores = snapshots\n    .filter((s) => s.healthScore !== undefined && s.healthScore !== null)\n    .map((s) => s.healthScore!);\n\n  if (scores.length === 0) {\n    return {\n      currentScore: null,\n      avgScore: null,\n      trend: 'stable',\n      volatility: 'low',\n    };\n  }\n\n  const currentScore = scores[0];\n  const avgScore = scores.reduce((a, b) => a + b, 0) / scores.length;\n\n  // Calculate trend (simple linear regression direction)\n  let trend: 'improving' | 'declining' | 'stable' = 'stable';\n  if (scores.length >= 2) {\n    const recentAvg = scores.slice(0, Math.ceil(scores.length / 2)).reduce((a, b) => a + b, 0) / Math.ceil(scores.length / 2);\n    const olderAvg = scores.slice(Math.ceil(scores.length / 2)).reduce((a, b) => a + b, 0) / Math.floor(scores.length / 2);\n    if (recentAvg - olderAvg > 5) trend = 'improving';\n    else if (olderAvg - recentAvg > 5) trend = 'declining';\n  }\n\n  // Calculate volatility (standard deviation)\n  const variance = scores.reduce((acc, s) => acc + Math.pow(s - avgScore, 2), 0) / scores.length;\n  const stdDev = Math.sqrt(variance);\n  const volatility = stdDev < 5 ? 'low' : stdDev < 15 ? 'medium' : 'high';\n\n  return {\n    currentScore,\n    avgScore,\n    trend,\n    volatility,\n  };\n}\n"]}
|