langwatch 0.1.3 → 0.1.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/index.mjs CHANGED
@@ -8,16 +8,16 @@ import {
8
8
  reservedSpanParamsSchema,
9
9
  reservedTraceMetadataSchema,
10
10
  spanSchema
11
- } from "./chunk-2I4YLOQY.mjs";
11
+ } from "./chunk-I5AU3P36.mjs";
12
12
 
13
13
  // src/index.ts
14
- import EventEmitter from "events";
14
+ import EventEmitter from "eventemitter3";
15
15
  import { nanoid } from "nanoid";
16
16
  import { ZodError } from "zod";
17
17
  import { fromZodError } from "zod-validation-error";
18
18
 
19
19
  // package.json
20
- var version = "0.1.3";
20
+ var version = "0.1.5";
21
21
 
22
22
  // src/evaluations.ts
23
23
  var evaluate = async (params) => {
@@ -455,14 +455,14 @@ function camelToSnakeCase(str) {
455
455
  function camelToSnakeCaseNested(obj, parentKey) {
456
456
  if (Array.isArray(obj)) {
457
457
  return obj.map(
458
- (item) => camelToSnakeCaseNested(item)
458
+ (item) => camelToSnakeCaseNested(item, parentKey)
459
459
  );
460
460
  } else if (typeof obj === "object" && obj !== null) {
461
461
  const newObj = {};
462
462
  for (const key in obj) {
463
463
  if (obj.hasOwnProperty(key)) {
464
464
  const newKey = camelToSnakeCase(key);
465
- if (parentKey === "metadata" && !Object.keys(reservedTraceMetadataSchema.shape).includes(newKey) || parentKey === "params" && !Object.keys(reservedSpanParamsSchema.shape).includes(newKey)) {
465
+ if (parentKey === "metadata" && !Object.keys(reservedTraceMetadataSchema.shape).includes(newKey) || parentKey === "params" && !Object.keys(reservedSpanParamsSchema.shape).includes(newKey) || parentKey === "input" && ["json", "raw", "list"].includes(newObj.type) && newKey === "value" || parentKey === "output" && ["json", "raw", "list"].includes(newObj.type) && newKey === "value" || parentKey === "contexts" && newKey === "content") {
466
466
  newObj[key] = obj[key];
467
467
  } else {
468
468
  newObj[newKey] = camelToSnakeCaseNested(obj[key], newKey);
@@ -475,6 +475,76 @@ function camelToSnakeCaseNested(obj, parentKey) {
475
475
  }
476
476
  }
477
477
 
478
+ // src/LangWatchExporter.ts
479
+ import { createExportTraceServiceRequest } from "@opentelemetry/otlp-transformer";
480
+
481
+ // node_modules/@opentelemetry/core/build/esm/ExportResult.js
482
+ var ExportResultCode;
483
+ (function(ExportResultCode2) {
484
+ ExportResultCode2[ExportResultCode2["SUCCESS"] = 0] = "SUCCESS";
485
+ ExportResultCode2[ExportResultCode2["FAILED"] = 1] = "FAILED";
486
+ })(ExportResultCode || (ExportResultCode = {}));
487
+
488
+ // src/LangWatchExporter.ts
489
+ var LangWatchExporter = class {
490
+ constructor(params = {}) {
491
+ var _a, _b, _c, _d, _e, _f;
492
+ this.endpoint = (_b = (_a = params.endpoint) != null ? _a : process.env.LANGWATCH_ENDPOINT) != null ? _b : "https://app.langwatch.ai";
493
+ this.apiKey = (_d = (_c = params.apiKey) != null ? _c : process.env.LANGWATCH_API_KEY) != null ? _d : "";
494
+ this.includeAllSpans = (_e = params.includeAllSpans) != null ? _e : false;
495
+ this.debug = (_f = params.debug) != null ? _f : false;
496
+ if (!this.apiKey) {
497
+ throw new Error("LANGWATCH_API_KEY is not set");
498
+ }
499
+ }
500
+ export(allSpans, resultCallback) {
501
+ const spans = allSpans.filter(
502
+ (span) => this.includeAllSpans || this.isAiSdkSpan(span)
503
+ );
504
+ if (spans.length === 0) {
505
+ resultCallback({ code: ExportResultCode.SUCCESS });
506
+ return;
507
+ }
508
+ if (this.debug) {
509
+ console.log("[LangWatchExporter] Exporting spans:", spans);
510
+ }
511
+ let body;
512
+ try {
513
+ body = JSON.stringify(createExportTraceServiceRequest(spans));
514
+ } catch (error) {
515
+ console.error("[LangWatchExporter] Failed to serialize spans:", error);
516
+ resultCallback({ code: ExportResultCode.FAILED });
517
+ return;
518
+ }
519
+ fetch(`${this.endpoint}/api/otel/v1/traces`, {
520
+ method: "POST",
521
+ headers: {
522
+ "Content-Type": "application/json",
523
+ Authorization: `Bearer ${this.apiKey}`
524
+ },
525
+ body
526
+ }).then((response) => {
527
+ if (!response.ok) {
528
+ resultCallback({ code: ExportResultCode.FAILED });
529
+ return;
530
+ }
531
+ resultCallback({ code: ExportResultCode.SUCCESS });
532
+ }).catch((error) => {
533
+ console.error("[LangWatchExporter] Failed to export spans:", error);
534
+ resultCallback({
535
+ code: ExportResultCode.FAILED,
536
+ error: error instanceof Error ? error : new Error("Unknown error")
537
+ });
538
+ });
539
+ }
540
+ isAiSdkSpan(span) {
541
+ return span.instrumentationLibrary.name === "ai";
542
+ }
543
+ shutdown() {
544
+ return Promise.resolve();
545
+ }
546
+ };
547
+
478
548
  // src/index.ts
479
549
  var LangWatch = class extends EventEmitter {
480
550
  constructor({
@@ -878,6 +948,7 @@ var LangWatchRAGSpan = class extends LangWatchSpan {
878
948
  };
879
949
  export {
880
950
  LangWatch,
951
+ LangWatchExporter,
881
952
  LangWatchLLMSpan,
882
953
  LangWatchRAGSpan,
883
954
  LangWatchSpan,
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../package.json","../src/evaluations.ts","../src/langchain.ts","../src/typeUtils.ts"],"sourcesContent":["import EventEmitter from \"events\";\nimport { nanoid } from \"nanoid\";\nimport { ZodError } from \"zod\";\nimport { fromZodError } from \"zod-validation-error\";\nimport { version } from \"../package.json\";\nimport {\n evaluate,\n type EvaluationParams,\n type EvaluationResultModel,\n} from \"./evaluations\";\nimport { LangWatchCallbackHandler } from \"./langchain\";\nimport {\n type CollectorRESTParams,\n type EvaluationResult,\n type Span as ServerSpan,\n type SpanTypes,\n type TypedValueEvaluationResult,\n} from \"./server/types/tracer\";\nimport {\n collectorRESTParamsSchema,\n spanSchema,\n} from \"./server/types/tracer.generated\";\nimport {\n type BaseSpan,\n type ChatMessage,\n type ChatRichContent,\n type LLMSpan,\n type Metadata,\n type PendingBaseSpan,\n type PendingLLMSpan,\n type PendingRAGSpan,\n type RAGSpan,\n type RESTEvaluation,\n type SpanInputOutput,\n} from \"./types\";\nimport { camelToSnakeCaseNested, type Strict } from \"./typeUtils\";\nimport {\n autoconvertTypedValues,\n captureError,\n convertFromVercelAIMessages,\n} from \"./utils\";\n\nexport type {\n BaseSpan,\n ChatMessage as ChatMessage,\n ChatRichContent,\n LLMSpan,\n Metadata,\n PendingBaseSpan,\n PendingLLMSpan,\n PendingRAGSpan,\n RAGSpan,\n SpanInputOutput,\n};\n\nexport { autoconvertTypedValues, captureError, convertFromVercelAIMessages };\n\nexport class LangWatch extends EventEmitter {\n apiKey: string | undefined;\n endpoint: string;\n\n constructor({\n apiKey,\n endpoint = process.env.LANGWATCH_ENDPOINT ?? \"https://app.langwatch.ai\",\n }: {\n apiKey?: string;\n endpoint?: string;\n } = {}) {\n super();\n const apiKey_ = apiKey ?? process.env.LANGWATCH_API_KEY;\n if (!apiKey_) {\n const error = new Error(\n \"LangWatch API key is not set, please set the LANGWATCH_API_KEY environment variable or pass it in the constructor. Traces will not be captured.\"\n );\n this.emit(\"error\", error);\n }\n this.apiKey = apiKey_;\n this.endpoint = endpoint;\n }\n\n getTrace({\n traceId,\n metadata,\n }: { traceId?: string; metadata?: Metadata } = {}) {\n return new LangWatchTrace({\n client: this,\n traceId: traceId ?? `trace_${nanoid()}`,\n metadata,\n });\n }\n\n async sendTrace(params: CollectorRESTParams) {\n const backoff = [1000, 2000, 4000, 8000, 16000];\n for (const backoffTime of backoff) {\n try {\n await this._sendTrace(params);\n return;\n } catch (e) {\n console.warn(\n `[LangWatch] ⚠️ Failed to send trace, retrying in ${\n backoffTime / 1000\n }s`\n );\n await new Promise((resolve) => setTimeout(resolve, backoffTime));\n }\n }\n console.warn(\"[LangWatch] ⚠️ Failed to send trace, giving up\");\n }\n\n async _sendTrace(params: CollectorRESTParams) {\n if (params.spans.length === 0) {\n return;\n }\n\n if (!this.apiKey) {\n const error = new Error(\n \"LangWatch API key is not set, LLMs traces will not be sent, go to https://langwatch.ai to set it up\"\n );\n this.emit(\"error\", error);\n return;\n }\n\n const response = await fetch(`${this.endpoint}/api/collector`, {\n method: \"POST\",\n headers: {\n \"X-Auth-Token\": this.apiKey,\n \"Content-Type\": \"application/json\",\n },\n body: JSON.stringify(params),\n });\n\n if (response.status === 429) {\n const error = new Error(\n \"Rate limit exceeded, dropping message from being sent to LangWatch. Please check your dashboard to upgrade your plan.\"\n );\n this.emit(\"error\", error);\n return;\n }\n if (!response.ok) {\n const error = new Error(\n `Failed to send trace, status: ${response.status}`\n );\n this.emit(\"error\", error);\n throw error;\n }\n }\n}\n\ntype CurrentSpan = {\n current: LangWatchSpan;\n previous?: CurrentSpan;\n};\n\ntype AddEvaluationParams = {\n evaluationId?: string;\n span?: LangWatchSpan;\n name: string;\n type?: string;\n isGuardrail?: boolean;\n status?: \"processed\" | \"skipped\" | \"error\";\n passed?: boolean;\n score?: number;\n label?: string;\n details?: string;\n error?: Error;\n timestamps?: RESTEvaluation[\"timestamps\"];\n};\n\nexport class LangWatchTrace {\n client: LangWatch;\n traceId: string;\n metadata?: Metadata;\n finishedSpans: Record<string, ServerSpan> = {};\n langchainCallback?: LangWatchCallbackHandler;\n evaluations: RESTEvaluation[] = [];\n private currentSpan?: CurrentSpan;\n private timeoutRef?: NodeJS.Timeout;\n\n constructor({\n client,\n traceId,\n metadata,\n }: {\n client: LangWatch;\n traceId: string;\n metadata?: Metadata;\n }) {\n this.client = client;\n this.traceId = traceId;\n this.metadata = {\n ...metadata,\n sdkVersion: version,\n sdkLanguage: \"typescript\",\n };\n }\n\n update({ metadata }: { metadata: Metadata }) {\n this.metadata = {\n ...this.metadata,\n ...metadata,\n ...(typeof metadata.labels !== \"undefined\"\n ? {\n labels: [\n ...(this.metadata?.labels ?? []),\n ...(metadata.labels ?? []),\n ],\n }\n : {}),\n };\n }\n\n setCurrentSpan(span: LangWatchSpan) {\n this.currentSpan = {\n current: span,\n previous: this.currentSpan,\n };\n }\n\n getCurrentSpan() {\n return this.currentSpan?.current;\n }\n\n resetCurrentSpan() {\n this.currentSpan = this.currentSpan?.previous;\n }\n\n startSpan(params: Omit<Partial<PendingBaseSpan>, \"parentId\">) {\n const span = new LangWatchSpan({\n trace: this,\n ...params,\n });\n this.setCurrentSpan(span);\n return span;\n }\n\n startLLMSpan(params: Omit<Partial<PendingLLMSpan>, \"parentId\">) {\n const span = new LangWatchLLMSpan({\n trace: this,\n ...params,\n });\n this.setCurrentSpan(span);\n return span;\n }\n\n startRAGSpan(params: Omit<Partial<PendingRAGSpan>, \"parentId\">) {\n const span = new LangWatchRAGSpan({\n trace: this,\n ...params,\n });\n this.setCurrentSpan(span);\n return span;\n }\n\n addEvaluation = ({\n evaluationId,\n span,\n name,\n type,\n isGuardrail,\n status = \"processed\",\n passed,\n score,\n label,\n details,\n error,\n timestamps,\n }: AddEvaluationParams): void => {\n const currentEvaluationIndex = this.evaluations.findIndex(\n (e) =>\n evaluationId && \"evaluationId\" in e && e.evaluationId === evaluationId\n );\n\n const currentEvaluation =\n currentEvaluationIndex !== -1\n ? this.evaluations[currentEvaluationIndex]\n : undefined;\n\n const evaluationResult: EvaluationResult = {\n status,\n ...(passed !== undefined && { passed }),\n ...(score !== undefined && { score }),\n ...(label !== undefined && { label }),\n ...(details !== undefined && { details }),\n };\n\n let span_ = span;\n if (!span_) {\n span_ = this.startSpan({\n type: \"evaluation\",\n });\n }\n if (span_.type !== \"evaluation\") {\n span_ = span_.startSpan({ type: \"evaluation\" });\n }\n\n span_.update({\n name,\n output: {\n type: \"evaluation_result\",\n value: evaluationResult,\n } as TypedValueEvaluationResult,\n error,\n timestamps: timestamps\n ? {\n startedAt: timestamps.startedAt ?? span_.timestamps.startedAt,\n finishedAt: timestamps.finishedAt ?? undefined,\n }\n : undefined,\n });\n span_.end();\n\n const evaluation: RESTEvaluation = {\n evaluationId: evaluationId ?? `eval_${nanoid()}`,\n spanId: span_.spanId,\n name,\n type,\n isGuardrail,\n status,\n passed,\n score,\n label,\n details,\n error: error ? captureError(error) : undefined,\n timestamps: timestamps ?? {\n startedAt: span_.timestamps.startedAt,\n finishedAt: span_.timestamps.finishedAt,\n },\n };\n\n if (currentEvaluation && currentEvaluationIndex !== -1) {\n this.evaluations[currentEvaluationIndex] = {\n ...currentEvaluation,\n ...evaluation,\n };\n } else {\n this.evaluations.push(evaluation);\n }\n };\n\n async evaluate(params: EvaluationParams): Promise<EvaluationResultModel> {\n return evaluate({\n trace: this,\n ...params,\n });\n }\n\n getLangChainCallback() {\n if (!this.langchainCallback) {\n this.langchainCallback = new LangWatchCallbackHandler({ trace: this });\n }\n return this.langchainCallback;\n }\n\n onEnd(span: ServerSpan) {\n this.finishedSpans[span.span_id] = span;\n this.resetCurrentSpan();\n this.delayedSendSpans();\n }\n\n delayedSendSpans() {\n clearTimeout(this.timeoutRef);\n this.timeoutRef = setTimeout(() => {\n void this.sendSpans();\n }, 1000);\n }\n\n async sendSpans() {\n clearTimeout(this.timeoutRef);\n\n let trace: CollectorRESTParams | undefined = undefined;\n try {\n trace = collectorRESTParamsSchema.parse({\n trace_id: this.traceId,\n metadata: camelToSnakeCaseNested(this.metadata, \"metadata\"),\n spans: Object.values(this.finishedSpans),\n evaluations: camelToSnakeCaseNested(this.evaluations),\n } as Strict<CollectorRESTParams>);\n } catch (error) {\n if (error instanceof ZodError) {\n console.warn(\"[LangWatch] ⚠️ Failed to parse trace\");\n console.warn(fromZodError(error).message);\n }\n this.client.emit(\"error\", error);\n }\n\n if (trace) {\n await this.client.sendTrace(trace);\n }\n }\n}\n\nexport class LangWatchSpan implements PendingBaseSpan {\n trace: LangWatchTrace;\n\n spanId: string;\n parentId?: string | null;\n type: SpanTypes;\n name?: string | null;\n input?: PendingBaseSpan[\"input\"];\n output?: PendingBaseSpan[\"output\"];\n error?: PendingBaseSpan[\"error\"];\n timestamps: PendingBaseSpan[\"timestamps\"];\n metrics: PendingBaseSpan[\"metrics\"];\n\n constructor({\n trace,\n spanId,\n parentId,\n type,\n name,\n input,\n output,\n error,\n timestamps,\n metrics,\n }: Partial<PendingBaseSpan> & { trace: LangWatchTrace }) {\n this.spanId = spanId ?? `span_${nanoid()}`;\n this.parentId = parentId;\n this.trace = trace;\n this.type = type ?? \"span\";\n this.name = name;\n this.input = input;\n this.output = output;\n this.error = error;\n this.timestamps = timestamps ?? {\n startedAt: Date.now(),\n };\n this.metrics = metrics;\n }\n\n update(params: Partial<Omit<PendingBaseSpan, \"spanId\" | \"parentId\">>) {\n if (Object.isFrozen(this)) {\n const error = new Error(\n `Tried to update span ${this.spanId}, but the span is already finished, discarding update`\n );\n this.trace.client.emit(\"error\", error);\n return;\n }\n\n if (params.type) {\n this.type = params.type;\n }\n if (\"name\" in params) {\n this.name = params.name;\n }\n if (\"input\" in params) {\n this.input = params.input;\n }\n if (\"output\" in params) {\n this.output = params.output;\n }\n if (\"error\" in params) {\n this.error = params.error;\n }\n if (params.timestamps) {\n this.timestamps = params.timestamps;\n }\n if (\"metrics\" in params) {\n this.metrics = params.metrics;\n }\n }\n\n startSpan(params: Omit<Partial<PendingBaseSpan>, \"parentId\">) {\n const span = new LangWatchSpan({\n trace: this.trace,\n parentId: this.spanId,\n ...params,\n });\n this.trace.setCurrentSpan(span);\n return span;\n }\n\n startLLMSpan(params: Omit<Partial<PendingLLMSpan>, \"parentId\">) {\n const span = new LangWatchLLMSpan({\n trace: this.trace,\n parentId: this.spanId,\n ...params,\n });\n this.trace.setCurrentSpan(span);\n return span;\n }\n\n startRAGSpan(params: Omit<Partial<PendingRAGSpan>, \"parentId\">) {\n const span = new LangWatchRAGSpan({\n trace: this.trace,\n parentId: this.spanId,\n ...params,\n });\n this.trace.setCurrentSpan(span);\n return span;\n }\n\n addEvaluation(params: AddEvaluationParams) {\n this.trace.addEvaluation({\n ...params,\n span: this,\n });\n }\n\n async evaluate(params: EvaluationParams): Promise<EvaluationResultModel> {\n return evaluate({\n span: this,\n ...params,\n });\n }\n\n end(params?: Partial<Omit<PendingBaseSpan, \"spanId\" | \"parentId\">>) {\n this.timestamps.finishedAt = Date.now();\n if (params) {\n this.update(params);\n }\n\n Object.freeze(this);\n\n try {\n const finalSpan = spanSchema.parse(\n camelToSnakeCaseNested({\n ...this,\n trace: undefined,\n traceId: this.trace.traceId,\n timestamps: {\n ...this.timestamps,\n finishedAt: this.timestamps.finishedAt,\n },\n ...(this.error && { error: captureError(this.error) }),\n }) as ServerSpan\n );\n this.trace.onEnd(finalSpan);\n } catch (error) {\n if (error instanceof ZodError) {\n console.warn(\"[LangWatch] ⚠️ Failed to parse span\");\n console.warn(fromZodError(error).message);\n }\n this.trace.client.emit(\"error\", error);\n }\n }\n}\n\nexport class LangWatchLLMSpan extends LangWatchSpan implements PendingLLMSpan {\n type: \"llm\";\n model: PendingLLMSpan[\"model\"];\n params: PendingLLMSpan[\"params\"];\n\n constructor(params: Partial<PendingLLMSpan> & { trace: LangWatchTrace }) {\n super({ ...params });\n this.type = \"llm\";\n this.model = params.model ?? \"unknown\";\n this.params = params.params ?? {};\n }\n\n update(params: Partial<PendingLLMSpan>) {\n super.update(params);\n if (params.model) {\n this.model = params.model;\n }\n if (params.params) {\n this.params = params.params;\n }\n }\n\n end(params?: Partial<PendingLLMSpan>) {\n super.end(params);\n }\n}\n\nexport class LangWatchRAGSpan extends LangWatchSpan implements PendingRAGSpan {\n type: \"rag\";\n contexts: PendingRAGSpan[\"contexts\"];\n\n constructor(params: Partial<PendingRAGSpan> & { trace: LangWatchTrace }) {\n super({ ...params });\n this.type = \"rag\";\n this.contexts = params.contexts ?? [];\n }\n\n update(params: Partial<PendingRAGSpan>) {\n super.update(params);\n if (params.contexts) {\n this.contexts = params.contexts;\n }\n }\n\n end(params?: Partial<PendingRAGSpan>) {\n super.end(params);\n }\n}\n","{\n \"name\": \"langwatch\",\n \"version\": \"0.1.3\",\n \"description\": \"\",\n \"main\": \"./dist/index.js\",\n \"module\": \"./dist/index.mjs\",\n \"types\": \"./dist/index.d.ts\",\n \"exports\": {\n \".\": {\n \"import\": \"./dist/index.mjs\",\n \"require\": \"./dist/index.js\"\n }\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/langwatch/langwatch.git\",\n \"directory\": \"typescript-sdk\"\n },\n \"scripts\": {\n \"prepare\": \"./copy-types.sh\",\n \"test\": \"vitest\",\n \"build\": \"npm run prepare && tsup && esbuild src/index.ts --bundle --platform=node --outfile=dist/index.js\",\n \"prepublish\": \"npm run build\"\n },\n \"author\": \"\",\n \"license\": \"Apache-2.0\",\n \"engines\": {\n \"node\": \">=18.0.0\"\n },\n \"devDependencies\": {\n \"@ai-sdk/openai\": \"^0.0.18\",\n \"@eslint/js\": \"^9.4.0\",\n \"@types/debug\": \"^4.1.12\",\n \"@types/eslint__js\": \"^8.42.3\",\n \"@types/node\": \"^16.0.0\",\n \"dotenv\": \"^16.4.5\",\n \"esbuild\": \"^0.21.5\",\n \"eslint\": \"^8.57.0\",\n \"ts-to-zod\": \"3.8.5\",\n \"tsup\": \"^8.1.0\",\n \"typescript\": \"^4.9.5\",\n \"typescript-eslint\": \"^7.11.0\",\n \"vitest\": \"^0.5.0\"\n },\n \"dependencies\": {\n \"@langchain/core\": \"^0.2.7\",\n \"ai\": \"^3.1.23\",\n \"javascript-stringify\": \"^2.1.0\",\n \"nanoid\": \"^5.0.7\",\n \"openai\": \"^4.47.3\",\n \"zod\": \"^3.22.4\",\n \"zod-validation-error\": \"^3.3.0\"\n }\n}\n","import { type LangWatchSpan, type LangWatchTrace } from \"./index\";\nimport { type Conversation } from \"./server/types/evaluations\";\nimport {\n type Evaluators,\n type EvaluatorTypes,\n} from \"./server/types/evaluators.generated\";\nimport {\n type RAGChunk,\n type SpanTypes,\n type TypedValueEvaluationResult,\n type TypedValueGuardrailResult,\n type TypedValueJson,\n} from \"./server/types/tracer\";\n\ntype Money = {\n currency: string;\n amount: number;\n};\n\nexport type EvaluationResultModel = {\n status: \"processed\" | \"skipped\" | \"error\";\n passed?: boolean;\n score?: number;\n details?: string;\n label?: string;\n cost?: Money;\n};\n\nexport type CommonEvaluationParams = {\n name?: string;\n input?: string;\n output?: string;\n expectedOutput?: string;\n contexts?: RAGChunk[] | string[];\n conversation?: Conversation;\n asGuardrail?: boolean;\n trace?: LangWatchTrace;\n span?: LangWatchSpan;\n};\n\nexport type SavedEvaluationParams = {\n slug: string;\n settings?: Record<string, unknown>;\n} & CommonEvaluationParams;\n\nexport type LangEvalsEvaluationParams<T extends EvaluatorTypes> = {\n evaluator: T;\n settings?: Evaluators[T][\"settings\"];\n} & CommonEvaluationParams;\n\nexport type EvaluationParams =\n | SavedEvaluationParams\n | LangEvalsEvaluationParams<EvaluatorTypes>;\n\nexport const evaluate = async (\n params: EvaluationParams\n): Promise<EvaluationResultModel> => {\n const slug = \"slug\" in params ? params.slug : params.evaluator;\n const span = optionalCreateSpan({\n trace: params.trace,\n span: params.span,\n name: params.name ? params.name : slug,\n type: params.asGuardrail ? \"guardrail\" : \"evaluation\",\n });\n\n try {\n const requestParams = prepareData({\n ...params,\n slug,\n traceId: span?.trace.traceId,\n spanId: span?.spanId,\n span,\n });\n\n const response = await fetch(requestParams.url, {\n method: \"POST\",\n headers: requestParams.headers,\n body: JSON.stringify(requestParams.json),\n });\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n\n const result = await response.json();\n return handleResponse(result, span, params.asGuardrail);\n } catch (e) {\n return handleException(e as Error, span, params.asGuardrail);\n }\n};\n\nconst optionalCreateSpan = ({\n trace,\n span,\n name,\n type,\n}: {\n trace?: LangWatchTrace;\n span?: LangWatchSpan;\n name: string;\n type: SpanTypes;\n}): LangWatchSpan | undefined => {\n if (span) {\n return span.startSpan({ name, type });\n } else if (trace) {\n return trace.startSpan({ name, type });\n }\n return undefined;\n};\n\nconst prepareData = (params: {\n slug: string;\n name?: string;\n input?: string;\n output?: string;\n expectedOutput?: string;\n contexts?: RAGChunk[] | string[];\n conversation?: Conversation;\n settings?: Record<string, unknown>;\n traceId?: string;\n spanId?: string;\n span?: LangWatchSpan;\n asGuardrail?: boolean;\n}) => {\n const data: Record<string, unknown> = {};\n if (params.input) data.input = params.input;\n if (params.output) data.output = params.output;\n if (params.expectedOutput) data.expected_output = params.expectedOutput;\n if (params.contexts && params.contexts.length > 0)\n data.contexts = params.contexts;\n if (params.conversation && params.conversation.length > 0)\n data.conversation = params.conversation;\n\n if (params.span) {\n params.span.update({\n input: { type: \"json\", value: data } as TypedValueJson,\n params: params.settings,\n });\n }\n\n return {\n url: `${process.env.LANGWATCH_ENDPOINT}/api/evaluations/${params.slug}/evaluate`,\n json: {\n trace_id: params.traceId,\n span_id: params.spanId,\n name: params.name,\n data,\n settings: params.settings,\n as_guardrail: params.asGuardrail,\n },\n headers: {\n \"X-Auth-Token\": process.env.LANGWATCH_API_KEY ?? \"\",\n \"Content-Type\": \"application/json\",\n },\n };\n};\n\nconst handleResponse = (\n response: EvaluationResultModel,\n span?: LangWatchSpan,\n asGuardrail = false\n): EvaluationResultModel => {\n if (response.status === \"error\") {\n response.details = response.details ?? \"\";\n }\n\n for (const key of Object.keys(response)) {\n if (\n response[key as keyof EvaluationResultModel] === null ||\n response[key as keyof EvaluationResultModel] === undefined\n ) {\n delete response[key as keyof EvaluationResultModel];\n }\n }\n\n if (span) {\n const output: TypedValueGuardrailResult | TypedValueEvaluationResult =\n asGuardrail\n ? {\n type: \"guardrail_result\",\n value: response,\n }\n : {\n type: \"evaluation_result\",\n value: response,\n };\n\n span.update({ output });\n\n if (response.cost) {\n span.update({\n metrics: {\n cost: response.cost.amount,\n },\n });\n }\n\n span.end();\n }\n\n return response;\n};\n\nconst handleException = (\n e: Error,\n span?: LangWatchSpan,\n asGuardrail = false\n): EvaluationResultModel => {\n const response: EvaluationResultModel = {\n status: \"error\",\n details: e.toString(),\n };\n\n if (asGuardrail) {\n response.passed = true;\n }\n\n return handleResponse(response, span, asGuardrail);\n};\n","import type { AgentAction, AgentFinish } from \"@langchain/core/agents\";\nimport { BaseCallbackHandler } from \"@langchain/core/callbacks/base\";\nimport { type DocumentInterface } from \"@langchain/core/documents\";\nimport type { Serialized } from \"@langchain/core/load/serializable\";\nimport {\n AIMessage,\n AIMessageChunk,\n FunctionMessage,\n FunctionMessageChunk,\n HumanMessage,\n HumanMessageChunk,\n SystemMessage,\n SystemMessageChunk,\n ToolMessage,\n ToolMessageChunk,\n mapChatMessagesToStoredMessages,\n type BaseMessage,\n type StoredMessage,\n} from \"@langchain/core/messages\";\nimport type { ChatGeneration, LLMResult } from \"@langchain/core/outputs\";\nimport type { ChainValues } from \"@langchain/core/utils/types\";\nimport { stringify } from \"javascript-stringify\";\nimport {\n type LangWatchRAGSpan,\n type LangWatchSpan,\n type LangWatchTrace,\n} from \".\";\nimport {\n type RAGSpan,\n type BaseSpan,\n type ChatMessage,\n type ChatRichContent,\n type SpanInputOutput,\n} from \"./types\";\n\nexport class LangWatchCallbackHandler extends BaseCallbackHandler {\n name = \"LangWatchCallbackHandler\";\n trace: LangWatchTrace;\n spans: Record<string, LangWatchSpan> = {};\n\n constructor({ trace }: { trace: LangWatchTrace }) {\n super();\n this.trace = trace;\n }\n\n async handleLLMStart(\n llm: Serialized,\n prompts: string[],\n runId: string,\n parentRunId?: string | undefined,\n extraParams?: Record<string, unknown> | undefined,\n _tags?: string[] | undefined,\n metadata?: Record<string, unknown> | undefined,\n name?: string\n ): Promise<void> {\n this.spans[runId] = this.buildLLMSpan({\n llm,\n runId,\n parentRunId,\n input: {\n type: \"json\",\n value: prompts,\n },\n extraParams,\n metadata,\n name,\n });\n }\n\n private buildLLMSpan({\n llm,\n runId,\n parentRunId,\n input,\n extraParams,\n metadata,\n name,\n }: {\n llm: Serialized;\n runId: string;\n parentRunId?: string | undefined;\n input: SpanInputOutput;\n extraParams?: Record<string, unknown> | undefined;\n metadata?: Record<string, unknown> | undefined;\n name?: string | undefined;\n }) {\n try {\n const parent = this.getParent(parentRunId);\n\n const vendor = metadata?.ls_provider ?? llm.id.at(-2)?.toString();\n const model =\n metadata?.ls_model_name ?? (llm as any).kwargs?.model ?? \"unknown\";\n\n const span = parent.startLLMSpan({\n spanId: runId,\n name: name ?? llm.id.at(-1)?.toString(),\n input,\n model: [vendor, model].filter((x) => x).join(\"/\"),\n params: {\n temperature: (extraParams?.invocation_params as any)?.temperature,\n ...((extraParams?.invocation_params as any)?.functions\n ? { functions: (extraParams?.invocation_params as any)?.functions }\n : {}),\n },\n });\n\n return span;\n } catch (e) {\n this.trace.client.emit(\"error\", e);\n throw e;\n }\n }\n\n async handleChatModelStart(\n llm: Serialized,\n messages: BaseMessage[][],\n runId: string,\n parentRunId?: string | undefined,\n extraParams?: Record<string, unknown> | undefined,\n tags?: string[] | undefined,\n metadata?: Record<string, unknown> | undefined,\n name?: string\n ): Promise<void> {\n this.spans[runId] = this.buildLLMSpan({\n name,\n llm,\n runId,\n parentRunId,\n input: {\n type: \"chat_messages\",\n value: messages.flatMap(convertFromLangChainMessages),\n },\n extraParams,\n metadata,\n });\n }\n\n async handleNewToken(_token: string, runId: string): Promise<void> {\n const span = this.spans[runId];\n if (runId && span && !span.timestamps.firstTokenAt) {\n span.update({\n timestamps: { ...span.timestamps, firstTokenAt: Date.now() },\n });\n }\n }\n\n async handleLLMEnd(\n response: LLMResult,\n runId: string,\n _parentRunId?: string | undefined\n ): Promise<void> {\n try {\n const span = this.spans[runId];\n if (!span) {\n return;\n }\n\n const outputs: SpanInputOutput[] = [];\n for (const generation of response.generations) {\n // TODO: again, why the twice loop? Can OpenAI generate multiple chat outputs?\n for (const generation_ of generation) {\n if (\"message\" in generation_) {\n outputs.push({\n type: \"chat_messages\",\n value: convertFromLangChainMessages([\n (generation_ as ChatGeneration).message,\n ]),\n });\n } else if (\"text\" in generation_) {\n outputs.push({\n type: \"text\",\n value: generation_.text,\n });\n } else {\n outputs.push({\n type: \"text\",\n value: JSON.stringify(generation_),\n });\n }\n }\n }\n\n const output: SpanInputOutput | undefined =\n outputs.length === 1\n ? outputs[0]\n : { type: \"list\", value: outputs as any };\n\n // Commenting it out because LangChain.js prompt and completion tokens is broken, this one doesn't work as it should with python,\n // and response_metadata.prompt and response_metadata.completion is there but it's always 0. Better let our server count.\n // const metrics = response.llmOutput?.token_usage\n // ? {\n // promptTokens: response.llmOutput.token_usage.prompt_tokens,\n // completionTokens: response.llmOutput.token_usage.completion_tokens,\n // }\n // : undefined;\n\n span.end({\n output,\n // ...(metrics ? { metrics } : {}),\n });\n } catch (e) {\n this.trace.client.emit(\"error\", e);\n throw e;\n }\n }\n\n async handleLLMError(\n err: Error,\n runId: string,\n _parentRunId?: string | undefined\n ): Promise<void> {\n this.errorSpan({ runId, error: err });\n }\n\n async handleChainStart(\n chain: Serialized,\n inputs: ChainValues,\n runId: string,\n parentRunId?: string | undefined,\n _tags?: string[] | undefined,\n _metadata?: Record<string, unknown> | undefined,\n _runType?: string,\n name?: string\n ): Promise<void> {\n this.spans[runId] = this.buildSpan({\n type: \"chain\",\n serialized: chain,\n runId,\n parentRunId,\n input: inputs,\n name,\n });\n }\n\n async handleChainEnd(\n output: ChainValues,\n runId: string,\n _parentRunId?: string | undefined\n ): Promise<void> {\n this.endSpan({\n runId,\n output,\n });\n }\n\n async handleChainError(\n err: Error,\n runId: string,\n _parentRunId?: string | undefined,\n _tags?: string[] | undefined,\n _kwargs?: { inputs?: Record<string, unknown> | undefined } | undefined\n ): Promise<void> {\n this.errorSpan({ runId, error: err });\n }\n\n async handleToolStart(\n tool: Serialized,\n input: string,\n runId: string,\n parentRunId?: string | undefined,\n _tags?: string[] | undefined,\n _metadata?: Record<string, unknown> | undefined,\n name?: string\n ): Promise<void> {\n this.spans[runId] = this.buildSpan({\n type: \"tool\",\n serialized: tool,\n runId,\n parentRunId,\n input,\n name,\n });\n }\n\n async handleToolEnd(\n output: string,\n runId: string,\n _parentRunId?: string | undefined\n ): Promise<void> {\n this.endSpan({ runId, output });\n }\n\n async handleToolError(\n err: Error,\n runId: string,\n _parentRunId?: string | undefined,\n _tags?: string[] | undefined\n ): Promise<void> {\n this.errorSpan({ runId, error: err });\n }\n\n async handleRetrieverStart(\n retriever: Serialized,\n query: string,\n runId: string,\n parentRunId?: string | undefined,\n _tags?: string[] | undefined,\n _metadata?: Record<string, unknown> | undefined,\n name?: string | undefined\n ) {\n try {\n const parent = this.getParent(parentRunId);\n\n this.spans[runId] = parent.startRAGSpan({\n spanId: runId,\n name: name ?? retriever.name ?? retriever.id.at(-1)?.toString(),\n input: this.autoconvertTypedValues(query),\n });\n } catch (e) {\n this.trace.client.emit(\"error\", e);\n throw e;\n }\n }\n\n async handleRetrieverEnd(\n documents: DocumentInterface<Record<string, any>>[],\n runId: string,\n _parentRunId?: string | undefined,\n _tags?: string[] | undefined\n ) {\n try {\n const contexts: RAGSpan[\"contexts\"] = documents.map((doc) => ({\n content: doc.pageContent,\n ...(doc.metadata.source ? { documentId: doc.metadata.source } : {}),\n }));\n\n const span = this.spans[runId] as LangWatchRAGSpan;\n if (!span) {\n return;\n }\n\n span.end({\n contexts,\n output: this.autoconvertTypedValues(documents),\n });\n } catch (e) {\n this.trace.client.emit(\"error\", e);\n throw e;\n }\n }\n\n async handleRetrieverError(\n err: Error,\n runId: string,\n _parentRunId?: string | undefined,\n _tags?: string[] | undefined\n ) {\n this.errorSpan({ runId, error: err });\n }\n\n async handleAgentAction(\n _action: AgentAction,\n runId: string,\n _parentRunId?: string | undefined,\n _tags?: string[] | undefined\n ): Promise<void> {\n const span = this.spans[runId];\n if (!span) {\n return;\n }\n\n span.update({\n type: \"agent\",\n });\n }\n\n async handleAgentEnd(\n action: AgentFinish,\n runId: string,\n _parentRunId?: string | undefined,\n _tags?: string[] | undefined\n ): Promise<void> {\n this.endSpan({\n runId,\n output: action.returnValues,\n });\n }\n\n private buildSpan({\n type,\n serialized,\n runId,\n parentRunId,\n input,\n name,\n }: {\n type: BaseSpan[\"type\"];\n serialized: Serialized;\n runId: string;\n parentRunId?: string | undefined;\n input: unknown;\n name?: string | undefined;\n }) {\n try {\n const parent = this.getParent(parentRunId);\n\n const span = parent.startSpan({\n spanId: runId,\n type,\n name: name ?? serialized.name ?? serialized.id.at(-1)?.toString(),\n input: this.autoconvertTypedValues(input),\n });\n\n return span;\n } catch (e) {\n this.trace.client.emit(\"error\", e);\n throw e;\n }\n }\n\n private endSpan({ runId, output }: { runId: string; output: unknown }): void {\n try {\n const span = this.spans[runId];\n if (!span) {\n return;\n }\n\n span.end({\n output: this.autoconvertTypedValues(output),\n });\n } catch (e) {\n this.trace.client.emit(\"error\", e);\n throw e;\n }\n }\n\n private errorSpan({ runId, error }: { runId: string; error: Error }): void {\n const span = this.spans[runId];\n if (!span) {\n return;\n }\n\n span.end({\n error,\n });\n }\n\n private autoconvertTypedValues(value: any): SpanInputOutput | undefined {\n if (\n !value ||\n (typeof value === \"object\" && Object.keys(value).length === 0)\n ) {\n return undefined;\n }\n if (typeof value === \"string\") {\n return { type: \"text\", value };\n }\n try {\n JSON.stringify(value);\n return { type: \"json\", value };\n } catch (e) {\n return { type: \"text\", value: stringify(value) ?? value.toString() };\n }\n }\n\n private getParent(\n parentRunId?: string | undefined\n ): LangWatchSpan | LangWatchTrace {\n return (\n (parentRunId\n ? this.spans[parentRunId]\n : this.spans[Object.keys(this.spans).at(-1) ?? \"\"]) ?? this.trace\n );\n }\n}\n\nexport const convertFromLangChainMessages = (\n messages: BaseMessage[]\n): ChatMessage[] => {\n const chatMessages: ChatMessage[] = [];\n for (const message of messages) {\n chatMessages.push(convertFromLangChainMessage(message));\n }\n return chatMessages;\n};\n\nconst convertFromLangChainMessage = (\n message: BaseMessage & { id?: string[] }\n): ChatMessage => {\n let role: ChatMessage[\"role\"] = \"user\";\n\n const message_: (BaseMessage | StoredMessage) & {\n id?: string[];\n type?: string;\n } = message.lc_serializable\n ? mapChatMessagesToStoredMessages([message])[0]!\n : message;\n\n // Dang this is so hard, langchain.js has 3 ways of representing the same thing...\n if (\n message_ instanceof HumanMessage ||\n message_ instanceof HumanMessageChunk ||\n message_.id?.at(-1) === \"HumanMessage\" ||\n message_.id?.at(-1) === \"HumanMessageChunk\" ||\n message_.type === \"human\"\n ) {\n role = \"user\";\n } else if (\n message instanceof AIMessage ||\n message instanceof AIMessageChunk ||\n message.id?.at(-1) === \"AIMessage\" ||\n message.id?.at(-1) === \"AIMessageChunk\" ||\n message_.type === \"ai\"\n ) {\n role = \"assistant\";\n } else if (\n message instanceof SystemMessage ||\n message instanceof SystemMessageChunk ||\n message.id?.at(-1) === \"SystemMessage\" ||\n message.id?.at(-1) === \"SystemMessageChunk\" ||\n message_.type === \"system\"\n ) {\n role = \"system\";\n } else if (\n message instanceof FunctionMessage ||\n message instanceof FunctionMessageChunk ||\n message.id?.at(-1) === \"FunctionMessage\" ||\n message.id?.at(-1) === \"FunctionMessageChunk\" ||\n message_.type === \"function\"\n ) {\n role = \"function\";\n } else if (\n message instanceof ToolMessage ||\n message instanceof ToolMessageChunk ||\n message.id?.at(-1) === \"ToolMessage\" ||\n message.id?.at(-1) === \"ToolMessageChunk\" ||\n message_.type === \"tool\"\n ) {\n role = \"tool\";\n }\n\n const content =\n typeof message.content === \"string\"\n ? message.content\n : message.content.map(\n (content): ChatRichContent =>\n content.type === \"text\"\n ? { type: \"text\", text: content.text }\n : content.type == \"image_url\"\n ? { type: \"image_url\", image_url: content.image_url }\n : { type: \"text\", text: JSON.stringify(content) }\n );\n\n const functionCall = message.additional_kwargs as\n | ChatMessage[\"function_call\"]\n | undefined;\n\n return {\n role,\n content,\n ...(functionCall &&\n typeof functionCall === \"object\" &&\n Object.keys(functionCall).length > 0\n ? { function_call: functionCall }\n : {}),\n };\n};\n","import {\n reservedSpanParamsSchema,\n reservedTraceMetadataSchema\n} from \"./server/types/tracer.generated\";\n\nexport type Strict<T> = T & { [K in Exclude<keyof any, keyof T>]: never };\n\ntype SnakeToCamelCase<S extends string> = S extends `${infer T}_${infer U}`\n ? `${T}${Capitalize<SnakeToCamelCase<U>>}`\n : S;\n\nexport type SnakeToCamelCaseNested<T> = T extends object\n ? T extends (infer U)[]\n ? U extends object\n ? {\n [K in keyof U as SnakeToCamelCase<\n K & string\n >]: SnakeToCamelCaseNested<U[K]>;\n }[]\n : T\n : {\n [K in keyof T as SnakeToCamelCase<K & string>]: SnakeToCamelCaseNested<\n T[K]\n >;\n }\n : T;\n\ntype CamelToSnakeCase<S extends string> = S extends `${infer T}${infer U}`\n ? `${T extends Capitalize<T> ? \"_\" : \"\"}${Lowercase<T>}${CamelToSnakeCase<U>}`\n : S;\n\nexport type CamelToSnakeCaseNested<T> = T extends object\n ? T extends (infer U)[]\n ? U extends object\n ? {\n [K in keyof U as CamelToSnakeCase<\n K & string\n >]: CamelToSnakeCaseNested<U[K]>;\n }[]\n : T\n : {\n [K in keyof T as CamelToSnakeCase<K & string>]: CamelToSnakeCaseNested<\n T[K]\n >;\n }\n : T;\n\nfunction camelToSnakeCase(str: string): string {\n return str.replace(/[A-Z]/g, (letter) => `_${letter.toLowerCase()}`);\n}\n\nexport function camelToSnakeCaseNested<T>(\n obj: T,\n parentKey?: string\n): CamelToSnakeCaseNested<T> {\n if (Array.isArray(obj)) {\n return obj.map((item) =>\n camelToSnakeCaseNested(item)\n ) as CamelToSnakeCaseNested<T>;\n } else if (typeof obj === \"object\" && obj !== null) {\n const newObj: any = {};\n for (const key in obj) {\n if (obj.hasOwnProperty(key)) {\n const newKey = camelToSnakeCase(key);\n // Keep arbitrary keys the same\n if (\n (parentKey === \"metadata\" &&\n !Object.keys(reservedTraceMetadataSchema.shape).includes(newKey)) ||\n (parentKey === \"params\" &&\n !Object.keys(reservedSpanParamsSchema.shape).includes(newKey))\n ) {\n newObj[key] = (obj as any)[key];\n } else {\n newObj[newKey] = camelToSnakeCaseNested((obj as any)[key], newKey);\n }\n }\n }\n return newObj as CamelToSnakeCaseNested<T>;\n } else {\n return obj as CamelToSnakeCaseNested<T>;\n }\n}\n"],"mappings":"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","names":["content"]}
1
+ {"version":3,"sources":["../src/index.ts","../package.json","../src/evaluations.ts","../src/langchain.ts","../src/typeUtils.ts","../src/LangWatchExporter.ts","../node_modules/@opentelemetry/core/src/ExportResult.ts"],"sourcesContent":["import EventEmitter from 'eventemitter3';\nimport { nanoid } from \"nanoid\";\nimport { ZodError } from \"zod\";\nimport { fromZodError } from \"zod-validation-error\";\nimport { version } from \"../package.json\";\nimport {\n evaluate,\n type EvaluationParams,\n type EvaluationResultModel,\n} from \"./evaluations\";\nimport { LangWatchCallbackHandler } from \"./langchain\";\nimport {\n type CollectorRESTParams,\n type EvaluationResult,\n type Span as ServerSpan,\n type SpanTypes,\n type TypedValueEvaluationResult,\n} from \"./server/types/tracer\";\nimport {\n collectorRESTParamsSchema,\n spanSchema,\n} from \"./server/types/tracer.generated\";\nimport {\n type BaseSpan,\n type ChatMessage,\n type ChatRichContent,\n type LLMSpan,\n type Metadata,\n type PendingBaseSpan,\n type PendingLLMSpan,\n type PendingRAGSpan,\n type RAGSpan,\n type RESTEvaluation,\n type SpanInputOutput,\n} from \"./types\";\nimport { camelToSnakeCaseNested, type Strict } from \"./typeUtils\";\nimport {\n autoconvertTypedValues,\n captureError,\n convertFromVercelAIMessages,\n} from \"./utils\";\nimport { LangWatchExporter } from \"./LangWatchExporter\";\n\nexport type {\n BaseSpan,\n ChatMessage as ChatMessage,\n ChatRichContent,\n LLMSpan,\n Metadata,\n PendingBaseSpan,\n PendingLLMSpan,\n PendingRAGSpan,\n RAGSpan,\n SpanInputOutput,\n};\n\nexport {\n autoconvertTypedValues,\n captureError,\n convertFromVercelAIMessages,\n LangWatchExporter,\n};\n\nexport class LangWatch extends EventEmitter {\n apiKey: string | undefined;\n endpoint: string;\n\n constructor({\n apiKey,\n endpoint = process.env.LANGWATCH_ENDPOINT ?? \"https://app.langwatch.ai\",\n }: {\n apiKey?: string;\n endpoint?: string;\n } = {}) {\n super();\n const apiKey_ = apiKey ?? process.env.LANGWATCH_API_KEY;\n if (!apiKey_) {\n const error = new Error(\n \"LangWatch API key is not set, please set the LANGWATCH_API_KEY environment variable or pass it in the constructor. Traces will not be captured.\"\n );\n this.emit(\"error\", error);\n }\n this.apiKey = apiKey_;\n this.endpoint = endpoint;\n }\n\n getTrace({\n traceId,\n metadata,\n }: { traceId?: string; metadata?: Metadata } = {}) {\n return new LangWatchTrace({\n client: this,\n traceId: traceId ?? `trace_${nanoid()}`,\n metadata,\n });\n }\n\n async sendTrace(params: CollectorRESTParams) {\n const backoff = [1000, 2000, 4000, 8000, 16000];\n for (const backoffTime of backoff) {\n try {\n await this._sendTrace(params);\n return;\n } catch (e) {\n console.warn(\n `[LangWatch] ⚠️ Failed to send trace, retrying in ${\n backoffTime / 1000\n }s`\n );\n await new Promise((resolve) => setTimeout(resolve, backoffTime));\n }\n }\n console.warn(\"[LangWatch] ⚠️ Failed to send trace, giving up\");\n }\n\n async _sendTrace(params: CollectorRESTParams) {\n if (params.spans.length === 0) {\n return;\n }\n\n if (!this.apiKey) {\n const error = new Error(\n \"LangWatch API key is not set, LLMs traces will not be sent, go to https://langwatch.ai to set it up\"\n );\n this.emit(\"error\", error);\n return;\n }\n\n const response = await fetch(`${this.endpoint}/api/collector`, {\n method: \"POST\",\n headers: {\n \"X-Auth-Token\": this.apiKey,\n \"Content-Type\": \"application/json\",\n },\n body: JSON.stringify(params),\n });\n\n if (response.status === 429) {\n const error = new Error(\n \"Rate limit exceeded, dropping message from being sent to LangWatch. Please check your dashboard to upgrade your plan.\"\n );\n this.emit(\"error\", error);\n return;\n }\n if (!response.ok) {\n const error = new Error(\n `Failed to send trace, status: ${response.status}`\n );\n this.emit(\"error\", error);\n throw error;\n }\n }\n}\n\ntype CurrentSpan = {\n current: LangWatchSpan;\n previous?: CurrentSpan;\n};\n\ntype AddEvaluationParams = {\n evaluationId?: string;\n span?: LangWatchSpan;\n name: string;\n type?: string;\n isGuardrail?: boolean;\n status?: \"processed\" | \"skipped\" | \"error\";\n passed?: boolean;\n score?: number;\n label?: string;\n details?: string;\n error?: Error;\n timestamps?: RESTEvaluation[\"timestamps\"];\n};\n\nexport class LangWatchTrace {\n client: LangWatch;\n traceId: string;\n metadata?: Metadata;\n finishedSpans: Record<string, ServerSpan> = {};\n langchainCallback?: LangWatchCallbackHandler;\n evaluations: RESTEvaluation[] = [];\n private currentSpan?: CurrentSpan;\n private timeoutRef?: NodeJS.Timeout;\n\n constructor({\n client,\n traceId,\n metadata,\n }: {\n client: LangWatch;\n traceId: string;\n metadata?: Metadata;\n }) {\n this.client = client;\n this.traceId = traceId;\n this.metadata = {\n ...metadata,\n sdkVersion: version,\n sdkLanguage: \"typescript\",\n };\n }\n\n update({ metadata }: { metadata: Metadata }) {\n this.metadata = {\n ...this.metadata,\n ...metadata,\n ...(typeof metadata.labels !== \"undefined\"\n ? {\n labels: [\n ...(this.metadata?.labels ?? []),\n ...(metadata.labels ?? []),\n ],\n }\n : {}),\n };\n }\n\n setCurrentSpan(span: LangWatchSpan) {\n this.currentSpan = {\n current: span,\n previous: this.currentSpan,\n };\n }\n\n getCurrentSpan() {\n return this.currentSpan?.current;\n }\n\n resetCurrentSpan() {\n this.currentSpan = this.currentSpan?.previous;\n }\n\n startSpan(params: Omit<Partial<PendingBaseSpan>, \"parentId\">) {\n const span = new LangWatchSpan({\n trace: this,\n ...params,\n });\n this.setCurrentSpan(span);\n return span;\n }\n\n startLLMSpan(params: Omit<Partial<PendingLLMSpan>, \"parentId\">) {\n const span = new LangWatchLLMSpan({\n trace: this,\n ...params,\n });\n this.setCurrentSpan(span);\n return span;\n }\n\n startRAGSpan(params: Omit<Partial<PendingRAGSpan>, \"parentId\">) {\n const span = new LangWatchRAGSpan({\n trace: this,\n ...params,\n });\n this.setCurrentSpan(span);\n return span;\n }\n\n addEvaluation = ({\n evaluationId,\n span,\n name,\n type,\n isGuardrail,\n status = \"processed\",\n passed,\n score,\n label,\n details,\n error,\n timestamps,\n }: AddEvaluationParams): void => {\n const currentEvaluationIndex = this.evaluations.findIndex(\n (e) =>\n evaluationId && \"evaluationId\" in e && e.evaluationId === evaluationId\n );\n\n const currentEvaluation =\n currentEvaluationIndex !== -1\n ? this.evaluations[currentEvaluationIndex]\n : undefined;\n\n const evaluationResult: EvaluationResult = {\n status,\n ...(passed !== undefined && { passed }),\n ...(score !== undefined && { score }),\n ...(label !== undefined && { label }),\n ...(details !== undefined && { details }),\n };\n\n let span_ = span;\n if (!span_) {\n span_ = this.startSpan({\n type: \"evaluation\",\n });\n }\n if (span_.type !== \"evaluation\") {\n span_ = span_.startSpan({ type: \"evaluation\" });\n }\n\n span_.update({\n name,\n output: {\n type: \"evaluation_result\",\n value: evaluationResult,\n } as TypedValueEvaluationResult,\n error,\n timestamps: timestamps\n ? {\n startedAt: timestamps.startedAt ?? span_.timestamps.startedAt,\n finishedAt: timestamps.finishedAt ?? undefined,\n }\n : undefined,\n });\n span_.end();\n\n const evaluation: RESTEvaluation = {\n evaluationId: evaluationId ?? `eval_${nanoid()}`,\n spanId: span_.spanId,\n name,\n type,\n isGuardrail,\n status,\n passed,\n score,\n label,\n details,\n error: error ? captureError(error) : undefined,\n timestamps: timestamps ?? {\n startedAt: span_.timestamps.startedAt,\n finishedAt: span_.timestamps.finishedAt,\n },\n };\n\n if (currentEvaluation && currentEvaluationIndex !== -1) {\n this.evaluations[currentEvaluationIndex] = {\n ...currentEvaluation,\n ...evaluation,\n };\n } else {\n this.evaluations.push(evaluation);\n }\n };\n\n async evaluate(params: EvaluationParams): Promise<EvaluationResultModel> {\n return evaluate({\n trace: this,\n ...params,\n });\n }\n\n getLangChainCallback() {\n if (!this.langchainCallback) {\n this.langchainCallback = new LangWatchCallbackHandler({ trace: this });\n }\n return this.langchainCallback;\n }\n\n onEnd(span: ServerSpan) {\n this.finishedSpans[span.span_id] = span;\n this.resetCurrentSpan();\n this.delayedSendSpans();\n }\n\n delayedSendSpans() {\n clearTimeout(this.timeoutRef);\n this.timeoutRef = setTimeout(() => {\n void this.sendSpans();\n }, 1000);\n }\n\n async sendSpans() {\n clearTimeout(this.timeoutRef);\n\n let trace: CollectorRESTParams | undefined = undefined;\n try {\n trace = collectorRESTParamsSchema.parse({\n trace_id: this.traceId,\n metadata: camelToSnakeCaseNested(this.metadata, \"metadata\"),\n spans: Object.values(this.finishedSpans),\n evaluations: camelToSnakeCaseNested(this.evaluations),\n } as Strict<CollectorRESTParams>);\n } catch (error) {\n if (error instanceof ZodError) {\n console.warn(\"[LangWatch] ⚠️ Failed to parse trace\");\n console.warn(fromZodError(error).message);\n }\n this.client.emit(\"error\", error);\n }\n\n if (trace) {\n await this.client.sendTrace(trace);\n }\n }\n}\n\nexport class LangWatchSpan implements PendingBaseSpan {\n trace: LangWatchTrace;\n\n spanId: string;\n parentId?: string | null;\n type: SpanTypes;\n name?: string | null;\n input?: PendingBaseSpan[\"input\"];\n output?: PendingBaseSpan[\"output\"];\n error?: PendingBaseSpan[\"error\"];\n timestamps: PendingBaseSpan[\"timestamps\"];\n metrics: PendingBaseSpan[\"metrics\"];\n\n constructor({\n trace,\n spanId,\n parentId,\n type,\n name,\n input,\n output,\n error,\n timestamps,\n metrics,\n }: Partial<PendingBaseSpan> & { trace: LangWatchTrace }) {\n this.spanId = spanId ?? `span_${nanoid()}`;\n this.parentId = parentId;\n this.trace = trace;\n this.type = type ?? \"span\";\n this.name = name;\n this.input = input;\n this.output = output;\n this.error = error;\n this.timestamps = timestamps ?? {\n startedAt: Date.now(),\n };\n this.metrics = metrics;\n }\n\n update(params: Partial<Omit<PendingBaseSpan, \"spanId\" | \"parentId\">>) {\n if (Object.isFrozen(this)) {\n const error = new Error(\n `Tried to update span ${this.spanId}, but the span is already finished, discarding update`\n );\n this.trace.client.emit(\"error\", error);\n return;\n }\n\n if (params.type) {\n this.type = params.type;\n }\n if (\"name\" in params) {\n this.name = params.name;\n }\n if (\"input\" in params) {\n this.input = params.input;\n }\n if (\"output\" in params) {\n this.output = params.output;\n }\n if (\"error\" in params) {\n this.error = params.error;\n }\n if (params.timestamps) {\n this.timestamps = params.timestamps;\n }\n if (\"metrics\" in params) {\n this.metrics = params.metrics;\n }\n }\n\n startSpan(params: Omit<Partial<PendingBaseSpan>, \"parentId\">) {\n const span = new LangWatchSpan({\n trace: this.trace,\n parentId: this.spanId,\n ...params,\n });\n this.trace.setCurrentSpan(span);\n return span;\n }\n\n startLLMSpan(params: Omit<Partial<PendingLLMSpan>, \"parentId\">) {\n const span = new LangWatchLLMSpan({\n trace: this.trace,\n parentId: this.spanId,\n ...params,\n });\n this.trace.setCurrentSpan(span);\n return span;\n }\n\n startRAGSpan(params: Omit<Partial<PendingRAGSpan>, \"parentId\">) {\n const span = new LangWatchRAGSpan({\n trace: this.trace,\n parentId: this.spanId,\n ...params,\n });\n this.trace.setCurrentSpan(span);\n return span;\n }\n\n addEvaluation(params: AddEvaluationParams) {\n this.trace.addEvaluation({\n ...params,\n span: this,\n });\n }\n\n async evaluate(params: EvaluationParams): Promise<EvaluationResultModel> {\n return evaluate({\n span: this,\n ...params,\n });\n }\n\n end(params?: Partial<Omit<PendingBaseSpan, \"spanId\" | \"parentId\">>) {\n this.timestamps.finishedAt = Date.now();\n if (params) {\n this.update(params);\n }\n\n Object.freeze(this);\n\n try {\n const finalSpan = spanSchema.parse(\n camelToSnakeCaseNested({\n ...this,\n trace: undefined,\n traceId: this.trace.traceId,\n timestamps: {\n ...this.timestamps,\n finishedAt: this.timestamps.finishedAt,\n },\n ...(this.error && { error: captureError(this.error) }),\n }) as ServerSpan\n );\n this.trace.onEnd(finalSpan);\n } catch (error) {\n if (error instanceof ZodError) {\n console.warn(\"[LangWatch] ⚠️ Failed to parse span\");\n console.warn(fromZodError(error).message);\n }\n this.trace.client.emit(\"error\", error);\n }\n }\n}\n\nexport class LangWatchLLMSpan extends LangWatchSpan implements PendingLLMSpan {\n type: \"llm\";\n model: PendingLLMSpan[\"model\"];\n params: PendingLLMSpan[\"params\"];\n\n constructor(params: Partial<PendingLLMSpan> & { trace: LangWatchTrace }) {\n super({ ...params });\n this.type = \"llm\";\n this.model = params.model ?? \"unknown\";\n this.params = params.params ?? {};\n }\n\n update(params: Partial<PendingLLMSpan>) {\n super.update(params);\n if (params.model) {\n this.model = params.model;\n }\n if (params.params) {\n this.params = params.params;\n }\n }\n\n end(params?: Partial<PendingLLMSpan>) {\n super.end(params);\n }\n}\n\nexport class LangWatchRAGSpan extends LangWatchSpan implements PendingRAGSpan {\n type: \"rag\";\n contexts: PendingRAGSpan[\"contexts\"];\n\n constructor(params: Partial<PendingRAGSpan> & { trace: LangWatchTrace }) {\n super({ ...params });\n this.type = \"rag\";\n this.contexts = params.contexts ?? [];\n }\n\n update(params: Partial<PendingRAGSpan>) {\n super.update(params);\n if (params.contexts) {\n this.contexts = params.contexts;\n }\n }\n\n end(params?: Partial<PendingRAGSpan>) {\n super.end(params);\n }\n}\n","{\n \"name\": \"langwatch\",\n \"version\": \"0.1.5\",\n \"description\": \"\",\n \"main\": \"./dist/index.js\",\n \"module\": \"./dist/index.mjs\",\n \"types\": \"./dist/index.d.ts\",\n \"exports\": {\n \".\": {\n \"import\": \"./dist/index.mjs\",\n \"require\": \"./dist/index.js\"\n }\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/langwatch/langwatch.git\",\n \"directory\": \"typescript-sdk\"\n },\n \"scripts\": {\n \"prepare\": \"./copy-types.sh\",\n \"test\": \"vitest\",\n \"build\": \"npm run prepare && tsup && esbuild src/index.ts --bundle --platform=node --outfile=dist/index.js\",\n \"prepublish\": \"npm run build\"\n },\n \"author\": \"\",\n \"license\": \"Apache-2.0\",\n \"engines\": {\n \"node\": \">=18.0.0\"\n },\n \"devDependencies\": {\n \"@ai-sdk/openai\": \"^0.0.18\",\n \"@eslint/js\": \"^9.4.0\",\n \"@types/debug\": \"^4.1.12\",\n \"@types/eslint__js\": \"^8.42.3\",\n \"@types/node\": \"^16.0.0\",\n \"dotenv\": \"^16.4.5\",\n \"esbuild\": \"^0.21.5\",\n \"eslint\": \"^8.57.0\",\n \"ts-to-zod\": \"3.8.5\",\n \"tsup\": \"^8.1.0\",\n \"typescript\": \"^4.9.5\",\n \"typescript-eslint\": \"^7.11.0\",\n \"vitest\": \"^0.5.0\"\n },\n \"dependencies\": {\n \"@langchain/core\": \"^0.2.7\",\n \"@opentelemetry/otlp-transformer\": \"^0.56.0\",\n \"@opentelemetry/sdk-trace-base\": \"^1.29.0\",\n \"ai\": \"^3.1.23\",\n \"eventemitter3\": \"^5.0.1\",\n \"javascript-stringify\": \"^2.1.0\",\n \"nanoid\": \"^5.0.7\",\n \"openai\": \"^4.47.3\",\n \"zod\": \"^3.22.4\",\n \"zod-validation-error\": \"^3.3.0\"\n }\n}\n","import { type LangWatchSpan, type LangWatchTrace } from \"./index\";\nimport { type Conversation } from \"./server/types/evaluations\";\nimport {\n type Evaluators,\n type EvaluatorTypes,\n} from \"./server/types/evaluators.generated\";\nimport {\n type RAGChunk,\n type SpanTypes,\n type TypedValueEvaluationResult,\n type TypedValueGuardrailResult,\n type TypedValueJson,\n} from \"./server/types/tracer\";\n\ntype Money = {\n currency: string;\n amount: number;\n};\n\nexport type EvaluationResultModel = {\n status: \"processed\" | \"skipped\" | \"error\";\n passed?: boolean;\n score?: number;\n details?: string;\n label?: string;\n cost?: Money;\n};\n\nexport type CommonEvaluationParams = {\n name?: string;\n input?: string;\n output?: string;\n expectedOutput?: string;\n contexts?: RAGChunk[] | string[];\n conversation?: Conversation;\n asGuardrail?: boolean;\n trace?: LangWatchTrace;\n span?: LangWatchSpan;\n};\n\nexport type SavedEvaluationParams = {\n slug: string;\n settings?: Record<string, unknown>;\n} & CommonEvaluationParams;\n\nexport type LangEvalsEvaluationParams<T extends EvaluatorTypes> = {\n evaluator: T;\n settings?: Evaluators[T][\"settings\"];\n} & CommonEvaluationParams;\n\nexport type EvaluationParams =\n | SavedEvaluationParams\n | LangEvalsEvaluationParams<EvaluatorTypes>;\n\nexport const evaluate = async (\n params: EvaluationParams\n): Promise<EvaluationResultModel> => {\n const slug = \"slug\" in params ? params.slug : params.evaluator;\n const span = optionalCreateSpan({\n trace: params.trace,\n span: params.span,\n name: params.name ? params.name : slug,\n type: params.asGuardrail ? \"guardrail\" : \"evaluation\",\n });\n\n try {\n const requestParams = prepareData({\n ...params,\n slug,\n traceId: span?.trace.traceId,\n spanId: span?.spanId,\n span,\n });\n\n const response = await fetch(requestParams.url, {\n method: \"POST\",\n headers: requestParams.headers,\n body: JSON.stringify(requestParams.json),\n });\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n\n const result = await response.json();\n return handleResponse(result, span, params.asGuardrail);\n } catch (e) {\n return handleException(e as Error, span, params.asGuardrail);\n }\n};\n\nconst optionalCreateSpan = ({\n trace,\n span,\n name,\n type,\n}: {\n trace?: LangWatchTrace;\n span?: LangWatchSpan;\n name: string;\n type: SpanTypes;\n}): LangWatchSpan | undefined => {\n if (span) {\n return span.startSpan({ name, type });\n } else if (trace) {\n return trace.startSpan({ name, type });\n }\n return undefined;\n};\n\nconst prepareData = (params: {\n slug: string;\n name?: string;\n input?: string;\n output?: string;\n expectedOutput?: string;\n contexts?: RAGChunk[] | string[];\n conversation?: Conversation;\n settings?: Record<string, unknown>;\n traceId?: string;\n spanId?: string;\n span?: LangWatchSpan;\n asGuardrail?: boolean;\n}) => {\n const data: Record<string, unknown> = {};\n if (params.input) data.input = params.input;\n if (params.output) data.output = params.output;\n if (params.expectedOutput) data.expected_output = params.expectedOutput;\n if (params.contexts && params.contexts.length > 0)\n data.contexts = params.contexts;\n if (params.conversation && params.conversation.length > 0)\n data.conversation = params.conversation;\n\n if (params.span) {\n params.span.update({\n input: { type: \"json\", value: data } as TypedValueJson,\n params: params.settings,\n });\n }\n\n return {\n url: `${process.env.LANGWATCH_ENDPOINT}/api/evaluations/${params.slug}/evaluate`,\n json: {\n trace_id: params.traceId,\n span_id: params.spanId,\n name: params.name,\n data,\n settings: params.settings,\n as_guardrail: params.asGuardrail,\n },\n headers: {\n \"X-Auth-Token\": process.env.LANGWATCH_API_KEY ?? \"\",\n \"Content-Type\": \"application/json\",\n },\n };\n};\n\nconst handleResponse = (\n response: EvaluationResultModel,\n span?: LangWatchSpan,\n asGuardrail = false\n): EvaluationResultModel => {\n if (response.status === \"error\") {\n response.details = response.details ?? \"\";\n }\n\n for (const key of Object.keys(response)) {\n if (\n response[key as keyof EvaluationResultModel] === null ||\n response[key as keyof EvaluationResultModel] === undefined\n ) {\n delete response[key as keyof EvaluationResultModel];\n }\n }\n\n if (span) {\n const output: TypedValueGuardrailResult | TypedValueEvaluationResult =\n asGuardrail\n ? {\n type: \"guardrail_result\",\n value: response,\n }\n : {\n type: \"evaluation_result\",\n value: response,\n };\n\n span.update({ output });\n\n if (response.cost) {\n span.update({\n metrics: {\n cost: response.cost.amount,\n },\n });\n }\n\n span.end();\n }\n\n return response;\n};\n\nconst handleException = (\n e: Error,\n span?: LangWatchSpan,\n asGuardrail = false\n): EvaluationResultModel => {\n const response: EvaluationResultModel = {\n status: \"error\",\n details: e.toString(),\n };\n\n if (asGuardrail) {\n response.passed = true;\n }\n\n return handleResponse(response, span, asGuardrail);\n};\n","import type { AgentAction, AgentFinish } from \"@langchain/core/agents\";\nimport { BaseCallbackHandler } from \"@langchain/core/callbacks/base\";\nimport { type DocumentInterface } from \"@langchain/core/documents\";\nimport type { Serialized } from \"@langchain/core/load/serializable\";\nimport {\n AIMessage,\n AIMessageChunk,\n FunctionMessage,\n FunctionMessageChunk,\n HumanMessage,\n HumanMessageChunk,\n SystemMessage,\n SystemMessageChunk,\n ToolMessage,\n ToolMessageChunk,\n mapChatMessagesToStoredMessages,\n type BaseMessage,\n type StoredMessage,\n} from \"@langchain/core/messages\";\nimport type { ChatGeneration, LLMResult } from \"@langchain/core/outputs\";\nimport type { ChainValues } from \"@langchain/core/utils/types\";\nimport { stringify } from \"javascript-stringify\";\nimport {\n type LangWatchRAGSpan,\n type LangWatchSpan,\n type LangWatchTrace,\n} from \".\";\nimport {\n type RAGSpan,\n type BaseSpan,\n type ChatMessage,\n type ChatRichContent,\n type SpanInputOutput,\n} from \"./types\";\n\nexport class LangWatchCallbackHandler extends BaseCallbackHandler {\n name = \"LangWatchCallbackHandler\";\n trace: LangWatchTrace;\n spans: Record<string, LangWatchSpan> = {};\n\n constructor({ trace }: { trace: LangWatchTrace }) {\n super();\n this.trace = trace;\n }\n\n async handleLLMStart(\n llm: Serialized,\n prompts: string[],\n runId: string,\n parentRunId?: string | undefined,\n extraParams?: Record<string, unknown> | undefined,\n _tags?: string[] | undefined,\n metadata?: Record<string, unknown> | undefined,\n name?: string\n ): Promise<void> {\n this.spans[runId] = this.buildLLMSpan({\n llm,\n runId,\n parentRunId,\n input: {\n type: \"json\",\n value: prompts,\n },\n extraParams,\n metadata,\n name,\n });\n }\n\n private buildLLMSpan({\n llm,\n runId,\n parentRunId,\n input,\n extraParams,\n metadata,\n name,\n }: {\n llm: Serialized;\n runId: string;\n parentRunId?: string | undefined;\n input: SpanInputOutput;\n extraParams?: Record<string, unknown> | undefined;\n metadata?: Record<string, unknown> | undefined;\n name?: string | undefined;\n }) {\n try {\n const parent = this.getParent(parentRunId);\n\n const vendor = metadata?.ls_provider ?? llm.id.at(-2)?.toString();\n const model =\n metadata?.ls_model_name ?? (llm as any).kwargs?.model ?? \"unknown\";\n\n const span = parent.startLLMSpan({\n spanId: runId,\n name: name ?? llm.id.at(-1)?.toString(),\n input,\n model: [vendor, model].filter((x) => x).join(\"/\"),\n params: {\n temperature: (extraParams?.invocation_params as any)?.temperature,\n ...((extraParams?.invocation_params as any)?.functions\n ? { functions: (extraParams?.invocation_params as any)?.functions }\n : {}),\n },\n });\n\n return span;\n } catch (e) {\n this.trace.client.emit(\"error\", e);\n throw e;\n }\n }\n\n async handleChatModelStart(\n llm: Serialized,\n messages: BaseMessage[][],\n runId: string,\n parentRunId?: string | undefined,\n extraParams?: Record<string, unknown> | undefined,\n tags?: string[] | undefined,\n metadata?: Record<string, unknown> | undefined,\n name?: string\n ): Promise<void> {\n this.spans[runId] = this.buildLLMSpan({\n name,\n llm,\n runId,\n parentRunId,\n input: {\n type: \"chat_messages\",\n value: messages.flatMap(convertFromLangChainMessages),\n },\n extraParams,\n metadata,\n });\n }\n\n async handleNewToken(_token: string, runId: string): Promise<void> {\n const span = this.spans[runId];\n if (runId && span && !span.timestamps.firstTokenAt) {\n span.update({\n timestamps: { ...span.timestamps, firstTokenAt: Date.now() },\n });\n }\n }\n\n async handleLLMEnd(\n response: LLMResult,\n runId: string,\n _parentRunId?: string | undefined\n ): Promise<void> {\n try {\n const span = this.spans[runId];\n if (!span) {\n return;\n }\n\n const outputs: SpanInputOutput[] = [];\n for (const generation of response.generations) {\n // TODO: again, why the twice loop? Can OpenAI generate multiple chat outputs?\n for (const generation_ of generation) {\n if (\"message\" in generation_) {\n outputs.push({\n type: \"chat_messages\",\n value: convertFromLangChainMessages([\n (generation_ as ChatGeneration).message,\n ]),\n });\n } else if (\"text\" in generation_) {\n outputs.push({\n type: \"text\",\n value: generation_.text,\n });\n } else {\n outputs.push({\n type: \"text\",\n value: JSON.stringify(generation_),\n });\n }\n }\n }\n\n const output: SpanInputOutput | undefined =\n outputs.length === 1\n ? outputs[0]\n : { type: \"list\", value: outputs as any };\n\n // Commenting it out because LangChain.js prompt and completion tokens is broken, this one doesn't work as it should with python,\n // and response_metadata.prompt and response_metadata.completion is there but it's always 0. Better let our server count.\n // const metrics = response.llmOutput?.token_usage\n // ? {\n // promptTokens: response.llmOutput.token_usage.prompt_tokens,\n // completionTokens: response.llmOutput.token_usage.completion_tokens,\n // }\n // : undefined;\n\n span.end({\n output,\n // ...(metrics ? { metrics } : {}),\n });\n } catch (e) {\n this.trace.client.emit(\"error\", e);\n throw e;\n }\n }\n\n async handleLLMError(\n err: Error,\n runId: string,\n _parentRunId?: string | undefined\n ): Promise<void> {\n this.errorSpan({ runId, error: err });\n }\n\n async handleChainStart(\n chain: Serialized,\n inputs: ChainValues,\n runId: string,\n parentRunId?: string | undefined,\n _tags?: string[] | undefined,\n _metadata?: Record<string, unknown> | undefined,\n _runType?: string,\n name?: string\n ): Promise<void> {\n this.spans[runId] = this.buildSpan({\n type: \"chain\",\n serialized: chain,\n runId,\n parentRunId,\n input: inputs,\n name,\n });\n }\n\n async handleChainEnd(\n output: ChainValues,\n runId: string,\n _parentRunId?: string | undefined\n ): Promise<void> {\n this.endSpan({\n runId,\n output,\n });\n }\n\n async handleChainError(\n err: Error,\n runId: string,\n _parentRunId?: string | undefined,\n _tags?: string[] | undefined,\n _kwargs?: { inputs?: Record<string, unknown> | undefined } | undefined\n ): Promise<void> {\n this.errorSpan({ runId, error: err });\n }\n\n async handleToolStart(\n tool: Serialized,\n input: string,\n runId: string,\n parentRunId?: string | undefined,\n _tags?: string[] | undefined,\n _metadata?: Record<string, unknown> | undefined,\n name?: string\n ): Promise<void> {\n this.spans[runId] = this.buildSpan({\n type: \"tool\",\n serialized: tool,\n runId,\n parentRunId,\n input,\n name,\n });\n }\n\n async handleToolEnd(\n output: string,\n runId: string,\n _parentRunId?: string | undefined\n ): Promise<void> {\n this.endSpan({ runId, output });\n }\n\n async handleToolError(\n err: Error,\n runId: string,\n _parentRunId?: string | undefined,\n _tags?: string[] | undefined\n ): Promise<void> {\n this.errorSpan({ runId, error: err });\n }\n\n async handleRetrieverStart(\n retriever: Serialized,\n query: string,\n runId: string,\n parentRunId?: string | undefined,\n _tags?: string[] | undefined,\n _metadata?: Record<string, unknown> | undefined,\n name?: string | undefined\n ) {\n try {\n const parent = this.getParent(parentRunId);\n\n this.spans[runId] = parent.startRAGSpan({\n spanId: runId,\n name: name ?? retriever.name ?? retriever.id.at(-1)?.toString(),\n input: this.autoconvertTypedValues(query),\n });\n } catch (e) {\n this.trace.client.emit(\"error\", e);\n throw e;\n }\n }\n\n async handleRetrieverEnd(\n documents: DocumentInterface<Record<string, any>>[],\n runId: string,\n _parentRunId?: string | undefined,\n _tags?: string[] | undefined\n ) {\n try {\n const contexts: RAGSpan[\"contexts\"] = documents.map((doc) => ({\n content: doc.pageContent,\n ...(doc.metadata.source ? { documentId: doc.metadata.source } : {}),\n }));\n\n const span = this.spans[runId] as LangWatchRAGSpan;\n if (!span) {\n return;\n }\n\n span.end({\n contexts,\n output: this.autoconvertTypedValues(documents),\n });\n } catch (e) {\n this.trace.client.emit(\"error\", e);\n throw e;\n }\n }\n\n async handleRetrieverError(\n err: Error,\n runId: string,\n _parentRunId?: string | undefined,\n _tags?: string[] | undefined\n ) {\n this.errorSpan({ runId, error: err });\n }\n\n async handleAgentAction(\n _action: AgentAction,\n runId: string,\n _parentRunId?: string | undefined,\n _tags?: string[] | undefined\n ): Promise<void> {\n const span = this.spans[runId];\n if (!span) {\n return;\n }\n\n span.update({\n type: \"agent\",\n });\n }\n\n async handleAgentEnd(\n action: AgentFinish,\n runId: string,\n _parentRunId?: string | undefined,\n _tags?: string[] | undefined\n ): Promise<void> {\n this.endSpan({\n runId,\n output: action.returnValues,\n });\n }\n\n private buildSpan({\n type,\n serialized,\n runId,\n parentRunId,\n input,\n name,\n }: {\n type: BaseSpan[\"type\"];\n serialized: Serialized;\n runId: string;\n parentRunId?: string | undefined;\n input: unknown;\n name?: string | undefined;\n }) {\n try {\n const parent = this.getParent(parentRunId);\n\n const span = parent.startSpan({\n spanId: runId,\n type,\n name: name ?? serialized.name ?? serialized.id.at(-1)?.toString(),\n input: this.autoconvertTypedValues(input),\n });\n\n return span;\n } catch (e) {\n this.trace.client.emit(\"error\", e);\n throw e;\n }\n }\n\n private endSpan({ runId, output }: { runId: string; output: unknown }): void {\n try {\n const span = this.spans[runId];\n if (!span) {\n return;\n }\n\n span.end({\n output: this.autoconvertTypedValues(output),\n });\n } catch (e) {\n this.trace.client.emit(\"error\", e);\n throw e;\n }\n }\n\n private errorSpan({ runId, error }: { runId: string; error: Error }): void {\n const span = this.spans[runId];\n if (!span) {\n return;\n }\n\n span.end({\n error,\n });\n }\n\n private autoconvertTypedValues(value: any): SpanInputOutput | undefined {\n if (\n !value ||\n (typeof value === \"object\" && Object.keys(value).length === 0)\n ) {\n return undefined;\n }\n if (typeof value === \"string\") {\n return { type: \"text\", value };\n }\n try {\n JSON.stringify(value);\n return { type: \"json\", value };\n } catch (e) {\n return { type: \"text\", value: stringify(value) ?? value.toString() };\n }\n }\n\n private getParent(\n parentRunId?: string | undefined\n ): LangWatchSpan | LangWatchTrace {\n return (\n (parentRunId\n ? this.spans[parentRunId]\n : this.spans[Object.keys(this.spans).at(-1) ?? \"\"]) ?? this.trace\n );\n }\n}\n\nexport const convertFromLangChainMessages = (\n messages: BaseMessage[]\n): ChatMessage[] => {\n const chatMessages: ChatMessage[] = [];\n for (const message of messages) {\n chatMessages.push(convertFromLangChainMessage(message));\n }\n return chatMessages;\n};\n\nconst convertFromLangChainMessage = (\n message: BaseMessage & { id?: string[] }\n): ChatMessage => {\n let role: ChatMessage[\"role\"] = \"user\";\n\n const message_: (BaseMessage | StoredMessage) & {\n id?: string[];\n type?: string;\n } = message.lc_serializable\n ? mapChatMessagesToStoredMessages([message])[0]!\n : message;\n\n // Dang this is so hard, langchain.js has 3 ways of representing the same thing...\n if (\n message_ instanceof HumanMessage ||\n message_ instanceof HumanMessageChunk ||\n message_.id?.at(-1) === \"HumanMessage\" ||\n message_.id?.at(-1) === \"HumanMessageChunk\" ||\n message_.type === \"human\"\n ) {\n role = \"user\";\n } else if (\n message instanceof AIMessage ||\n message instanceof AIMessageChunk ||\n message.id?.at(-1) === \"AIMessage\" ||\n message.id?.at(-1) === \"AIMessageChunk\" ||\n message_.type === \"ai\"\n ) {\n role = \"assistant\";\n } else if (\n message instanceof SystemMessage ||\n message instanceof SystemMessageChunk ||\n message.id?.at(-1) === \"SystemMessage\" ||\n message.id?.at(-1) === \"SystemMessageChunk\" ||\n message_.type === \"system\"\n ) {\n role = \"system\";\n } else if (\n message instanceof FunctionMessage ||\n message instanceof FunctionMessageChunk ||\n message.id?.at(-1) === \"FunctionMessage\" ||\n message.id?.at(-1) === \"FunctionMessageChunk\" ||\n message_.type === \"function\"\n ) {\n role = \"function\";\n } else if (\n message instanceof ToolMessage ||\n message instanceof ToolMessageChunk ||\n message.id?.at(-1) === \"ToolMessage\" ||\n message.id?.at(-1) === \"ToolMessageChunk\" ||\n message_.type === \"tool\"\n ) {\n role = \"tool\";\n }\n\n const content =\n typeof message.content === \"string\"\n ? message.content\n : message.content.map(\n (content): ChatRichContent =>\n content.type === \"text\"\n ? { type: \"text\", text: content.text }\n : content.type == \"image_url\"\n ? { type: \"image_url\", image_url: content.image_url }\n : { type: \"text\", text: JSON.stringify(content) }\n );\n\n const functionCall = message.additional_kwargs as\n | ChatMessage[\"function_call\"]\n | undefined;\n\n return {\n role,\n content,\n ...(functionCall &&\n typeof functionCall === \"object\" &&\n Object.keys(functionCall).length > 0\n ? { function_call: functionCall }\n : {}),\n };\n};\n","import {\n reservedSpanParamsSchema,\n reservedTraceMetadataSchema,\n} from \"./server/types/tracer.generated\";\n\nexport type Strict<T> = T & { [K in Exclude<keyof any, keyof T>]: never };\n\ntype SnakeToCamelCase<S extends string> = S extends `${infer T}_${infer U}`\n ? `${T}${Capitalize<SnakeToCamelCase<U>>}`\n : S;\n\nexport type SnakeToCamelCaseNested<T> = T extends object\n ? T extends (infer U)[]\n ? U extends object\n ? {\n [K in keyof U as SnakeToCamelCase<\n K & string\n >]: SnakeToCamelCaseNested<U[K]>;\n }[]\n : T\n : {\n [K in keyof T as SnakeToCamelCase<K & string>]: SnakeToCamelCaseNested<\n T[K]\n >;\n }\n : T;\n\ntype CamelToSnakeCase<S extends string> = S extends `${infer T}${infer U}`\n ? `${T extends Capitalize<T> ? \"_\" : \"\"}${Lowercase<T>}${CamelToSnakeCase<U>}`\n : S;\n\nexport type CamelToSnakeCaseNested<T> = T extends object\n ? T extends (infer U)[]\n ? U extends object\n ? {\n [K in keyof U as CamelToSnakeCase<\n K & string\n >]: CamelToSnakeCaseNested<U[K]>;\n }[]\n : T\n : {\n [K in keyof T as CamelToSnakeCase<K & string>]: CamelToSnakeCaseNested<\n T[K]\n >;\n }\n : T;\n\nfunction camelToSnakeCase(str: string): string {\n return str.replace(/[A-Z]/g, (letter) => `_${letter.toLowerCase()}`);\n}\n\nexport function camelToSnakeCaseNested<T>(\n obj: T,\n parentKey?: string\n): CamelToSnakeCaseNested<T> {\n if (Array.isArray(obj)) {\n return obj.map((item) =>\n camelToSnakeCaseNested(item, parentKey)\n ) as CamelToSnakeCaseNested<T>;\n } else if (typeof obj === \"object\" && obj !== null) {\n const newObj: any = {};\n for (const key in obj) {\n if (obj.hasOwnProperty(key)) {\n const newKey = camelToSnakeCase(key);\n // Keep arbitrary keys the same\n if (\n (parentKey === \"metadata\" &&\n !Object.keys(reservedTraceMetadataSchema.shape).includes(newKey)) ||\n (parentKey === \"params\" &&\n !Object.keys(reservedSpanParamsSchema.shape).includes(newKey)) ||\n (parentKey === \"input\" &&\n [\"json\", \"raw\", \"list\"].includes(newObj.type) &&\n newKey === \"value\") ||\n (parentKey === \"output\" &&\n [\"json\", \"raw\", \"list\"].includes(newObj.type) &&\n newKey === \"value\") ||\n (parentKey === \"contexts\" && newKey === \"content\")\n ) {\n newObj[key] = (obj as any)[key];\n } else {\n newObj[newKey] = camelToSnakeCaseNested((obj as any)[key], newKey);\n }\n }\n }\n return newObj as CamelToSnakeCaseNested<T>;\n } else {\n return obj as CamelToSnakeCaseNested<T>;\n }\n}\n","import {\n type ReadableSpan,\n type SpanExporter,\n} from \"@opentelemetry/sdk-trace-base\";\nimport { createExportTraceServiceRequest } from \"@opentelemetry/otlp-transformer\";\n\nimport { type ExportResult, ExportResultCode } from \"@opentelemetry/core\";\n\nexport class LangWatchExporter implements SpanExporter {\n private endpoint: string;\n private apiKey: string;\n private includeAllSpans: boolean;\n private debug: boolean;\n\n constructor(\n params: {\n endpoint?: string;\n apiKey?: string;\n includeAllSpans?: boolean;\n debug?: boolean;\n } = {}\n ) {\n this.endpoint =\n params.endpoint ??\n process.env.LANGWATCH_ENDPOINT ??\n \"https://app.langwatch.ai\";\n this.apiKey = params.apiKey ?? process.env.LANGWATCH_API_KEY ?? \"\";\n this.includeAllSpans = params.includeAllSpans ?? false;\n this.debug = params.debug ?? false;\n\n if (!this.apiKey) {\n throw new Error(\"LANGWATCH_API_KEY is not set\");\n }\n }\n\n export(\n allSpans: ReadableSpan[],\n resultCallback: (result: ExportResult) => void\n ): void {\n const spans = allSpans.filter(\n (span) => this.includeAllSpans || this.isAiSdkSpan(span)\n );\n if (spans.length === 0) {\n resultCallback({ code: ExportResultCode.SUCCESS });\n return;\n }\n if (this.debug) {\n console.log(\"[LangWatchExporter] Exporting spans:\", spans);\n }\n\n let body;\n try {\n body = JSON.stringify(createExportTraceServiceRequest(spans));\n } catch (error) {\n console.error(\"[LangWatchExporter] Failed to serialize spans:\", error);\n resultCallback({ code: ExportResultCode.FAILED });\n return;\n }\n\n fetch(`${this.endpoint}/api/otel/v1/traces`, {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${this.apiKey}`,\n },\n body,\n })\n .then((response) => {\n if (!response.ok) {\n resultCallback({ code: ExportResultCode.FAILED });\n return;\n }\n resultCallback({ code: ExportResultCode.SUCCESS });\n })\n .catch((error) => {\n console.error(\"[LangWatchExporter] Failed to export spans:\", error);\n resultCallback({\n code: ExportResultCode.FAILED,\n error: error instanceof Error ? error : new Error(\"Unknown error\"),\n });\n });\n }\n\n private isAiSdkSpan(span: ReadableSpan): boolean {\n return span.instrumentationLibrary.name === \"ai\";\n }\n\n shutdown(): Promise<void> {\n return Promise.resolve();\n }\n}\n","/*\n * Copyright The OpenTelemetry Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport interface ExportResult {\n code: ExportResultCode;\n error?: Error;\n}\n\nexport enum ExportResultCode {\n SUCCESS,\n FAILED,\n}\n"],"mappings":"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","names":["content","ExportResultCode"]}
@@ -27,6 +27,16 @@ type ChatRichContent$1 = {
27
27
  url: string;
28
28
  detail?: "auto" | "low" | "high";
29
29
  };
30
+ } | {
31
+ type: "tool_call";
32
+ toolName?: string;
33
+ toolCallId?: string;
34
+ args?: string;
35
+ } | {
36
+ type: "tool_result";
37
+ toolName?: string;
38
+ toolCallId?: string;
39
+ result?: any;
30
40
  };
31
41
  interface TypedValueChatMessages {
32
42
  type: "chat_messages";
@@ -105,7 +115,7 @@ interface SpanTimestamps {
105
115
  first_token_at?: number | null;
106
116
  finished_at: number;
107
117
  }
108
- type SpanTypes = "span" | "llm" | "chain" | "tool" | "agent" | "rag" | "guardrail" | "evaluation" | "workflow" | "component" | "server" | "client" | "producer" | "consumer" | "task" | "unknown";
118
+ type SpanTypes = "span" | "llm" | "chain" | "tool" | "agent" | "rag" | "guardrail" | "evaluation" | "workflow" | "component" | "module" | "server" | "client" | "producer" | "consumer" | "task" | "unknown";
109
119
  interface BaseSpan$1 {
110
120
  span_id: string;
111
121
  parent_id?: string | null;
@@ -27,6 +27,16 @@ type ChatRichContent$1 = {
27
27
  url: string;
28
28
  detail?: "auto" | "low" | "high";
29
29
  };
30
+ } | {
31
+ type: "tool_call";
32
+ toolName?: string;
33
+ toolCallId?: string;
34
+ args?: string;
35
+ } | {
36
+ type: "tool_result";
37
+ toolName?: string;
38
+ toolCallId?: string;
39
+ result?: any;
30
40
  };
31
41
  interface TypedValueChatMessages {
32
42
  type: "chat_messages";
@@ -105,7 +115,7 @@ interface SpanTimestamps {
105
115
  first_token_at?: number | null;
106
116
  finished_at: number;
107
117
  }
108
- type SpanTypes = "span" | "llm" | "chain" | "tool" | "agent" | "rag" | "guardrail" | "evaluation" | "workflow" | "component" | "server" | "client" | "producer" | "consumer" | "task" | "unknown";
118
+ type SpanTypes = "span" | "llm" | "chain" | "tool" | "agent" | "rag" | "guardrail" | "evaluation" | "workflow" | "component" | "module" | "server" | "client" | "producer" | "consumer" | "task" | "unknown";
109
119
  interface BaseSpan$1 {
110
120
  span_id: string;
111
121
  parent_id?: string | null;
package/dist/utils.d.mts CHANGED
@@ -1,2 +1,2 @@
1
1
  import 'ai';
2
- export { i as autoconvertTypedValues, j as captureError, k as convertFromVercelAIMessages } from './utils-CFtM8VVg.mjs';
2
+ export { i as autoconvertTypedValues, j as captureError, k as convertFromVercelAIMessages } from './utils-DJoZVcOA.mjs';
package/dist/utils.d.ts CHANGED
@@ -1,2 +1,2 @@
1
1
  import 'ai';
2
- export { i as autoconvertTypedValues, j as captureError, k as convertFromVercelAIMessages } from './utils-CFtM8VVg.js';
2
+ export { i as autoconvertTypedValues, j as captureError, k as convertFromVercelAIMessages } from './utils-DJoZVcOA.js';
package/dist/utils.js CHANGED
@@ -196,6 +196,18 @@ var chatRichContentSchema = import_zod.z.union([
196
196
  url: import_zod.z.string(),
197
197
  detail: import_zod.z.union([import_zod.z.literal("auto"), import_zod.z.literal("low"), import_zod.z.literal("high")]).optional()
198
198
  }).optional()
199
+ }),
200
+ import_zod.z.object({
201
+ type: import_zod.z.literal("tool_call"),
202
+ toolName: import_zod.z.string().optional(),
203
+ toolCallId: import_zod.z.string().optional(),
204
+ args: import_zod.z.string().optional()
205
+ }),
206
+ import_zod.z.object({
207
+ type: import_zod.z.literal("tool_result"),
208
+ toolName: import_zod.z.string().optional(),
209
+ toolCallId: import_zod.z.string().optional(),
210
+ result: import_zod.z.any().optional()
199
211
  })
200
212
  ]);
201
213
  var typedValueTextSchema = import_zod.z.object({
@@ -288,6 +300,7 @@ var spanTypesSchema = import_zod.z.union([
288
300
  import_zod.z.literal("evaluation"),
289
301
  import_zod.z.literal("workflow"),
290
302
  import_zod.z.literal("component"),
303
+ import_zod.z.literal("module"),
291
304
  import_zod.z.literal("server"),
292
305
  import_zod.z.literal("client"),
293
306
  import_zod.z.literal("producer"),
@@ -574,6 +587,11 @@ var traceSchema = import_zod.z.object({
574
587
  events: import_zod.z.array(eventSchema).optional(),
575
588
  evaluations: import_zod.z.array(evaluationSchema).optional()
576
589
  });
590
+ var traceWithSpansSchema = traceSchema.and(
591
+ import_zod.z.object({
592
+ spans: import_zod.z.array(spanSchema)
593
+ })
594
+ );
577
595
 
578
596
  // src/utils.ts
579
597
  var convertImageToUrl = (image, mimeType) => {