@thinkhive/sdk 4.2.3 → 4.2.5
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/dist/api/calibration.js +2 -2
- package/dist/api/claims.d.ts +3 -3
- package/dist/api/claims.js +8 -3
- package/dist/api/signals.js +14 -3
- package/dist/core/config.d.ts +1 -1
- package/dist/core/config.js +2 -2
- package/dist/core/types.d.ts +3 -3
- package/dist/core/types.js +1 -1
- package/dist/index.d.ts +5 -1
- package/dist/index.js +2 -2
- package/package.json +12 -12
package/dist/api/calibration.js
CHANGED
|
@@ -27,7 +27,7 @@ exports.calibration = {
|
|
|
27
27
|
* ```
|
|
28
28
|
*/
|
|
29
29
|
async status(agentId, predictionType) {
|
|
30
|
-
return (0, client_1.
|
|
30
|
+
return (0, client_1.apiRequest)(`/calibration/${agentId}/status?predictionType=${predictionType}`, { apiVersion: 'v3' });
|
|
31
31
|
},
|
|
32
32
|
/**
|
|
33
33
|
* Get all calibration metrics for an agent
|
|
@@ -168,4 +168,4 @@ function getCalibrationQuality(brierScore) {
|
|
|
168
168
|
function formatBrierScore(score) {
|
|
169
169
|
return score.toFixed(4);
|
|
170
170
|
}
|
|
171
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calibration.js","sourceRoot":"","sources":["../../src/api/calibration.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Calibration API\n *\n * Prediction accuracy tracking with Brier scores and calibration metrics\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\nimport type {\n  CalibrationStatus,\n  CalibrationBucket,\n  PredictionType,\n  ApiResponse,\n} from '../core/types';\n\n// ============================================================================\n// CALIBRATION API CLIENT\n// ============================================================================\n\n/**\n * Calibration metrics\n */\nexport interface CalibrationMetrics {\n  agentId: string;\n  predictionType: PredictionType;\n  /** Brier score (lower is better, <0.1 is good) */\n  brierScore: number;\n  /** Expected Calibration Error */\n  ece: number;\n  /** Maximum Calibration Error */\n  mce: number;\n  /** Sample count */\n  sampleCount: number;\n  /** Is the model well-calibrated */\n  isCalibrated: boolean;\n  /** Reliability diagram data */\n  reliabilityDiagram: CalibrationBucket[];\n  /** Last updated */\n  lastUpdated: string;\n}\n\n/**\n * Calibration API client for prediction accuracy tracking\n */\nexport const calibration = {\n  /**\n   * Get calibration status for an agent\n   *\n   * @example\n   * ```typescript\n   * const status = await calibration.status('agent_123', 'churn_risk');\n   * console.log(`Brier score: ${status.brierScore}`);\n   * console.log(`Is calibrated: ${status.isCalibrated}`);\n   * ```\n   */\n  async status(\n    agentId: string,\n    predictionType: PredictionType\n  ): Promise<CalibrationStatus> {\n    return apiRequestWithData<CalibrationStatus>(\n      `/calibration/${agentId}/status?predictionType=${predictionType}`,\n      { apiVersion: 'v3' }\n    );\n  },\n\n  /**\n   * Get all calibration metrics for an agent\n   *\n   * @example\n   * ```typescript\n   * const metrics = await calibration.allMetrics('agent_123');\n   * for (const m of metrics) {\n   *   console.log(`${m.predictionType}: Brier=${m.brierScore}`);\n   * }\n   * ```\n   */\n  async allMetrics(agentId: string): Promise<CalibrationMetrics[]> {\n    return apiRequestWithData<CalibrationMetrics[]>(\n      `/calibration/${agentId}/metrics`,\n      { apiVersion: 'v3' }\n    );\n  },\n\n  /**\n   * Trigger recalibration for an agent\n   *\n   * @example\n   * ```typescript\n   * const result = await calibration.retrain('agent_123', {\n   *   predictionTypes: ['churn_risk', 'escalation_risk'],\n   * });\n   * console.log(`Retrained: ${result.success}`);\n   * ```\n   */\n  async retrain(\n    agentId: string,\n    options: {\n      predictionTypes?: PredictionType[];\n      minSamples?: number;\n    } = {}\n  ): Promise<{\n    success: boolean;\n    retrainedTypes: PredictionType[];\n    skippedTypes: Array<{ type: PredictionType; reason: string }>;\n    newMetrics: CalibrationMetrics[];\n  }> {\n    return apiRequestWithData(`/calibration/${agentId}/retrain`, {\n      method: 'POST',\n      body: options,\n      apiVersion: 'v3',\n    });\n  },\n\n};\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Calculate Brier score from predictions and outcomes\n * Lower is better, <0.1 is considered good\n *\n * Supports two calling conventions:\n * - calculateBrierScore(0.8, true)  — single prediction (returns squared error)\n * - calculateBrierScore([{predicted: 0.8, actual: 1}, ...]) — batch (returns mean squared error)\n */\nexport function calculateBrierScore(\n  predictionsOrProbability: Array<{ predicted: number; actual: number }> | number,\n  outcome?: boolean | number\n): number {\n  // Single prediction convenience: calculateBrierScore(0.8, true)\n  if (typeof predictionsOrProbability === 'number') {\n    const predicted = predictionsOrProbability;\n    const actual = outcome === true ? 1 : outcome === false ? 0 : (outcome ?? 0);\n    return Math.pow(predicted - actual, 2);\n  }\n\n  // Batch mode: calculateBrierScore([{predicted, actual}, ...])\n  const predictions = predictionsOrProbability;\n  if (predictions.length === 0) return 0;\n\n  const sum = predictions.reduce((acc, { predicted, actual }) => {\n    return acc + Math.pow(predicted - actual, 2);\n  }, 0);\n\n  return sum / predictions.length;\n}\n\n/**\n * Calculate Expected Calibration Error (ECE)\n * Measures how well-calibrated predictions are across confidence buckets\n *\n * Supports two calling conventions:\n * - calculateECE([{predicted, actual}, ...])  — raw predictions, auto-bucketed\n * - calculateECE([{averageConfidence, accuracy, count}, ...]) — pre-computed buckets\n */\nexport function calculateECE(\n  predictionsOrBuckets: Array<{ predicted: number; actual: number }> | Array<{ averageConfidence: number; accuracy: number; count: number }>,\n  numBuckets: number = 10\n): number {\n  if (predictionsOrBuckets.length === 0) return 0;\n\n  // Check if pre-computed buckets were passed\n  const first = predictionsOrBuckets[0];\n  if ('averageConfidence' in first && 'accuracy' in first && 'count' in first) {\n    const buckets = predictionsOrBuckets as Array<{ averageConfidence: number; accuracy: number; count: number }>;\n    const totalCount = buckets.reduce((sum, b) => sum + b.count, 0);\n    if (totalCount === 0) return 0;\n\n    let ece = 0;\n    for (const bucket of buckets) {\n      if (bucket.count === 0) continue;\n      const weight = bucket.count / totalCount;\n      ece += weight * Math.abs(bucket.averageConfidence - bucket.accuracy);\n    }\n    return ece;\n  }\n\n  // Raw predictions mode\n  const predictions = predictionsOrBuckets as Array<{ predicted: number; actual: number }>;\n\n  const buckets: Array<{ predictions: number[]; actuals: number[] }> = [];\n  for (let i = 0; i < numBuckets; i++) {\n    buckets.push({ predictions: [], actuals: [] });\n  }\n\n  // Assign predictions to buckets\n  for (const { predicted, actual } of predictions) {\n    const bucketIndex = Math.min(\n      Math.floor(predicted * numBuckets),\n      numBuckets - 1\n    );\n    buckets[bucketIndex].predictions.push(predicted);\n    buckets[bucketIndex].actuals.push(actual);\n  }\n\n  // Calculate ECE\n  let ece = 0;\n  for (const bucket of buckets) {\n    if (bucket.predictions.length === 0) continue;\n\n    const avgPredicted =\n      bucket.predictions.reduce((a, b) => a + b, 0) / bucket.predictions.length;\n    const avgActual =\n      bucket.actuals.reduce((a, b) => a + b, 0) / bucket.actuals.length;\n    const weight = bucket.predictions.length / predictions.length;\n\n    ece += weight * Math.abs(avgPredicted - avgActual);\n  }\n\n  return ece;\n}\n\n/**\n * Check if a model is well-calibrated based on Brier score\n * Accepts a number or an object with brierScore property\n */\nexport function isWellCalibrated(brierScoreOrStatus: number | { brierScore: number }): boolean {\n  const score = typeof brierScoreOrStatus === 'number'\n    ? brierScoreOrStatus\n    : brierScoreOrStatus.brierScore;\n  return score < 0.1;\n}\n\n/**\n * Get calibration quality label\n */\nexport function getCalibrationQuality(\n  brierScore: number\n): 'excellent' | 'good' | 'fair' | 'poor' {\n  if (brierScore < 0.05) return 'excellent';\n  if (brierScore < 0.1) return 'good';\n  if (brierScore < 0.2) return 'fair';\n  return 'poor';\n}\n\n/**\n * Format Brier score for display\n */\nexport function formatBrierScore(score: number): string {\n  return score.toFixed(4);\n}\n"]}
|
|
171
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calibration.js","sourceRoot":"","sources":["../../src/api/calibration.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Calibration API\n *\n * Prediction accuracy tracking with Brier scores and calibration metrics\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\nimport type {\n  CalibrationStatus,\n  CalibrationBucket,\n  PredictionType,\n  ApiResponse,\n} from '../core/types';\n\n// ============================================================================\n// CALIBRATION API CLIENT\n// ============================================================================\n\n/**\n * Calibration metrics\n */\nexport interface CalibrationMetrics {\n  agentId: string;\n  predictionType: PredictionType;\n  /** Brier score (lower is better, <0.1 is good) */\n  brierScore: number;\n  /** Expected Calibration Error */\n  ece: number;\n  /** Maximum Calibration Error */\n  mce: number;\n  /** Sample count */\n  sampleCount: number;\n  /** Is the model well-calibrated */\n  isCalibrated: boolean;\n  /** Reliability diagram data */\n  reliabilityDiagram: CalibrationBucket[];\n  /** Last updated */\n  lastUpdated: string;\n}\n\n/**\n * Calibration API client for prediction accuracy tracking\n */\nexport const calibration = {\n  /**\n   * Get calibration status for an agent\n   *\n   * @example\n   * ```typescript\n   * const status = await calibration.status('agent_123', 'churn_risk');\n   * console.log(`Brier score: ${status.brierScore}`);\n   * console.log(`Is calibrated: ${status.isCalibrated}`);\n   * ```\n   */\n  async status(\n    agentId: string,\n    predictionType: PredictionType\n  ): Promise<CalibrationStatus> {\n    return apiRequest<CalibrationStatus>(\n      `/calibration/${agentId}/status?predictionType=${predictionType}`,\n      { apiVersion: 'v3' }\n    );\n  },\n\n  /**\n   * Get all calibration metrics for an agent\n   *\n   * @example\n   * ```typescript\n   * const metrics = await calibration.allMetrics('agent_123');\n   * for (const m of metrics) {\n   *   console.log(`${m.predictionType}: Brier=${m.brierScore}`);\n   * }\n   * ```\n   */\n  async allMetrics(agentId: string): Promise<CalibrationMetrics[]> {\n    return apiRequestWithData<CalibrationMetrics[]>(\n      `/calibration/${agentId}/metrics`,\n      { apiVersion: 'v3' }\n    );\n  },\n\n  /**\n   * Trigger recalibration for an agent\n   *\n   * @example\n   * ```typescript\n   * const result = await calibration.retrain('agent_123', {\n   *   predictionTypes: ['churn_risk', 'escalation_risk'],\n   * });\n   * console.log(`Retrained: ${result.success}`);\n   * ```\n   */\n  async retrain(\n    agentId: string,\n    options: {\n      predictionTypes?: PredictionType[];\n      minSamples?: number;\n    } = {}\n  ): Promise<{\n    success: boolean;\n    retrainedTypes: PredictionType[];\n    skippedTypes: Array<{ type: PredictionType; reason: string }>;\n    newMetrics: CalibrationMetrics[];\n  }> {\n    return apiRequestWithData(`/calibration/${agentId}/retrain`, {\n      method: 'POST',\n      body: options,\n      apiVersion: 'v3',\n    });\n  },\n\n};\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Calculate Brier score from predictions and outcomes\n * Lower is better, <0.1 is considered good\n *\n * Supports two calling conventions:\n * - calculateBrierScore(0.8, true)  — single prediction (returns squared error)\n * - calculateBrierScore([{predicted: 0.8, actual: 1}, ...]) — batch (returns mean squared error)\n */\nexport function calculateBrierScore(\n  predictionsOrProbability: Array<{ predicted: number; actual: number }> | number,\n  outcome?: boolean | number\n): number {\n  // Single prediction convenience: calculateBrierScore(0.8, true)\n  if (typeof predictionsOrProbability === 'number') {\n    const predicted = predictionsOrProbability;\n    const actual = outcome === true ? 1 : outcome === false ? 0 : (outcome ?? 0);\n    return Math.pow(predicted - actual, 2);\n  }\n\n  // Batch mode: calculateBrierScore([{predicted, actual}, ...])\n  const predictions = predictionsOrProbability;\n  if (predictions.length === 0) return 0;\n\n  const sum = predictions.reduce((acc, { predicted, actual }) => {\n    return acc + Math.pow(predicted - actual, 2);\n  }, 0);\n\n  return sum / predictions.length;\n}\n\n/**\n * Calculate Expected Calibration Error (ECE)\n * Measures how well-calibrated predictions are across confidence buckets\n *\n * Supports two calling conventions:\n * - calculateECE([{predicted, actual}, ...])  — raw predictions, auto-bucketed\n * - calculateECE([{averageConfidence, accuracy, count}, ...]) — pre-computed buckets\n */\nexport function calculateECE(\n  predictionsOrBuckets: Array<{ predicted: number; actual: number }> | Array<{ averageConfidence: number; accuracy: number; count: number }>,\n  numBuckets: number = 10\n): number {\n  if (predictionsOrBuckets.length === 0) return 0;\n\n  // Check if pre-computed buckets were passed\n  const first = predictionsOrBuckets[0];\n  if ('averageConfidence' in first && 'accuracy' in first && 'count' in first) {\n    const buckets = predictionsOrBuckets as Array<{ averageConfidence: number; accuracy: number; count: number }>;\n    const totalCount = buckets.reduce((sum, b) => sum + b.count, 0);\n    if (totalCount === 0) return 0;\n\n    let ece = 0;\n    for (const bucket of buckets) {\n      if (bucket.count === 0) continue;\n      const weight = bucket.count / totalCount;\n      ece += weight * Math.abs(bucket.averageConfidence - bucket.accuracy);\n    }\n    return ece;\n  }\n\n  // Raw predictions mode\n  const predictions = predictionsOrBuckets as Array<{ predicted: number; actual: number }>;\n\n  const buckets: Array<{ predictions: number[]; actuals: number[] }> = [];\n  for (let i = 0; i < numBuckets; i++) {\n    buckets.push({ predictions: [], actuals: [] });\n  }\n\n  // Assign predictions to buckets\n  for (const { predicted, actual } of predictions) {\n    const bucketIndex = Math.min(\n      Math.floor(predicted * numBuckets),\n      numBuckets - 1\n    );\n    buckets[bucketIndex].predictions.push(predicted);\n    buckets[bucketIndex].actuals.push(actual);\n  }\n\n  // Calculate ECE\n  let ece = 0;\n  for (const bucket of buckets) {\n    if (bucket.predictions.length === 0) continue;\n\n    const avgPredicted =\n      bucket.predictions.reduce((a, b) => a + b, 0) / bucket.predictions.length;\n    const avgActual =\n      bucket.actuals.reduce((a, b) => a + b, 0) / bucket.actuals.length;\n    const weight = bucket.predictions.length / predictions.length;\n\n    ece += weight * Math.abs(avgPredicted - avgActual);\n  }\n\n  return ece;\n}\n\n/**\n * Check if a model is well-calibrated based on Brier score\n * Accepts a number or an object with brierScore property\n */\nexport function isWellCalibrated(brierScoreOrStatus: number | { brierScore: number }): boolean {\n  const score = typeof brierScoreOrStatus === 'number'\n    ? brierScoreOrStatus\n    : brierScoreOrStatus.brierScore;\n  return score < 0.1;\n}\n\n/**\n * Get calibration quality label\n */\nexport function getCalibrationQuality(\n  brierScore: number\n): 'excellent' | 'good' | 'fair' | 'poor' {\n  if (brierScore < 0.05) return 'excellent';\n  if (brierScore < 0.1) return 'good';\n  if (brierScore < 0.2) return 'fair';\n  return 'poor';\n}\n\n/**\n * Format Brier score for display\n */\nexport function formatBrierScore(score: number): string {\n  return score.toFixed(4);\n}\n"]}
|
package/dist/api/claims.d.ts
CHANGED
|
@@ -22,7 +22,7 @@ export interface ListClaimsOptions {
|
|
|
22
22
|
*/
|
|
23
23
|
export interface CreateAnalysisOptions {
|
|
24
24
|
runId: string;
|
|
25
|
-
modelUsed
|
|
25
|
+
modelUsed: string;
|
|
26
26
|
outcomeVerdict: 'success' | 'partial_success' | 'failure';
|
|
27
27
|
outcomeConfidence?: number;
|
|
28
28
|
rootCauseCategory?: string;
|
|
@@ -34,8 +34,8 @@ export interface CreateClaimInput {
|
|
|
34
34
|
claimCategory: ClaimCategory;
|
|
35
35
|
claimText: string;
|
|
36
36
|
confidence: number;
|
|
37
|
-
confidenceCalibration
|
|
38
|
-
evidence
|
|
37
|
+
confidenceCalibration: 'calibrated' | 'uncalibrated' | 'rule_based';
|
|
38
|
+
evidence: EvidenceReference[];
|
|
39
39
|
isExplainable?: boolean;
|
|
40
40
|
probabilityValue?: number;
|
|
41
41
|
}
|
package/dist/api/claims.js
CHANGED
|
@@ -259,10 +259,15 @@ function groupClaimsByCategory(claimsList) {
|
|
|
259
259
|
const groups = {
|
|
260
260
|
outcome: [],
|
|
261
261
|
root_cause: [],
|
|
262
|
-
|
|
262
|
+
sentiment: [],
|
|
263
263
|
churn_risk: [],
|
|
264
|
-
|
|
264
|
+
escalation_risk: [],
|
|
265
|
+
satisfaction: [],
|
|
266
|
+
recontact: [],
|
|
267
|
+
resolution_time: [],
|
|
268
|
+
cost: [],
|
|
265
269
|
quality: [],
|
|
270
|
+
compliance: [],
|
|
266
271
|
other: [],
|
|
267
272
|
};
|
|
268
273
|
for (const claim of claimsList) {
|
|
@@ -270,4 +275,4 @@ function groupClaimsByCategory(claimsList) {
|
|
|
270
275
|
}
|
|
271
276
|
return groups;
|
|
272
277
|
}
|
|
273
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"claims.js","sourceRoot":"","sources":["../../src/api/claims.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Claims API\n *\n * Facts vs Inferences API for accessing analysis claims\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\nimport type {\n  Claim,\n  ClaimType,\n  ClaimCategory,\n  AnalysisResult,\n  ApiResponse,\n  PaginatedResponse,\n  EvidenceReference,\n} from '../core/types';\n\n// ============================================================================\n// CLAIMS API CLIENT\n// ============================================================================\n\n/**\n * List claims query options\n */\nexport interface ListClaimsOptions {\n  runId?: string;\n  analysisId?: string;\n  claimType?: ClaimType;\n  claimCategory?: ClaimCategory;\n  minConfidence?: number;\n  humanVerified?: boolean;\n  limit?: number;\n  offset?: number;\n}\n\n/**\n * Create analysis options\n */\nexport interface CreateAnalysisOptions {\n  runId: string;\n  modelUsed?: string;\n  outcomeVerdict: 'success' | 'partial_success' | 'failure';\n  outcomeConfidence?: number;\n  rootCauseCategory?: string;\n  rootCauseConfidence?: number;\n  claims?: CreateClaimInput[];\n}\n\nexport interface CreateClaimInput {\n  claimType: ClaimType;\n  claimCategory: ClaimCategory;\n  claimText: string;\n  confidence: number;\n  confidenceCalibration?: 'calibrated' | 'uncalibrated' | 'needs_more_data';\n  evidence?: EvidenceReference[];\n  isExplainable?: boolean;\n  probabilityValue?: number;\n}\n\n/**\n * Facts vs inferences summary\n */\nexport interface FactsVsInferencesSummary {\n  analysisIds: string[];\n  totalClaims: number;\n  observed: {\n    count: number;\n    avgConfidence: number;\n    categories: Record<string, number>;\n  };\n  inferred: {\n    count: number;\n    avgConfidence: number;\n    categories: Record<string, number>;\n  };\n  computed: {\n    count: number;\n    avgConfidence: number;\n    categories: Record<string, number>;\n  };\n  humanVerifiedCount: number;\n  humanRejectedCount: number;\n}\n\n/**\n * Claims API client for facts vs inferences management\n */\nexport const claims = {\n  /**\n   * Create a new analysis for a run\n   *\n   * @example\n   * ```typescript\n   * const analysis = await claims.createAnalysis({\n   *   runId: 'run_abc123',\n   *   outcomeVerdict: 'failure',\n   *   outcomeConfidence: 0.85,\n   *   rootCauseCategory: 'retrieval_failure',\n   *   claims: [\n   *     {\n   *       claimType: 'observed',\n   *       claimCategory: 'root_cause',\n   *       claimText: 'Vector search returned 0 results',\n   *       confidence: 1.0,\n   *       evidence: [{ type: 'span', referenceId: 'span_123', relevance: 'direct', confidence: 1.0 }],\n   *     },\n   *     {\n   *       claimType: 'inferred',\n   *       claimCategory: 'churn_risk',\n   *       claimText: 'High churn risk due to repeated failures',\n   *       confidence: 0.7,\n   *     },\n   *   ],\n   * });\n   * ```\n   */\n  async createAnalysis(options: CreateAnalysisOptions): Promise<AnalysisResult> {\n    return apiRequestWithData<AnalysisResult>('/analyses', {\n      method: 'POST',\n      body: options,\n      apiVersion: 'v3',\n    });\n  },\n\n  /**\n   * Get an analysis by ID\n   *\n   * @example\n   * ```typescript\n   * const analysis = await claims.getAnalysis('analysis_abc123');\n   * ```\n   */\n  async getAnalysis(analysisId: string): Promise<AnalysisResult> {\n    return apiRequestWithData<AnalysisResult>(`/analyses/${analysisId}`, { apiVersion: 'v3' });\n  },\n\n  /**\n   * Get current analysis for a run\n   *\n   * @example\n   * ```typescript\n   * const analysis = await claims.getRunAnalysis('run_abc123');\n   * ```\n   */\n  async getRunAnalysis(runId: string): Promise<AnalysisResult> {\n    return apiRequestWithData<AnalysisResult>(`/runs/${runId}/analysis`, { apiVersion: 'v3' });\n  },\n\n  /**\n   * Get analysis history for a run\n   *\n   * @example\n   * ```typescript\n   * const history = await claims.getAnalysisHistory('run_abc123');\n   * ```\n   */\n  async getAnalysisHistory(runId: string): Promise<{\n    runId: string;\n    analyses: Array<{\n      id: string;\n      analysisVersion: string;\n      modelUsed: string;\n      outcomeVerdict: string;\n      isCurrent: boolean;\n      supersededBy?: string;\n      supersessionReason?: string;\n      analyzedAt: string;\n    }>;\n  }> {\n    return apiRequestWithData(`/runs/${runId}/analyses`, { apiVersion: 'v3' });\n  },\n\n  /**\n   * Supersede an analysis with a new one\n   *\n   * @example\n   * ```typescript\n   * const newAnalysis = await claims.supersedeAnalysis('analysis_old', {\n   *   reason: 'Improved model accuracy',\n   *   newAnalysis: {\n   *     outcomeVerdict: 'success',\n   *     outcomeConfidence: 0.95,\n   *     claims: [...],\n   *   },\n   * });\n   * ```\n   */\n  async supersedeAnalysis(\n    analysisId: string,\n    options: {\n      reason: string;\n      newAnalysis: Omit<CreateAnalysisOptions, 'runId'>;\n    }\n  ): Promise<{ supersededAnalysisId: string; newAnalysis: AnalysisResult }> {\n    return apiRequestWithData(`/analyses/${analysisId}/supersede`, {\n      method: 'POST',\n      body: options,\n      apiVersion: 'v3',\n    });\n  },\n\n  /**\n   * List claims with filters\n   *\n   * @example\n   * ```typescript\n   * // Get all inferred claims with high confidence\n   * const { claims } = await claims.list({\n   *   claimType: 'inferred',\n   *   minConfidence: 0.8,\n   * });\n   *\n   * // Get all churn risk claims for a run\n   * const { claims } = await claims.list({\n   *   runId: 'run_abc123',\n   *   claimCategory: 'churn_risk',\n   * });\n   * ```\n   */\n  async list(\n    options: ListClaimsOptions = {}\n  ): Promise<{ claims: Claim[]; limit: number; offset: number; hasMore: boolean }> {\n    const params = new URLSearchParams();\n    if (options.runId) params.set('runId', options.runId);\n    if (options.analysisId) params.set('analysisId', options.analysisId);\n    if (options.claimType) params.set('claimType', options.claimType);\n    if (options.claimCategory) params.set('claimCategory', options.claimCategory);\n    if (options.minConfidence !== undefined) {\n      params.set('minConfidence', String(options.minConfidence));\n    }\n    if (options.humanVerified !== undefined) {\n      params.set('humanVerified', String(options.humanVerified));\n    }\n    if (options.limit) params.set('limit', String(options.limit));\n    if (options.offset) params.set('offset', String(options.offset));\n\n    return apiRequestWithData<{ claims: Claim[]; limit: number; offset: number; hasMore: boolean }>(\n      `/claims?${params.toString()}`,\n      { apiVersion: 'v3' }\n    );\n  },\n\n  /**\n   * Get a claim by ID\n   *\n   * @example\n   * ```typescript\n   * const claim = await claims.get('claim_abc123');\n   * ```\n   */\n  async get(claimId: string): Promise<Claim> {\n    return apiRequestWithData<Claim>(`/claims/${claimId}`, { apiVersion: 'v3' });\n  },\n\n  /**\n   * Verify or reject a claim (human feedback)\n   *\n   * @example\n   * ```typescript\n   * // Confirm a claim\n   * await claims.verify('claim_abc123', {\n   *   verdict: 'confirmed',\n   *   notes: 'Verified against ticket history',\n   * });\n   *\n   * // Reject a claim\n   * await claims.verify('claim_abc123', {\n   *   verdict: 'rejected',\n   *   notes: 'Customer context was missing',\n   * });\n   * ```\n   */\n  async verify(\n    claimId: string,\n    options: {\n      verdict: 'confirmed' | 'rejected' | 'modified';\n      notes?: string;\n      modifiedText?: string;\n    }\n  ): Promise<{ claimId: string; verdict: string; message: string }> {\n    return apiRequestWithData(`/claims/${claimId}/verify`, {\n      method: 'POST',\n      body: options,\n      apiVersion: 'v3',\n    });\n  },\n\n  /**\n   * Get facts vs inferences summary\n   *\n   * @example\n   * ```typescript\n   * // Summary for a specific run\n   * const summary = await claims.summary({ runId: 'run_abc123' });\n   *\n   * // Summary for multiple analyses\n   * const summary = await claims.summary({\n   *   analysisIds: ['analysis_1', 'analysis_2'],\n   * });\n   * ```\n   */\n  async summary(\n    options: { runId?: string; analysisIds?: string[] } = {}\n  ): Promise<FactsVsInferencesSummary> {\n    const params = new URLSearchParams();\n    if (options.runId) params.set('runId', options.runId);\n    if (options.analysisIds) params.set('analysisIds', options.analysisIds.join(','));\n\n    return apiRequestWithData<FactsVsInferencesSummary>(\n      `/claims/summary?${params.toString()}`,\n      { apiVersion: 'v3' }\n    );\n  },\n};\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Check if a claim is a fact (observed)\n * Accepts both { claimType: 'observed' } (API format) and { type: 'fact' } (shorthand)\n */\nexport function isFact(claim: Claim | { type?: string; claimType?: string }): boolean {\n  return claim.claimType === 'observed' || (claim as any).type === 'fact';\n}\n\n/**\n * Check if a claim is an inference\n * Accepts both { claimType: 'inferred' } (API format) and { type: 'inference' } (shorthand)\n */\nexport function isInference(claim: Claim | { type?: string; claimType?: string }): boolean {\n  return claim.claimType === 'inferred' || (claim as any).type === 'inference';\n}\n\n/**\n * Check if a claim is computed\n * Accepts both { claimType: 'computed' } (API format) and { type: 'computed' } (shorthand)\n */\nexport function isComputed(claim: Claim | { type?: string; claimType?: string }): boolean {\n  return claim.claimType === 'computed' || (claim as any).type === 'computed';\n}\n\n/**\n * Get high confidence claims (>= threshold)\n */\nexport function getHighConfidenceClaims(\n  claimsList: Claim[],\n  threshold: number = 0.8\n): Claim[] {\n  return claimsList.filter((c) => c.confidence >= threshold);\n}\n\n/**\n * Group claims by type\n * Returns groups keyed by both API names (observed/inferred/computed)\n * and shorthand names (fact/inference/computed) for convenience\n */\nexport function groupClaimsByType(\n  claimsList: Array<Claim | { type?: string; claimType?: string }>\n): Record<string, Array<Claim | { type?: string; claimType?: string }>> {\n  const observed = claimsList.filter((c) => c.claimType === 'observed' || (c as any).type === 'fact');\n  const inferred = claimsList.filter((c) => c.claimType === 'inferred' || (c as any).type === 'inference');\n  const computed = claimsList.filter((c) => c.claimType === 'computed' || (c as any).type === 'computed');\n\n  return {\n    observed, inferred, computed,\n    // Shorthand aliases\n    fact: observed,\n    inference: inferred,\n  };\n}\n\n/**\n * Group claims by category\n */\nexport function groupClaimsByCategory(\n  claimsList: Claim[]\n): Record<ClaimCategory, Claim[]> {\n  const groups: Record<ClaimCategory, Claim[]> = {\n    outcome: [],\n    root_cause: [],\n    customer_impact: [],\n    churn_risk: [],\n    revenue_impact: [],\n    quality: [],\n    other: [],\n  };\n\n  for (const claim of claimsList) {\n    groups[claim.claimCategory].push(claim);\n  }\n\n  return groups;\n}\n"]}
|
|
278
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"claims.js","sourceRoot":"","sources":["../../src/api/claims.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Claims API\n *\n * Facts vs Inferences API for accessing analysis claims\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\nimport type {\n  Claim,\n  ClaimType,\n  ClaimCategory,\n  AnalysisResult,\n  ApiResponse,\n  PaginatedResponse,\n  EvidenceReference,\n} from '../core/types';\n\n// ============================================================================\n// CLAIMS API CLIENT\n// ============================================================================\n\n/**\n * List claims query options\n */\nexport interface ListClaimsOptions {\n  runId?: string;\n  analysisId?: string;\n  claimType?: ClaimType;\n  claimCategory?: ClaimCategory;\n  minConfidence?: number;\n  humanVerified?: boolean;\n  limit?: number;\n  offset?: number;\n}\n\n/**\n * Create analysis options\n */\nexport interface CreateAnalysisOptions {\n  runId: string;\n  modelUsed: string;\n  outcomeVerdict: 'success' | 'partial_success' | 'failure';\n  outcomeConfidence?: number;\n  rootCauseCategory?: string;\n  rootCauseConfidence?: number;\n  claims?: CreateClaimInput[];\n}\n\nexport interface CreateClaimInput {\n  claimType: ClaimType;\n  claimCategory: ClaimCategory;\n  claimText: string;\n  confidence: number;\n  confidenceCalibration: 'calibrated' | 'uncalibrated' | 'rule_based';\n  evidence: EvidenceReference[];\n  isExplainable?: boolean;\n  probabilityValue?: number;\n}\n\n/**\n * Facts vs inferences summary\n */\nexport interface FactsVsInferencesSummary {\n  analysisIds: string[];\n  totalClaims: number;\n  observed: {\n    count: number;\n    avgConfidence: number;\n    categories: Record<string, number>;\n  };\n  inferred: {\n    count: number;\n    avgConfidence: number;\n    categories: Record<string, number>;\n  };\n  computed: {\n    count: number;\n    avgConfidence: number;\n    categories: Record<string, number>;\n  };\n  humanVerifiedCount: number;\n  humanRejectedCount: number;\n}\n\n/**\n * Claims API client for facts vs inferences management\n */\nexport const claims = {\n  /**\n   * Create a new analysis for a run\n   *\n   * @example\n   * ```typescript\n   * const analysis = await claims.createAnalysis({\n   *   runId: 'run_abc123',\n   *   outcomeVerdict: 'failure',\n   *   outcomeConfidence: 0.85,\n   *   rootCauseCategory: 'retrieval_failure',\n   *   claims: [\n   *     {\n   *       claimType: 'observed',\n   *       claimCategory: 'root_cause',\n   *       claimText: 'Vector search returned 0 results',\n   *       confidence: 1.0,\n   *       evidence: [{ type: 'span', referenceId: 'span_123', relevance: 'direct', confidence: 1.0 }],\n   *     },\n   *     {\n   *       claimType: 'inferred',\n   *       claimCategory: 'churn_risk',\n   *       claimText: 'High churn risk due to repeated failures',\n   *       confidence: 0.7,\n   *     },\n   *   ],\n   * });\n   * ```\n   */\n  async createAnalysis(options: CreateAnalysisOptions): Promise<AnalysisResult> {\n    return apiRequestWithData<AnalysisResult>('/analyses', {\n      method: 'POST',\n      body: options,\n      apiVersion: 'v3',\n    });\n  },\n\n  /**\n   * Get an analysis by ID\n   *\n   * @example\n   * ```typescript\n   * const analysis = await claims.getAnalysis('analysis_abc123');\n   * ```\n   */\n  async getAnalysis(analysisId: string): Promise<AnalysisResult> {\n    return apiRequestWithData<AnalysisResult>(`/analyses/${analysisId}`, { apiVersion: 'v3' });\n  },\n\n  /**\n   * Get current analysis for a run\n   *\n   * @example\n   * ```typescript\n   * const analysis = await claims.getRunAnalysis('run_abc123');\n   * ```\n   */\n  async getRunAnalysis(runId: string): Promise<AnalysisResult> {\n    return apiRequestWithData<AnalysisResult>(`/runs/${runId}/analysis`, { apiVersion: 'v3' });\n  },\n\n  /**\n   * Get analysis history for a run\n   *\n   * @example\n   * ```typescript\n   * const history = await claims.getAnalysisHistory('run_abc123');\n   * ```\n   */\n  async getAnalysisHistory(runId: string): Promise<{\n    runId: string;\n    analyses: Array<{\n      id: string;\n      analysisVersion: string;\n      modelUsed: string;\n      outcomeVerdict: string;\n      isCurrent: boolean;\n      supersededBy?: string;\n      supersessionReason?: string;\n      analyzedAt: string;\n    }>;\n  }> {\n    return apiRequestWithData(`/runs/${runId}/analyses`, { apiVersion: 'v3' });\n  },\n\n  /**\n   * Supersede an analysis with a new one\n   *\n   * @example\n   * ```typescript\n   * const newAnalysis = await claims.supersedeAnalysis('analysis_old', {\n   *   reason: 'Improved model accuracy',\n   *   newAnalysis: {\n   *     outcomeVerdict: 'success',\n   *     outcomeConfidence: 0.95,\n   *     claims: [...],\n   *   },\n   * });\n   * ```\n   */\n  async supersedeAnalysis(\n    analysisId: string,\n    options: {\n      reason: string;\n      newAnalysis: Omit<CreateAnalysisOptions, 'runId'>;\n    }\n  ): Promise<{ supersededAnalysisId: string; newAnalysis: AnalysisResult }> {\n    return apiRequestWithData(`/analyses/${analysisId}/supersede`, {\n      method: 'POST',\n      body: options,\n      apiVersion: 'v3',\n    });\n  },\n\n  /**\n   * List claims with filters\n   *\n   * @example\n   * ```typescript\n   * // Get all inferred claims with high confidence\n   * const { claims } = await claims.list({\n   *   claimType: 'inferred',\n   *   minConfidence: 0.8,\n   * });\n   *\n   * // Get all churn risk claims for a run\n   * const { claims } = await claims.list({\n   *   runId: 'run_abc123',\n   *   claimCategory: 'churn_risk',\n   * });\n   * ```\n   */\n  async list(\n    options: ListClaimsOptions = {}\n  ): Promise<{ claims: Claim[]; limit: number; offset: number; hasMore: boolean }> {\n    const params = new URLSearchParams();\n    if (options.runId) params.set('runId', options.runId);\n    if (options.analysisId) params.set('analysisId', options.analysisId);\n    if (options.claimType) params.set('claimType', options.claimType);\n    if (options.claimCategory) params.set('claimCategory', options.claimCategory);\n    if (options.minConfidence !== undefined) {\n      params.set('minConfidence', String(options.minConfidence));\n    }\n    if (options.humanVerified !== undefined) {\n      params.set('humanVerified', String(options.humanVerified));\n    }\n    if (options.limit) params.set('limit', String(options.limit));\n    if (options.offset) params.set('offset', String(options.offset));\n\n    return apiRequestWithData<{ claims: Claim[]; limit: number; offset: number; hasMore: boolean }>(\n      `/claims?${params.toString()}`,\n      { apiVersion: 'v3' }\n    );\n  },\n\n  /**\n   * Get a claim by ID\n   *\n   * @example\n   * ```typescript\n   * const claim = await claims.get('claim_abc123');\n   * ```\n   */\n  async get(claimId: string): Promise<Claim> {\n    return apiRequestWithData<Claim>(`/claims/${claimId}`, { apiVersion: 'v3' });\n  },\n\n  /**\n   * Verify or reject a claim (human feedback)\n   *\n   * @example\n   * ```typescript\n   * // Confirm a claim\n   * await claims.verify('claim_abc123', {\n   *   verdict: 'confirmed',\n   *   notes: 'Verified against ticket history',\n   * });\n   *\n   * // Reject a claim\n   * await claims.verify('claim_abc123', {\n   *   verdict: 'rejected',\n   *   notes: 'Customer context was missing',\n   * });\n   * ```\n   */\n  async verify(\n    claimId: string,\n    options: {\n      verdict: 'confirmed' | 'rejected' | 'modified';\n      notes?: string;\n      modifiedText?: string;\n    }\n  ): Promise<{ claimId: string; verdict: string; message: string }> {\n    return apiRequestWithData(`/claims/${claimId}/verify`, {\n      method: 'POST',\n      body: options,\n      apiVersion: 'v3',\n    });\n  },\n\n  /**\n   * Get facts vs inferences summary\n   *\n   * @example\n   * ```typescript\n   * // Summary for a specific run\n   * const summary = await claims.summary({ runId: 'run_abc123' });\n   *\n   * // Summary for multiple analyses\n   * const summary = await claims.summary({\n   *   analysisIds: ['analysis_1', 'analysis_2'],\n   * });\n   * ```\n   */\n  async summary(\n    options: { runId?: string; analysisIds?: string[] } = {}\n  ): Promise<FactsVsInferencesSummary> {\n    const params = new URLSearchParams();\n    if (options.runId) params.set('runId', options.runId);\n    if (options.analysisIds) params.set('analysisIds', options.analysisIds.join(','));\n\n    return apiRequestWithData<FactsVsInferencesSummary>(\n      `/claims/summary?${params.toString()}`,\n      { apiVersion: 'v3' }\n    );\n  },\n};\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Check if a claim is a fact (observed)\n * Accepts both { claimType: 'observed' } (API format) and { type: 'fact' } (shorthand)\n */\nexport function isFact(claim: Claim | { type?: string; claimType?: string }): boolean {\n  return claim.claimType === 'observed' || (claim as any).type === 'fact';\n}\n\n/**\n * Check if a claim is an inference\n * Accepts both { claimType: 'inferred' } (API format) and { type: 'inference' } (shorthand)\n */\nexport function isInference(claim: Claim | { type?: string; claimType?: string }): boolean {\n  return claim.claimType === 'inferred' || (claim as any).type === 'inference';\n}\n\n/**\n * Check if a claim is computed\n * Accepts both { claimType: 'computed' } (API format) and { type: 'computed' } (shorthand)\n */\nexport function isComputed(claim: Claim | { type?: string; claimType?: string }): boolean {\n  return claim.claimType === 'computed' || (claim as any).type === 'computed';\n}\n\n/**\n * Get high confidence claims (>= threshold)\n */\nexport function getHighConfidenceClaims(\n  claimsList: Claim[],\n  threshold: number = 0.8\n): Claim[] {\n  return claimsList.filter((c) => c.confidence >= threshold);\n}\n\n/**\n * Group claims by type\n * Returns groups keyed by both API names (observed/inferred/computed)\n * and shorthand names (fact/inference/computed) for convenience\n */\nexport function groupClaimsByType(\n  claimsList: Array<Claim | { type?: string; claimType?: string }>\n): Record<string, Array<Claim | { type?: string; claimType?: string }>> {\n  const observed = claimsList.filter((c) => c.claimType === 'observed' || (c as any).type === 'fact');\n  const inferred = claimsList.filter((c) => c.claimType === 'inferred' || (c as any).type === 'inference');\n  const computed = claimsList.filter((c) => c.claimType === 'computed' || (c as any).type === 'computed');\n\n  return {\n    observed, inferred, computed,\n    // Shorthand aliases\n    fact: observed,\n    inference: inferred,\n  };\n}\n\n/**\n * Group claims by category\n */\nexport function groupClaimsByCategory(\n  claimsList: Claim[]\n): Record<ClaimCategory, Claim[]> {\n  const groups: Record<ClaimCategory, Claim[]> = {\n    outcome: [],\n    root_cause: [],\n    sentiment: [],\n    churn_risk: [],\n    escalation_risk: [],\n    satisfaction: [],\n    recontact: [],\n    resolution_time: [],\n    cost: [],\n    quality: [],\n    compliance: [],\n    other: [],\n  };\n\n  for (const claim of claimsList) {\n    groups[claim.claimCategory].push(claim);\n  }\n\n  return groups;\n}\n"]}
|
package/dist/api/signals.js
CHANGED
|
@@ -29,9 +29,15 @@ exports.signals = {
|
|
|
29
29
|
if (opts?.isEnabled !== undefined)
|
|
30
30
|
params.set('isEnabled', String(opts.isEnabled));
|
|
31
31
|
const query = params.toString();
|
|
32
|
-
|
|
32
|
+
const response = await (0, client_1.apiRequest)(`/signals/${query ? `?${query}` : ''}`, {
|
|
33
33
|
apiVersion: 'v1',
|
|
34
34
|
});
|
|
35
|
+
// Handle both response formats: { signals: [...] } and { success: true, data: [...] }
|
|
36
|
+
if ('signals' in response)
|
|
37
|
+
return response.signals;
|
|
38
|
+
if ('data' in response)
|
|
39
|
+
return response.data;
|
|
40
|
+
return response;
|
|
35
41
|
},
|
|
36
42
|
/**
|
|
37
43
|
* Create a new behavioral signal
|
|
@@ -104,9 +110,14 @@ exports.signals = {
|
|
|
104
110
|
if (opts?.agentId)
|
|
105
111
|
params.set('agentId', opts.agentId);
|
|
106
112
|
const query = params.toString();
|
|
107
|
-
|
|
113
|
+
const response = await (0, client_1.apiRequest)(`/signals/stats${query ? `?${query}` : ''}`, {
|
|
108
114
|
apiVersion: 'v1',
|
|
109
115
|
});
|
|
116
|
+
if ('stats' in response)
|
|
117
|
+
return response.stats;
|
|
118
|
+
if ('data' in response)
|
|
119
|
+
return response.data;
|
|
120
|
+
return response;
|
|
110
121
|
},
|
|
111
122
|
/**
|
|
112
123
|
* Get signal trend data over time
|
|
@@ -173,4 +184,4 @@ exports.signals = {
|
|
|
173
184
|
},
|
|
174
185
|
};
|
|
175
186
|
exports.default = exports.signals;
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signals.js","sourceRoot":"","sources":["../../src/api/signals.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK - Signals API\n *\n * Behavioral signal management for detecting patterns in agent interactions\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\n/** Signal detection configuration */\nexport interface DetectionConfig {\n  type: string;\n  threshold?: number;\n  pattern?: string;\n  [key: string]: unknown;\n}\n\n/** Options for creating a signal */\nexport interface CreateSignalOptions {\n  description?: string;\n  isEnabled?: boolean;\n  severity?: string;\n}\n\n/** Options for updating a signal */\nexport interface UpdateSignalOptions {\n  name?: string;\n  group?: string;\n  description?: string;\n  detectionConfig?: DetectionConfig;\n  isEnabled?: boolean;\n  severity?: string;\n}\n\n/** Options for listing signals */\nexport interface ListSignalsOptions {\n  group?: string;\n  source?: string;\n  isEnabled?: boolean;\n}\n\n/** Options for getting signal stats */\nexport interface SignalStatsOptions {\n  startDate?: string;\n  endDate?: string;\n  agentId?: string;\n}\n\n/** Options for getting signal trends */\nexport interface SignalTrendsOptions {\n  startDate?: string;\n  endDate?: string;\n  agentId?: string;\n  granularity?: 'hour' | 'day' | 'week' | 'month';\n}\n\n/** Options for getting signal traces */\nexport interface SignalTracesOptions {\n  limit?: number;\n  offset?: number;\n  startDate?: string;\n  endDate?: string;\n  agentId?: string;\n}\n\n/** Options for getting signal events */\nexport interface SignalEventsOptions {\n  limit?: number;\n  offset?: number;\n}\n\n/** A behavioral signal definition */\nexport interface Signal {\n  id: string;\n  name: string;\n  group: string;\n  description?: string;\n  detectionConfig: DetectionConfig;\n  isEnabled: boolean;\n  severity?: string;\n  source?: string;\n  createdAt: string;\n  updatedAt: string;\n}\n\n/** Signal statistics */\nexport interface SignalStats {\n  signalId: string;\n  name: string;\n  eventCount: number;\n  traceCount: number;\n  lastTriggeredAt?: string;\n}\n\n/** Signal trend data point */\nexport interface SignalTrendPoint {\n  period: string;\n  eventCount: number;\n  traceCount: number;\n}\n\n/** A signal event occurrence */\nexport interface SignalEvent {\n  id: string;\n  signalId: string;\n  traceId: string;\n  detectedAt: string;\n  metadata?: Record<string, unknown>;\n}\n\n// ============================================================================\n// SIGNALS API CLIENT\n// ============================================================================\n\n/**\n * Signals API client for managing behavioral signal detection\n */\nexport const signals = {\n  /**\n   * List all signals with optional filters\n   *\n   * @param opts - Filter options for group, source, or enabled status\n   * @returns List of signals\n   */\n  async list(opts?: ListSignalsOptions): Promise<Signal[]> {\n    const params = new URLSearchParams();\n    if (opts?.group) params.set('group', opts.group);\n    if (opts?.source) params.set('source', opts.source);\n    if (opts?.isEnabled !== undefined) params.set('isEnabled', String(opts.isEnabled));\n\n    const query = params.toString();\n    return apiRequestWithData<Signal[]>(`/signals/${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Create a new behavioral signal\n   *\n   * @param name - Signal name\n   * @param group - Signal group/category\n   * @param detectionConfig - Detection configuration\n   * @param opts - Additional signal options\n   * @returns The created signal\n   */\n  async create(\n    name: string,\n    group: string,\n    detectionConfig: DetectionConfig,\n    opts?: CreateSignalOptions\n  ): Promise<Signal> {\n    return apiRequestWithData<Signal>('/signals/', {\n      method: 'POST',\n      body: { name, group, detectionConfig, ...opts },\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Update an existing signal\n   *\n   * @param id - Signal ID to update\n   * @param opts - Fields to update\n   * @returns The updated signal\n   */\n  async update(id: string, opts: UpdateSignalOptions): Promise<Signal> {\n    return apiRequestWithData<Signal>(`/signals/${id}`, {\n      method: 'PUT',\n      body: opts,\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Delete a signal\n   *\n   * @param id - Signal ID to delete\n   */\n  async remove(id: string): Promise<void> {\n    return apiRequest<void>(`/signals/${id}`, {\n      method: 'DELETE',\n      apiVersion: 'v1',\n    });\n  },\n\n  /** Alias for remove() */\n  async delete(id: string): Promise<void> {\n    return this.remove(id);\n  },\n\n  /**\n   * Seed default signal definitions\n   *\n   * @returns List of seeded signals\n   */\n  async seedDefaults(): Promise<Signal[]> {\n    return apiRequestWithData<Signal[]>('/signals/seed', {\n      method: 'POST',\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Get signal statistics\n   *\n   * @param opts - Date range and agent filter options\n   * @returns Signal statistics\n   */\n  async getStats(opts?: SignalStatsOptions): Promise<SignalStats[]> {\n    const params = new URLSearchParams();\n    if (opts?.startDate) params.set('startDate', opts.startDate);\n    if (opts?.endDate) params.set('endDate', opts.endDate);\n    if (opts?.agentId) params.set('agentId', opts.agentId);\n\n    const query = params.toString();\n    return apiRequestWithData<SignalStats[]>(`/signals/stats${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Get signal trend data over time\n   *\n   * @param opts - Date range, agent, and granularity options\n   * @returns Signal trend data points\n   */\n  async getTrends(opts?: SignalTrendsOptions): Promise<SignalTrendPoint[]> {\n    const params = new URLSearchParams();\n    if (opts?.startDate) params.set('startDate', opts.startDate);\n    if (opts?.endDate) params.set('endDate', opts.endDate);\n    if (opts?.agentId) params.set('agentId', opts.agentId);\n    if (opts?.granularity) params.set('granularity', opts.granularity);\n\n    const query = params.toString();\n    return apiRequestWithData<SignalTrendPoint[]>(`/signals/trends${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Get traces that triggered a specific signal\n   *\n   * @param id - Signal ID\n   * @param opts - Pagination and filter options\n   * @returns Traces associated with the signal\n   */\n  async getTraces(id: string, opts?: SignalTracesOptions): Promise<{\n    traces: any[];\n    limit: number;\n    offset: number;\n    hasMore: boolean;\n  }> {\n    const params = new URLSearchParams();\n    if (opts?.limit !== undefined) params.set('limit', String(opts.limit));\n    if (opts?.offset !== undefined) params.set('offset', String(opts.offset));\n    if (opts?.startDate) params.set('startDate', opts.startDate);\n    if (opts?.endDate) params.set('endDate', opts.endDate);\n    if (opts?.agentId) params.set('agentId', opts.agentId);\n\n    const query = params.toString();\n    return apiRequestWithData(`/signals/${id}/traces${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Get events for a specific signal\n   *\n   * @param id - Signal ID\n   * @param opts - Pagination options\n   * @returns Signal events\n   */\n  async getEvents(id: string, opts?: SignalEventsOptions): Promise<{\n    events: SignalEvent[];\n    limit: number;\n    offset: number;\n    hasMore: boolean;\n  }> {\n    const params = new URLSearchParams();\n    if (opts?.limit !== undefined) params.set('limit', String(opts.limit));\n    if (opts?.offset !== undefined) params.set('offset', String(opts.offset));\n\n    const query = params.toString();\n    return apiRequestWithData(`/signals/${id}/events${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n  },\n};\n\nexport { signals as default };\n"]}
|
|
187
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signals.js","sourceRoot":"","sources":["../../src/api/signals.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK - Signals API\n *\n * Behavioral signal management for detecting patterns in agent interactions\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\n/** Signal detection configuration */\nexport interface DetectionConfig {\n  type: string;\n  threshold?: number;\n  pattern?: string;\n  [key: string]: unknown;\n}\n\n/** Options for creating a signal */\nexport interface CreateSignalOptions {\n  description?: string;\n  isEnabled?: boolean;\n  severity?: string;\n}\n\n/** Options for updating a signal */\nexport interface UpdateSignalOptions {\n  name?: string;\n  group?: string;\n  description?: string;\n  detectionConfig?: DetectionConfig;\n  isEnabled?: boolean;\n  severity?: string;\n}\n\n/** Options for listing signals */\nexport interface ListSignalsOptions {\n  group?: string;\n  source?: string;\n  isEnabled?: boolean;\n}\n\n/** Options for getting signal stats */\nexport interface SignalStatsOptions {\n  startDate?: string;\n  endDate?: string;\n  agentId?: string;\n}\n\n/** Options for getting signal trends */\nexport interface SignalTrendsOptions {\n  startDate?: string;\n  endDate?: string;\n  agentId?: string;\n  granularity?: 'hour' | 'day' | 'week' | 'month';\n}\n\n/** Options for getting signal traces */\nexport interface SignalTracesOptions {\n  limit?: number;\n  offset?: number;\n  startDate?: string;\n  endDate?: string;\n  agentId?: string;\n}\n\n/** Options for getting signal events */\nexport interface SignalEventsOptions {\n  limit?: number;\n  offset?: number;\n}\n\n/** A behavioral signal definition */\nexport interface Signal {\n  id: string;\n  name: string;\n  group: string;\n  description?: string;\n  detectionConfig: DetectionConfig;\n  isEnabled: boolean;\n  severity?: string;\n  source?: string;\n  createdAt: string;\n  updatedAt: string;\n}\n\n/** Signal statistics */\nexport interface SignalStats {\n  signalId: string;\n  name: string;\n  eventCount: number;\n  traceCount: number;\n  lastTriggeredAt?: string;\n}\n\n/** Signal trend data point */\nexport interface SignalTrendPoint {\n  period: string;\n  eventCount: number;\n  traceCount: number;\n}\n\n/** A signal event occurrence */\nexport interface SignalEvent {\n  id: string;\n  signalId: string;\n  traceId: string;\n  detectedAt: string;\n  metadata?: Record<string, unknown>;\n}\n\n// ============================================================================\n// SIGNALS API CLIENT\n// ============================================================================\n\n/**\n * Signals API client for managing behavioral signal detection\n */\nexport const signals = {\n  /**\n   * List all signals with optional filters\n   *\n   * @param opts - Filter options for group, source, or enabled status\n   * @returns List of signals\n   */\n  async list(opts?: ListSignalsOptions): Promise<Signal[]> {\n    const params = new URLSearchParams();\n    if (opts?.group) params.set('group', opts.group);\n    if (opts?.source) params.set('source', opts.source);\n    if (opts?.isEnabled !== undefined) params.set('isEnabled', String(opts.isEnabled));\n\n    const query = params.toString();\n    const response = await apiRequest<{ signals: Signal[] } | { success: boolean; data: Signal[] }>(`/signals/${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n    // Handle both response formats: { signals: [...] } and { success: true, data: [...] }\n    if ('signals' in response) return response.signals;\n    if ('data' in response) return response.data;\n    return response as unknown as Signal[];\n  },\n\n  /**\n   * Create a new behavioral signal\n   *\n   * @param name - Signal name\n   * @param group - Signal group/category\n   * @param detectionConfig - Detection configuration\n   * @param opts - Additional signal options\n   * @returns The created signal\n   */\n  async create(\n    name: string,\n    group: string,\n    detectionConfig: DetectionConfig,\n    opts?: CreateSignalOptions\n  ): Promise<Signal> {\n    return apiRequestWithData<Signal>('/signals/', {\n      method: 'POST',\n      body: { name, group, detectionConfig, ...opts },\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Update an existing signal\n   *\n   * @param id - Signal ID to update\n   * @param opts - Fields to update\n   * @returns The updated signal\n   */\n  async update(id: string, opts: UpdateSignalOptions): Promise<Signal> {\n    return apiRequestWithData<Signal>(`/signals/${id}`, {\n      method: 'PUT',\n      body: opts,\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Delete a signal\n   *\n   * @param id - Signal ID to delete\n   */\n  async remove(id: string): Promise<void> {\n    return apiRequest<void>(`/signals/${id}`, {\n      method: 'DELETE',\n      apiVersion: 'v1',\n    });\n  },\n\n  /** Alias for remove() */\n  async delete(id: string): Promise<void> {\n    return this.remove(id);\n  },\n\n  /**\n   * Seed default signal definitions\n   *\n   * @returns List of seeded signals\n   */\n  async seedDefaults(): Promise<Signal[]> {\n    return apiRequestWithData<Signal[]>('/signals/seed', {\n      method: 'POST',\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Get signal statistics\n   *\n   * @param opts - Date range and agent filter options\n   * @returns Signal statistics\n   */\n  async getStats(opts?: SignalStatsOptions): Promise<SignalStats[]> {\n    const params = new URLSearchParams();\n    if (opts?.startDate) params.set('startDate', opts.startDate);\n    if (opts?.endDate) params.set('endDate', opts.endDate);\n    if (opts?.agentId) params.set('agentId', opts.agentId);\n\n    const query = params.toString();\n    const response = await apiRequest<{ stats: SignalStats[] } | { success: boolean; data: SignalStats[] }>(`/signals/stats${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n    if ('stats' in response) return response.stats;\n    if ('data' in response) return response.data;\n    return response as unknown as SignalStats[];\n  },\n\n  /**\n   * Get signal trend data over time\n   *\n   * @param opts - Date range, agent, and granularity options\n   * @returns Signal trend data points\n   */\n  async getTrends(opts?: SignalTrendsOptions): Promise<SignalTrendPoint[]> {\n    const params = new URLSearchParams();\n    if (opts?.startDate) params.set('startDate', opts.startDate);\n    if (opts?.endDate) params.set('endDate', opts.endDate);\n    if (opts?.agentId) params.set('agentId', opts.agentId);\n    if (opts?.granularity) params.set('granularity', opts.granularity);\n\n    const query = params.toString();\n    return apiRequestWithData<SignalTrendPoint[]>(`/signals/trends${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Get traces that triggered a specific signal\n   *\n   * @param id - Signal ID\n   * @param opts - Pagination and filter options\n   * @returns Traces associated with the signal\n   */\n  async getTraces(id: string, opts?: SignalTracesOptions): Promise<{\n    traces: any[];\n    limit: number;\n    offset: number;\n    hasMore: boolean;\n  }> {\n    const params = new URLSearchParams();\n    if (opts?.limit !== undefined) params.set('limit', String(opts.limit));\n    if (opts?.offset !== undefined) params.set('offset', String(opts.offset));\n    if (opts?.startDate) params.set('startDate', opts.startDate);\n    if (opts?.endDate) params.set('endDate', opts.endDate);\n    if (opts?.agentId) params.set('agentId', opts.agentId);\n\n    const query = params.toString();\n    return apiRequestWithData(`/signals/${id}/traces${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Get events for a specific signal\n   *\n   * @param id - Signal ID\n   * @param opts - Pagination options\n   * @returns Signal events\n   */\n  async getEvents(id: string, opts?: SignalEventsOptions): Promise<{\n    events: SignalEvent[];\n    limit: number;\n    offset: number;\n    hasMore: boolean;\n  }> {\n    const params = new URLSearchParams();\n    if (opts?.limit !== undefined) params.set('limit', String(opts.limit));\n    if (opts?.offset !== undefined) params.set('offset', String(opts.offset));\n\n    const query = params.toString();\n    return apiRequestWithData(`/signals/${id}/events${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n  },\n};\n\nexport { signals as default };\n"]}
|
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.2.
|
|
5
|
+
export declare const SDK_VERSION = "4.2.5";
|
|
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.2.
|
|
15
|
+
exports.SDK_VERSION = '4.2.5';
|
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvcmUvY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7R0FFRzs7O0FBb0NILGdDQXNCQztBQU1ELDhCQUtDO0FBS0Qsc0NBRUM7QUFLRCxrQ0FHQztBQUtELDRCQUlDO0FBekZELCtFQUErRTtBQUMvRSxZQUFZO0FBQ1osK0VBQStFO0FBRWxFLFFBQUEsV0FBVyxHQUFHLE9BQU8sQ0FBQztBQUN0QixRQUFBLGdCQUFnQixHQUFHLDBCQUEwQixDQUFDO0FBQzlDLFFBQUEsb0JBQW9CLEdBQUcsYUFBYSxDQUFDO0FBZ0JsRCxJQUFJLE1BQU0sR0FBMEIsSUFBSSxDQUFDO0FBQ3pDLElBQUksV0FBVyxHQUFHLEtBQUssQ0FBQztBQUV4QiwrRUFBK0U7QUFDL0UsbUJBQW1CO0FBQ25CLCtFQUErRTtBQUUvRTs7R0FFRztBQUNILFNBQWdCLFVBQVUsQ0FBQyxVQUF1QixFQUFFO0lBQ2xELE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxNQUFNLElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsSUFBSSxFQUFFLENBQUM7SUFDckUsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLE9BQU8sSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQixJQUFJLEVBQUUsQ0FBQztJQUV4RSxJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDeEIsTUFBTSxJQUFJLEtBQUssQ0FDYiw4RUFBOEUsQ0FDL0UsQ0FBQztJQUNKLENBQUM7SUFFRCxNQUFNLEdBQUc7UUFDUCxNQUFNO1FBQ04sT0FBTztRQUNQLFFBQVEsRUFBRSxPQUFPLENBQUMsUUFBUSxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCLElBQUksd0JBQWdCO1FBQ2hGLFdBQVcsRUFBRSxPQUFPLENBQUMsV0FBVyxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsc0JBQXNCLElBQUksNEJBQW9CO1FBQzlGLGNBQWMsRUFBRSxPQUFPLENBQUMsY0FBYyxJQUFJLEtBQUs7UUFDL0MsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVLElBQUksQ0FBQyxXQUFXLEVBQUUsUUFBUSxDQUFDO1FBQ3pELEtBQUssRUFBRSxPQUFPLENBQUMsS0FBSyxJQUFJLEtBQUs7S0FDOUIsQ0FBQztJQUVGLFdBQVcsR0FBRyxJQUFJLENBQUM7SUFDbkIsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVEOzs7R0FHRztBQUNILFNBQWdCLFNBQVM7SUFDdkIsSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQzVCLE1BQU0sSUFBSSxLQUFLLENBQUMsbURBQW1ELENBQUMsQ0FBQztJQUN2RSxDQUFDO0lBQ0QsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVEOztHQUVHO0FBQ0gsU0FBZ0IsYUFBYTtJQUMzQixPQUFPLFdBQVcsQ0FBQztBQUNyQixDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixXQUFXO0lBQ3pCLE1BQU0sR0FBRyxJQUFJLENBQUM7SUFDZCxXQUFXLEdBQUcsS0FBSyxDQUFDO0FBQ3RCLENBQUM7QUFFRDs7R0FFRztBQUNILFNBQWdCLFFBQVEsQ0FBQyxHQUFHLElBQWU7SUFDekMsSUFBSSxNQUFNLEVBQUUsS0FBSyxFQUFFLENBQUM7UUFDbEIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztJQUN0QyxDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVGhpbmtIaXZlIFNESyB2My4wIC0gQ29uZmlndXJhdGlvblxuICovXG5cbmltcG9ydCB0eXBlIHsgSW5pdE9wdGlvbnMsIEZyYW1ld29yayB9IGZyb20gJy4vdHlwZXMnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBDT05TVEFOVFNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGNvbnN0IFNES19WRVJTSU9OID0gJzQuMi41JztcbmV4cG9ydCBjb25zdCBERUZBVUxUX0VORFBPSU5UID0gJ2h0dHBzOi8vYXBwLnRoaW5raGl2ZS5haSc7XG5leHBvcnQgY29uc3QgREVGQVVMVF9TRVJWSUNFX05BTUUgPSAnbXktYWktYWdlbnQnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBHTE9CQUwgQ09ORklHIFNUQVRFXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb2x2ZWRDb25maWcge1xuICBhcGlLZXk6IHN0cmluZztcbiAgYWdlbnRJZDogc3RyaW5nO1xuICBlbmRwb2ludDogc3RyaW5nO1xuICBzZXJ2aWNlTmFtZTogc3RyaW5nO1xuICBhdXRvSW5zdHJ1bWVudDogYm9vbGVhbjtcbiAgZnJhbWV3b3JrczogRnJhbWV3b3JrW107XG4gIGRlYnVnOiBib29sZWFuO1xufVxuXG5sZXQgY29uZmlnOiBSZXNvbHZlZENvbmZpZyB8IG51bGwgPSBudWxsO1xubGV0IGluaXRpYWxpemVkID0gZmFsc2U7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIENPTkZJRyBGVU5DVElPTlNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBJbml0aWFsaXplIGNvbmZpZ3VyYXRpb24gZnJvbSBvcHRpb25zXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpbml0Q29uZmlnKG9wdGlvbnM6IEluaXRPcHRpb25zID0ge30pOiBSZXNvbHZlZENvbmZpZyB7XG4gIGNvbnN0IGFwaUtleSA9IG9wdGlvbnMuYXBpS2V5IHx8IHByb2Nlc3MuZW52LlRISU5LSElWRV9BUElfS0VZIHx8ICcnO1xuICBjb25zdCBhZ2VudElkID0gb3B0aW9ucy5hZ2VudElkIHx8IHByb2Nlc3MuZW52LlRISU5LSElWRV9BR0VOVF9JRCB8fCAnJztcblxuICBpZiAoIWFwaUtleSAmJiAhYWdlbnRJZCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICdFaXRoZXIgYXBpS2V5IG9yIGFnZW50SWQgbXVzdCBiZSBwcm92aWRlZCAob3Igc2V0IFRISU5LSElWRV9BUElfS0VZIGVudiB2YXIpJ1xuICAgICk7XG4gIH1cblxuICBjb25maWcgPSB7XG4gICAgYXBpS2V5LFxuICAgIGFnZW50SWQsXG4gICAgZW5kcG9pbnQ6IG9wdGlvbnMuZW5kcG9pbnQgfHwgcHJvY2Vzcy5lbnYuVEhJTktISVZFX0VORFBPSU5UIHx8IERFRkFVTFRfRU5EUE9JTlQsXG4gICAgc2VydmljZU5hbWU6IG9wdGlvbnMuc2VydmljZU5hbWUgfHwgcHJvY2Vzcy5lbnYuVEhJTktISVZFX1NFUlZJQ0VfTkFNRSB8fCBERUZBVUxUX1NFUlZJQ0VfTkFNRSxcbiAgICBhdXRvSW5zdHJ1bWVudDogb3B0aW9ucy5hdXRvSW5zdHJ1bWVudCA/PyBmYWxzZSxcbiAgICBmcmFtZXdvcmtzOiBvcHRpb25zLmZyYW1ld29ya3MgfHwgWydsYW5nY2hhaW4nLCAnb3BlbmFpJ10sXG4gICAgZGVidWc6IG9wdGlvbnMuZGVidWcgPz8gZmFsc2UsXG4gIH07XG5cbiAgaW5pdGlhbGl6ZWQgPSB0cnVlO1xuICByZXR1cm4gY29uZmlnO1xufVxuXG4vKipcbiAqIEdldCBjdXJyZW50IGNvbmZpZ3VyYXRpb25cbiAqIEB0aHJvd3MgaWYgbm90IGluaXRpYWxpemVkXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRDb25maWcoKTogUmVzb2x2ZWRDb25maWcge1xuICBpZiAoIWNvbmZpZyB8fCAhaW5pdGlhbGl6ZWQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1RoaW5rSGl2ZSBTREsgbm90IGluaXRpYWxpemVkLiBDYWxsIGluaXQoKSBmaXJzdC4nKTtcbiAgfVxuICByZXR1cm4gY29uZmlnO1xufVxuXG4vKipcbiAqIENoZWNrIGlmIFNESyBpcyBpbml0aWFsaXplZFxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNJbml0aWFsaXplZCgpOiBib29sZWFuIHtcbiAgcmV0dXJuIGluaXRpYWxpemVkO1xufVxuXG4vKipcbiAqIFJlc2V0IGNvbmZpZ3VyYXRpb24gKGZvciB0ZXN0aW5nKVxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVzZXRDb25maWcoKTogdm9pZCB7XG4gIGNvbmZpZyA9IG51bGw7XG4gIGluaXRpYWxpemVkID0gZmFsc2U7XG59XG5cbi8qKlxuICogRGVidWcgbG9nIGhlbHBlclxuICovXG5leHBvcnQgZnVuY3Rpb24gZGVidWdMb2coLi4uYXJnczogdW5rbm93bltdKTogdm9pZCB7XG4gIGlmIChjb25maWc/LmRlYnVnKSB7XG4gICAgY29uc29sZS5sb2coJ1tUaGlua0hpdmVdJywgLi4uYXJncyk7XG4gIH1cbn1cbiJdfQ==
|
package/dist/core/types.d.ts
CHANGED
|
@@ -244,11 +244,11 @@ export interface Claim {
|
|
|
244
244
|
createdAt?: string;
|
|
245
245
|
}
|
|
246
246
|
export type ClaimType = 'observed' | 'inferred' | 'computed';
|
|
247
|
-
export type ClaimCategory = 'outcome' | 'root_cause' | '
|
|
248
|
-
export type ConfidenceCalibration = 'calibrated' | 'uncalibrated' | '
|
|
247
|
+
export type ClaimCategory = 'outcome' | 'root_cause' | 'sentiment' | 'churn_risk' | 'escalation_risk' | 'satisfaction' | 'recontact' | 'resolution_time' | 'cost' | 'quality' | 'compliance' | 'other';
|
|
248
|
+
export type ConfidenceCalibration = 'calibrated' | 'uncalibrated' | 'rule_based';
|
|
249
249
|
export interface EvidenceReference {
|
|
250
250
|
/** Type of evidence */
|
|
251
|
-
type: 'span' | 'message' | 'tool_call' | '
|
|
251
|
+
type: 'span' | 'message' | 'tool_call' | 'retrieval' | 'pattern' | 'metric' | 'external';
|
|
252
252
|
/** ID of the referenced item */
|
|
253
253
|
referenceId: string;
|
|
254
254
|
/** How relevant is this evidence */
|
package/dist/core/types.js
CHANGED
|
@@ -5,4 +5,4 @@
|
|
|
5
5
|
* Run-centric types with facts vs inferences and customer context snapshots
|
|
6
6
|
*/
|
|
7
7
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/core/types.ts"],"names":[],"mappings":";AAAA;;;;GAIG","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Core Types\n *\n * Run-centric types with facts vs inferences and customer context snapshots\n */\n\n// ============================================================================\n// INIT OPTIONS\n// ============================================================================\n\nexport interface InitOptions {\n  /** ThinkHive API key (starts with th_) */\n  apiKey?: string;\n  /** Agent ID */\n  agentId?: string;\n  /** ThinkHive API endpoint */\n  endpoint?: string;\n  /** Service name for traces */\n  serviceName?: string;\n  /** Enable auto-instrumentation */\n  autoInstrument?: boolean;\n  /** Frameworks to auto-instrument */\n  frameworks?: Framework[];\n  /** Enable debug logging */\n  debug?: boolean;\n}\n\nexport type Framework =\n  | 'langchain'\n  | 'langgraph'\n  | 'openai'\n  | 'openai-assistants'\n  | 'anthropic'\n  | 'llamaindex'\n  | 'n8n'\n  | 'voiceflow';\n\n// ============================================================================\n// RUN OPTIONS (v3)\n// ============================================================================\n\n/**\n * Options for creating a run (v3 atomic unit)\n */\nexport interface RunOptions {\n  /** Agent ID */\n  agentId: string;\n  /** When the run started */\n  startedAt?: string | Date;\n  /** When the run ended */\n  endedAt?: string | Date;\n  /** Run outcome */\n  outcome?: RunOutcome;\n  /** Reason for the outcome */\n  outcomeReason?: string;\n  /** Conversation messages */\n  conversationMessages: ConversationMessage[];\n  /** Model ID used */\n  modelId?: string;\n  /** Prompt version */\n  promptVersion?: string;\n  /** Session ID for conversation tracking */\n  sessionId?: string;\n  /** Customer context snapshot (ARR, health AS OF this run) */\n  customerContext?: CustomerContextSnapshot;\n  /** Ticket linking options */\n  ticketLinking?: TicketLinkingOptions;\n  /** Custom metadata */\n  metadata?: Record<string, unknown>;\n  /**\n   * Custom business metrics to record with this run.\n   * Keys should match metrics declared during agent setup (onboarding).\n   * Values can be numbers, booleans, or short strings (max 100 chars).\n   *\n   * Metrics are aggregated over time for dashboard display and trend analysis.\n   * Undeclared metrics will be tracked but flagged as \"discovered\" metrics.\n   *\n   * @example\n   * metrics: {\n   *   customer_satisfaction: 4.5,\n   *   resolution_time_ms: 2450,\n   *   escalated: false,\n   *   ticket_priority: 'high'\n   * }\n   */\n  metrics?: Record<string, number | boolean | string>;\n  /**\n   * Request evaluation when run is ingested.\n   * Overrides agent's auto_evaluate setting for this run.\n   *\n   * - true: Force evaluation on this run\n   * - false: Skip evaluation even if agent has auto_evaluate enabled\n   * - undefined: Use agent's auto_evaluate setting (default)\n   */\n  runEvaluation?: boolean;\n}\n\nexport type RunOutcome =\n  | 'resolved'\n  | 'escalated'\n  | 'abandoned'\n  | 'failed'\n  | 'transferred'\n  | 'pending';\n\nexport interface ConversationMessage {\n  role: 'user' | 'assistant' | 'system' | 'tool';\n  content: string;\n  timestamp?: string;\n  metadata?: Record<string, unknown>;\n}\n\n// ============================================================================\n// CUSTOMER CONTEXT SNAPSHOT (v3)\n// ============================================================================\n\n/**\n * Customer context captured AS OF the run time (not current values)\n */\nexport interface CustomerContextSnapshot {\n  /** Customer account ID */\n  customerId?: string;\n  /** ARR at the time of the run (not current ARR) */\n  arr?: number;\n  /** Health score at the time of the run (0-100) */\n  healthScore?: number;\n  /** Customer segment (e.g., 'enterprise', 'mid-market', 'smb') */\n  segment?: string;\n  /** When this snapshot was captured */\n  capturedAt?: string;\n  /** Custom fields (will be validated against schema) */\n  customFields?: Record<string, unknown>;\n}\n\n// ============================================================================\n// TICKET LINKING (v3)\n// ============================================================================\n\n/**\n * Options for deterministic ticket linking\n */\nexport interface TicketLinkingOptions {\n  /** Link method to use */\n  method: LinkMethod;\n  /** Ticket ID (for sdk_explicit method) */\n  ticketId?: string;\n  /** External ticket ID (e.g., Zendesk ticket ID) */\n  externalTicketId?: string;\n  /** Platform for external ticket */\n  platform?: 'zendesk' | 'intercom' | 'salesforce' | 'freshdesk';\n  /** Custom field name for linking */\n  customFieldName?: string;\n  /** Custom field value */\n  customFieldValue?: string;\n}\n\nexport type LinkMethod =\n  | 'sdk_explicit'      // Direct SDK call with ticket ID (confidence: 1.0)\n  | 'zendesk_marker'    // Embedded THID marker in response (confidence: 1.0)\n  | 'custom_field'      // Zendesk custom field (confidence: 1.0)\n  | 'middleware_stamp'  // Middleware-injected trace ID (confidence: 0.98)\n  | 'session_match'     // Session ID correlation (confidence: 0.95)\n  | 'email_time_window' // Email + 15min window (confidence: 0.6)\n  | 'manual';           // Human-assigned (confidence: 1.0)\n\n// ============================================================================\n// TRACE OPTIONS (v2 compatibility)\n// ============================================================================\n\n/**\n * Classification flags for categorizing trace issues\n * Separate from binary outcome (success/failure)\n */\nexport type TraceCustomFlag =\n  | 'hallucination'\n  | 'policy_violation'\n  | 'tone_issue'\n  | 'retrieval_miss'\n  | 'error';\n\n/**\n * Trace options (v2 format, converted to runs internally)\n * @deprecated Use RunOptions instead\n */\nexport interface TraceOptions {\n  /** User's message/query */\n  userMessage: string;\n  /** Agent's response */\n  agentResponse: string;\n  /** User's detected intent */\n  userIntent?: string;\n  /** Binary outcome: success or failure */\n  outcome?: 'success' | 'failure';\n  /** Classification flags for categorizing the issue type (hallucination, policy_violation, etc.) */\n  customFlags?: TraceCustomFlag[];\n  /** Duration in milliseconds */\n  duration?: number;\n  /** Session ID for conversation tracking */\n  sessionId?: string;\n  /** Conversation history */\n  conversationHistory?: Array<{ role: string; content: string }>;\n  /** Span data for detailed analysis */\n  spans?: SpanData[];\n  /** Business context for ROI calculation */\n  businessContext?: BusinessContext;\n  /** Custom metadata */\n  metadata?: Record<string, unknown>;\n  /**\n   * Custom business metrics to record with this trace.\n   * Keys should match metrics declared during agent setup.\n   * Values can be numbers, booleans, or short strings.\n   *\n   * @example\n   * metrics: {\n   *   customer_satisfaction: 4.5,\n   *   resolution_time_ms: 2450,\n   *   escalated: false\n   * }\n   */\n  metrics?: Record<string, number | boolean | string>;\n  /**\n   * Request evaluation when trace is ingested.\n   * Overrides agent's auto_evaluate setting for this trace.\n   *\n   * - true: Force evaluation on this trace\n   * - false: Skip evaluation even if agent has auto_evaluate enabled\n   * - undefined: Use agent's auto_evaluate setting (default)\n   */\n  runEvaluation?: boolean;\n}\n\nexport interface SpanData {\n  id?: string;\n  name: string;\n  type: 'llm' | 'tool' | 'retrieval' | 'embedding' | 'chain' | 'custom';\n  startTime?: Date;\n  endTime?: Date;\n  durationMs?: number;\n  status?: 'ok' | 'error' | 'timeout';\n  error?: string;\n  input?: unknown;\n  output?: unknown;\n  // LLM-specific\n  model?: string;\n  provider?: string;\n  promptTokens?: number;\n  completionTokens?: number;\n  // Tool-specific\n  toolName?: string;\n  toolParameters?: Record<string, unknown>;\n  // Retrieval-specific\n  query?: string;\n  documentCount?: number;\n  topScore?: number;\n  sources?: string[];\n  // Children\n  children?: SpanData[];\n}\n\n/**\n * @deprecated Use CustomerContextSnapshot instead\n */\nexport interface BusinessContext {\n  /** Customer ID */\n  customerId?: string;\n  /** Transaction value in dollars */\n  transactionValue?: number;\n  /** Priority level */\n  priority?: 'low' | 'medium' | 'high' | 'critical';\n  /** Department */\n  department?: string;\n  /** Industry vertical */\n  industry?: string;\n  /** Custom fields */\n  custom?: Record<string, unknown>;\n}\n\n// ============================================================================\n// CLAIM TYPES (v3)\n// ============================================================================\n\n/**\n * A claim about a run (fact vs inference)\n */\nexport interface Claim {\n  id: string;\n  analysisId: string;\n  /** Type of claim */\n  claimType: ClaimType;\n  /** Category of the claim */\n  claimCategory: ClaimCategory;\n  /** The claim text */\n  claimText: string;\n  /** Confidence in this claim (0-1) */\n  confidence: number;\n  /** How well calibrated is this confidence */\n  confidenceCalibration: ConfidenceCalibration;\n  /** Evidence supporting this claim */\n  evidence: EvidenceReference[];\n  /** Is this claim explainable to end users */\n  isExplainable: boolean;\n  /** Probability value for probability claims */\n  probabilityValue?: number;\n  /** Human-assigned verification status */\n  humanVerified?: boolean;\n  /** Human verification verdict */\n  humanVerdict?: 'confirmed' | 'rejected' | 'modified';\n  createdAt?: string;\n}\n\nexport type ClaimType = 'observed' | 'inferred' | 'computed';\nexport type ClaimCategory =\n  | 'outcome'\n  | 'root_cause'\n  | 'customer_impact'\n  | 'churn_risk'\n  | 'revenue_impact'\n  | 'quality'\n  | 'other';\nexport type ConfidenceCalibration = 'calibrated' | 'uncalibrated' | 'needs_more_data';\n\nexport interface EvidenceReference {\n  /** Type of evidence */\n  type: 'span' | 'message' | 'tool_call' | 'external' | 'computed';\n  /** ID of the referenced item */\n  referenceId: string;\n  /** How relevant is this evidence */\n  relevance: string;\n  /** Confidence in this evidence */\n  confidence: number;\n}\n\n// ============================================================================\n// ANALYSIS RESULT (v3)\n// ============================================================================\n\nexport interface AnalysisResult {\n  id: string;\n  runId: string;\n  analysisVersion: string;\n  modelUsed: string;\n  /** Overall outcome verdict */\n  outcomeVerdict: 'success' | 'partial_success' | 'failure';\n  /** Confidence in the verdict (0-1) */\n  outcomeConfidence: number;\n  /** Root cause category if failure */\n  rootCauseCategory?: string;\n  /** Confidence in root cause (0-1) */\n  rootCauseConfidence?: number;\n  /** Is this the current analysis */\n  isCurrent: boolean;\n  /** ID of analysis that superseded this one */\n  supersededBy?: string;\n  /** Claims from this analysis */\n  claims: Claim[];\n  analyzedAt?: string;\n  createdAt?: string;\n}\n\n// ============================================================================\n// CALIBRATION TYPES (v3)\n// ============================================================================\n\nexport interface CalibrationStatus {\n  agentId: string;\n  predictionType: PredictionType;\n  /** Brier score (lower is better, <0.1 is good) */\n  brierScore: number;\n  /** Expected Calibration Error */\n  ece: number;\n  /** Sample count */\n  sampleCount: number;\n  /** Is the model well-calibrated */\n  isCalibrated: boolean;\n  /** Calibration by confidence bucket */\n  buckets: CalibrationBucket[];\n  lastUpdated?: string;\n}\n\nexport type PredictionType =\n  | 'outcome'\n  | 'churn_risk'\n  | 'escalation_risk'\n  | 'resolution_time'\n  | 'customer_satisfaction';\n\nexport interface CalibrationBucket {\n  bucketStart: number;\n  bucketEnd: number;\n  predictedProbability: number;\n  actualFrequency: number;\n  sampleCount: number;\n}\n\n// ============================================================================\n// ROI TYPES (v3)\n// ============================================================================\n\nexport interface RoiConfig {\n  /** Cost per support ticket deflected */\n  ticketDeflectionValue: number;\n  /** Cost per escalation */\n  escalationCost: number;\n  /** Cost per hour of agent time */\n  agentHourlyCost: number;\n  /** Average resolution time (minutes) */\n  avgResolutionMinutes: number;\n  /** CSAT impact multiplier */\n  csatImpactMultiplier: number;\n}\n\nexport interface RoiSummary {\n  period: { from: string; to: string };\n  /** Total estimated savings */\n  totalSavings: number;\n  /** Breakdown by category */\n  breakdown: {\n    ticketDeflection: number;\n    escalationPrevention: number;\n    timeToResolution: number;\n    churnPrevention: number;\n  };\n  /** Confidence in these estimates */\n  confidence: 'low' | 'medium' | 'high';\n  /** Methodology used */\n  methodology: string;\n}\n\n// ============================================================================\n// EXPLAINABILITY RESULT (v2 compatibility)\n// ============================================================================\n\n/**\n * @deprecated Use AnalysisResult instead\n */\nexport interface ExplainabilityResult {\n  traceId: string;\n  explainabilityId: string;\n  summary: string;\n  outcome: {\n    verdict: 'success' | 'partial_success' | 'failure';\n    confidence: number;\n    reasoning: string;\n  };\n  businessImpact: {\n    impactScore: number;\n    customerSatisfaction: number;\n    revenueRisk: string;\n  };\n  recommendations: Array<{\n    priority: string;\n    category: string;\n    action: string;\n    expectedImpact: string;\n  }>;\n  ragEvaluation?: {\n    groundedness: number;\n    faithfulness: number;\n    answerRelevance: number;\n  };\n  hallucinationReport?: {\n    detected: boolean;\n    types: string[];\n    severity: string;\n  };\n  processingTimeMs: number;\n}\n\n// ============================================================================\n// API RESPONSE TYPES\n// ============================================================================\n\nexport interface ApiResponse<T> {\n  success: boolean;\n  data?: T;\n  error?: {\n    code: string;\n    message: string;\n    details?: unknown;\n  };\n}\n\nexport interface PaginatedResponse<T> {\n  success: boolean;\n  data: {\n    items: T[];\n    limit: number;\n    offset: number;\n    hasMore: boolean;\n  };\n}\n\nexport interface RunResponse {\n  id: string;\n  companyId: string;\n  agentId: string;\n  ticketId?: string;\n  customerAccountId?: string;\n  sessionId?: string;\n  startedAt: string;\n  endedAt?: string;\n  durationMs?: number;\n  outcome?: RunOutcome;\n  outcomeReason?: string;\n  conversationMessages: ConversationMessage[];\n  modelId?: string;\n  promptVersion?: string;\n  customerContextSnapshot?: CustomerContextSnapshot;\n  zendeskMarker?: string;\n  createdAt: string;\n  updatedAt: string;\n}\n"]}
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/core/types.ts"],"names":[],"mappings":";AAAA;;;;GAIG","sourcesContent":["/**\n * ThinkHive SDK v3.0 - Core Types\n *\n * Run-centric types with facts vs inferences and customer context snapshots\n */\n\n// ============================================================================\n// INIT OPTIONS\n// ============================================================================\n\nexport interface InitOptions {\n  /** ThinkHive API key (starts with th_) */\n  apiKey?: string;\n  /** Agent ID */\n  agentId?: string;\n  /** ThinkHive API endpoint */\n  endpoint?: string;\n  /** Service name for traces */\n  serviceName?: string;\n  /** Enable auto-instrumentation */\n  autoInstrument?: boolean;\n  /** Frameworks to auto-instrument */\n  frameworks?: Framework[];\n  /** Enable debug logging */\n  debug?: boolean;\n}\n\nexport type Framework =\n  | 'langchain'\n  | 'langgraph'\n  | 'openai'\n  | 'openai-assistants'\n  | 'anthropic'\n  | 'llamaindex'\n  | 'n8n'\n  | 'voiceflow';\n\n// ============================================================================\n// RUN OPTIONS (v3)\n// ============================================================================\n\n/**\n * Options for creating a run (v3 atomic unit)\n */\nexport interface RunOptions {\n  /** Agent ID */\n  agentId: string;\n  /** When the run started */\n  startedAt?: string | Date;\n  /** When the run ended */\n  endedAt?: string | Date;\n  /** Run outcome */\n  outcome?: RunOutcome;\n  /** Reason for the outcome */\n  outcomeReason?: string;\n  /** Conversation messages */\n  conversationMessages: ConversationMessage[];\n  /** Model ID used */\n  modelId?: string;\n  /** Prompt version */\n  promptVersion?: string;\n  /** Session ID for conversation tracking */\n  sessionId?: string;\n  /** Customer context snapshot (ARR, health AS OF this run) */\n  customerContext?: CustomerContextSnapshot;\n  /** Ticket linking options */\n  ticketLinking?: TicketLinkingOptions;\n  /** Custom metadata */\n  metadata?: Record<string, unknown>;\n  /**\n   * Custom business metrics to record with this run.\n   * Keys should match metrics declared during agent setup (onboarding).\n   * Values can be numbers, booleans, or short strings (max 100 chars).\n   *\n   * Metrics are aggregated over time for dashboard display and trend analysis.\n   * Undeclared metrics will be tracked but flagged as \"discovered\" metrics.\n   *\n   * @example\n   * metrics: {\n   *   customer_satisfaction: 4.5,\n   *   resolution_time_ms: 2450,\n   *   escalated: false,\n   *   ticket_priority: 'high'\n   * }\n   */\n  metrics?: Record<string, number | boolean | string>;\n  /**\n   * Request evaluation when run is ingested.\n   * Overrides agent's auto_evaluate setting for this run.\n   *\n   * - true: Force evaluation on this run\n   * - false: Skip evaluation even if agent has auto_evaluate enabled\n   * - undefined: Use agent's auto_evaluate setting (default)\n   */\n  runEvaluation?: boolean;\n}\n\nexport type RunOutcome =\n  | 'resolved'\n  | 'escalated'\n  | 'abandoned'\n  | 'failed'\n  | 'transferred'\n  | 'pending';\n\nexport interface ConversationMessage {\n  role: 'user' | 'assistant' | 'system' | 'tool';\n  content: string;\n  timestamp?: string;\n  metadata?: Record<string, unknown>;\n}\n\n// ============================================================================\n// CUSTOMER CONTEXT SNAPSHOT (v3)\n// ============================================================================\n\n/**\n * Customer context captured AS OF the run time (not current values)\n */\nexport interface CustomerContextSnapshot {\n  /** Customer account ID */\n  customerId?: string;\n  /** ARR at the time of the run (not current ARR) */\n  arr?: number;\n  /** Health score at the time of the run (0-100) */\n  healthScore?: number;\n  /** Customer segment (e.g., 'enterprise', 'mid-market', 'smb') */\n  segment?: string;\n  /** When this snapshot was captured */\n  capturedAt?: string;\n  /** Custom fields (will be validated against schema) */\n  customFields?: Record<string, unknown>;\n}\n\n// ============================================================================\n// TICKET LINKING (v3)\n// ============================================================================\n\n/**\n * Options for deterministic ticket linking\n */\nexport interface TicketLinkingOptions {\n  /** Link method to use */\n  method: LinkMethod;\n  /** Ticket ID (for sdk_explicit method) */\n  ticketId?: string;\n  /** External ticket ID (e.g., Zendesk ticket ID) */\n  externalTicketId?: string;\n  /** Platform for external ticket */\n  platform?: 'zendesk' | 'intercom' | 'salesforce' | 'freshdesk';\n  /** Custom field name for linking */\n  customFieldName?: string;\n  /** Custom field value */\n  customFieldValue?: string;\n}\n\nexport type LinkMethod =\n  | 'sdk_explicit'      // Direct SDK call with ticket ID (confidence: 1.0)\n  | 'zendesk_marker'    // Embedded THID marker in response (confidence: 1.0)\n  | 'custom_field'      // Zendesk custom field (confidence: 1.0)\n  | 'middleware_stamp'  // Middleware-injected trace ID (confidence: 0.98)\n  | 'session_match'     // Session ID correlation (confidence: 0.95)\n  | 'email_time_window' // Email + 15min window (confidence: 0.6)\n  | 'manual';           // Human-assigned (confidence: 1.0)\n\n// ============================================================================\n// TRACE OPTIONS (v2 compatibility)\n// ============================================================================\n\n/**\n * Classification flags for categorizing trace issues\n * Separate from binary outcome (success/failure)\n */\nexport type TraceCustomFlag =\n  | 'hallucination'\n  | 'policy_violation'\n  | 'tone_issue'\n  | 'retrieval_miss'\n  | 'error';\n\n/**\n * Trace options (v2 format, converted to runs internally)\n * @deprecated Use RunOptions instead\n */\nexport interface TraceOptions {\n  /** User's message/query */\n  userMessage: string;\n  /** Agent's response */\n  agentResponse: string;\n  /** User's detected intent */\n  userIntent?: string;\n  /** Binary outcome: success or failure */\n  outcome?: 'success' | 'failure';\n  /** Classification flags for categorizing the issue type (hallucination, policy_violation, etc.) */\n  customFlags?: TraceCustomFlag[];\n  /** Duration in milliseconds */\n  duration?: number;\n  /** Session ID for conversation tracking */\n  sessionId?: string;\n  /** Conversation history */\n  conversationHistory?: Array<{ role: string; content: string }>;\n  /** Span data for detailed analysis */\n  spans?: SpanData[];\n  /** Business context for ROI calculation */\n  businessContext?: BusinessContext;\n  /** Custom metadata */\n  metadata?: Record<string, unknown>;\n  /**\n   * Custom business metrics to record with this trace.\n   * Keys should match metrics declared during agent setup.\n   * Values can be numbers, booleans, or short strings.\n   *\n   * @example\n   * metrics: {\n   *   customer_satisfaction: 4.5,\n   *   resolution_time_ms: 2450,\n   *   escalated: false\n   * }\n   */\n  metrics?: Record<string, number | boolean | string>;\n  /**\n   * Request evaluation when trace is ingested.\n   * Overrides agent's auto_evaluate setting for this trace.\n   *\n   * - true: Force evaluation on this trace\n   * - false: Skip evaluation even if agent has auto_evaluate enabled\n   * - undefined: Use agent's auto_evaluate setting (default)\n   */\n  runEvaluation?: boolean;\n}\n\nexport interface SpanData {\n  id?: string;\n  name: string;\n  type: 'llm' | 'tool' | 'retrieval' | 'embedding' | 'chain' | 'custom';\n  startTime?: Date;\n  endTime?: Date;\n  durationMs?: number;\n  status?: 'ok' | 'error' | 'timeout';\n  error?: string;\n  input?: unknown;\n  output?: unknown;\n  // LLM-specific\n  model?: string;\n  provider?: string;\n  promptTokens?: number;\n  completionTokens?: number;\n  // Tool-specific\n  toolName?: string;\n  toolParameters?: Record<string, unknown>;\n  // Retrieval-specific\n  query?: string;\n  documentCount?: number;\n  topScore?: number;\n  sources?: string[];\n  // Children\n  children?: SpanData[];\n}\n\n/**\n * @deprecated Use CustomerContextSnapshot instead\n */\nexport interface BusinessContext {\n  /** Customer ID */\n  customerId?: string;\n  /** Transaction value in dollars */\n  transactionValue?: number;\n  /** Priority level */\n  priority?: 'low' | 'medium' | 'high' | 'critical';\n  /** Department */\n  department?: string;\n  /** Industry vertical */\n  industry?: string;\n  /** Custom fields */\n  custom?: Record<string, unknown>;\n}\n\n// ============================================================================\n// CLAIM TYPES (v3)\n// ============================================================================\n\n/**\n * A claim about a run (fact vs inference)\n */\nexport interface Claim {\n  id: string;\n  analysisId: string;\n  /** Type of claim */\n  claimType: ClaimType;\n  /** Category of the claim */\n  claimCategory: ClaimCategory;\n  /** The claim text */\n  claimText: string;\n  /** Confidence in this claim (0-1) */\n  confidence: number;\n  /** How well calibrated is this confidence */\n  confidenceCalibration: ConfidenceCalibration;\n  /** Evidence supporting this claim */\n  evidence: EvidenceReference[];\n  /** Is this claim explainable to end users */\n  isExplainable: boolean;\n  /** Probability value for probability claims */\n  probabilityValue?: number;\n  /** Human-assigned verification status */\n  humanVerified?: boolean;\n  /** Human verification verdict */\n  humanVerdict?: 'confirmed' | 'rejected' | 'modified';\n  createdAt?: string;\n}\n\nexport type ClaimType = 'observed' | 'inferred' | 'computed';\nexport type ClaimCategory =\n  | 'outcome'\n  | 'root_cause'\n  | 'sentiment'\n  | 'churn_risk'\n  | 'escalation_risk'\n  | 'satisfaction'\n  | 'recontact'\n  | 'resolution_time'\n  | 'cost'\n  | 'quality'\n  | 'compliance'\n  | 'other';\nexport type ConfidenceCalibration = 'calibrated' | 'uncalibrated' | 'rule_based';\n\nexport interface EvidenceReference {\n  /** Type of evidence */\n  type: 'span' | 'message' | 'tool_call' | 'retrieval' | 'pattern' | 'metric' | 'external';\n  /** ID of the referenced item */\n  referenceId: string;\n  /** How relevant is this evidence */\n  relevance: string;\n  /** Confidence in this evidence */\n  confidence: number;\n}\n\n// ============================================================================\n// ANALYSIS RESULT (v3)\n// ============================================================================\n\nexport interface AnalysisResult {\n  id: string;\n  runId: string;\n  analysisVersion: string;\n  modelUsed: string;\n  /** Overall outcome verdict */\n  outcomeVerdict: 'success' | 'partial_success' | 'failure';\n  /** Confidence in the verdict (0-1) */\n  outcomeConfidence: number;\n  /** Root cause category if failure */\n  rootCauseCategory?: string;\n  /** Confidence in root cause (0-1) */\n  rootCauseConfidence?: number;\n  /** Is this the current analysis */\n  isCurrent: boolean;\n  /** ID of analysis that superseded this one */\n  supersededBy?: string;\n  /** Claims from this analysis */\n  claims: Claim[];\n  analyzedAt?: string;\n  createdAt?: string;\n}\n\n// ============================================================================\n// CALIBRATION TYPES (v3)\n// ============================================================================\n\nexport interface CalibrationStatus {\n  agentId: string;\n  predictionType: PredictionType;\n  /** Brier score (lower is better, <0.1 is good) */\n  brierScore: number;\n  /** Expected Calibration Error */\n  ece: number;\n  /** Sample count */\n  sampleCount: number;\n  /** Is the model well-calibrated */\n  isCalibrated: boolean;\n  /** Calibration by confidence bucket */\n  buckets: CalibrationBucket[];\n  lastUpdated?: string;\n}\n\nexport type PredictionType =\n  | 'outcome'\n  | 'churn_risk'\n  | 'escalation_risk'\n  | 'resolution_time'\n  | 'customer_satisfaction';\n\nexport interface CalibrationBucket {\n  bucketStart: number;\n  bucketEnd: number;\n  predictedProbability: number;\n  actualFrequency: number;\n  sampleCount: number;\n}\n\n// ============================================================================\n// ROI TYPES (v3)\n// ============================================================================\n\nexport interface RoiConfig {\n  /** Cost per support ticket deflected */\n  ticketDeflectionValue: number;\n  /** Cost per escalation */\n  escalationCost: number;\n  /** Cost per hour of agent time */\n  agentHourlyCost: number;\n  /** Average resolution time (minutes) */\n  avgResolutionMinutes: number;\n  /** CSAT impact multiplier */\n  csatImpactMultiplier: number;\n}\n\nexport interface RoiSummary {\n  period: { from: string; to: string };\n  /** Total estimated savings */\n  totalSavings: number;\n  /** Breakdown by category */\n  breakdown: {\n    ticketDeflection: number;\n    escalationPrevention: number;\n    timeToResolution: number;\n    churnPrevention: number;\n  };\n  /** Confidence in these estimates */\n  confidence: 'low' | 'medium' | 'high';\n  /** Methodology used */\n  methodology: string;\n}\n\n// ============================================================================\n// EXPLAINABILITY RESULT (v2 compatibility)\n// ============================================================================\n\n/**\n * @deprecated Use AnalysisResult instead\n */\nexport interface ExplainabilityResult {\n  traceId: string;\n  explainabilityId: string;\n  summary: string;\n  outcome: {\n    verdict: 'success' | 'partial_success' | 'failure';\n    confidence: number;\n    reasoning: string;\n  };\n  businessImpact: {\n    impactScore: number;\n    customerSatisfaction: number;\n    revenueRisk: string;\n  };\n  recommendations: Array<{\n    priority: string;\n    category: string;\n    action: string;\n    expectedImpact: string;\n  }>;\n  ragEvaluation?: {\n    groundedness: number;\n    faithfulness: number;\n    answerRelevance: number;\n  };\n  hallucinationReport?: {\n    detected: boolean;\n    types: string[];\n    severity: string;\n  };\n  processingTimeMs: number;\n}\n\n// ============================================================================\n// API RESPONSE TYPES\n// ============================================================================\n\nexport interface ApiResponse<T> {\n  success: boolean;\n  data?: T;\n  error?: {\n    code: string;\n    message: string;\n    details?: unknown;\n  };\n}\n\nexport interface PaginatedResponse<T> {\n  success: boolean;\n  data: {\n    items: T[];\n    limit: number;\n    offset: number;\n    hasMore: boolean;\n  };\n}\n\nexport interface RunResponse {\n  id: string;\n  companyId: string;\n  agentId: string;\n  ticketId?: string;\n  customerAccountId?: string;\n  sessionId?: string;\n  startedAt: string;\n  endedAt?: string;\n  durationMs?: number;\n  outcome?: RunOutcome;\n  outcomeReason?: string;\n  conversationMessages: ConversationMessage[];\n  modelId?: string;\n  promptVersion?: string;\n  customerContextSnapshot?: CustomerContextSnapshot;\n  zendeskMarker?: string;\n  createdAt: string;\n  updatedAt: string;\n}\n"]}
|
package/dist/index.d.ts
CHANGED
|
@@ -692,7 +692,11 @@ declare const _default: {
|
|
|
692
692
|
};
|
|
693
693
|
}>;
|
|
694
694
|
calculateV3(options: {
|
|
695
|
-
agentId
|
|
695
|
+
agentId
|
|
696
|
+
/**
|
|
697
|
+
* Trace an LLM call
|
|
698
|
+
*/
|
|
699
|
+
?: string;
|
|
696
700
|
startDate: string | Date;
|
|
697
701
|
endDate: string | Date;
|
|
698
702
|
configurationVersion?: number;
|
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"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@thinkhive/sdk",
|
|
3
|
-
"version": "4.2.
|
|
3
|
+
"version": "4.2.5",
|
|
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",
|
|
@@ -81,23 +81,23 @@
|
|
|
81
81
|
"node": ">=18.0.0"
|
|
82
82
|
},
|
|
83
83
|
"dependencies": {
|
|
84
|
-
"@opentelemetry/api": "^1.
|
|
85
|
-
"@opentelemetry/exporter-trace-otlp-proto": "^0.
|
|
86
|
-
"@opentelemetry/resources": "^
|
|
87
|
-
"@opentelemetry/sdk-trace-
|
|
88
|
-
"@opentelemetry/sdk-trace-
|
|
84
|
+
"@opentelemetry/api": "^1.9.0",
|
|
85
|
+
"@opentelemetry/exporter-trace-otlp-proto": "^0.213.0",
|
|
86
|
+
"@opentelemetry/resources": "^2.6.0",
|
|
87
|
+
"@opentelemetry/sdk-trace-base": "^2.6.0",
|
|
88
|
+
"@opentelemetry/sdk-trace-node": "^2.6.0"
|
|
89
89
|
},
|
|
90
90
|
"devDependencies": {
|
|
91
91
|
"@types/node": "^20.0.0",
|
|
92
|
-
"typescript": "^5.0.0",
|
|
93
|
-
"vitest": "^1.0.0",
|
|
94
|
-
"eslint": "^8.0.0",
|
|
95
92
|
"@typescript-eslint/eslint-plugin": "^6.0.0",
|
|
96
|
-
"@typescript-eslint/parser": "^6.0.0"
|
|
93
|
+
"@typescript-eslint/parser": "^6.0.0",
|
|
94
|
+
"eslint": "^8.0.0",
|
|
95
|
+
"typescript": "^5.0.0",
|
|
96
|
+
"vitest": "^1.0.0"
|
|
97
97
|
},
|
|
98
98
|
"peerDependencies": {
|
|
99
|
-
"
|
|
100
|
-
"
|
|
99
|
+
"@langchain/core": ">=0.1.0",
|
|
100
|
+
"openai": ">=4.0.0"
|
|
101
101
|
},
|
|
102
102
|
"peerDependenciesMeta": {
|
|
103
103
|
"openai": {
|