@thinkhive/sdk 4.2.1 → 4.2.3

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.
@@ -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.1.0";
5
+ export declare const SDK_VERSION = "4.2.3";
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 {
@@ -12,7 +12,7 @@ exports.debugLog = debugLog;
12
12
  // ============================================================================
13
13
  // CONSTANTS
14
14
  // ============================================================================
15
- exports.SDK_VERSION = '4.1.0';
15
+ exports.SDK_VERSION = '4.2.3';
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvcmUvY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7R0FFRzs7O0FBb0NILGdDQXNCQztBQU1ELDhCQUtDO0FBS0Qsc0NBRUM7QUFLRCxrQ0FHQztBQUtELDRCQUlDO0FBekZELCtFQUErRTtBQUMvRSxZQUFZO0FBQ1osK0VBQStFO0FBRWxFLFFBQUEsV0FBVyxHQUFHLE9BQU8sQ0FBQztBQUN0QixRQUFBLGdCQUFnQixHQUFHLDBCQUEwQixDQUFDO0FBQzlDLFFBQUEsb0JBQW9CLEdBQUcsYUFBYSxDQUFDO0FBZ0JsRCxJQUFJLE1BQU0sR0FBMEIsSUFBSSxDQUFDO0FBQ3pDLElBQUksV0FBVyxHQUFHLEtBQUssQ0FBQztBQUV4QiwrRUFBK0U7QUFDL0UsbUJBQW1CO0FBQ25CLCtFQUErRTtBQUUvRTs7R0FFRztBQUNILFNBQWdCLFVBQVUsQ0FBQyxVQUF1QixFQUFFO0lBQ2xELE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxNQUFNLElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsSUFBSSxFQUFFLENBQUM7SUFDckUsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLE9BQU8sSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQixJQUFJLEVBQUUsQ0FBQztJQUV4RSxJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDeEIsTUFBTSxJQUFJLEtBQUssQ0FDYiw4RUFBOEUsQ0FDL0UsQ0FBQztJQUNKLENBQUM7SUFFRCxNQUFNLEdBQUc7UUFDUCxNQUFNO1FBQ04sT0FBTztRQUNQLFFBQVEsRUFBRSxPQUFPLENBQUMsUUFBUSxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCLElBQUksd0JBQWdCO1FBQ2hGLFdBQVcsRUFBRSxPQUFPLENBQUMsV0FBVyxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsc0JBQXNCLElBQUksNEJBQW9CO1FBQzlGLGNBQWMsRUFBRSxPQUFPLENBQUMsY0FBYyxJQUFJLEtBQUs7UUFDL0MsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVLElBQUksQ0FBQyxXQUFXLEVBQUUsUUFBUSxDQUFDO1FBQ3pELEtBQUssRUFBRSxPQUFPLENBQUMsS0FBSyxJQUFJLEtBQUs7S0FDOUIsQ0FBQztJQUVGLFdBQVcsR0FBRyxJQUFJLENBQUM7SUFDbkIsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVEOzs7R0FHRztBQUNILFNBQWdCLFNBQVM7SUFDdkIsSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQzVCLE1BQU0sSUFBSSxLQUFLLENBQUMsbURBQW1ELENBQUMsQ0FBQztJQUN2RSxDQUFDO0lBQ0QsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVEOztHQUVHO0FBQ0gsU0FBZ0IsYUFBYTtJQUMzQixPQUFPLFdBQVcsQ0FBQztBQUNyQixDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixXQUFXO0lBQ3pCLE1BQU0sR0FBRyxJQUFJLENBQUM7SUFDZCxXQUFXLEdBQUcsS0FBSyxDQUFDO0FBQ3RCLENBQUM7QUFFRDs7R0FFRztBQUNILFNBQWdCLFFBQVEsQ0FBQyxHQUFHLElBQWU7SUFDekMsSUFBSSxNQUFNLEVBQUUsS0FBSyxFQUFFLENBQUM7UUFDbEIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztJQUN0QyxDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVGhpbmtIaXZlIFNESyB2My4wIC0gQ29uZmlndXJhdGlvblxuICovXG5cbmltcG9ydCB0eXBlIHsgSW5pdE9wdGlvbnMsIEZyYW1ld29yayB9IGZyb20gJy4vdHlwZXMnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBDT05TVEFOVFNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGNvbnN0IFNES19WRVJTSU9OID0gJzQuMS4wJztcbmV4cG9ydCBjb25zdCBERUZBVUxUX0VORFBPSU5UID0gJ2h0dHBzOi8vYXBwLnRoaW5raGl2ZS5haSc7XG5leHBvcnQgY29uc3QgREVGQVVMVF9TRVJWSUNFX05BTUUgPSAnbXktYWktYWdlbnQnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBHTE9CQUwgQ09ORklHIFNUQVRFXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb2x2ZWRDb25maWcge1xuICBhcGlLZXk6IHN0cmluZztcbiAgYWdlbnRJZDogc3RyaW5nO1xuICBlbmRwb2ludDogc3RyaW5nO1xuICBzZXJ2aWNlTmFtZTogc3RyaW5nO1xuICBhdXRvSW5zdHJ1bWVudDogYm9vbGVhbjtcbiAgZnJhbWV3b3JrczogRnJhbWV3b3JrW107XG4gIGRlYnVnOiBib29sZWFuO1xufVxuXG5sZXQgY29uZmlnOiBSZXNvbHZlZENvbmZpZyB8IG51bGwgPSBudWxsO1xubGV0IGluaXRpYWxpemVkID0gZmFsc2U7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIENPTkZJRyBGVU5DVElPTlNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBJbml0aWFsaXplIGNvbmZpZ3VyYXRpb24gZnJvbSBvcHRpb25zXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpbml0Q29uZmlnKG9wdGlvbnM6IEluaXRPcHRpb25zID0ge30pOiBSZXNvbHZlZENvbmZpZyB7XG4gIGNvbnN0IGFwaUtleSA9IG9wdGlvbnMuYXBpS2V5IHx8IHByb2Nlc3MuZW52LlRISU5LSElWRV9BUElfS0VZIHx8ICcnO1xuICBjb25zdCBhZ2VudElkID0gb3B0aW9ucy5hZ2VudElkIHx8IHByb2Nlc3MuZW52LlRISU5LSElWRV9BR0VOVF9JRCB8fCAnJztcblxuICBpZiAoIWFwaUtleSAmJiAhYWdlbnRJZCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICdFaXRoZXIgYXBpS2V5IG9yIGFnZW50SWQgbXVzdCBiZSBwcm92aWRlZCAob3Igc2V0IFRISU5LSElWRV9BUElfS0VZIGVudiB2YXIpJ1xuICAgICk7XG4gIH1cblxuICBjb25maWcgPSB7XG4gICAgYXBpS2V5LFxuICAgIGFnZW50SWQsXG4gICAgZW5kcG9pbnQ6IG9wdGlvbnMuZW5kcG9pbnQgfHwgcHJvY2Vzcy5lbnYuVEhJTktISVZFX0VORFBPSU5UIHx8IERFRkFVTFRfRU5EUE9JTlQsXG4gICAgc2VydmljZU5hbWU6IG9wdGlvbnMuc2VydmljZU5hbWUgfHwgcHJvY2Vzcy5lbnYuVEhJTktISVZFX1NFUlZJQ0VfTkFNRSB8fCBERUZBVUxUX1NFUlZJQ0VfTkFNRSxcbiAgICBhdXRvSW5zdHJ1bWVudDogb3B0aW9ucy5hdXRvSW5zdHJ1bWVudCA/PyBmYWxzZSxcbiAgICBmcmFtZXdvcmtzOiBvcHRpb25zLmZyYW1ld29ya3MgfHwgWydsYW5nY2hhaW4nLCAnb3BlbmFpJ10sXG4gICAgZGVidWc6IG9wdGlvbnMuZGVidWcgPz8gZmFsc2UsXG4gIH07XG5cbiAgaW5pdGlhbGl6ZWQgPSB0cnVlO1xuICByZXR1cm4gY29uZmlnO1xufVxuXG4vKipcbiAqIEdldCBjdXJyZW50IGNvbmZpZ3VyYXRpb25cbiAqIEB0aHJvd3MgaWYgbm90IGluaXRpYWxpemVkXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRDb25maWcoKTogUmVzb2x2ZWRDb25maWcge1xuICBpZiAoIWNvbmZpZyB8fCAhaW5pdGlhbGl6ZWQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1RoaW5rSGl2ZSBTREsgbm90IGluaXRpYWxpemVkLiBDYWxsIGluaXQoKSBmaXJzdC4nKTtcbiAgfVxuICByZXR1cm4gY29uZmlnO1xufVxuXG4vKipcbiAqIENoZWNrIGlmIFNESyBpcyBpbml0aWFsaXplZFxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNJbml0aWFsaXplZCgpOiBib29sZWFuIHtcbiAgcmV0dXJuIGluaXRpYWxpemVkO1xufVxuXG4vKipcbiAqIFJlc2V0IGNvbmZpZ3VyYXRpb24gKGZvciB0ZXN0aW5nKVxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVzZXRDb25maWcoKTogdm9pZCB7XG4gIGNvbmZpZyA9IG51bGw7XG4gIGluaXRpYWxpemVkID0gZmFsc2U7XG59XG5cbi8qKlxuICogRGVidWcgbG9nIGhlbHBlclxuICovXG5leHBvcnQgZnVuY3Rpb24gZGVidWdMb2coLi4uYXJnczogdW5rbm93bltdKTogdm9pZCB7XG4gIGlmIChjb25maWc/LmRlYnVnKSB7XG4gICAgY29uc29sZS5sb2coJ1tUaGlua0hpdmVdJywgLi4uYXJncyk7XG4gIH1cbn1cbiJdfQ==
75
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvcmUvY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7R0FFRzs7O0FBb0NILGdDQXNCQztBQU1ELDhCQUtDO0FBS0Qsc0NBRUM7QUFLRCxrQ0FHQztBQUtELDRCQUlDO0FBekZELCtFQUErRTtBQUMvRSxZQUFZO0FBQ1osK0VBQStFO0FBRWxFLFFBQUEsV0FBVyxHQUFHLE9BQU8sQ0FBQztBQUN0QixRQUFBLGdCQUFnQixHQUFHLDBCQUEwQixDQUFDO0FBQzlDLFFBQUEsb0JBQW9CLEdBQUcsYUFBYSxDQUFDO0FBZ0JsRCxJQUFJLE1BQU0sR0FBMEIsSUFBSSxDQUFDO0FBQ3pDLElBQUksV0FBVyxHQUFHLEtBQUssQ0FBQztBQUV4QiwrRUFBK0U7QUFDL0UsbUJBQW1CO0FBQ25CLCtFQUErRTtBQUUvRTs7R0FFRztBQUNILFNBQWdCLFVBQVUsQ0FBQyxVQUF1QixFQUFFO0lBQ2xELE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxNQUFNLElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsSUFBSSxFQUFFLENBQUM7SUFDckUsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLE9BQU8sSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQixJQUFJLEVBQUUsQ0FBQztJQUV4RSxJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDeEIsTUFBTSxJQUFJLEtBQUssQ0FDYiw4RUFBOEUsQ0FDL0UsQ0FBQztJQUNKLENBQUM7SUFFRCxNQUFNLEdBQUc7UUFDUCxNQUFNO1FBQ04sT0FBTztRQUNQLFFBQVEsRUFBRSxPQUFPLENBQUMsUUFBUSxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCLElBQUksd0JBQWdCO1FBQ2hGLFdBQVcsRUFBRSxPQUFPLENBQUMsV0FBVyxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsc0JBQXNCLElBQUksNEJBQW9CO1FBQzlGLGNBQWMsRUFBRSxPQUFPLENBQUMsY0FBYyxJQUFJLEtBQUs7UUFDL0MsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVLElBQUksQ0FBQyxXQUFXLEVBQUUsUUFBUSxDQUFDO1FBQ3pELEtBQUssRUFBRSxPQUFPLENBQUMsS0FBSyxJQUFJLEtBQUs7S0FDOUIsQ0FBQztJQUVGLFdBQVcsR0FBRyxJQUFJLENBQUM7SUFDbkIsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVEOzs7R0FHRztBQUNILFNBQWdCLFNBQVM7SUFDdkIsSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQzVCLE1BQU0sSUFBSSxLQUFLLENBQUMsbURBQW1ELENBQUMsQ0FBQztJQUN2RSxDQUFDO0lBQ0QsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVEOztHQUVHO0FBQ0gsU0FBZ0IsYUFBYTtJQUMzQixPQUFPLFdBQVcsQ0FBQztBQUNyQixDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixXQUFXO0lBQ3pCLE1BQU0sR0FBRyxJQUFJLENBQUM7SUFDZCxXQUFXLEdBQUcsS0FBSyxDQUFDO0FBQ3RCLENBQUM7QUFFRDs7R0FFRztBQUNILFNBQWdCLFFBQVEsQ0FBQyxHQUFHLElBQWU7SUFDekMsSUFBSSxNQUFNLEVBQUUsS0FBSyxFQUFFLENBQUM7UUFDbEIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztJQUN0QyxDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVGhpbmtIaXZlIFNESyB2My4wIC0gQ29uZmlndXJhdGlvblxuICovXG5cbmltcG9ydCB0eXBlIHsgSW5pdE9wdGlvbnMsIEZyYW1ld29yayB9IGZyb20gJy4vdHlwZXMnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBDT05TVEFOVFNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGNvbnN0IFNES19WRVJTSU9OID0gJzQuMi4zJztcbmV4cG9ydCBjb25zdCBERUZBVUxUX0VORFBPSU5UID0gJ2h0dHBzOi8vYXBwLnRoaW5raGl2ZS5haSc7XG5leHBvcnQgY29uc3QgREVGQVVMVF9TRVJWSUNFX05BTUUgPSAnbXktYWktYWdlbnQnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBHTE9CQUwgQ09ORklHIFNUQVRFXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb2x2ZWRDb25maWcge1xuICBhcGlLZXk6IHN0cmluZztcbiAgYWdlbnRJZDogc3RyaW5nO1xuICBlbmRwb2ludDogc3RyaW5nO1xuICBzZXJ2aWNlTmFtZTogc3RyaW5nO1xuICBhdXRvSW5zdHJ1bWVudDogYm9vbGVhbjtcbiAgZnJhbWV3b3JrczogRnJhbWV3b3JrW107XG4gIGRlYnVnOiBib29sZWFuO1xufVxuXG5sZXQgY29uZmlnOiBSZXNvbHZlZENvbmZpZyB8IG51bGwgPSBudWxsO1xubGV0IGluaXRpYWxpemVkID0gZmFsc2U7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIENPTkZJRyBGVU5DVElPTlNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBJbml0aWFsaXplIGNvbmZpZ3VyYXRpb24gZnJvbSBvcHRpb25zXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpbml0Q29uZmlnKG9wdGlvbnM6IEluaXRPcHRpb25zID0ge30pOiBSZXNvbHZlZENvbmZpZyB7XG4gIGNvbnN0IGFwaUtleSA9IG9wdGlvbnMuYXBpS2V5IHx8IHByb2Nlc3MuZW52LlRISU5LSElWRV9BUElfS0VZIHx8ICcnO1xuICBjb25zdCBhZ2VudElkID0gb3B0aW9ucy5hZ2VudElkIHx8IHByb2Nlc3MuZW52LlRISU5LSElWRV9BR0VOVF9JRCB8fCAnJztcblxuICBpZiAoIWFwaUtleSAmJiAhYWdlbnRJZCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICdFaXRoZXIgYXBpS2V5IG9yIGFnZW50SWQgbXVzdCBiZSBwcm92aWRlZCAob3Igc2V0IFRISU5LSElWRV9BUElfS0VZIGVudiB2YXIpJ1xuICAgICk7XG4gIH1cblxuICBjb25maWcgPSB7XG4gICAgYXBpS2V5LFxuICAgIGFnZW50SWQsXG4gICAgZW5kcG9pbnQ6IG9wdGlvbnMuZW5kcG9pbnQgfHwgcHJvY2Vzcy5lbnYuVEhJTktISVZFX0VORFBPSU5UIHx8IERFRkFVTFRfRU5EUE9JTlQsXG4gICAgc2VydmljZU5hbWU6IG9wdGlvbnMuc2VydmljZU5hbWUgfHwgcHJvY2Vzcy5lbnYuVEhJTktISVZFX1NFUlZJQ0VfTkFNRSB8fCBERUZBVUxUX1NFUlZJQ0VfTkFNRSxcbiAgICBhdXRvSW5zdHJ1bWVudDogb3B0aW9ucy5hdXRvSW5zdHJ1bWVudCA/PyBmYWxzZSxcbiAgICBmcmFtZXdvcmtzOiBvcHRpb25zLmZyYW1ld29ya3MgfHwgWydsYW5nY2hhaW4nLCAnb3BlbmFpJ10sXG4gICAgZGVidWc6IG9wdGlvbnMuZGVidWcgPz8gZmFsc2UsXG4gIH07XG5cbiAgaW5pdGlhbGl6ZWQgPSB0cnVlO1xuICByZXR1cm4gY29uZmlnO1xufVxuXG4vKipcbiAqIEdldCBjdXJyZW50IGNvbmZpZ3VyYXRpb25cbiAqIEB0aHJvd3MgaWYgbm90IGluaXRpYWxpemVkXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRDb25maWcoKTogUmVzb2x2ZWRDb25maWcge1xuICBpZiAoIWNvbmZpZyB8fCAhaW5pdGlhbGl6ZWQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1RoaW5rSGl2ZSBTREsgbm90IGluaXRpYWxpemVkLiBDYWxsIGluaXQoKSBmaXJzdC4nKTtcbiAgfVxuICByZXR1cm4gY29uZmlnO1xufVxuXG4vKipcbiAqIENoZWNrIGlmIFNESyBpcyBpbml0aWFsaXplZFxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNJbml0aWFsaXplZCgpOiBib29sZWFuIHtcbiAgcmV0dXJuIGluaXRpYWxpemVkO1xufVxuXG4vKipcbiAqIFJlc2V0IGNvbmZpZ3VyYXRpb24gKGZvciB0ZXN0aW5nKVxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVzZXRDb25maWcoKTogdm9pZCB7XG4gIGNvbmZpZyA9IG51bGw7XG4gIGluaXRpYWxpemVkID0gZmFsc2U7XG59XG5cbi8qKlxuICogRGVidWcgbG9nIGhlbHBlclxuICovXG5leHBvcnQgZnVuY3Rpb24gZGVidWdMb2coLi4uYXJnczogdW5rbm93bltdKTogdm9pZCB7XG4gIGlmIChjb25maWc/LmRlYnVnKSB7XG4gICAgY29uc29sZS5sb2coJ1tUaGlua0hpdmVdJywgLi4uYXJncyk7XG4gIH1cbn1cbiJdfQ==
@@ -67,4 +67,6 @@ export declare const guardrails: {
67
67
  name: string;
68
68
  description: string;
69
69
  }>>;
70
+ /** Alias for scan() */
71
+ evaluate(request: ScanRequest): Promise<ScanResponse>;
70
72
  };
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3VhcmRyYWlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9ndWFyZHJhaWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7O0dBR0c7OztBQUVILDBDQUFtRDtBQW9EbkQ7OztHQUdHO0FBQ1UsUUFBQSxVQUFVLEdBQUc7SUFDeEI7O09BRUc7SUFDSCxLQUFLLENBQUMsSUFBSSxDQUFDLE9BQW9CO1FBQzdCLE9BQU8sSUFBQSwyQkFBa0IsRUFBZSxxQkFBcUIsRUFBRTtZQUM3RCxNQUFNLEVBQUUsTUFBTTtZQUNkLElBQUksRUFBRSxPQUFPO1lBQ2IsT0FBTyxFQUFFLElBQUk7U0FDZCxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxLQUFLLENBQUMsWUFBWTtRQUNoQixNQUFNLE1BQU0sR0FBRyxNQUFNLElBQUEsMkJBQWtCLEVBQTZELHlCQUF5QixFQUFFO1lBQzdILE9BQU8sRUFBRSxJQUFJO1NBQ2QsQ0FBQyxDQUFDO1FBQ0gsT0FBTyxNQUFNLENBQUMsUUFBUSxDQUFDO0lBQ3pCLENBQUM7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBUaGlua0hpdmUgR3VhcmRyYWlscyBTREsgTW9kdWxlXG4gKiBSZWFsLXRpbWUgY29udGVudCBzY2FubmluZyB1c2luZyBjZW50cmFsaXplZCBTREsgY29uZmlndXJhdGlvblxuICovXG5cbmltcG9ydCB7IGFwaVJlcXVlc3RXaXRoRGF0YSB9IGZyb20gJy4vY29yZS9jbGllbnQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNjYW5SZXF1ZXN0IHtcbiAgaW5wdXQ/OiBzdHJpbmc7XG4gIG91dHB1dD86IHN0cmluZztcbiAgdG9vbENhbGw/OiB7IG5hbWU6IHN0cmluZzsgYXJndW1lbnRzOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiB9O1xuICBzY2FubmVycz86IHN0cmluZ1tdO1xuICBwb2xpY3lJZD86IHN0cmluZztcbiAgY29uZmlnPzogUmVjb3JkPHN0cmluZywgUmVjb3JkPHN0cmluZywgdW5rbm93bj4+O1xuICBvcHRpb25zPzoge1xuICAgIHRpbWVvdXQ/OiBudW1iZXI7XG4gICAgZmFpbE9wZW4/OiBib29sZWFuO1xuICAgIHNob3J0Q2lyY3VpdD86IGJvb2xlYW47XG4gICAgcmV0dXJuUmVkYWN0ZWQ/OiBib29sZWFuO1xuICB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZpbmRpbmcge1xuICB0eXBlOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIHN0YXJ0OiBudW1iZXI7XG4gIGVuZDogbnVtYmVyO1xuICBjb25maWRlbmNlOiBudW1iZXI7XG4gIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2Nhbm5lclJlc3VsdCB7XG4gIHNjYW5uZXI6IHN0cmluZztcbiAgc3RhdHVzOiAnY29tcGxldGVkJyB8ICd0aW1lb3V0JyB8ICdlcnJvcic7XG4gIGFjdGlvbjogJ3Bhc3MnIHwgJ2Jsb2NrJyB8ICdyZWRhY3QnIHwgJ2ZsYWcnO1xuICBmaW5kaW5nczogRmluZGluZ1tdO1xuICBsYXRlbmN5TXM6IG51bWJlcjtcbiAgc2FuaXRpemVkQ29udGVudD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTY2FuUmVzcG9uc2Uge1xuICBhY3Rpb246ICdwYXNzJyB8ICdibG9jaycgfCAncmVkYWN0JyB8ICdmbGFnJztcbiAgYWN0aW9uUmVhc29uPzogc3RyaW5nO1xuICByZWRhY3RlZElucHV0Pzogc3RyaW5nO1xuICByZWRhY3RlZE91dHB1dD86IHN0cmluZztcbiAgcmVzdWx0czogUmVjb3JkPHN0cmluZywgU2Nhbm5lclJlc3VsdD47XG4gIG1ldGFkYXRhOiB7XG4gICAgc2NhbklkOiBzdHJpbmc7XG4gICAgdG90YWxMYXRlbmN5TXM6IG51bWJlcjtcbiAgICBzY2FubmVyc0V4ZWN1dGVkOiBudW1iZXI7XG4gICAgc2Nhbm5lcnNCbG9ja2VkOiBudW1iZXI7XG4gICAgc2Nhbm5lcnNGbGFnZ2VkOiBudW1iZXI7XG4gICAgc2Nhbm5lcnNUaW1lZE91dDogbnVtYmVyO1xuICAgIGNhY2hlZDogYm9vbGVhbjtcbiAgfTtcbn1cblxuLyoqXG4gKiBHdWFyZHJhaWxzIEFQSSBjbGllbnRcbiAqIFJlYWwtdGltZSBjb250ZW50IHNjYW5uaW5nIGZvciBQSUksIHNlY3JldHMsIGtleXdvcmRzLCBhbmQgbW9yZVxuICovXG5leHBvcnQgY29uc3QgZ3VhcmRyYWlscyA9IHtcbiAgLyoqXG4gICAqIFNjYW4gY29udGVudCBmb3IgcG9saWN5IHZpb2xhdGlvbnNcbiAgICovXG4gIGFzeW5jIHNjYW4ocmVxdWVzdDogU2NhblJlcXVlc3QpOiBQcm9taXNlPFNjYW5SZXNwb25zZT4ge1xuICAgIHJldHVybiBhcGlSZXF1ZXN0V2l0aERhdGE8U2NhblJlc3BvbnNlPignL3YxL2d1YXJkcmFpbHMvc2NhbicsIHtcbiAgICAgIG1ldGhvZDogJ1BPU1QnLFxuICAgICAgYm9keTogcmVxdWVzdCxcbiAgICAgIHJhd1BhdGg6IHRydWUsXG4gICAgfSk7XG4gIH0sXG5cbiAgLyoqXG4gICAqIExpc3QgYXZhaWxhYmxlIHNjYW5uZXJzXG4gICAqL1xuICBhc3luYyBsaXN0U2Nhbm5lcnMoKTogUHJvbWlzZTxBcnJheTx7IG5hbWU6IHN0cmluZzsgZGVzY3JpcHRpb246IHN0cmluZyB9Pj4ge1xuICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IGFwaVJlcXVlc3RXaXRoRGF0YTx7IHNjYW5uZXJzOiBBcnJheTx7IG5hbWU6IHN0cmluZzsgZGVzY3JpcHRpb246IHN0cmluZyB9PiB9PignL3YxL2d1YXJkcmFpbHMvc2Nhbm5lcnMnLCB7XG4gICAgICByYXdQYXRoOiB0cnVlLFxuICAgIH0pO1xuICAgIHJldHVybiByZXN1bHQuc2Nhbm5lcnM7XG4gIH0sXG59O1xuIl19
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[]>;
@@ -764,6 +765,16 @@ declare const _default: {
764
765
  summary: import("./api/quality-metrics").BatchEvaluationSummary;
765
766
  results: import("./api/quality-metrics").BatchEvaluationResult[];
766
767
  }>;
768
+ evaluate(input: {
769
+ query: string;
770
+ response: string;
771
+ retrievedContexts: import("./api/quality-metrics").RetrievedContext[];
772
+ groundTruthContexts?: import("./api/quality-metrics").GroundTruthContext[];
773
+ citations?: string[];
774
+ }): Promise<{
775
+ evaluation: import("./api/quality-metrics").RAGEvaluation;
776
+ evidence: import("./api/quality-metrics").RAGEvidence;
777
+ }>;
767
778
  };
768
779
  businessMetrics: {
769
780
  current(agentId: string, metricName?: string): Promise<import("./api/business-metrics").CurrentMetricResponse>;
@@ -794,6 +805,7 @@ declare const _default: {
794
805
  create(name: string, group: string, detectionConfig: import("./api/signals").DetectionConfig, opts?: import("./api/signals").CreateSignalOptions): Promise<import("./api/signals").Signal>;
795
806
  update(id: string, opts: import("./api/signals").UpdateSignalOptions): Promise<import("./api/signals").Signal>;
796
807
  remove(id: string): Promise<void>;
808
+ delete(id: string): Promise<void>;
797
809
  seedDefaults(): Promise<import("./api/signals").Signal[]>;
798
810
  getStats(opts?: import("./api/signals").SignalStatsOptions): Promise<import("./api/signals").SignalStats[]>;
799
811
  getTrends(opts?: import("./api/signals").SignalTrendsOptions): Promise<import("./api/signals").SignalTrendPoint[]>;
@@ -818,6 +830,7 @@ declare const _default: {
818
830
  deleteRule(id: string): Promise<void>;
819
831
  listNotifications(agentId: string, unreadOnly?: boolean): Promise<import("./api/notifications").Notification[]>;
820
832
  markAsRead(id: string): Promise<import("./api/notifications").Notification>;
833
+ list(agentId: string, unreadOnly?: boolean): Promise<import("./api/notifications").Notification[]>;
821
834
  };
822
835
  documents: {
823
836
  list(agentId: string): Promise<import("./api/documents").Document[]>;
@@ -849,6 +862,7 @@ declare const _default: {
849
862
  getBreakdown(agentId: string, opts?: import("./api/llm-costs").CostQueryOptions): Promise<import("./api/llm-costs").AgentCostBreakdown>;
850
863
  getSavings(): Promise<import("./api/llm-costs").CostSavings>;
851
864
  getOptimizationStats(): Promise<import("./api/llm-costs").OptimizationStats>;
865
+ summary(opts?: import("./api/llm-costs").CostQueryOptions): Promise<import("./api/llm-costs").CostSummary>;
852
866
  };
853
867
  guardrails: {
854
868
  scan(request: import("./guardrails").ScanRequest): Promise<import("./guardrails").ScanResponse>;
@@ -856,6 +870,7 @@ declare const _default: {
856
870
  name: string;
857
871
  description: string;
858
872
  }>>;
873
+ evaluate(request: import("./guardrails").ScanRequest): Promise<import("./guardrails").ScanResponse>;
859
874
  };
860
875
  generateZendeskMarker: typeof generateZendeskMarker;
861
876
  parseZendeskMarker: typeof parseZendeskMarker;
@@ -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":"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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  /** 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"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@thinkhive/sdk",
3
- "version": "4.2.1",
3
+ "version": "4.2.3",
4
4
  "description": "ThinkHive SDK v4.0 - AI agent observability with business metrics, ROI analytics, and 25+ trace format support",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",