@lmnr-ai/lmnr 0.4.8 → 0.4.9-alpha

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.d.mts CHANGED
@@ -267,6 +267,7 @@ declare class Laminar {
267
267
  sessionId?: string;
268
268
  userId?: string;
269
269
  }): _opentelemetry_api.Context;
270
+ static shutdown(): Promise<void>;
270
271
  static createEvaluation(name: string): Promise<any>;
271
272
  static postEvaluationResults<D, T, O>(evaluationName: string, data: EvaluationDatapoint<D, T, O>[]): Promise<void>;
272
273
  static updateEvaluationStatus(evaluationName: string, status: EvaluationStatus): Promise<void>;
package/dist/index.d.ts CHANGED
@@ -267,6 +267,7 @@ declare class Laminar {
267
267
  sessionId?: string;
268
268
  userId?: string;
269
269
  }): _opentelemetry_api.Context;
270
+ static shutdown(): Promise<void>;
270
271
  static createEvaluation(name: string): Promise<any>;
271
272
  static postEvaluationResults<D, T, O>(evaluationName: string, data: EvaluationDatapoint<D, T, O>[]): Promise<void>;
272
273
  static updateEvaluationStatus(evaluationName: string, status: EvaluationStatus): Promise<void>;
package/dist/index.js CHANGED
@@ -35,7 +35,7 @@ var require_package = __commonJS({
35
35
  "package.json"(exports2, module2) {
36
36
  module2.exports = {
37
37
  name: "@lmnr-ai/lmnr",
38
- version: "0.4.8",
38
+ version: "0.4.9-alpha",
39
39
  description: "TypeScript SDK for Laminar AI",
40
40
  main: "dist/index.js",
41
41
  types: "dist/index.d.ts",
@@ -492,6 +492,9 @@ var shouldSendTraces = () => {
492
492
  }
493
493
  return true;
494
494
  };
495
+ var forceFlush = async () => {
496
+ await _spanProcessor.forceFlush();
497
+ };
495
498
 
496
499
  // src/sdk/configuration/index.ts
497
500
  var import_api3 = require("@opentelemetry/api");
@@ -755,7 +758,7 @@ var Laminar = class {
755
758
  exporter,
756
759
  silenceInitializationMessage: true,
757
760
  instrumentModules,
758
- disableBatch: true
761
+ disableBatch: false
759
762
  });
760
763
  }
761
764
  /**
@@ -941,6 +944,9 @@ var Laminar = class {
941
944
  }
942
945
  return entityContext;
943
946
  }
947
+ static async shutdown() {
948
+ await forceFlush();
949
+ }
944
950
  static async createEvaluation(name) {
945
951
  const response = await fetch(`${this.baseUrl}/v1/evaluations`, {
946
952
  method: "POST",
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../package.json","../src/index.ts","../src/laminar.ts","../src/sdk/errors/index.ts","../src/sdk/tracing/index.ts","../src/sdk/tracing/tracing.ts","../src/sdk/telemetry/telemetry.ts","../src/sdk/configuration/index.ts","../src/sdk/tracing/decorators.ts","../src/sdk/tracing/manual.ts","../src/sdk/tracing/association.ts","../src/utils.ts","../src/evaluations.ts","../src/decorators.ts"],"sourcesContent":["{\n \"name\": \"@lmnr-ai/lmnr\",\n \"version\": \"0.4.8\",\n \"description\": \"TypeScript SDK for Laminar AI\",\n \"main\": \"dist/index.js\",\n \"types\": \"dist/index.d.ts\",\n \"scripts\": {\n \"build\": \"tsup src/index.ts --format esm,cjs --dts\",\n \"test\": \"echo \\\"Error: no test specified\\\" && exit 1\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git+https://github.com/lmnr-ai/lmnr-ts.git\"\n },\n \"keywords\": [\n \"laminar\",\n \"lmnr\",\n \"sdk\",\n \"lmnr.ai\"\n ],\n \"author\": \"founders@lmnr.ai\",\n \"license\": \"Apache-2.0\",\n \"bugs\": {\n \"url\": \"https://github.com/lmnr-ai/lmnr-ts/issues\"\n },\n \"homepage\": \"https://github.com/lmnr-ai/lmnr-ts#README\",\n \"devDependencies\": {\n \"@anthropic-ai/sdk\": \"^0.27.3\",\n \"@aws-sdk/client-bedrock-runtime\": \"^3.649.0\",\n \"@azure/openai\": \"2.0.0-beta.2\",\n \"@google-cloud/aiplatform\": \"^3.29.0\",\n \"@google-cloud/vertexai\": \"^1.7.0\",\n \"@langchain/core\": \"^0.2.32\",\n \"@pinecone-database/pinecone\": \"^3.0.2\",\n \"@qdrant/js-client-rest\": \"^1.11.0\",\n \"@types/node\": \"^22.5.4\",\n \"@types/uuid\": \"^10.0.0\",\n \"bufferutil\": \"^4.0.8\",\n \"chromadb\": \"^1.8.1\",\n \"cohere-ai\": \"^7.13.0\",\n \"langchain\": \"^0.2.18\",\n \"llamaindex\": \"^0.5.23\",\n \"openai\": \"^4.58.2\",\n \"runnables\": \"link:@langchain/core/runnables\",\n \"tsup\": \"^8.2.4\",\n \"typescript\": \"^5.5.4\",\n \"vectorstores\": \"link:@langchain/core/vectorstores\"\n },\n \"dependencies\": {\n \"@grpc/grpc-js\": \"^1.11.2\",\n \"@opentelemetry/api\": \"^1.9.0\",\n \"@opentelemetry/core\": \"^1.26.0\",\n \"@opentelemetry/exporter-trace-otlp-grpc\": \"^0.53.0\",\n \"@opentelemetry/exporter-trace-otlp-proto\": \"^0.53.0\",\n \"@opentelemetry/instrumentation\": \"^0.53.0\",\n \"@opentelemetry/resources\": \"^1.26.0\",\n \"@opentelemetry/sdk-node\": \"^0.53.0\",\n \"@opentelemetry/sdk-trace-base\": \"^1.26.0\",\n \"@opentelemetry/sdk-trace-node\": \"^1.26.0\",\n \"@opentelemetry/semantic-conventions\": \"^1.27.0\",\n \"@traceloop/ai-semantic-conventions\": \"^0.11.0\",\n \"@traceloop/instrumentation-anthropic\": \"^0.11.1\",\n \"@traceloop/instrumentation-azure\": \"^0.11.1\",\n \"@traceloop/instrumentation-bedrock\": \"^0.11.1\",\n \"@traceloop/instrumentation-chromadb\": \"^0.11.1\",\n \"@traceloop/instrumentation-cohere\": \"^0.11.1\",\n \"@traceloop/instrumentation-langchain\": \"^0.11.1\",\n \"@traceloop/instrumentation-llamaindex\": \"^0.11.1\",\n \"@traceloop/instrumentation-openai\": \"^0.11.1\",\n \"@traceloop/instrumentation-pinecone\": \"^0.11.1\",\n \"@traceloop/instrumentation-qdrant\": \"^0.11.1\",\n \"@traceloop/instrumentation-vertexai\": \"^0.11.1\",\n \"posthog-node\": \"^4.2.0\",\n \"uuid\": \"^10.0.0\"\n }\n}","\nexport {\n NodeInput,\n PipelineRunResponse,\n PipelineRunRequest,\n ChatMessage,\n Event,\n EvaluateEvent,\n} from './types';\n\nexport { Laminar } from './laminar';\nexport { Evaluation, Dataset, Datapoint } from './evaluations';\nexport { observe } from './decorators';\n","import { PipelineRunResponse, PipelineRunRequest, EvaluationDatapoint, EvaluationStatus } from './types';\nimport { Attributes, AttributeValue, context, createContextKey, isSpanContextValid, TimeInput, trace } from '@opentelemetry/api';\nimport { InitializeOptions, initialize as traceloopInitialize } from './sdk/node-server-sdk'\nimport { otelSpanIdToUUID, otelTraceIdToUUID } from './utils';\nimport { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-grpc';\nimport { Metadata } from '@grpc/grpc-js';\nimport { ASSOCIATION_PROPERTIES_KEY } from './sdk/tracing/tracing';\n\n// quick patch to get the traceloop's default tracer, since their \n// `getTracer` function is not exported.\n// Another option would be to import directly \n// like so: `import { getTracer } from '@traceloop/node-server-sdk/dist/src/lib/tracing/tracing';`\n// which isn't too nice either.\nconst DEFAULT_TRACER_NAME = 'traceloop.tracer';\n\ninterface LaminarInitializeProps {\n projectApiKey?: string;\n env?: Record<string, string>;\n baseUrl?: string;\n instrumentModules?: InitializeOptions[\"instrumentModules\"];\n}\n\nexport class Laminar {\n private static baseUrl: string = 'https://api.lmnr.ai:8443';\n private static projectApiKey: string;\n private static env: Record<string, string> = {};\n private static isInitialized: boolean = false;\n\n /**\n * Initialize Laminar context across the application.\n * This method must be called before using any other Laminar methods or decorators.\n *\n * @param project_api_key - Laminar project api key. You can generate one by going\n * to the projects settings page on the Laminar dashboard.\n * If not specified, it will try to read from the LMNR_PROJECT_API_KEY environment variable.\n * @param env - Default environment passed to `run` and `evaluateEvent` requests,\n * unless overriden at request time. Usually, model provider keys are stored here.\n * @param baseUrl - Url of Laminar endpoint, or the custom open telemetry ingester.\n * If not specified, defaults to https://api.lmnr.ai:8443. For locally hosted Laminar,\n * default setting must be http://localhost:8001.\n * @param instrumentModules - List of modules to instrument.\n * If not specified, all auto-instrumentable modules will be instrumented, which include\n * LLM calls (OpenAI, Anthropic, etc), Langchain, VectorDB calls (Pinecone, Qdrant, etc).\n * Pass an empty object {} to disable any kind of automatic instrumentation.\n * If you only want to auto-instrument specific modules, then pass them in the object.\n * \n * Example:\n * ```typescript\n * import { Laminar as L } from '@lmnr-ai/lmnr';\n * import { OpenAI } from 'openai';\n * import * as ChainsModule from \"langchain/chains\";\n * \n * // Initialize Laminar while auto-instrumenting Langchain and OpenAI modules.\n * L.initialize({ projectApiKey: \"<LMNR_PROJECT_API_KEY>\", instrumentModules: {\n * langchain: {\n * chainsModule: ChainsModule\n * },\n * openAI: OpenAI\n * } });\n * ```\n *\n * @throws {Error} - If project API key is not set\n */\n public static initialize({\n projectApiKey,\n env,\n baseUrl,\n instrumentModules\n }: LaminarInitializeProps) {\n\n let key = projectApiKey ?? process.env.LMNR_PROJECT_API_KEY;\n if (key === undefined) {\n throw new Error(\n 'Please initialize the Laminar object with your project API key ' +\n 'or set the LMNR_PROJECT_API_KEY environment variable'\n );\n }\n this.projectApiKey = key;\n if (baseUrl) {\n this.baseUrl = baseUrl;\n }\n this.isInitialized = true;\n this.env = env ?? {};\n\n const metadata = new Metadata();\n metadata.set('authorization', `Bearer ${this.projectApiKey}`);\n const exporter = new OTLPTraceExporter({\n url: this.baseUrl,\n metadata,\n });\n\n traceloopInitialize({\n exporter,\n silenceInitializationMessage: true,\n instrumentModules,\n disableBatch: true,\n });\n }\n\n /**\n * Check if Laminar has been initialized. Utility to make sure other methods\n * are called after initialization.\n */\n public static initialized(): boolean {\n return this.isInitialized;\n }\n\n /**\n * Sets the environment that will be sent to Laminar requests.\n * \n * @param env - The environment variables to override. If not provided, the current environment will not be modified.\n */\n public static setEnv(env?: Record<string, string>) {\n if (env) {\n this.env = env;\n }\n }\n\n /**\n * Sets the project API key for authentication with Laminar.\n *\n * @param projectApiKey - The API key to be set. If not provided, the existing API key will not be modified.\n */\n public static setProjectApiKey(projectApiKey?: string) {\n if (projectApiKey) {\n this.projectApiKey = projectApiKey;\n }\n }\n\n /**\n * Runs the pipeline with the given inputs\n *\n * @param pipeline - The name of the Laminar pipeline. Pipeline must have a target version.\n * @param inputs - The inputs for the pipeline. Map from an input node name to input data.\n * @param env - The environment variables for the pipeline execution. Typically used for model provider keys.\n * @param metadata - Additional metadata for the pipeline run.\n * @param currentSpanId - The ID of the current span.\n * @param currentTraceId - The ID of the current trace.\n * @returns A promise that resolves to the response of the pipeline run.\n * @throws An error if the Laminar object is not initialized with a project API key. Or if the request fails.\n */\n public static async run({\n pipeline,\n inputs,\n env,\n metadata = {},\n currentSpanId,\n currentTraceId,\n }: PipelineRunRequest): Promise<PipelineRunResponse> {\n const currentSpan = trace.getActiveSpan();\n let parentSpanId: string | undefined;\n let traceId: string | undefined;\n if (currentSpan !== undefined && isSpanContextValid(currentSpan.spanContext())) {\n parentSpanId = currentSpanId ?? otelSpanIdToUUID(currentSpan.spanContext().spanId);\n traceId = currentTraceId ?? otelTraceIdToUUID(currentSpan.spanContext().traceId);\n } else {\n parentSpanId = currentSpanId;\n traceId = currentTraceId;\n }\n if (this.projectApiKey === undefined) {\n throw new Error(\n 'Please initialize the Laminar object with your project API key ' +\n 'or set the LMNR_PROJECT_API_KEY environment variable'\n );\n }\n const envirionment = env === undefined ? this.env : env;\n\n const response = await fetch(`${this.baseUrl}/v1/pipeline/run`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify({\n inputs,\n pipeline,\n env: envirionment,\n metadata,\n parentSpanId,\n traceId,\n })\n });\n\n if (!response.ok) {\n throw new Error(`Failed to run pipeline ${pipeline}. Response: ${response.statusText}`);\n }\n try {\n return await response.json() as PipelineRunResponse;\n } catch (error) {\n throw new Error(`Failed to parse response from pipeline ${pipeline}. Error: ${error}`);\n }\n }\n\n /**\n * Associates an event with the current span. If event with such name never\n * existed, Laminar will create a new event and infer its type from the value.\n * If the event already exists, Laminar will append the value to the event\n * if and only if the value is of a matching type. Otherwise, the event won't\n * be recorded. Supported types are string, number, and boolean. If the value\n * is `null`, event is considered a boolean tag with the value of `true`.\n *\n * @param name - The name of the event.\n * @param value - The value of the event. Must be a primitive type. If not specified, boolean true is assumed in the backend.\n * @param timestamp - The timestamp of the event. If not specified, relies on the underlying OpenTelemetry implementation.\n * If specified as an integer, it must be epoch nanoseconds.\n */\n public static event(\n name: string,\n value?: AttributeValue,\n timestamp?: TimeInput,\n ) {\n const currentSpan = trace.getActiveSpan();\n if (currentSpan === undefined || !isSpanContextValid(currentSpan.spanContext())) {\n console.warn(\"Laminar().event()\\` called outside of span context.\" +\n ` Event '${name}' will not be recorded in the trace.` +\n \" Make sure to annotate the function with a decorator\"\n );\n return;\n }\n\n const event: Attributes = {\n \"lmnr.event.type\": \"default\",\n }\n if (value !== undefined) {\n event[\"lmnr.event.value\"] = value;\n }\n\n currentSpan.addEvent(name, event, timestamp);\n }\n\n /**\n * Sends an event for evaluation to the Laminar backend.\n * \n * @param name - The name of the event.\n * @param evaluator - The name of the pipeline that evaluates the event.\n * @param data - A map from input node name to its value in the evaluator pipeline.\n * @param env - Environment variables required to run the pipeline.\n * @param timestamp - If specified as an integer, it must be epoch nanoseconds.\n * If not specified, relies on the underlying OpenTelemetry implementation.\n */\n public static evaluateEvent(\n name: string,\n evaluator: string,\n data: Record<string, any>,\n env?: Record<string, string>,\n timestamp?: TimeInput,\n ) {\n const currentSpan = trace.getActiveSpan();\n\n if (currentSpan === undefined || !isSpanContextValid(currentSpan.spanContext())) {\n console.warn(\"Laminar().evaluateEvent()\\` called outside of span context.\" +\n ` Evaluate event '${name}' will not be recorded in the trace.` +\n \" Make sure to annotate the function with a decorator\"\n );\n return;\n }\n\n const event = {\n \"lmnr.event.type\": \"evaluate\",\n \"lmnr.event.evaluator\": evaluator,\n \"lmnr.event.data\": JSON.stringify(data),\n \"lmnr.event.env\": JSON.stringify(env ?? {}),\n }\n\n currentSpan.addEvent(name, event, timestamp);\n }\n\n /**\n * Sets the session information for the current span and returns the context to use for the following spans.\n * \n * Example:\n * ```typescript\n * import { context as contextApi } from '@opentelemetry/api';\n * import { Laminar } from '@lmnr-ai/laminar';\n * const context = Laminar.contextWithSession({ sessionId: \"1234\", userId: \"5678\" });\n * contextApi.with(context, () => {\n * // Your code here\n * });\n * ```\n * \n * @param sessionId - The session ID to associate with the span.\n * @param userId - The user ID to associate with the span.\n * @returns The updated context with the association properties.\n */\n public static contextWithSession({ sessionId, userId }: { sessionId?: string, userId?: string }) {\n\n const currentSpan = trace.getActiveSpan();\n if (currentSpan !== undefined && isSpanContextValid(currentSpan.spanContext())) {\n if (sessionId) {\n currentSpan.setAttribute(\"traceloop.association.properties.session_id\", sessionId);\n }\n if (userId) {\n currentSpan.setAttribute(\"traceloop.association.properties.user_id\", userId);\n }\n }\n let associationProperties = {};\n if (sessionId) {\n associationProperties = { ...associationProperties, \"session_id\": sessionId };\n }\n if (userId) {\n associationProperties = { ...associationProperties, \"user_id\": userId };\n }\n\n let entityContext = context.active();\n const currentAssociationProperties = entityContext.getValue(ASSOCIATION_PROPERTIES_KEY);\n if (associationProperties) {\n entityContext = entityContext.setValue(\n ASSOCIATION_PROPERTIES_KEY,\n { ...(currentAssociationProperties ?? {}), ...associationProperties },\n );\n }\n\n return entityContext;\n }\n\n public static async createEvaluation(name: string) {\n const response = await fetch(`${this.baseUrl}/v1/evaluations`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify({\n name,\n })\n });\n\n return await response.json();\n }\n\n public static async postEvaluationResults<D, T, O>(\n evaluationName: string,\n data: EvaluationDatapoint<D, T, O>[]\n ): Promise<void> {\n const body = JSON.stringify({\n name: evaluationName,\n points: data,\n });\n const headers = this.getHeaders();\n const url = `${this.baseUrl}/v1/evaluation-datapoints`;\n try {\n const response = await fetch(url, {\n method: \"POST\",\n headers,\n body,\n });\n if (!response.ok) {\n console.error(\"Failed to send evaluation results. Response: \");\n response.text().then((text) => console.error(text));\n }\n } catch (error) {\n console.error(\"Failed to send evaluation results. Error: \", error);\n };\n }\n\n public static async updateEvaluationStatus(\n evaluationName: string,\n status: EvaluationStatus,\n ): Promise<void> {\n const body = JSON.stringify({\n name: evaluationName,\n status,\n });\n const headers = this.getHeaders();\n const url = `${this.baseUrl}/v1/evaluations`;\n try {\n const response = await fetch(url, {\n method: \"PUT\",\n headers,\n body,\n });\n if (!response.ok) {\n console.error(\"Failed to update evaluation status. Response: \");\n response.text().then((text) => console.error(text));\n }\n } catch (error) {\n console.error(\"Failed to update evaluation status. Error: \", error);\n }\n }\n\n private static getHeaders() {\n return {\n \"Content-Type\": \"application/json\",\n \"Authorization\": `Bearer ${this.projectApiKey}`,\n };\n };\n}\n","/**\n * The severity of an error.\n */\nexport const SEVERITY = {\n Warning: \"Warning\",\n Error: \"Error\",\n Critical: \"Critical\",\n} as const;\n\nexport type Severity = (typeof SEVERITY)[keyof typeof SEVERITY];\n\n/**\n * Base class for all Traceloop errors.\n */\nexport class TraceloopError extends Error {\n /**\n * The severity of the error.\n */\n severity: Severity;\n /**\n * The underlying cause of the error.\n */\n underlyingCause?: Error;\n\n constructor(message: string, severity: Severity = SEVERITY.Error) {\n super(message);\n this.severity = severity;\n }\n}\n\nexport class NotInitializedError extends TraceloopError {\n constructor() {\n super(\n `The Traceloop SDK must be initialized by calling the \"initialize\" function prior to use.`,\n SEVERITY.Critical,\n );\n }\n}\n\nexport class InitializationError extends TraceloopError {\n constructor(message?: string, cause?: Error) {\n super(message ?? \"Failed to initialize Traceloop SDK\", SEVERITY.Critical);\n this.underlyingCause = cause;\n }\n}\n\nexport class ArgumentNotProvidedError extends TraceloopError {\n constructor(argumentName: string) {\n super(`The \"${argumentName}\" argument is required and must be a string.`);\n }\n}\n\nexport class PromptNotFoundError extends TraceloopError {\n constructor(key: string) {\n super(`The prompt \"${key}\" was not found in the registry.`);\n }\n}\n","/* eslint-disable @typescript-eslint/no-var-requires */\nimport { NodeSDK } from \"@opentelemetry/sdk-node\";\nimport {\n SimpleSpanProcessor,\n BatchSpanProcessor,\n SpanProcessor,\n} from \"@opentelemetry/sdk-trace-node\";\nimport { baggageUtils } from \"@opentelemetry/core\";\nimport { Span, context, diag } from \"@opentelemetry/api\";\nimport { OTLPTraceExporter } from \"@opentelemetry/exporter-trace-otlp-proto\";\nimport { Resource } from \"@opentelemetry/resources\";\nimport { SEMRESATTRS_SERVICE_NAME } from \"@opentelemetry/semantic-conventions\";\nimport { Instrumentation } from \"@opentelemetry/instrumentation\";\nimport { InitializeOptions } from \"../interfaces\";\nimport {\n Detector,\n DetectorSync,\n IResource,\n ResourceDetectionConfig,\n envDetectorSync,\n hostDetectorSync,\n processDetectorSync,\n} from \"@opentelemetry/resources\"\nimport {\n ASSOCIATION_PROPERTIES_KEY,\n} from \"./tracing\";\nimport { Telemetry } from \"../telemetry/telemetry\";\nimport { _configuration } from \"../configuration\";\nimport {\n SpanAttributes,\n} from \"@traceloop/ai-semantic-conventions\";\nimport { AnthropicInstrumentation } from \"@traceloop/instrumentation-anthropic\";\nimport { OpenAIInstrumentation } from \"@traceloop/instrumentation-openai\";\nimport { AzureOpenAIInstrumentation } from \"@traceloop/instrumentation-azure\";\nimport { LlamaIndexInstrumentation } from \"@traceloop/instrumentation-llamaindex\";\nimport {\n AIPlatformInstrumentation,\n VertexAIInstrumentation,\n} from \"@traceloop/instrumentation-vertexai\";\nimport { BedrockInstrumentation } from \"@traceloop/instrumentation-bedrock\";\nimport { CohereInstrumentation } from \"@traceloop/instrumentation-cohere\";\nimport { PineconeInstrumentation } from \"@traceloop/instrumentation-pinecone\";\nimport { LangChainInstrumentation } from \"@traceloop/instrumentation-langchain\";\nimport { ChromaDBInstrumentation } from \"@traceloop/instrumentation-chromadb\";\nimport { QdrantInstrumentation } from \"@traceloop/instrumentation-qdrant\";\n\nlet _sdk: NodeSDK;\nlet _spanProcessor: SimpleSpanProcessor | BatchSpanProcessor;\nlet openAIInstrumentation: OpenAIInstrumentation | undefined;\nlet anthropicInstrumentation: AnthropicInstrumentation | undefined;\nlet azureOpenAIInstrumentation: AzureOpenAIInstrumentation | undefined;\nlet cohereInstrumentation: CohereInstrumentation | undefined;\nlet vertexaiInstrumentation: VertexAIInstrumentation | undefined;\nlet aiplatformInstrumentation: AIPlatformInstrumentation | undefined;\nlet bedrockInstrumentation: BedrockInstrumentation | undefined;\nlet langchainInstrumentation: LangChainInstrumentation | undefined;\nlet llamaIndexInstrumentation: LlamaIndexInstrumentation | undefined;\nlet pineconeInstrumentation: PineconeInstrumentation | undefined;\nlet chromadbInstrumentation: ChromaDBInstrumentation | undefined;\nlet qdrantInstrumentation: QdrantInstrumentation | undefined;\n\n\nconst instrumentations: Instrumentation[] = [];\n\nconst initInstrumentations = () => {\n const exceptionLogger = (e: Error) => Telemetry.getInstance().logException(e);\n const enrichTokens =\n (process.env.TRACELOOP_ENRICH_TOKENS || \"true\").toLowerCase() === \"true\";\n\n openAIInstrumentation = new OpenAIInstrumentation({\n enrichTokens,\n exceptionLogger,\n });\n instrumentations.push(openAIInstrumentation);\n\n anthropicInstrumentation = new AnthropicInstrumentation({ exceptionLogger });\n instrumentations.push(anthropicInstrumentation);\n\n azureOpenAIInstrumentation = new AzureOpenAIInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(azureOpenAIInstrumentation);\n\n cohereInstrumentation = new CohereInstrumentation({ exceptionLogger });\n instrumentations.push(cohereInstrumentation);\n\n vertexaiInstrumentation = new VertexAIInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(vertexaiInstrumentation);\n\n aiplatformInstrumentation = new AIPlatformInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(aiplatformInstrumentation);\n\n bedrockInstrumentation = new BedrockInstrumentation({ exceptionLogger });\n instrumentations.push(bedrockInstrumentation);\n\n pineconeInstrumentation = new PineconeInstrumentation({ exceptionLogger });\n instrumentations.push(pineconeInstrumentation);\n\n langchainInstrumentation = new LangChainInstrumentation({ exceptionLogger });\n instrumentations.push(langchainInstrumentation);\n\n llamaIndexInstrumentation = new LlamaIndexInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(llamaIndexInstrumentation);\n\n chromadbInstrumentation = new ChromaDBInstrumentation({ exceptionLogger });\n instrumentations.push(chromadbInstrumentation);\n\n qdrantInstrumentation = new QdrantInstrumentation({ exceptionLogger });\n instrumentations.push(qdrantInstrumentation);\n};\n\nconst manuallyInitInstrumentations = (\n instrumentModules: InitializeOptions[\"instrumentModules\"],\n) => {\n const exceptionLogger = (e: Error) => Telemetry.getInstance().logException(e);\n const enrichTokens =\n (process.env.TRACELOOP_ENRICH_TOKENS || \"true\").toLowerCase() === \"true\";\n\n instrumentations.length = 0;\n\n if (instrumentModules?.openAI) {\n openAIInstrumentation = new OpenAIInstrumentation({\n enrichTokens,\n exceptionLogger,\n });\n instrumentations.push(openAIInstrumentation);\n openAIInstrumentation.manuallyInstrument(instrumentModules.openAI);\n }\n\n if (instrumentModules?.anthropic) {\n anthropicInstrumentation = new AnthropicInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(anthropicInstrumentation);\n anthropicInstrumentation.manuallyInstrument(instrumentModules.anthropic);\n }\n\n if (instrumentModules?.azureOpenAI) {\n const instrumentation = new AzureOpenAIInstrumentation({ exceptionLogger });\n instrumentations.push(instrumentation as Instrumentation);\n azureOpenAIInstrumentation = instrumentation;\n instrumentation.manuallyInstrument(instrumentModules.azureOpenAI);\n }\n\n if (instrumentModules?.cohere) {\n cohereInstrumentation = new CohereInstrumentation({ exceptionLogger });\n instrumentations.push(cohereInstrumentation);\n cohereInstrumentation.manuallyInstrument(instrumentModules.cohere);\n }\n\n if (instrumentModules?.google_vertexai) {\n vertexaiInstrumentation = new VertexAIInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(vertexaiInstrumentation);\n vertexaiInstrumentation.manuallyInstrument(\n instrumentModules.google_vertexai,\n );\n }\n\n if (instrumentModules?.google_aiplatform) {\n aiplatformInstrumentation = new AIPlatformInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(aiplatformInstrumentation);\n aiplatformInstrumentation.manuallyInstrument(\n instrumentModules.google_aiplatform,\n );\n }\n\n if (instrumentModules?.bedrock) {\n bedrockInstrumentation = new BedrockInstrumentation({ exceptionLogger });\n instrumentations.push(bedrockInstrumentation);\n bedrockInstrumentation.manuallyInstrument(instrumentModules.bedrock);\n }\n\n if (instrumentModules?.pinecone) {\n const instrumentation = new PineconeInstrumentation({ exceptionLogger });\n instrumentations.push(instrumentation as Instrumentation);\n instrumentation.manuallyInstrument(instrumentModules.pinecone);\n }\n\n if (instrumentModules?.langchain) {\n langchainInstrumentation = new LangChainInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(langchainInstrumentation);\n langchainInstrumentation.manuallyInstrument(instrumentModules.langchain);\n }\n\n if (instrumentModules?.llamaIndex) {\n llamaIndexInstrumentation = new LlamaIndexInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(llamaIndexInstrumentation);\n llamaIndexInstrumentation.manuallyInstrument(instrumentModules.llamaIndex);\n }\n\n if (instrumentModules?.chromadb) {\n chromadbInstrumentation = new ChromaDBInstrumentation({ exceptionLogger });\n instrumentations.push(chromadbInstrumentation);\n chromadbInstrumentation.manuallyInstrument(instrumentModules.chromadb);\n }\n\n if (instrumentModules?.qdrant) {\n qdrantInstrumentation = new QdrantInstrumentation({ exceptionLogger });\n instrumentations.push(qdrantInstrumentation);\n qdrantInstrumentation.manuallyInstrument(instrumentModules.qdrant);\n }\n};\n\nfunction awaitAttributes(detector: DetectorSync): Detector {\n return {\n async detect(config?: ResourceDetectionConfig): Promise<IResource> {\n const resource = detector.detect(config)\n await resource.waitForAsyncAttributes?.()\n\n return resource\n },\n }\n}\n\n/**\n * Initializes the Traceloop SDK.\n * Must be called once before any other SDK methods.\n *\n * @param options - The options to initialize the SDK. See the {@link InitializeOptions} for details.\n */\nexport const startTracing = (options: InitializeOptions) => {\n if (options.instrumentModules !== undefined) {\n // If options.instrumentModules is empty, it will not initialize anything,\n // so empty dict can essentially be passed to disable any kind of automatic instrumentation.\n manuallyInitInstrumentations(options.instrumentModules);\n } else {\n initInstrumentations();\n }\n\n if (!shouldSendTraces()) {\n openAIInstrumentation?.setConfig({\n traceContent: false,\n });\n azureOpenAIInstrumentation?.setConfig({\n traceContent: false,\n });\n llamaIndexInstrumentation?.setConfig({\n traceContent: false,\n });\n vertexaiInstrumentation?.setConfig({\n traceContent: false,\n });\n aiplatformInstrumentation?.setConfig({\n traceContent: false,\n });\n bedrockInstrumentation?.setConfig({\n traceContent: false,\n });\n cohereInstrumentation?.setConfig({\n traceContent: false,\n });\n chromadbInstrumentation?.setConfig({\n traceContent: false,\n });\n }\n\n const headers = process.env.TRACELOOP_HEADERS\n ? baggageUtils.parseKeyPairsIntoRecord(process.env.TRACELOOP_HEADERS)\n : { Authorization: `Bearer ${options.apiKey}` };\n\n const traceExporter =\n options.exporter ??\n new OTLPTraceExporter({\n url: `${options.baseUrl}/v1/traces`,\n headers,\n });\n _spanProcessor = options.disableBatch\n ? new SimpleSpanProcessor(traceExporter)\n : new BatchSpanProcessor(traceExporter);\n\n _spanProcessor.onStart = (span: Span) => {\n // This sets the properties only if the context has them\n const associationProperties = context\n .active()\n .getValue(ASSOCIATION_PROPERTIES_KEY);\n if (associationProperties) {\n for (const [key, value] of Object.entries(associationProperties)) {\n span.setAttribute(\n `${SpanAttributes.TRACELOOP_ASSOCIATION_PROPERTIES}.${key}`,\n value,\n );\n }\n }\n };\n\n if (options.exporter) {\n Telemetry.getInstance().capture(\"tracer:init\", {\n exporter: \"custom\",\n processor: options.disableBatch ? \"simple\" : \"batch\",\n });\n } else {\n Telemetry.getInstance().capture(\"tracer:init\", {\n exporter: options.baseUrl ?? \"\",\n processor: options.disableBatch ? \"simple\" : \"batch\",\n });\n }\n\n const spanProcessors: SpanProcessor[] = [_spanProcessor];\n if (options.processor) {\n spanProcessors.push(options.processor);\n }\n\n _sdk = new NodeSDK({\n resource: new Resource({\n [SEMRESATTRS_SERVICE_NAME]:\n options.appName || process.env.npm_package_name,\n }),\n spanProcessors,\n contextManager: options.contextManager,\n textMapPropagator: options.propagator,\n traceExporter,\n instrumentations,\n // We should re-consider removing irrelevant spans here in the future\n // sampler: new TraceloopSampler(),\n resourceDetectors: [\n awaitAttributes(envDetectorSync),\n awaitAttributes(processDetectorSync),\n awaitAttributes(hostDetectorSync),\n ],\n });\n\n _sdk.start();\n};\n\nexport const shouldSendTraces = () => {\n if (!_configuration) {\n diag.warn(\"Traceloop not initialized\");\n return false;\n }\n\n if (\n _configuration.traceContent === false ||\n (process.env.TRACELOOP_TRACE_CONTENT || \"true\").toLowerCase() === \"false\"\n ) {\n return false;\n }\n\n return true;\n};\n\nexport const forceFlush = async () => {\n await _spanProcessor.forceFlush();\n};\n","import { trace, createContextKey } from \"@opentelemetry/api\";\nimport { Context } from \"@opentelemetry/api/build/src/context/types\";\n\nconst TRACER_NAME = \"traceloop.tracer\";\nexport const WORKFLOW_NAME_KEY = createContextKey(\"workflow_name\");\nexport const ENTITY_NAME_KEY = createContextKey(\"entity_name\");\nexport const ASSOCIATION_PROPERTIES_KEY = createContextKey(\n \"association_properties\",\n);\n\nexport const getTracer = () => {\n return trace.getTracer(TRACER_NAME);\n};\n\nexport const getEntityPath = (entityContext: Context): string | undefined => {\n const path = entityContext.getValue(ENTITY_NAME_KEY);\n\n return path ? `${path}` : undefined;\n};\n","import * as os from \"os\";\nimport * as fs from \"fs\";\nimport * as path from \"path\";\nimport { v4 as uuid } from \"uuid\";\nimport { PostHog } from \"posthog-node\";\nconst { version } = require('../../../package.json');\n\nexport class Telemetry {\n private static instance: Telemetry;\n\n private static readonly ANON_ID_PATH = `${os.homedir()}/.cache/lmnr/telemetry_anon_id`;\n private static readonly UNKNOWN_ANON_ID = \"UNKNOWN\";\n\n private telemetryEnabled: boolean;\n private posthog: PostHog | undefined;\n private anonId: string | undefined;\n\n public static getInstance(): Telemetry {\n if (!Telemetry.instance) {\n Telemetry.instance = new Telemetry();\n }\n return Telemetry.instance;\n }\n\n private constructor() {\n this.telemetryEnabled =\n !process.env.LMNR_TELEMETRY ||\n process.env.LMNR_TELEMETRY.toLowerCase() === \"true\";\n\n if (this.telemetryEnabled) {\n this.posthog = new PostHog(\n \"phc_dUMdjfNKf11jcHgtn7juSnT4P1pO0tafsPUWt4PuwG7\",\n );\n }\n }\n\n private getAnonId() {\n if (this.anonId) {\n return this.anonId;\n }\n\n try {\n if (!fs.existsSync(Telemetry.ANON_ID_PATH)) {\n fs.mkdirSync(path.dirname(Telemetry.ANON_ID_PATH), { recursive: true });\n const anonIdFile = fs.openSync(Telemetry.ANON_ID_PATH, \"w\");\n this.anonId = uuid();\n fs.writeSync(anonIdFile, this.anonId);\n fs.closeSync(anonIdFile);\n } else {\n const anonIdFile = fs.openSync(Telemetry.ANON_ID_PATH, \"r\");\n this.anonId = fs.readFileSync(anonIdFile, \"utf8\");\n fs.closeSync(anonIdFile);\n }\n return this.anonId;\n } catch (e) {\n return Telemetry.UNKNOWN_ANON_ID;\n }\n }\n\n private getContext() {\n return {\n sdk: \"typescript\",\n sdk_version: version,\n };\n }\n\n public capture(event: string, properties?: Record<string, string>) {\n if (this.telemetryEnabled && this.posthog) {\n this.posthog.capture({\n distinctId: this.getAnonId(),\n event,\n properties: {\n ...properties,\n ...this.getContext(),\n },\n });\n this.posthog.flush();\n }\n }\n\n public logException(error: Error) {\n if (this.telemetryEnabled) {\n this.capture(\"error\", { error: error.message, stack: error.stack || \"\" });\n }\n }\n}\n","import { InitializeOptions } from \"../interfaces\";\nimport { startTracing } from \"../tracing\";\nimport { diag, DiagConsoleLogger, DiagLogLevel } from \"@opentelemetry/api\";\nimport { InitializationError } from \"../errors\";\n\nexport let _configuration: InitializeOptions | undefined;\n\n/**\n * Initializes the SDK.\n * Must be called once before any other SDK methods.\n *\n * @param options - The options to initialize the SDK. See the {@link InitializeOptions} for details.\n * @throws {InitializationError} if the configuration is invalid or if failed to fetch feature data.\n */\nexport const initialize = (options: InitializeOptions) => {\n if (_configuration) {\n return;\n }\n\n if (!options.baseUrl) {\n options.baseUrl =\n process.env.LMNR_BASE_URL || \"https://api.lmnr.ai:8443\";\n }\n if (!options.apiKey) {\n options.apiKey = process.env.LMNR_PROJECT_API_KEY;\n }\n if (options.apiKey && typeof options.apiKey !== \"string\") {\n throw new InitializationError('\"apiKey\" must be a string');\n }\n\n if (!options.appName) {\n options.appName = process.env.npm_package_name;\n }\n\n _configuration = Object.freeze(options);\n\n if (options.logLevel) {\n diag.setLogger(\n new DiagConsoleLogger(),\n logLevelToOtelLogLevel(options.logLevel),\n );\n }\n\n if (!options.silenceInitializationMessage) {\n console.log(\n `Laminar exporting traces to ${\n _configuration.exporter ? \"a custom exporter\" : _configuration.baseUrl\n }`,\n );\n }\n\n startTracing(_configuration);\n};\n\nconst logLevelToOtelLogLevel = (\n logLevel: \"debug\" | \"info\" | \"warn\" | \"error\",\n) => {\n switch (logLevel) {\n case \"debug\":\n return DiagLogLevel.DEBUG;\n case \"info\":\n return DiagLogLevel.INFO;\n case \"warn\":\n return DiagLogLevel.WARN;\n case \"error\":\n return DiagLogLevel.ERROR;\n }\n};\n","import { Span, context } from \"@opentelemetry/api\";\nimport { suppressTracing } from \"@opentelemetry/core\";\nimport {\n ASSOCIATION_PROPERTIES_KEY,\n getTracer,\n} from \"./tracing\";\nimport {\n SpanAttributes,\n} from \"@traceloop/ai-semantic-conventions\";\nimport { shouldSendTraces } from \".\";\nimport { Telemetry } from \"../telemetry/telemetry\";\n\nexport type DecoratorConfig = {\n name: string;\n associationProperties?: { [name: string]: string };\n inputParameters?: unknown[];\n suppressTracing?: boolean;\n};\n\nexport function withEntity<\n A extends unknown[],\n F extends (...args: A) => ReturnType<F>,\n>(\n {\n name,\n associationProperties,\n inputParameters,\n suppressTracing: shouldSuppressTracing,\n }: DecoratorConfig,\n fn: F,\n thisArg?: ThisParameterType<F>,\n ...args: A\n) {\n let entityContext = context.active();\n\n const currentAssociationProperties = entityContext.getValue(ASSOCIATION_PROPERTIES_KEY);\n\n if (associationProperties) {\n entityContext = entityContext.setValue(\n ASSOCIATION_PROPERTIES_KEY,\n { ...(currentAssociationProperties ?? {}), ...associationProperties },\n );\n }\n\n if (shouldSuppressTracing) {\n entityContext = suppressTracing(entityContext);\n }\n\n return context.with(entityContext, () =>\n getTracer().startActiveSpan(\n name,\n {},\n entityContext,\n async (span: Span) => {\n if (shouldSendTraces()) {\n try {\n const input = inputParameters ?? args;\n if (\n input.length === 1 &&\n typeof input[0] === \"object\" &&\n !(input[0] instanceof Map)\n ) {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_INPUT,\n serialize({ args: [], kwargs: input[0] }),\n );\n } else {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_INPUT,\n serialize({\n args: input,\n kwargs: {},\n }),\n );\n }\n } catch (error) {\n Telemetry.getInstance().logException(error as any);\n }\n }\n\n const res = fn.apply(thisArg, args);\n if (res instanceof Promise) {\n return res.then((resolvedRes) => {\n try {\n if (shouldSendTraces()) {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_OUTPUT,\n serialize(resolvedRes),\n );\n }\n } catch (error) {\n Telemetry.getInstance().logException(error as any);\n } finally {\n span.end();\n }\n\n return resolvedRes;\n });\n }\n try {\n if (shouldSendTraces()) {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_OUTPUT,\n serialize(res),\n );\n }\n } catch (error) {\n Telemetry.getInstance().logException(error as any);\n } finally {\n span.end();\n }\n\n return res;\n },\n ),\n );\n}\n\nfunction cleanInput(input: unknown): unknown {\n if (input instanceof Map) {\n return Array.from(input.entries());\n } else if (Array.isArray(input)) {\n return input.map((value) => cleanInput(value));\n } else if (!input) {\n return input;\n } else if (typeof input === \"object\") {\n // serialize object one by one\n const output: any = {};\n Object.entries(input as any).forEach(([key, value]) => {\n output[key] = cleanInput(value);\n });\n return output;\n }\n\n return input;\n}\n\nfunction serialize(input: unknown): string {\n return JSON.stringify(cleanInput(input));\n}\n","import { Span, context, trace } from \"@opentelemetry/api\";\nimport { getTracer } from \"./tracing\";\nimport {\n Events,\n EventAttributes,\n SpanAttributes,\n} from \"@traceloop/ai-semantic-conventions\";\nimport { shouldSendTraces } from \".\";\n\ntype VectorDBCallConfig = {\n vendor: string;\n type: \"query\" | \"upsert\" | \"delete\";\n};\n\ntype LLMCallConfig = {\n vendor: string;\n type: \"chat\" | \"completion\";\n};\n\nexport class VectorSpan {\n private span: Span;\n\n constructor(span: Span) {\n this.span = span;\n }\n\n reportQuery({ queryVector }: { queryVector: number[] }) {\n if (!shouldSendTraces()) {\n this.span.addEvent(Events.DB_QUERY_EMBEDDINGS);\n }\n\n this.span.addEvent(Events.DB_QUERY_EMBEDDINGS, {\n [EventAttributes.DB_QUERY_EMBEDDINGS_VECTOR]: JSON.stringify(queryVector),\n });\n }\n\n reportResults({\n results,\n }: {\n results: {\n ids?: string;\n scores?: number;\n distances?: number;\n metadata?: Record<string, unknown>;\n vectors?: number[];\n documents?: string;\n }[];\n }) {\n for (let i = 0; i < results.length; i++) {\n this.span.addEvent(Events.DB_QUERY_RESULT, {\n [EventAttributes.DB_QUERY_RESULT_ID]: results[i].ids,\n [EventAttributes.DB_QUERY_RESULT_SCORE]: results[i].scores,\n [EventAttributes.DB_QUERY_RESULT_DISTANCE]: results[i].distances,\n [EventAttributes.DB_QUERY_RESULT_METADATA]: JSON.stringify(\n results[i].metadata,\n ),\n [EventAttributes.DB_QUERY_RESULT_VECTOR]: results[i].vectors,\n [EventAttributes.DB_QUERY_RESULT_DOCUMENT]: results[i].documents,\n });\n }\n }\n}\n\nexport class LLMSpan {\n private span: Span;\n\n constructor(span: Span) {\n this.span = span;\n }\n\n reportRequest({\n model,\n messages,\n }: {\n model: string;\n messages: {\n role: string;\n content?: string | unknown;\n }[];\n }) {\n this.span.setAttributes({\n [SpanAttributes.LLM_REQUEST_MODEL]: model,\n });\n\n messages.forEach((message, index) => {\n this.span.setAttributes({\n [`${SpanAttributes.LLM_PROMPTS}.${index}.role`]: message.role,\n [`${SpanAttributes.LLM_PROMPTS}.${index}.content`]:\n typeof message.content === \"string\"\n ? message.content\n : JSON.stringify(message.content),\n });\n });\n }\n\n reportResponse({\n model,\n usage,\n completions,\n }: {\n model: string;\n usage?: {\n prompt_tokens: number;\n completion_tokens: number;\n total_tokens: number;\n };\n completions?: {\n finish_reason: string;\n message: {\n role: \"system\" | \"user\" | \"assistant\";\n content: string | null;\n };\n }[];\n }) {\n this.span.setAttribute(SpanAttributes.LLM_RESPONSE_MODEL, model);\n\n if (usage) {\n this.span.setAttributes({\n [SpanAttributes.LLM_USAGE_PROMPT_TOKENS]: usage.prompt_tokens,\n [SpanAttributes.LLM_USAGE_COMPLETION_TOKENS]: usage.completion_tokens,\n [SpanAttributes.LLM_USAGE_TOTAL_TOKENS]: usage.total_tokens,\n });\n }\n\n completions?.forEach((completion, index) => {\n this.span.setAttributes({\n [`${SpanAttributes.LLM_COMPLETIONS}.${index}.finish_reason`]:\n completion.finish_reason,\n [`${SpanAttributes.LLM_COMPLETIONS}.${index}.role`]:\n completion.message.role,\n [`${SpanAttributes.LLM_COMPLETIONS}.${index}.content`]:\n completion.message.content || \"\",\n });\n });\n }\n}\n\nexport function withVectorDBCall<\n F extends ({ span }: { span: VectorSpan }) => ReturnType<F>,\n>({ vendor, type }: VectorDBCallConfig, fn: F, thisArg?: ThisParameterType<F>) {\n const entityContext = context.active();\n\n return getTracer().startActiveSpan(\n `${vendor}.${type}`,\n { [SpanAttributes.LLM_REQUEST_TYPE]: type },\n entityContext,\n (span: Span) => {\n const res = fn.apply(thisArg, [{ span: new VectorSpan(span) }]);\n if (res instanceof Promise) {\n return res.then((resolvedRes) => {\n span.end();\n return resolvedRes;\n });\n }\n\n span.end();\n return res;\n },\n );\n}\n\nexport function withLLMCall<\n F extends ({ span }: { span: LLMSpan }) => ReturnType<F>,\n>({ vendor, type }: LLMCallConfig, fn: F, thisArg?: ThisParameterType<F>) {\n const span = getTracer().startSpan(`${vendor}.${type}`, {}, context.active());\n span.setAttribute(SpanAttributes.LLM_REQUEST_TYPE, type);\n trace.setSpan(context.active(), span);\n\n const res = fn.apply(thisArg, [{ span: new LLMSpan(span) }]);\n if (res instanceof Promise) {\n return res.then((resolvedRes) => {\n span.end();\n return resolvedRes;\n });\n }\n\n span.end();\n return res;\n}\n","import { context } from \"@opentelemetry/api\";\nimport { ASSOCIATION_PROPERTIES_KEY } from \"./tracing\";\n\nexport function withAssociationProperties<\n A extends unknown[],\n F extends (...args: A) => ReturnType<F>,\n>(\n properties: { [name: string]: string },\n fn: F,\n thisArg?: ThisParameterType<F>,\n ...args: A\n) {\n if (Object.keys(properties).length === 0) {\n return fn.apply(thisArg, args);\n }\n\n const newContext = context\n .active()\n .setValue(ASSOCIATION_PROPERTIES_KEY, properties);\n return context.with(newContext, fn, thisArg, ...args);\n}\n","import { v4 as uuidv4 } from 'uuid';\n\nexport type StringUUID = `${string}-${string}-${string}-${string}-${string}`;\n\nexport const newUUID = (): StringUUID => {\n // crypto.randomUUID is available in most of the modern browsers and node,\n // but is not available in \"insecure\" contexts, e.g. not https, not localhost\n // so we fallback to uuidv4 in those cases, which is less secure, but works\n // just fine.\n if (typeof crypto !== 'undefined' && typeof crypto.randomUUID === 'function') {\n return crypto.randomUUID();\n } else {\n return uuidv4() as `${string}-${string}-${string}-${string}-${string}`;\n }\n}\n\nexport const otelSpanIdToUUID = (spanId: string): string => {\n let id = spanId.toLowerCase();\n if (id.startsWith('0x')) {\n id = id.slice(2);\n }\n if (id.length !== 16) {\n console.warn(`Span ID ${spanId} is not 16 hex chars long. This is not a valid OpenTelemetry span ID.`);\n }\n\n if (!/^[0-9a-f]+$/.test(id)) {\n console.error(`Span ID ${spanId} is not a valid hex string. Generating a random UUID instead.`);\n return newUUID();\n }\n\n return id.padStart(32, '0').replace(/^(.{8})(.{4})(.{4})(.{4})(.{12})$/, '$1-$2-$3-$4-$5');\n}\n\nexport const otelTraceIdToUUID = (traceId: string): string => {\n let id = traceId.toLowerCase();\n if (id.startsWith('0x')) {\n id = id.slice(2);\n }\n if (id.length !== 32) {\n console.warn(`Trace ID ${traceId} is not 32 hex chars long. This is not a valid OpenTelemetry trace ID.`);\n }\n if (!/^[0-9a-f]+$/.test(id)) {\n console.error(`Trace ID ${traceId} is not a valid hex string. Generating a random UUID instead.`);\n return newUUID();\n }\n\n return id.replace(/^(.{8})(.{4})(.{4})(.{4})(.{12})$/, '$1-$2-$3-$4-$5');\n}\n","import { Laminar } from \"./laminar\";\nimport { CreateEvaluationResponse, EvaluationDatapoint } from \"./types\";\n\nconst DEFAULT_BATCH_SIZE = 5;\n\n/**\n * Configuration for the Evaluator\n */\ninterface EvaluatorConfig {\n batchSize?: number;\n projectApiKey?: string;\n baseUrl?: string;\n}\n\nexport abstract class Dataset<D, T> {\n public slice(start: number, end: number): Datapoint<D, T>[] {\n const result = [];\n for (let i = Math.max(start, 0); i < Math.min(end, this.size()); i++) {\n result.push(this.get(i));\n }\n return result;\n }\n public abstract size(): number;\n public abstract get(index: number): Datapoint<D, T>;\n}\n\n/**\n * Datapoint is a single data point in the evaluation. `D` is the type of the input data, `T` is the type of the target data.\n */\nexport type Datapoint<D, T> = {\n /**\n * input to the executor function. Must be a record with string keys and any values.\n */\n data: Record<string, any> & D;\n /**\n * input to the evaluator function (alongside the executor output).\n * Must be a record with string keys and any values.\n */\n target: Record<string, any> & T;\n}\n\ntype EvaluatorFunctionReturn = number | Record<string, number>;\n\n/**\n * EvaluatorFunction is a function that takes the output of the executor and the target data, and returns a score.\n * The score can be a single number or a record of string keys and number values. The latter is useful for evaluating\n * multiple criteria in one go instead of running multiple evaluators.\n */\ntype EvaluatorFunction<O, T> = (output: O, target: T, ...args: any[]) => EvaluatorFunctionReturn | Promise<EvaluatorFunctionReturn>;\n\ninterface EvaluatorConstructorProps<D, T, O> {\n /**\n * List of data points to evaluate. `data` is the input to the executor function, `target` is the input to the evaluator function.\n */\n data: (Datapoint<D, T>[]) | Dataset<D, T>;\n /**\n * The executor function. Takes the data point + any additional arguments and returns the output to evaluate.\n */\n executor: (data: D, ...args: any[]) => O | Promise<O>;\n /**\n * List of evaluator functions. Each evaluator function takes the output of the executor _and_ the target data, and returns\n * a score. The score can be a single number or a record of string keys and number values.\n * If the score is a single number, it will be named after the evaluator function. If the function is anonymous, it will be named\n * `evaluator_${index}`, where index is the index of the evaluator function in the list starting from 1.\n */\n evaluators: EvaluatorFunction<O, T>[];\n /**\n * Optional override configurations for the evaluator.\n */\n config?: EvaluatorConfig;\n}\n\nexport class Evaluation<D, T, O> {\n private name: string;\n private data: Datapoint<D, T>[] | Dataset<D, T>;\n private executor: (data: D, ...args: any[]) => O | Promise<O>;\n private evaluators: Record<string, EvaluatorFunction<O, T>>;\n private evaluatorNames: string[];\n private batchSize: number = DEFAULT_BATCH_SIZE;\n\n /**\n * Create a new evaluation and prepare data.\n * @param name Name of the evaluation.\n * @param props.data List of data points to evaluate. `data` is the input to the executor function, `target` is the input to the evaluator function.\n * @param props.executor The executor function. Takes the data point + any additional arguments and returns the output to evaluate.\n * @param props.evaluators List of evaluator functions. Each evaluator function takes the output of the executor and the target data, and returns.\n */\n constructor(name: string, {\n data, executor, evaluators, config\n }: EvaluatorConstructorProps<D, T, O>) {\n this.name = name;\n this.data = data;\n this.executor = executor;\n this.evaluators = Object.fromEntries(evaluators.map((e, i) => [e.name.length > 0 ? e.name : `evaluator_${i + 1}`, e]));\n this.evaluatorNames = evaluators.map((e, i) => e.name.length > 0 ? e.name : `evaluator_${i + 1}`);\n if (config) {\n this.batchSize = config.batchSize ?? DEFAULT_BATCH_SIZE;\n }\n Laminar.initialize({ projectApiKey: config?.projectApiKey, baseUrl: config?.baseUrl });\n }\n\n /** \n * Runs the evaluation.\n *\n * Creates a new evaluation if no evaluation with such name exists, or adds data to an existing one otherwise.\n * Evaluates data points in batches of `batchSize`. The executor function is called on each data point\n * to get the output, and then evaluate it by each evaluator function.\n */\n public async run(): Promise<void> {\n const response = await Laminar.createEvaluation(this.name) as CreateEvaluationResponse;\n const length = this.data instanceof Dataset ? this.data.size() : this.data.length;\n for (let i = 0; i < length; i += this.batchSize) {\n const batch = this.data.slice(i, i + this.batchSize);\n try {\n await this.evaluateBatch(batch);\n } catch (e) {\n console.error(`Error evaluating batch: ${e}`);\n }\n }\n try {\n // After all batches are completed, update the evaluation status\n await Laminar.updateEvaluationStatus(response.name, 'Finished');\n } catch (e) {\n console.error(`Error updating evaluation status: ${e}`);\n }\n }\n \n private async evaluateBatch(batch: Datapoint<D, T>[]): Promise<void> {\n const batchPromises = batch.map(async (datapoint) => {\n const output = await this.executor(datapoint.data);\n const target = datapoint.target;\n \n let scores: Record<string, EvaluatorFunctionReturn> = {};\n for (const evaluatorName of this.evaluatorNames) {\n const evaluator = this.evaluators[evaluatorName];\n const value = await evaluator(output, target);\n \n // If the evaluator returns a single number, use the evaluator name as the key\n if (typeof value === 'number') {\n scores[evaluatorName] = value;\n } else {\n // If the evaluator returns an object, merge its keys with the existing scores (flatten)\n scores = { ...scores, ...value };\n }\n }\n \n return {\n executorOutput: output,\n data: datapoint.data,\n target,\n scores,\n } as EvaluationDatapoint<D, T, O>;\n });\n \n const results = await Promise.all(batchPromises);\n \n return Laminar.postEvaluationResults(this.name, results);\n }\n \n}\n","import { withEntity } from './sdk/node-server-sdk'\n\ninterface ObserveOptions {\n name?: string;\n sessionId?: string;\n userId?: string;\n}\n\n/**\n * The main decorator entrypoint for Laminar. This is used to wrap\n * functions and methods to create spans.\n *\n * @param name - Name of the span. Function name is used if not specified.\n * @param user_id - User ID to associate with the span and the following context.\n * @param session_id - Session ID to associate with the span and the following context.\n * @returns Returns the result of the wrapped function.\n * @throws Exception - Re-throws the exception if the wrapped function throws an exception.\n * \n * @example\n * ```typescript\n * import { observe } from '@lmnr-ai/lmnr';\n * \n * await observe({ name: 'my_function' }, () => {\n * // Your code here\n * });\n */\nexport async function observe<A extends unknown[], F extends (...args: A) => ReturnType<F>>(\n {\n name,\n sessionId,\n userId,\n }: ObserveOptions, fn: F, ...args: A): Promise<ReturnType<F>> {\n\n let associationProperties = {};\n if (sessionId) {\n associationProperties = { ...associationProperties, \"session_id\": sessionId };\n }\n if (userId) {\n associationProperties = { ...associationProperties, \"user_id\": userId };\n }\n\n return await withEntity<A, F>({ name: name ?? fn.name, associationProperties }, fn, undefined, ...args);\n}\n"],"mappings":"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","names":["exports","module","import_api","import_api","import_resources","uuid","import_api","import_api","import_core","import_ai_semantic_conventions","import_api","import_ai_semantic_conventions","import_api","import_uuid","uuidv4"]}
1
+ {"version":3,"sources":["../package.json","../src/index.ts","../src/laminar.ts","../src/sdk/errors/index.ts","../src/sdk/tracing/index.ts","../src/sdk/tracing/tracing.ts","../src/sdk/telemetry/telemetry.ts","../src/sdk/configuration/index.ts","../src/sdk/tracing/decorators.ts","../src/sdk/tracing/manual.ts","../src/sdk/tracing/association.ts","../src/utils.ts","../src/evaluations.ts","../src/decorators.ts"],"sourcesContent":["{\n \"name\": \"@lmnr-ai/lmnr\",\n \"version\": \"0.4.9-alpha\",\n \"description\": \"TypeScript SDK for Laminar AI\",\n \"main\": \"dist/index.js\",\n \"types\": \"dist/index.d.ts\",\n \"scripts\": {\n \"build\": \"tsup src/index.ts --format esm,cjs --dts\",\n \"test\": \"echo \\\"Error: no test specified\\\" && exit 1\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git+https://github.com/lmnr-ai/lmnr-ts.git\"\n },\n \"keywords\": [\n \"laminar\",\n \"lmnr\",\n \"sdk\",\n \"lmnr.ai\"\n ],\n \"author\": \"founders@lmnr.ai\",\n \"license\": \"Apache-2.0\",\n \"bugs\": {\n \"url\": \"https://github.com/lmnr-ai/lmnr-ts/issues\"\n },\n \"homepage\": \"https://github.com/lmnr-ai/lmnr-ts#README\",\n \"devDependencies\": {\n \"@anthropic-ai/sdk\": \"^0.27.3\",\n \"@aws-sdk/client-bedrock-runtime\": \"^3.649.0\",\n \"@azure/openai\": \"2.0.0-beta.2\",\n \"@google-cloud/aiplatform\": \"^3.29.0\",\n \"@google-cloud/vertexai\": \"^1.7.0\",\n \"@langchain/core\": \"^0.2.32\",\n \"@pinecone-database/pinecone\": \"^3.0.2\",\n \"@qdrant/js-client-rest\": \"^1.11.0\",\n \"@types/node\": \"^22.5.4\",\n \"@types/uuid\": \"^10.0.0\",\n \"bufferutil\": \"^4.0.8\",\n \"chromadb\": \"^1.8.1\",\n \"cohere-ai\": \"^7.13.0\",\n \"langchain\": \"^0.2.18\",\n \"llamaindex\": \"^0.5.23\",\n \"openai\": \"^4.58.2\",\n \"runnables\": \"link:@langchain/core/runnables\",\n \"tsup\": \"^8.2.4\",\n \"typescript\": \"^5.5.4\",\n \"vectorstores\": \"link:@langchain/core/vectorstores\"\n },\n \"dependencies\": {\n \"@grpc/grpc-js\": \"^1.11.2\",\n \"@opentelemetry/api\": \"^1.9.0\",\n \"@opentelemetry/core\": \"^1.26.0\",\n \"@opentelemetry/exporter-trace-otlp-grpc\": \"^0.53.0\",\n \"@opentelemetry/exporter-trace-otlp-proto\": \"^0.53.0\",\n \"@opentelemetry/instrumentation\": \"^0.53.0\",\n \"@opentelemetry/resources\": \"^1.26.0\",\n \"@opentelemetry/sdk-node\": \"^0.53.0\",\n \"@opentelemetry/sdk-trace-base\": \"^1.26.0\",\n \"@opentelemetry/sdk-trace-node\": \"^1.26.0\",\n \"@opentelemetry/semantic-conventions\": \"^1.27.0\",\n \"@traceloop/ai-semantic-conventions\": \"^0.11.0\",\n \"@traceloop/instrumentation-anthropic\": \"^0.11.1\",\n \"@traceloop/instrumentation-azure\": \"^0.11.1\",\n \"@traceloop/instrumentation-bedrock\": \"^0.11.1\",\n \"@traceloop/instrumentation-chromadb\": \"^0.11.1\",\n \"@traceloop/instrumentation-cohere\": \"^0.11.1\",\n \"@traceloop/instrumentation-langchain\": \"^0.11.1\",\n \"@traceloop/instrumentation-llamaindex\": \"^0.11.1\",\n \"@traceloop/instrumentation-openai\": \"^0.11.1\",\n \"@traceloop/instrumentation-pinecone\": \"^0.11.1\",\n \"@traceloop/instrumentation-qdrant\": \"^0.11.1\",\n \"@traceloop/instrumentation-vertexai\": \"^0.11.1\",\n \"posthog-node\": \"^4.2.0\",\n \"uuid\": \"^10.0.0\"\n }\n}","\nexport {\n NodeInput,\n PipelineRunResponse,\n PipelineRunRequest,\n ChatMessage,\n Event,\n EvaluateEvent,\n} from './types';\n\nexport { Laminar } from './laminar';\nexport { Evaluation, Dataset, Datapoint } from './evaluations';\nexport { observe } from './decorators';\n","import { PipelineRunResponse, PipelineRunRequest, EvaluationDatapoint, EvaluationStatus } from './types';\nimport { Attributes, AttributeValue, context, createContextKey, isSpanContextValid, TimeInput, trace } from '@opentelemetry/api';\nimport { InitializeOptions, initialize as traceloopInitialize } from './sdk/node-server-sdk'\nimport { otelSpanIdToUUID, otelTraceIdToUUID } from './utils';\nimport { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-grpc';\nimport { Metadata } from '@grpc/grpc-js';\nimport { ASSOCIATION_PROPERTIES_KEY } from './sdk/tracing/tracing';\nimport { forceFlush } from './sdk/node-server-sdk';\n\n// quick patch to get the traceloop's default tracer, since their \n// `getTracer` function is not exported.\n// Another option would be to import directly \n// like so: `import { getTracer } from '@traceloop/node-server-sdk/dist/src/lib/tracing/tracing';`\n// which isn't too nice either.\nconst DEFAULT_TRACER_NAME = 'traceloop.tracer';\n\ninterface LaminarInitializeProps {\n projectApiKey?: string;\n env?: Record<string, string>;\n baseUrl?: string;\n instrumentModules?: InitializeOptions[\"instrumentModules\"];\n}\n\nexport class Laminar {\n private static baseUrl: string = 'https://api.lmnr.ai:8443';\n private static projectApiKey: string;\n private static env: Record<string, string> = {};\n private static isInitialized: boolean = false;\n\n /**\n * Initialize Laminar context across the application.\n * This method must be called before using any other Laminar methods or decorators.\n *\n * @param project_api_key - Laminar project api key. You can generate one by going\n * to the projects settings page on the Laminar dashboard.\n * If not specified, it will try to read from the LMNR_PROJECT_API_KEY environment variable.\n * @param env - Default environment passed to `run` and `evaluateEvent` requests,\n * unless overriden at request time. Usually, model provider keys are stored here.\n * @param baseUrl - Url of Laminar endpoint, or the custom open telemetry ingester.\n * If not specified, defaults to https://api.lmnr.ai:8443. For locally hosted Laminar,\n * default setting must be http://localhost:8001.\n * @param instrumentModules - List of modules to instrument.\n * If not specified, all auto-instrumentable modules will be instrumented, which include\n * LLM calls (OpenAI, Anthropic, etc), Langchain, VectorDB calls (Pinecone, Qdrant, etc).\n * Pass an empty object {} to disable any kind of automatic instrumentation.\n * If you only want to auto-instrument specific modules, then pass them in the object.\n * \n * Example:\n * ```typescript\n * import { Laminar as L } from '@lmnr-ai/lmnr';\n * import { OpenAI } from 'openai';\n * import * as ChainsModule from \"langchain/chains\";\n * \n * // Initialize Laminar while auto-instrumenting Langchain and OpenAI modules.\n * L.initialize({ projectApiKey: \"<LMNR_PROJECT_API_KEY>\", instrumentModules: {\n * langchain: {\n * chainsModule: ChainsModule\n * },\n * openAI: OpenAI\n * } });\n * ```\n *\n * @throws {Error} - If project API key is not set\n */\n public static initialize({\n projectApiKey,\n env,\n baseUrl,\n instrumentModules\n }: LaminarInitializeProps) {\n\n let key = projectApiKey ?? process.env.LMNR_PROJECT_API_KEY;\n if (key === undefined) {\n throw new Error(\n 'Please initialize the Laminar object with your project API key ' +\n 'or set the LMNR_PROJECT_API_KEY environment variable'\n );\n }\n this.projectApiKey = key;\n if (baseUrl) {\n this.baseUrl = baseUrl;\n }\n this.isInitialized = true;\n this.env = env ?? {};\n\n const metadata = new Metadata();\n metadata.set('authorization', `Bearer ${this.projectApiKey}`);\n const exporter = new OTLPTraceExporter({\n url: this.baseUrl,\n metadata,\n });\n\n traceloopInitialize({\n exporter,\n silenceInitializationMessage: true,\n instrumentModules,\n disableBatch: false,\n });\n }\n\n /**\n * Check if Laminar has been initialized. Utility to make sure other methods\n * are called after initialization.\n */\n public static initialized(): boolean {\n return this.isInitialized;\n }\n\n /**\n * Sets the environment that will be sent to Laminar requests.\n * \n * @param env - The environment variables to override. If not provided, the current environment will not be modified.\n */\n public static setEnv(env?: Record<string, string>) {\n if (env) {\n this.env = env;\n }\n }\n\n /**\n * Sets the project API key for authentication with Laminar.\n *\n * @param projectApiKey - The API key to be set. If not provided, the existing API key will not be modified.\n */\n public static setProjectApiKey(projectApiKey?: string) {\n if (projectApiKey) {\n this.projectApiKey = projectApiKey;\n }\n }\n\n /**\n * Runs the pipeline with the given inputs\n *\n * @param pipeline - The name of the Laminar pipeline. Pipeline must have a target version.\n * @param inputs - The inputs for the pipeline. Map from an input node name to input data.\n * @param env - The environment variables for the pipeline execution. Typically used for model provider keys.\n * @param metadata - Additional metadata for the pipeline run.\n * @param currentSpanId - The ID of the current span.\n * @param currentTraceId - The ID of the current trace.\n * @returns A promise that resolves to the response of the pipeline run.\n * @throws An error if the Laminar object is not initialized with a project API key. Or if the request fails.\n */\n public static async run({\n pipeline,\n inputs,\n env,\n metadata = {},\n currentSpanId,\n currentTraceId,\n }: PipelineRunRequest): Promise<PipelineRunResponse> {\n const currentSpan = trace.getActiveSpan();\n let parentSpanId: string | undefined;\n let traceId: string | undefined;\n if (currentSpan !== undefined && isSpanContextValid(currentSpan.spanContext())) {\n parentSpanId = currentSpanId ?? otelSpanIdToUUID(currentSpan.spanContext().spanId);\n traceId = currentTraceId ?? otelTraceIdToUUID(currentSpan.spanContext().traceId);\n } else {\n parentSpanId = currentSpanId;\n traceId = currentTraceId;\n }\n if (this.projectApiKey === undefined) {\n throw new Error(\n 'Please initialize the Laminar object with your project API key ' +\n 'or set the LMNR_PROJECT_API_KEY environment variable'\n );\n }\n const envirionment = env === undefined ? this.env : env;\n\n const response = await fetch(`${this.baseUrl}/v1/pipeline/run`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify({\n inputs,\n pipeline,\n env: envirionment,\n metadata,\n parentSpanId,\n traceId,\n })\n });\n\n if (!response.ok) {\n throw new Error(`Failed to run pipeline ${pipeline}. Response: ${response.statusText}`);\n }\n try {\n return await response.json() as PipelineRunResponse;\n } catch (error) {\n throw new Error(`Failed to parse response from pipeline ${pipeline}. Error: ${error}`);\n }\n }\n\n /**\n * Associates an event with the current span. If event with such name never\n * existed, Laminar will create a new event and infer its type from the value.\n * If the event already exists, Laminar will append the value to the event\n * if and only if the value is of a matching type. Otherwise, the event won't\n * be recorded. Supported types are string, number, and boolean. If the value\n * is `null`, event is considered a boolean tag with the value of `true`.\n *\n * @param name - The name of the event.\n * @param value - The value of the event. Must be a primitive type. If not specified, boolean true is assumed in the backend.\n * @param timestamp - The timestamp of the event. If not specified, relies on the underlying OpenTelemetry implementation.\n * If specified as an integer, it must be epoch nanoseconds.\n */\n public static event(\n name: string,\n value?: AttributeValue,\n timestamp?: TimeInput,\n ) {\n const currentSpan = trace.getActiveSpan();\n if (currentSpan === undefined || !isSpanContextValid(currentSpan.spanContext())) {\n console.warn(\"Laminar().event()\\` called outside of span context.\" +\n ` Event '${name}' will not be recorded in the trace.` +\n \" Make sure to annotate the function with a decorator\"\n );\n return;\n }\n\n const event: Attributes = {\n \"lmnr.event.type\": \"default\",\n }\n if (value !== undefined) {\n event[\"lmnr.event.value\"] = value;\n }\n\n currentSpan.addEvent(name, event, timestamp);\n }\n\n /**\n * Sends an event for evaluation to the Laminar backend.\n * \n * @param name - The name of the event.\n * @param evaluator - The name of the pipeline that evaluates the event.\n * @param data - A map from input node name to its value in the evaluator pipeline.\n * @param env - Environment variables required to run the pipeline.\n * @param timestamp - If specified as an integer, it must be epoch nanoseconds.\n * If not specified, relies on the underlying OpenTelemetry implementation.\n */\n public static evaluateEvent(\n name: string,\n evaluator: string,\n data: Record<string, any>,\n env?: Record<string, string>,\n timestamp?: TimeInput,\n ) {\n const currentSpan = trace.getActiveSpan();\n\n if (currentSpan === undefined || !isSpanContextValid(currentSpan.spanContext())) {\n console.warn(\"Laminar().evaluateEvent()\\` called outside of span context.\" +\n ` Evaluate event '${name}' will not be recorded in the trace.` +\n \" Make sure to annotate the function with a decorator\"\n );\n return;\n }\n\n const event = {\n \"lmnr.event.type\": \"evaluate\",\n \"lmnr.event.evaluator\": evaluator,\n \"lmnr.event.data\": JSON.stringify(data),\n \"lmnr.event.env\": JSON.stringify(env ?? {}),\n }\n\n currentSpan.addEvent(name, event, timestamp);\n }\n\n /**\n * Sets the session information for the current span and returns the context to use for the following spans.\n * \n * Example:\n * ```typescript\n * import { context as contextApi } from '@opentelemetry/api';\n * import { Laminar } from '@lmnr-ai/laminar';\n * const context = Laminar.contextWithSession({ sessionId: \"1234\", userId: \"5678\" });\n * contextApi.with(context, () => {\n * // Your code here\n * });\n * ```\n * \n * @param sessionId - The session ID to associate with the span.\n * @param userId - The user ID to associate with the span.\n * @returns The updated context with the association properties.\n */\n public static contextWithSession({ sessionId, userId }: { sessionId?: string, userId?: string }) {\n\n const currentSpan = trace.getActiveSpan();\n if (currentSpan !== undefined && isSpanContextValid(currentSpan.spanContext())) {\n if (sessionId) {\n currentSpan.setAttribute(\"traceloop.association.properties.session_id\", sessionId);\n }\n if (userId) {\n currentSpan.setAttribute(\"traceloop.association.properties.user_id\", userId);\n }\n }\n let associationProperties = {};\n if (sessionId) {\n associationProperties = { ...associationProperties, \"session_id\": sessionId };\n }\n if (userId) {\n associationProperties = { ...associationProperties, \"user_id\": userId };\n }\n\n let entityContext = context.active();\n const currentAssociationProperties = entityContext.getValue(ASSOCIATION_PROPERTIES_KEY);\n if (associationProperties) {\n entityContext = entityContext.setValue(\n ASSOCIATION_PROPERTIES_KEY,\n { ...(currentAssociationProperties ?? {}), ...associationProperties },\n );\n }\n\n return entityContext;\n }\n\n public static async shutdown() {\n await forceFlush();\n }\n\n public static async createEvaluation(name: string) {\n const response = await fetch(`${this.baseUrl}/v1/evaluations`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify({\n name,\n })\n });\n\n return await response.json();\n }\n\n public static async postEvaluationResults<D, T, O>(\n evaluationName: string,\n data: EvaluationDatapoint<D, T, O>[]\n ): Promise<void> {\n const body = JSON.stringify({\n name: evaluationName,\n points: data,\n });\n const headers = this.getHeaders();\n const url = `${this.baseUrl}/v1/evaluation-datapoints`;\n try {\n const response = await fetch(url, {\n method: \"POST\",\n headers,\n body,\n });\n if (!response.ok) {\n console.error(\"Failed to send evaluation results. Response: \");\n response.text().then((text) => console.error(text));\n }\n } catch (error) {\n console.error(\"Failed to send evaluation results. Error: \", error);\n };\n }\n\n public static async updateEvaluationStatus(\n evaluationName: string,\n status: EvaluationStatus,\n ): Promise<void> {\n const body = JSON.stringify({\n name: evaluationName,\n status,\n });\n const headers = this.getHeaders();\n const url = `${this.baseUrl}/v1/evaluations`;\n try {\n const response = await fetch(url, {\n method: \"PUT\",\n headers,\n body,\n });\n if (!response.ok) {\n console.error(\"Failed to update evaluation status. Response: \");\n response.text().then((text) => console.error(text));\n }\n } catch (error) {\n console.error(\"Failed to update evaluation status. Error: \", error);\n }\n }\n\n private static getHeaders() {\n return {\n \"Content-Type\": \"application/json\",\n \"Authorization\": `Bearer ${this.projectApiKey}`,\n };\n };\n}\n","/**\n * The severity of an error.\n */\nexport const SEVERITY = {\n Warning: \"Warning\",\n Error: \"Error\",\n Critical: \"Critical\",\n} as const;\n\nexport type Severity = (typeof SEVERITY)[keyof typeof SEVERITY];\n\n/**\n * Base class for all Traceloop errors.\n */\nexport class TraceloopError extends Error {\n /**\n * The severity of the error.\n */\n severity: Severity;\n /**\n * The underlying cause of the error.\n */\n underlyingCause?: Error;\n\n constructor(message: string, severity: Severity = SEVERITY.Error) {\n super(message);\n this.severity = severity;\n }\n}\n\nexport class NotInitializedError extends TraceloopError {\n constructor() {\n super(\n `The Traceloop SDK must be initialized by calling the \"initialize\" function prior to use.`,\n SEVERITY.Critical,\n );\n }\n}\n\nexport class InitializationError extends TraceloopError {\n constructor(message?: string, cause?: Error) {\n super(message ?? \"Failed to initialize Traceloop SDK\", SEVERITY.Critical);\n this.underlyingCause = cause;\n }\n}\n\nexport class ArgumentNotProvidedError extends TraceloopError {\n constructor(argumentName: string) {\n super(`The \"${argumentName}\" argument is required and must be a string.`);\n }\n}\n\nexport class PromptNotFoundError extends TraceloopError {\n constructor(key: string) {\n super(`The prompt \"${key}\" was not found in the registry.`);\n }\n}\n","/* eslint-disable @typescript-eslint/no-var-requires */\nimport { NodeSDK } from \"@opentelemetry/sdk-node\";\nimport {\n SimpleSpanProcessor,\n BatchSpanProcessor,\n SpanProcessor,\n} from \"@opentelemetry/sdk-trace-node\";\nimport { baggageUtils } from \"@opentelemetry/core\";\nimport { Span, context, diag } from \"@opentelemetry/api\";\nimport { OTLPTraceExporter } from \"@opentelemetry/exporter-trace-otlp-proto\";\nimport { Resource } from \"@opentelemetry/resources\";\nimport { SEMRESATTRS_SERVICE_NAME } from \"@opentelemetry/semantic-conventions\";\nimport { Instrumentation } from \"@opentelemetry/instrumentation\";\nimport { InitializeOptions } from \"../interfaces\";\nimport {\n Detector,\n DetectorSync,\n IResource,\n ResourceDetectionConfig,\n envDetectorSync,\n hostDetectorSync,\n processDetectorSync,\n} from \"@opentelemetry/resources\"\nimport {\n ASSOCIATION_PROPERTIES_KEY,\n} from \"./tracing\";\nimport { Telemetry } from \"../telemetry/telemetry\";\nimport { _configuration } from \"../configuration\";\nimport {\n SpanAttributes,\n} from \"@traceloop/ai-semantic-conventions\";\nimport { AnthropicInstrumentation } from \"@traceloop/instrumentation-anthropic\";\nimport { OpenAIInstrumentation } from \"@traceloop/instrumentation-openai\";\nimport { AzureOpenAIInstrumentation } from \"@traceloop/instrumentation-azure\";\nimport { LlamaIndexInstrumentation } from \"@traceloop/instrumentation-llamaindex\";\nimport {\n AIPlatformInstrumentation,\n VertexAIInstrumentation,\n} from \"@traceloop/instrumentation-vertexai\";\nimport { BedrockInstrumentation } from \"@traceloop/instrumentation-bedrock\";\nimport { CohereInstrumentation } from \"@traceloop/instrumentation-cohere\";\nimport { PineconeInstrumentation } from \"@traceloop/instrumentation-pinecone\";\nimport { LangChainInstrumentation } from \"@traceloop/instrumentation-langchain\";\nimport { ChromaDBInstrumentation } from \"@traceloop/instrumentation-chromadb\";\nimport { QdrantInstrumentation } from \"@traceloop/instrumentation-qdrant\";\n\nlet _sdk: NodeSDK;\nlet _spanProcessor: SimpleSpanProcessor | BatchSpanProcessor;\nlet openAIInstrumentation: OpenAIInstrumentation | undefined;\nlet anthropicInstrumentation: AnthropicInstrumentation | undefined;\nlet azureOpenAIInstrumentation: AzureOpenAIInstrumentation | undefined;\nlet cohereInstrumentation: CohereInstrumentation | undefined;\nlet vertexaiInstrumentation: VertexAIInstrumentation | undefined;\nlet aiplatformInstrumentation: AIPlatformInstrumentation | undefined;\nlet bedrockInstrumentation: BedrockInstrumentation | undefined;\nlet langchainInstrumentation: LangChainInstrumentation | undefined;\nlet llamaIndexInstrumentation: LlamaIndexInstrumentation | undefined;\nlet pineconeInstrumentation: PineconeInstrumentation | undefined;\nlet chromadbInstrumentation: ChromaDBInstrumentation | undefined;\nlet qdrantInstrumentation: QdrantInstrumentation | undefined;\n\n\nconst instrumentations: Instrumentation[] = [];\n\nconst initInstrumentations = () => {\n const exceptionLogger = (e: Error) => Telemetry.getInstance().logException(e);\n const enrichTokens =\n (process.env.TRACELOOP_ENRICH_TOKENS || \"true\").toLowerCase() === \"true\";\n\n openAIInstrumentation = new OpenAIInstrumentation({\n enrichTokens,\n exceptionLogger,\n });\n instrumentations.push(openAIInstrumentation);\n\n anthropicInstrumentation = new AnthropicInstrumentation({ exceptionLogger });\n instrumentations.push(anthropicInstrumentation);\n\n azureOpenAIInstrumentation = new AzureOpenAIInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(azureOpenAIInstrumentation);\n\n cohereInstrumentation = new CohereInstrumentation({ exceptionLogger });\n instrumentations.push(cohereInstrumentation);\n\n vertexaiInstrumentation = new VertexAIInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(vertexaiInstrumentation);\n\n aiplatformInstrumentation = new AIPlatformInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(aiplatformInstrumentation);\n\n bedrockInstrumentation = new BedrockInstrumentation({ exceptionLogger });\n instrumentations.push(bedrockInstrumentation);\n\n pineconeInstrumentation = new PineconeInstrumentation({ exceptionLogger });\n instrumentations.push(pineconeInstrumentation);\n\n langchainInstrumentation = new LangChainInstrumentation({ exceptionLogger });\n instrumentations.push(langchainInstrumentation);\n\n llamaIndexInstrumentation = new LlamaIndexInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(llamaIndexInstrumentation);\n\n chromadbInstrumentation = new ChromaDBInstrumentation({ exceptionLogger });\n instrumentations.push(chromadbInstrumentation);\n\n qdrantInstrumentation = new QdrantInstrumentation({ exceptionLogger });\n instrumentations.push(qdrantInstrumentation);\n};\n\nconst manuallyInitInstrumentations = (\n instrumentModules: InitializeOptions[\"instrumentModules\"],\n) => {\n const exceptionLogger = (e: Error) => Telemetry.getInstance().logException(e);\n const enrichTokens =\n (process.env.TRACELOOP_ENRICH_TOKENS || \"true\").toLowerCase() === \"true\";\n\n instrumentations.length = 0;\n\n if (instrumentModules?.openAI) {\n openAIInstrumentation = new OpenAIInstrumentation({\n enrichTokens,\n exceptionLogger,\n });\n instrumentations.push(openAIInstrumentation);\n openAIInstrumentation.manuallyInstrument(instrumentModules.openAI);\n }\n\n if (instrumentModules?.anthropic) {\n anthropicInstrumentation = new AnthropicInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(anthropicInstrumentation);\n anthropicInstrumentation.manuallyInstrument(instrumentModules.anthropic);\n }\n\n if (instrumentModules?.azureOpenAI) {\n const instrumentation = new AzureOpenAIInstrumentation({ exceptionLogger });\n instrumentations.push(instrumentation as Instrumentation);\n azureOpenAIInstrumentation = instrumentation;\n instrumentation.manuallyInstrument(instrumentModules.azureOpenAI);\n }\n\n if (instrumentModules?.cohere) {\n cohereInstrumentation = new CohereInstrumentation({ exceptionLogger });\n instrumentations.push(cohereInstrumentation);\n cohereInstrumentation.manuallyInstrument(instrumentModules.cohere);\n }\n\n if (instrumentModules?.google_vertexai) {\n vertexaiInstrumentation = new VertexAIInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(vertexaiInstrumentation);\n vertexaiInstrumentation.manuallyInstrument(\n instrumentModules.google_vertexai,\n );\n }\n\n if (instrumentModules?.google_aiplatform) {\n aiplatformInstrumentation = new AIPlatformInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(aiplatformInstrumentation);\n aiplatformInstrumentation.manuallyInstrument(\n instrumentModules.google_aiplatform,\n );\n }\n\n if (instrumentModules?.bedrock) {\n bedrockInstrumentation = new BedrockInstrumentation({ exceptionLogger });\n instrumentations.push(bedrockInstrumentation);\n bedrockInstrumentation.manuallyInstrument(instrumentModules.bedrock);\n }\n\n if (instrumentModules?.pinecone) {\n const instrumentation = new PineconeInstrumentation({ exceptionLogger });\n instrumentations.push(instrumentation as Instrumentation);\n instrumentation.manuallyInstrument(instrumentModules.pinecone);\n }\n\n if (instrumentModules?.langchain) {\n langchainInstrumentation = new LangChainInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(langchainInstrumentation);\n langchainInstrumentation.manuallyInstrument(instrumentModules.langchain);\n }\n\n if (instrumentModules?.llamaIndex) {\n llamaIndexInstrumentation = new LlamaIndexInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(llamaIndexInstrumentation);\n llamaIndexInstrumentation.manuallyInstrument(instrumentModules.llamaIndex);\n }\n\n if (instrumentModules?.chromadb) {\n chromadbInstrumentation = new ChromaDBInstrumentation({ exceptionLogger });\n instrumentations.push(chromadbInstrumentation);\n chromadbInstrumentation.manuallyInstrument(instrumentModules.chromadb);\n }\n\n if (instrumentModules?.qdrant) {\n qdrantInstrumentation = new QdrantInstrumentation({ exceptionLogger });\n instrumentations.push(qdrantInstrumentation);\n qdrantInstrumentation.manuallyInstrument(instrumentModules.qdrant);\n }\n};\n\nfunction awaitAttributes(detector: DetectorSync): Detector {\n return {\n async detect(config?: ResourceDetectionConfig): Promise<IResource> {\n const resource = detector.detect(config)\n await resource.waitForAsyncAttributes?.()\n\n return resource\n },\n }\n}\n\n/**\n * Initializes the Traceloop SDK.\n * Must be called once before any other SDK methods.\n *\n * @param options - The options to initialize the SDK. See the {@link InitializeOptions} for details.\n */\nexport const startTracing = (options: InitializeOptions) => {\n if (options.instrumentModules !== undefined) {\n // If options.instrumentModules is empty, it will not initialize anything,\n // so empty dict can essentially be passed to disable any kind of automatic instrumentation.\n manuallyInitInstrumentations(options.instrumentModules);\n } else {\n initInstrumentations();\n }\n\n if (!shouldSendTraces()) {\n openAIInstrumentation?.setConfig({\n traceContent: false,\n });\n azureOpenAIInstrumentation?.setConfig({\n traceContent: false,\n });\n llamaIndexInstrumentation?.setConfig({\n traceContent: false,\n });\n vertexaiInstrumentation?.setConfig({\n traceContent: false,\n });\n aiplatformInstrumentation?.setConfig({\n traceContent: false,\n });\n bedrockInstrumentation?.setConfig({\n traceContent: false,\n });\n cohereInstrumentation?.setConfig({\n traceContent: false,\n });\n chromadbInstrumentation?.setConfig({\n traceContent: false,\n });\n }\n\n const headers = process.env.TRACELOOP_HEADERS\n ? baggageUtils.parseKeyPairsIntoRecord(process.env.TRACELOOP_HEADERS)\n : { Authorization: `Bearer ${options.apiKey}` };\n\n const traceExporter =\n options.exporter ??\n new OTLPTraceExporter({\n url: `${options.baseUrl}/v1/traces`,\n headers,\n });\n _spanProcessor = options.disableBatch\n ? new SimpleSpanProcessor(traceExporter)\n : new BatchSpanProcessor(traceExporter);\n\n _spanProcessor.onStart = (span: Span) => {\n // This sets the properties only if the context has them\n const associationProperties = context\n .active()\n .getValue(ASSOCIATION_PROPERTIES_KEY);\n if (associationProperties) {\n for (const [key, value] of Object.entries(associationProperties)) {\n span.setAttribute(\n `${SpanAttributes.TRACELOOP_ASSOCIATION_PROPERTIES}.${key}`,\n value,\n );\n }\n }\n };\n\n if (options.exporter) {\n Telemetry.getInstance().capture(\"tracer:init\", {\n exporter: \"custom\",\n processor: options.disableBatch ? \"simple\" : \"batch\",\n });\n } else {\n Telemetry.getInstance().capture(\"tracer:init\", {\n exporter: options.baseUrl ?? \"\",\n processor: options.disableBatch ? \"simple\" : \"batch\",\n });\n }\n\n const spanProcessors: SpanProcessor[] = [_spanProcessor];\n if (options.processor) {\n spanProcessors.push(options.processor);\n }\n\n _sdk = new NodeSDK({\n resource: new Resource({\n [SEMRESATTRS_SERVICE_NAME]:\n options.appName || process.env.npm_package_name,\n }),\n spanProcessors,\n contextManager: options.contextManager,\n textMapPropagator: options.propagator,\n traceExporter,\n instrumentations,\n // We should re-consider removing irrelevant spans here in the future\n // sampler: new TraceloopSampler(),\n resourceDetectors: [\n awaitAttributes(envDetectorSync),\n awaitAttributes(processDetectorSync),\n awaitAttributes(hostDetectorSync),\n ],\n });\n\n _sdk.start();\n};\n\nexport const shouldSendTraces = () => {\n if (!_configuration) {\n diag.warn(\"Traceloop not initialized\");\n return false;\n }\n\n if (\n _configuration.traceContent === false ||\n (process.env.TRACELOOP_TRACE_CONTENT || \"true\").toLowerCase() === \"false\"\n ) {\n return false;\n }\n\n return true;\n};\n\nexport const forceFlush = async () => {\n await _spanProcessor.forceFlush();\n};\n","import { trace, createContextKey } from \"@opentelemetry/api\";\nimport { Context } from \"@opentelemetry/api/build/src/context/types\";\n\nconst TRACER_NAME = \"traceloop.tracer\";\nexport const WORKFLOW_NAME_KEY = createContextKey(\"workflow_name\");\nexport const ENTITY_NAME_KEY = createContextKey(\"entity_name\");\nexport const ASSOCIATION_PROPERTIES_KEY = createContextKey(\n \"association_properties\",\n);\n\nexport const getTracer = () => {\n return trace.getTracer(TRACER_NAME);\n};\n\nexport const getEntityPath = (entityContext: Context): string | undefined => {\n const path = entityContext.getValue(ENTITY_NAME_KEY);\n\n return path ? `${path}` : undefined;\n};\n","import * as os from \"os\";\nimport * as fs from \"fs\";\nimport * as path from \"path\";\nimport { v4 as uuid } from \"uuid\";\nimport { PostHog } from \"posthog-node\";\nconst { version } = require('../../../package.json');\n\nexport class Telemetry {\n private static instance: Telemetry;\n\n private static readonly ANON_ID_PATH = `${os.homedir()}/.cache/lmnr/telemetry_anon_id`;\n private static readonly UNKNOWN_ANON_ID = \"UNKNOWN\";\n\n private telemetryEnabled: boolean;\n private posthog: PostHog | undefined;\n private anonId: string | undefined;\n\n public static getInstance(): Telemetry {\n if (!Telemetry.instance) {\n Telemetry.instance = new Telemetry();\n }\n return Telemetry.instance;\n }\n\n private constructor() {\n this.telemetryEnabled =\n !process.env.LMNR_TELEMETRY ||\n process.env.LMNR_TELEMETRY.toLowerCase() === \"true\";\n\n if (this.telemetryEnabled) {\n this.posthog = new PostHog(\n \"phc_dUMdjfNKf11jcHgtn7juSnT4P1pO0tafsPUWt4PuwG7\",\n );\n }\n }\n\n private getAnonId() {\n if (this.anonId) {\n return this.anonId;\n }\n\n try {\n if (!fs.existsSync(Telemetry.ANON_ID_PATH)) {\n fs.mkdirSync(path.dirname(Telemetry.ANON_ID_PATH), { recursive: true });\n const anonIdFile = fs.openSync(Telemetry.ANON_ID_PATH, \"w\");\n this.anonId = uuid();\n fs.writeSync(anonIdFile, this.anonId);\n fs.closeSync(anonIdFile);\n } else {\n const anonIdFile = fs.openSync(Telemetry.ANON_ID_PATH, \"r\");\n this.anonId = fs.readFileSync(anonIdFile, \"utf8\");\n fs.closeSync(anonIdFile);\n }\n return this.anonId;\n } catch (e) {\n return Telemetry.UNKNOWN_ANON_ID;\n }\n }\n\n private getContext() {\n return {\n sdk: \"typescript\",\n sdk_version: version,\n };\n }\n\n public capture(event: string, properties?: Record<string, string>) {\n if (this.telemetryEnabled && this.posthog) {\n this.posthog.capture({\n distinctId: this.getAnonId(),\n event,\n properties: {\n ...properties,\n ...this.getContext(),\n },\n });\n this.posthog.flush();\n }\n }\n\n public logException(error: Error) {\n if (this.telemetryEnabled) {\n this.capture(\"error\", { error: error.message, stack: error.stack || \"\" });\n }\n }\n}\n","import { InitializeOptions } from \"../interfaces\";\nimport { startTracing } from \"../tracing\";\nimport { diag, DiagConsoleLogger, DiagLogLevel } from \"@opentelemetry/api\";\nimport { InitializationError } from \"../errors\";\n\nexport let _configuration: InitializeOptions | undefined;\n\n/**\n * Initializes the SDK.\n * Must be called once before any other SDK methods.\n *\n * @param options - The options to initialize the SDK. See the {@link InitializeOptions} for details.\n * @throws {InitializationError} if the configuration is invalid or if failed to fetch feature data.\n */\nexport const initialize = (options: InitializeOptions) => {\n if (_configuration) {\n return;\n }\n\n if (!options.baseUrl) {\n options.baseUrl =\n process.env.LMNR_BASE_URL || \"https://api.lmnr.ai:8443\";\n }\n if (!options.apiKey) {\n options.apiKey = process.env.LMNR_PROJECT_API_KEY;\n }\n if (options.apiKey && typeof options.apiKey !== \"string\") {\n throw new InitializationError('\"apiKey\" must be a string');\n }\n\n if (!options.appName) {\n options.appName = process.env.npm_package_name;\n }\n\n _configuration = Object.freeze(options);\n\n if (options.logLevel) {\n diag.setLogger(\n new DiagConsoleLogger(),\n logLevelToOtelLogLevel(options.logLevel),\n );\n }\n\n if (!options.silenceInitializationMessage) {\n console.log(\n `Laminar exporting traces to ${\n _configuration.exporter ? \"a custom exporter\" : _configuration.baseUrl\n }`,\n );\n }\n\n startTracing(_configuration);\n};\n\nconst logLevelToOtelLogLevel = (\n logLevel: \"debug\" | \"info\" | \"warn\" | \"error\",\n) => {\n switch (logLevel) {\n case \"debug\":\n return DiagLogLevel.DEBUG;\n case \"info\":\n return DiagLogLevel.INFO;\n case \"warn\":\n return DiagLogLevel.WARN;\n case \"error\":\n return DiagLogLevel.ERROR;\n }\n};\n","import { Span, context } from \"@opentelemetry/api\";\nimport { suppressTracing } from \"@opentelemetry/core\";\nimport {\n ASSOCIATION_PROPERTIES_KEY,\n getTracer,\n} from \"./tracing\";\nimport {\n SpanAttributes,\n} from \"@traceloop/ai-semantic-conventions\";\nimport { shouldSendTraces } from \".\";\nimport { Telemetry } from \"../telemetry/telemetry\";\n\nexport type DecoratorConfig = {\n name: string;\n associationProperties?: { [name: string]: string };\n inputParameters?: unknown[];\n suppressTracing?: boolean;\n};\n\nexport function withEntity<\n A extends unknown[],\n F extends (...args: A) => ReturnType<F>,\n>(\n {\n name,\n associationProperties,\n inputParameters,\n suppressTracing: shouldSuppressTracing,\n }: DecoratorConfig,\n fn: F,\n thisArg?: ThisParameterType<F>,\n ...args: A\n) {\n let entityContext = context.active();\n\n const currentAssociationProperties = entityContext.getValue(ASSOCIATION_PROPERTIES_KEY);\n\n if (associationProperties) {\n entityContext = entityContext.setValue(\n ASSOCIATION_PROPERTIES_KEY,\n { ...(currentAssociationProperties ?? {}), ...associationProperties },\n );\n }\n\n if (shouldSuppressTracing) {\n entityContext = suppressTracing(entityContext);\n }\n\n return context.with(entityContext, () =>\n getTracer().startActiveSpan(\n name,\n {},\n entityContext,\n async (span: Span) => {\n if (shouldSendTraces()) {\n try {\n const input = inputParameters ?? args;\n if (\n input.length === 1 &&\n typeof input[0] === \"object\" &&\n !(input[0] instanceof Map)\n ) {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_INPUT,\n serialize({ args: [], kwargs: input[0] }),\n );\n } else {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_INPUT,\n serialize({\n args: input,\n kwargs: {},\n }),\n );\n }\n } catch (error) {\n Telemetry.getInstance().logException(error as any);\n }\n }\n\n const res = fn.apply(thisArg, args);\n if (res instanceof Promise) {\n return res.then((resolvedRes) => {\n try {\n if (shouldSendTraces()) {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_OUTPUT,\n serialize(resolvedRes),\n );\n }\n } catch (error) {\n Telemetry.getInstance().logException(error as any);\n } finally {\n span.end();\n }\n\n return resolvedRes;\n });\n }\n try {\n if (shouldSendTraces()) {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_OUTPUT,\n serialize(res),\n );\n }\n } catch (error) {\n Telemetry.getInstance().logException(error as any);\n } finally {\n span.end();\n }\n\n return res;\n },\n ),\n );\n}\n\nfunction cleanInput(input: unknown): unknown {\n if (input instanceof Map) {\n return Array.from(input.entries());\n } else if (Array.isArray(input)) {\n return input.map((value) => cleanInput(value));\n } else if (!input) {\n return input;\n } else if (typeof input === \"object\") {\n // serialize object one by one\n const output: any = {};\n Object.entries(input as any).forEach(([key, value]) => {\n output[key] = cleanInput(value);\n });\n return output;\n }\n\n return input;\n}\n\nfunction serialize(input: unknown): string {\n return JSON.stringify(cleanInput(input));\n}\n","import { Span, context, trace } from \"@opentelemetry/api\";\nimport { getTracer } from \"./tracing\";\nimport {\n Events,\n EventAttributes,\n SpanAttributes,\n} from \"@traceloop/ai-semantic-conventions\";\nimport { shouldSendTraces } from \".\";\n\ntype VectorDBCallConfig = {\n vendor: string;\n type: \"query\" | \"upsert\" | \"delete\";\n};\n\ntype LLMCallConfig = {\n vendor: string;\n type: \"chat\" | \"completion\";\n};\n\nexport class VectorSpan {\n private span: Span;\n\n constructor(span: Span) {\n this.span = span;\n }\n\n reportQuery({ queryVector }: { queryVector: number[] }) {\n if (!shouldSendTraces()) {\n this.span.addEvent(Events.DB_QUERY_EMBEDDINGS);\n }\n\n this.span.addEvent(Events.DB_QUERY_EMBEDDINGS, {\n [EventAttributes.DB_QUERY_EMBEDDINGS_VECTOR]: JSON.stringify(queryVector),\n });\n }\n\n reportResults({\n results,\n }: {\n results: {\n ids?: string;\n scores?: number;\n distances?: number;\n metadata?: Record<string, unknown>;\n vectors?: number[];\n documents?: string;\n }[];\n }) {\n for (let i = 0; i < results.length; i++) {\n this.span.addEvent(Events.DB_QUERY_RESULT, {\n [EventAttributes.DB_QUERY_RESULT_ID]: results[i].ids,\n [EventAttributes.DB_QUERY_RESULT_SCORE]: results[i].scores,\n [EventAttributes.DB_QUERY_RESULT_DISTANCE]: results[i].distances,\n [EventAttributes.DB_QUERY_RESULT_METADATA]: JSON.stringify(\n results[i].metadata,\n ),\n [EventAttributes.DB_QUERY_RESULT_VECTOR]: results[i].vectors,\n [EventAttributes.DB_QUERY_RESULT_DOCUMENT]: results[i].documents,\n });\n }\n }\n}\n\nexport class LLMSpan {\n private span: Span;\n\n constructor(span: Span) {\n this.span = span;\n }\n\n reportRequest({\n model,\n messages,\n }: {\n model: string;\n messages: {\n role: string;\n content?: string | unknown;\n }[];\n }) {\n this.span.setAttributes({\n [SpanAttributes.LLM_REQUEST_MODEL]: model,\n });\n\n messages.forEach((message, index) => {\n this.span.setAttributes({\n [`${SpanAttributes.LLM_PROMPTS}.${index}.role`]: message.role,\n [`${SpanAttributes.LLM_PROMPTS}.${index}.content`]:\n typeof message.content === \"string\"\n ? message.content\n : JSON.stringify(message.content),\n });\n });\n }\n\n reportResponse({\n model,\n usage,\n completions,\n }: {\n model: string;\n usage?: {\n prompt_tokens: number;\n completion_tokens: number;\n total_tokens: number;\n };\n completions?: {\n finish_reason: string;\n message: {\n role: \"system\" | \"user\" | \"assistant\";\n content: string | null;\n };\n }[];\n }) {\n this.span.setAttribute(SpanAttributes.LLM_RESPONSE_MODEL, model);\n\n if (usage) {\n this.span.setAttributes({\n [SpanAttributes.LLM_USAGE_PROMPT_TOKENS]: usage.prompt_tokens,\n [SpanAttributes.LLM_USAGE_COMPLETION_TOKENS]: usage.completion_tokens,\n [SpanAttributes.LLM_USAGE_TOTAL_TOKENS]: usage.total_tokens,\n });\n }\n\n completions?.forEach((completion, index) => {\n this.span.setAttributes({\n [`${SpanAttributes.LLM_COMPLETIONS}.${index}.finish_reason`]:\n completion.finish_reason,\n [`${SpanAttributes.LLM_COMPLETIONS}.${index}.role`]:\n completion.message.role,\n [`${SpanAttributes.LLM_COMPLETIONS}.${index}.content`]:\n completion.message.content || \"\",\n });\n });\n }\n}\n\nexport function withVectorDBCall<\n F extends ({ span }: { span: VectorSpan }) => ReturnType<F>,\n>({ vendor, type }: VectorDBCallConfig, fn: F, thisArg?: ThisParameterType<F>) {\n const entityContext = context.active();\n\n return getTracer().startActiveSpan(\n `${vendor}.${type}`,\n { [SpanAttributes.LLM_REQUEST_TYPE]: type },\n entityContext,\n (span: Span) => {\n const res = fn.apply(thisArg, [{ span: new VectorSpan(span) }]);\n if (res instanceof Promise) {\n return res.then((resolvedRes) => {\n span.end();\n return resolvedRes;\n });\n }\n\n span.end();\n return res;\n },\n );\n}\n\nexport function withLLMCall<\n F extends ({ span }: { span: LLMSpan }) => ReturnType<F>,\n>({ vendor, type }: LLMCallConfig, fn: F, thisArg?: ThisParameterType<F>) {\n const span = getTracer().startSpan(`${vendor}.${type}`, {}, context.active());\n span.setAttribute(SpanAttributes.LLM_REQUEST_TYPE, type);\n trace.setSpan(context.active(), span);\n\n const res = fn.apply(thisArg, [{ span: new LLMSpan(span) }]);\n if (res instanceof Promise) {\n return res.then((resolvedRes) => {\n span.end();\n return resolvedRes;\n });\n }\n\n span.end();\n return res;\n}\n","import { context } from \"@opentelemetry/api\";\nimport { ASSOCIATION_PROPERTIES_KEY } from \"./tracing\";\n\nexport function withAssociationProperties<\n A extends unknown[],\n F extends (...args: A) => ReturnType<F>,\n>(\n properties: { [name: string]: string },\n fn: F,\n thisArg?: ThisParameterType<F>,\n ...args: A\n) {\n if (Object.keys(properties).length === 0) {\n return fn.apply(thisArg, args);\n }\n\n const newContext = context\n .active()\n .setValue(ASSOCIATION_PROPERTIES_KEY, properties);\n return context.with(newContext, fn, thisArg, ...args);\n}\n","import { v4 as uuidv4 } from 'uuid';\n\nexport type StringUUID = `${string}-${string}-${string}-${string}-${string}`;\n\nexport const newUUID = (): StringUUID => {\n // crypto.randomUUID is available in most of the modern browsers and node,\n // but is not available in \"insecure\" contexts, e.g. not https, not localhost\n // so we fallback to uuidv4 in those cases, which is less secure, but works\n // just fine.\n if (typeof crypto !== 'undefined' && typeof crypto.randomUUID === 'function') {\n return crypto.randomUUID();\n } else {\n return uuidv4() as `${string}-${string}-${string}-${string}-${string}`;\n }\n}\n\nexport const otelSpanIdToUUID = (spanId: string): string => {\n let id = spanId.toLowerCase();\n if (id.startsWith('0x')) {\n id = id.slice(2);\n }\n if (id.length !== 16) {\n console.warn(`Span ID ${spanId} is not 16 hex chars long. This is not a valid OpenTelemetry span ID.`);\n }\n\n if (!/^[0-9a-f]+$/.test(id)) {\n console.error(`Span ID ${spanId} is not a valid hex string. Generating a random UUID instead.`);\n return newUUID();\n }\n\n return id.padStart(32, '0').replace(/^(.{8})(.{4})(.{4})(.{4})(.{12})$/, '$1-$2-$3-$4-$5');\n}\n\nexport const otelTraceIdToUUID = (traceId: string): string => {\n let id = traceId.toLowerCase();\n if (id.startsWith('0x')) {\n id = id.slice(2);\n }\n if (id.length !== 32) {\n console.warn(`Trace ID ${traceId} is not 32 hex chars long. This is not a valid OpenTelemetry trace ID.`);\n }\n if (!/^[0-9a-f]+$/.test(id)) {\n console.error(`Trace ID ${traceId} is not a valid hex string. Generating a random UUID instead.`);\n return newUUID();\n }\n\n return id.replace(/^(.{8})(.{4})(.{4})(.{4})(.{12})$/, '$1-$2-$3-$4-$5');\n}\n","import { Laminar } from \"./laminar\";\nimport { CreateEvaluationResponse, EvaluationDatapoint } from \"./types\";\n\nconst DEFAULT_BATCH_SIZE = 5;\n\n/**\n * Configuration for the Evaluator\n */\ninterface EvaluatorConfig {\n batchSize?: number;\n projectApiKey?: string;\n baseUrl?: string;\n}\n\nexport abstract class Dataset<D, T> {\n public slice(start: number, end: number): Datapoint<D, T>[] {\n const result = [];\n for (let i = Math.max(start, 0); i < Math.min(end, this.size()); i++) {\n result.push(this.get(i));\n }\n return result;\n }\n public abstract size(): number;\n public abstract get(index: number): Datapoint<D, T>;\n}\n\n/**\n * Datapoint is a single data point in the evaluation. `D` is the type of the input data, `T` is the type of the target data.\n */\nexport type Datapoint<D, T> = {\n /**\n * input to the executor function. Must be a record with string keys and any values.\n */\n data: Record<string, any> & D;\n /**\n * input to the evaluator function (alongside the executor output).\n * Must be a record with string keys and any values.\n */\n target: Record<string, any> & T;\n}\n\ntype EvaluatorFunctionReturn = number | Record<string, number>;\n\n/**\n * EvaluatorFunction is a function that takes the output of the executor and the target data, and returns a score.\n * The score can be a single number or a record of string keys and number values. The latter is useful for evaluating\n * multiple criteria in one go instead of running multiple evaluators.\n */\ntype EvaluatorFunction<O, T> = (output: O, target: T, ...args: any[]) => EvaluatorFunctionReturn | Promise<EvaluatorFunctionReturn>;\n\ninterface EvaluatorConstructorProps<D, T, O> {\n /**\n * List of data points to evaluate. `data` is the input to the executor function, `target` is the input to the evaluator function.\n */\n data: (Datapoint<D, T>[]) | Dataset<D, T>;\n /**\n * The executor function. Takes the data point + any additional arguments and returns the output to evaluate.\n */\n executor: (data: D, ...args: any[]) => O | Promise<O>;\n /**\n * List of evaluator functions. Each evaluator function takes the output of the executor _and_ the target data, and returns\n * a score. The score can be a single number or a record of string keys and number values.\n * If the score is a single number, it will be named after the evaluator function. If the function is anonymous, it will be named\n * `evaluator_${index}`, where index is the index of the evaluator function in the list starting from 1.\n */\n evaluators: EvaluatorFunction<O, T>[];\n /**\n * Optional override configurations for the evaluator.\n */\n config?: EvaluatorConfig;\n}\n\nexport class Evaluation<D, T, O> {\n private name: string;\n private data: Datapoint<D, T>[] | Dataset<D, T>;\n private executor: (data: D, ...args: any[]) => O | Promise<O>;\n private evaluators: Record<string, EvaluatorFunction<O, T>>;\n private evaluatorNames: string[];\n private batchSize: number = DEFAULT_BATCH_SIZE;\n\n /**\n * Create a new evaluation and prepare data.\n * @param name Name of the evaluation.\n * @param props.data List of data points to evaluate. `data` is the input to the executor function, `target` is the input to the evaluator function.\n * @param props.executor The executor function. Takes the data point + any additional arguments and returns the output to evaluate.\n * @param props.evaluators List of evaluator functions. Each evaluator function takes the output of the executor and the target data, and returns.\n */\n constructor(name: string, {\n data, executor, evaluators, config\n }: EvaluatorConstructorProps<D, T, O>) {\n this.name = name;\n this.data = data;\n this.executor = executor;\n this.evaluators = Object.fromEntries(evaluators.map((e, i) => [e.name.length > 0 ? e.name : `evaluator_${i + 1}`, e]));\n this.evaluatorNames = evaluators.map((e, i) => e.name.length > 0 ? e.name : `evaluator_${i + 1}`);\n if (config) {\n this.batchSize = config.batchSize ?? DEFAULT_BATCH_SIZE;\n }\n Laminar.initialize({ projectApiKey: config?.projectApiKey, baseUrl: config?.baseUrl });\n }\n\n /** \n * Runs the evaluation.\n *\n * Creates a new evaluation if no evaluation with such name exists, or adds data to an existing one otherwise.\n * Evaluates data points in batches of `batchSize`. The executor function is called on each data point\n * to get the output, and then evaluate it by each evaluator function.\n */\n public async run(): Promise<void> {\n const response = await Laminar.createEvaluation(this.name) as CreateEvaluationResponse;\n const length = this.data instanceof Dataset ? this.data.size() : this.data.length;\n for (let i = 0; i < length; i += this.batchSize) {\n const batch = this.data.slice(i, i + this.batchSize);\n try {\n await this.evaluateBatch(batch);\n } catch (e) {\n console.error(`Error evaluating batch: ${e}`);\n }\n }\n try {\n // After all batches are completed, update the evaluation status\n await Laminar.updateEvaluationStatus(response.name, 'Finished');\n } catch (e) {\n console.error(`Error updating evaluation status: ${e}`);\n }\n }\n \n private async evaluateBatch(batch: Datapoint<D, T>[]): Promise<void> {\n const batchPromises = batch.map(async (datapoint) => {\n const output = await this.executor(datapoint.data);\n const target = datapoint.target;\n \n let scores: Record<string, EvaluatorFunctionReturn> = {};\n for (const evaluatorName of this.evaluatorNames) {\n const evaluator = this.evaluators[evaluatorName];\n const value = await evaluator(output, target);\n \n // If the evaluator returns a single number, use the evaluator name as the key\n if (typeof value === 'number') {\n scores[evaluatorName] = value;\n } else {\n // If the evaluator returns an object, merge its keys with the existing scores (flatten)\n scores = { ...scores, ...value };\n }\n }\n \n return {\n executorOutput: output,\n data: datapoint.data,\n target,\n scores,\n } as EvaluationDatapoint<D, T, O>;\n });\n \n const results = await Promise.all(batchPromises);\n \n return Laminar.postEvaluationResults(this.name, results);\n }\n \n}\n","import { withEntity } from './sdk/node-server-sdk'\n\ninterface ObserveOptions {\n name?: string;\n sessionId?: string;\n userId?: string;\n}\n\n/**\n * The main decorator entrypoint for Laminar. This is used to wrap\n * functions and methods to create spans.\n *\n * @param name - Name of the span. Function name is used if not specified.\n * @param user_id - User ID to associate with the span and the following context.\n * @param session_id - Session ID to associate with the span and the following context.\n * @returns Returns the result of the wrapped function.\n * @throws Exception - Re-throws the exception if the wrapped function throws an exception.\n * \n * @example\n * ```typescript\n * import { observe } from '@lmnr-ai/lmnr';\n * \n * await observe({ name: 'my_function' }, () => {\n * // Your code here\n * });\n */\nexport async function observe<A extends unknown[], F extends (...args: A) => ReturnType<F>>(\n {\n name,\n sessionId,\n userId,\n }: ObserveOptions, fn: F, ...args: A): Promise<ReturnType<F>> {\n\n let associationProperties = {};\n if (sessionId) {\n associationProperties = { ...associationProperties, \"session_id\": sessionId };\n }\n if (userId) {\n associationProperties = { ...associationProperties, \"user_id\": userId };\n }\n\n return await withEntity<A, F>({ name: name ?? fn.name, associationProperties }, fn, undefined, ...args);\n}\n"],"mappings":"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","names":["exports","module","import_api","import_api","import_resources","uuid","import_api","import_api","import_core","import_ai_semantic_conventions","import_api","import_ai_semantic_conventions","import_api","import_uuid","uuidv4"]}
package/dist/index.mjs CHANGED
@@ -8,7 +8,7 @@ var require_package = __commonJS({
8
8
  "package.json"(exports, module) {
9
9
  module.exports = {
10
10
  name: "@lmnr-ai/lmnr",
11
- version: "0.4.8",
11
+ version: "0.4.9-alpha",
12
12
  description: "TypeScript SDK for Laminar AI",
13
13
  main: "dist/index.js",
14
14
  types: "dist/index.d.ts",
@@ -467,6 +467,9 @@ var shouldSendTraces = () => {
467
467
  }
468
468
  return true;
469
469
  };
470
+ var forceFlush = async () => {
471
+ await _spanProcessor.forceFlush();
472
+ };
470
473
 
471
474
  // src/sdk/configuration/index.ts
472
475
  import { diag as diag2, DiagConsoleLogger, DiagLogLevel } from "@opentelemetry/api";
@@ -736,7 +739,7 @@ var Laminar = class {
736
739
  exporter,
737
740
  silenceInitializationMessage: true,
738
741
  instrumentModules,
739
- disableBatch: true
742
+ disableBatch: false
740
743
  });
741
744
  }
742
745
  /**
@@ -922,6 +925,9 @@ var Laminar = class {
922
925
  }
923
926
  return entityContext;
924
927
  }
928
+ static async shutdown() {
929
+ await forceFlush();
930
+ }
925
931
  static async createEvaluation(name) {
926
932
  const response = await fetch(`${this.baseUrl}/v1/evaluations`, {
927
933
  method: "POST",
@@ -1 +1 @@
1
- {"version":3,"sources":["../package.json","../src/laminar.ts","../src/sdk/errors/index.ts","../src/sdk/tracing/index.ts","../src/sdk/tracing/tracing.ts","../src/sdk/telemetry/telemetry.ts","../src/sdk/configuration/index.ts","../src/sdk/tracing/decorators.ts","../src/sdk/tracing/manual.ts","../src/sdk/tracing/association.ts","../src/utils.ts","../src/evaluations.ts","../src/decorators.ts"],"sourcesContent":["{\n \"name\": \"@lmnr-ai/lmnr\",\n \"version\": \"0.4.8\",\n \"description\": \"TypeScript SDK for Laminar AI\",\n \"main\": \"dist/index.js\",\n \"types\": \"dist/index.d.ts\",\n \"scripts\": {\n \"build\": \"tsup src/index.ts --format esm,cjs --dts\",\n \"test\": \"echo \\\"Error: no test specified\\\" && exit 1\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git+https://github.com/lmnr-ai/lmnr-ts.git\"\n },\n \"keywords\": [\n \"laminar\",\n \"lmnr\",\n \"sdk\",\n \"lmnr.ai\"\n ],\n \"author\": \"founders@lmnr.ai\",\n \"license\": \"Apache-2.0\",\n \"bugs\": {\n \"url\": \"https://github.com/lmnr-ai/lmnr-ts/issues\"\n },\n \"homepage\": \"https://github.com/lmnr-ai/lmnr-ts#README\",\n \"devDependencies\": {\n \"@anthropic-ai/sdk\": \"^0.27.3\",\n \"@aws-sdk/client-bedrock-runtime\": \"^3.649.0\",\n \"@azure/openai\": \"2.0.0-beta.2\",\n \"@google-cloud/aiplatform\": \"^3.29.0\",\n \"@google-cloud/vertexai\": \"^1.7.0\",\n \"@langchain/core\": \"^0.2.32\",\n \"@pinecone-database/pinecone\": \"^3.0.2\",\n \"@qdrant/js-client-rest\": \"^1.11.0\",\n \"@types/node\": \"^22.5.4\",\n \"@types/uuid\": \"^10.0.0\",\n \"bufferutil\": \"^4.0.8\",\n \"chromadb\": \"^1.8.1\",\n \"cohere-ai\": \"^7.13.0\",\n \"langchain\": \"^0.2.18\",\n \"llamaindex\": \"^0.5.23\",\n \"openai\": \"^4.58.2\",\n \"runnables\": \"link:@langchain/core/runnables\",\n \"tsup\": \"^8.2.4\",\n \"typescript\": \"^5.5.4\",\n \"vectorstores\": \"link:@langchain/core/vectorstores\"\n },\n \"dependencies\": {\n \"@grpc/grpc-js\": \"^1.11.2\",\n \"@opentelemetry/api\": \"^1.9.0\",\n \"@opentelemetry/core\": \"^1.26.0\",\n \"@opentelemetry/exporter-trace-otlp-grpc\": \"^0.53.0\",\n \"@opentelemetry/exporter-trace-otlp-proto\": \"^0.53.0\",\n \"@opentelemetry/instrumentation\": \"^0.53.0\",\n \"@opentelemetry/resources\": \"^1.26.0\",\n \"@opentelemetry/sdk-node\": \"^0.53.0\",\n \"@opentelemetry/sdk-trace-base\": \"^1.26.0\",\n \"@opentelemetry/sdk-trace-node\": \"^1.26.0\",\n \"@opentelemetry/semantic-conventions\": \"^1.27.0\",\n \"@traceloop/ai-semantic-conventions\": \"^0.11.0\",\n \"@traceloop/instrumentation-anthropic\": \"^0.11.1\",\n \"@traceloop/instrumentation-azure\": \"^0.11.1\",\n \"@traceloop/instrumentation-bedrock\": \"^0.11.1\",\n \"@traceloop/instrumentation-chromadb\": \"^0.11.1\",\n \"@traceloop/instrumentation-cohere\": \"^0.11.1\",\n \"@traceloop/instrumentation-langchain\": \"^0.11.1\",\n \"@traceloop/instrumentation-llamaindex\": \"^0.11.1\",\n \"@traceloop/instrumentation-openai\": \"^0.11.1\",\n \"@traceloop/instrumentation-pinecone\": \"^0.11.1\",\n \"@traceloop/instrumentation-qdrant\": \"^0.11.1\",\n \"@traceloop/instrumentation-vertexai\": \"^0.11.1\",\n \"posthog-node\": \"^4.2.0\",\n \"uuid\": \"^10.0.0\"\n }\n}","import { PipelineRunResponse, PipelineRunRequest, EvaluationDatapoint, EvaluationStatus } from './types';\nimport { Attributes, AttributeValue, context, createContextKey, isSpanContextValid, TimeInput, trace } from '@opentelemetry/api';\nimport { InitializeOptions, initialize as traceloopInitialize } from './sdk/node-server-sdk'\nimport { otelSpanIdToUUID, otelTraceIdToUUID } from './utils';\nimport { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-grpc';\nimport { Metadata } from '@grpc/grpc-js';\nimport { ASSOCIATION_PROPERTIES_KEY } from './sdk/tracing/tracing';\n\n// quick patch to get the traceloop's default tracer, since their \n// `getTracer` function is not exported.\n// Another option would be to import directly \n// like so: `import { getTracer } from '@traceloop/node-server-sdk/dist/src/lib/tracing/tracing';`\n// which isn't too nice either.\nconst DEFAULT_TRACER_NAME = 'traceloop.tracer';\n\ninterface LaminarInitializeProps {\n projectApiKey?: string;\n env?: Record<string, string>;\n baseUrl?: string;\n instrumentModules?: InitializeOptions[\"instrumentModules\"];\n}\n\nexport class Laminar {\n private static baseUrl: string = 'https://api.lmnr.ai:8443';\n private static projectApiKey: string;\n private static env: Record<string, string> = {};\n private static isInitialized: boolean = false;\n\n /**\n * Initialize Laminar context across the application.\n * This method must be called before using any other Laminar methods or decorators.\n *\n * @param project_api_key - Laminar project api key. You can generate one by going\n * to the projects settings page on the Laminar dashboard.\n * If not specified, it will try to read from the LMNR_PROJECT_API_KEY environment variable.\n * @param env - Default environment passed to `run` and `evaluateEvent` requests,\n * unless overriden at request time. Usually, model provider keys are stored here.\n * @param baseUrl - Url of Laminar endpoint, or the custom open telemetry ingester.\n * If not specified, defaults to https://api.lmnr.ai:8443. For locally hosted Laminar,\n * default setting must be http://localhost:8001.\n * @param instrumentModules - List of modules to instrument.\n * If not specified, all auto-instrumentable modules will be instrumented, which include\n * LLM calls (OpenAI, Anthropic, etc), Langchain, VectorDB calls (Pinecone, Qdrant, etc).\n * Pass an empty object {} to disable any kind of automatic instrumentation.\n * If you only want to auto-instrument specific modules, then pass them in the object.\n * \n * Example:\n * ```typescript\n * import { Laminar as L } from '@lmnr-ai/lmnr';\n * import { OpenAI } from 'openai';\n * import * as ChainsModule from \"langchain/chains\";\n * \n * // Initialize Laminar while auto-instrumenting Langchain and OpenAI modules.\n * L.initialize({ projectApiKey: \"<LMNR_PROJECT_API_KEY>\", instrumentModules: {\n * langchain: {\n * chainsModule: ChainsModule\n * },\n * openAI: OpenAI\n * } });\n * ```\n *\n * @throws {Error} - If project API key is not set\n */\n public static initialize({\n projectApiKey,\n env,\n baseUrl,\n instrumentModules\n }: LaminarInitializeProps) {\n\n let key = projectApiKey ?? process.env.LMNR_PROJECT_API_KEY;\n if (key === undefined) {\n throw new Error(\n 'Please initialize the Laminar object with your project API key ' +\n 'or set the LMNR_PROJECT_API_KEY environment variable'\n );\n }\n this.projectApiKey = key;\n if (baseUrl) {\n this.baseUrl = baseUrl;\n }\n this.isInitialized = true;\n this.env = env ?? {};\n\n const metadata = new Metadata();\n metadata.set('authorization', `Bearer ${this.projectApiKey}`);\n const exporter = new OTLPTraceExporter({\n url: this.baseUrl,\n metadata,\n });\n\n traceloopInitialize({\n exporter,\n silenceInitializationMessage: true,\n instrumentModules,\n disableBatch: true,\n });\n }\n\n /**\n * Check if Laminar has been initialized. Utility to make sure other methods\n * are called after initialization.\n */\n public static initialized(): boolean {\n return this.isInitialized;\n }\n\n /**\n * Sets the environment that will be sent to Laminar requests.\n * \n * @param env - The environment variables to override. If not provided, the current environment will not be modified.\n */\n public static setEnv(env?: Record<string, string>) {\n if (env) {\n this.env = env;\n }\n }\n\n /**\n * Sets the project API key for authentication with Laminar.\n *\n * @param projectApiKey - The API key to be set. If not provided, the existing API key will not be modified.\n */\n public static setProjectApiKey(projectApiKey?: string) {\n if (projectApiKey) {\n this.projectApiKey = projectApiKey;\n }\n }\n\n /**\n * Runs the pipeline with the given inputs\n *\n * @param pipeline - The name of the Laminar pipeline. Pipeline must have a target version.\n * @param inputs - The inputs for the pipeline. Map from an input node name to input data.\n * @param env - The environment variables for the pipeline execution. Typically used for model provider keys.\n * @param metadata - Additional metadata for the pipeline run.\n * @param currentSpanId - The ID of the current span.\n * @param currentTraceId - The ID of the current trace.\n * @returns A promise that resolves to the response of the pipeline run.\n * @throws An error if the Laminar object is not initialized with a project API key. Or if the request fails.\n */\n public static async run({\n pipeline,\n inputs,\n env,\n metadata = {},\n currentSpanId,\n currentTraceId,\n }: PipelineRunRequest): Promise<PipelineRunResponse> {\n const currentSpan = trace.getActiveSpan();\n let parentSpanId: string | undefined;\n let traceId: string | undefined;\n if (currentSpan !== undefined && isSpanContextValid(currentSpan.spanContext())) {\n parentSpanId = currentSpanId ?? otelSpanIdToUUID(currentSpan.spanContext().spanId);\n traceId = currentTraceId ?? otelTraceIdToUUID(currentSpan.spanContext().traceId);\n } else {\n parentSpanId = currentSpanId;\n traceId = currentTraceId;\n }\n if (this.projectApiKey === undefined) {\n throw new Error(\n 'Please initialize the Laminar object with your project API key ' +\n 'or set the LMNR_PROJECT_API_KEY environment variable'\n );\n }\n const envirionment = env === undefined ? this.env : env;\n\n const response = await fetch(`${this.baseUrl}/v1/pipeline/run`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify({\n inputs,\n pipeline,\n env: envirionment,\n metadata,\n parentSpanId,\n traceId,\n })\n });\n\n if (!response.ok) {\n throw new Error(`Failed to run pipeline ${pipeline}. Response: ${response.statusText}`);\n }\n try {\n return await response.json() as PipelineRunResponse;\n } catch (error) {\n throw new Error(`Failed to parse response from pipeline ${pipeline}. Error: ${error}`);\n }\n }\n\n /**\n * Associates an event with the current span. If event with such name never\n * existed, Laminar will create a new event and infer its type from the value.\n * If the event already exists, Laminar will append the value to the event\n * if and only if the value is of a matching type. Otherwise, the event won't\n * be recorded. Supported types are string, number, and boolean. If the value\n * is `null`, event is considered a boolean tag with the value of `true`.\n *\n * @param name - The name of the event.\n * @param value - The value of the event. Must be a primitive type. If not specified, boolean true is assumed in the backend.\n * @param timestamp - The timestamp of the event. If not specified, relies on the underlying OpenTelemetry implementation.\n * If specified as an integer, it must be epoch nanoseconds.\n */\n public static event(\n name: string,\n value?: AttributeValue,\n timestamp?: TimeInput,\n ) {\n const currentSpan = trace.getActiveSpan();\n if (currentSpan === undefined || !isSpanContextValid(currentSpan.spanContext())) {\n console.warn(\"Laminar().event()\\` called outside of span context.\" +\n ` Event '${name}' will not be recorded in the trace.` +\n \" Make sure to annotate the function with a decorator\"\n );\n return;\n }\n\n const event: Attributes = {\n \"lmnr.event.type\": \"default\",\n }\n if (value !== undefined) {\n event[\"lmnr.event.value\"] = value;\n }\n\n currentSpan.addEvent(name, event, timestamp);\n }\n\n /**\n * Sends an event for evaluation to the Laminar backend.\n * \n * @param name - The name of the event.\n * @param evaluator - The name of the pipeline that evaluates the event.\n * @param data - A map from input node name to its value in the evaluator pipeline.\n * @param env - Environment variables required to run the pipeline.\n * @param timestamp - If specified as an integer, it must be epoch nanoseconds.\n * If not specified, relies on the underlying OpenTelemetry implementation.\n */\n public static evaluateEvent(\n name: string,\n evaluator: string,\n data: Record<string, any>,\n env?: Record<string, string>,\n timestamp?: TimeInput,\n ) {\n const currentSpan = trace.getActiveSpan();\n\n if (currentSpan === undefined || !isSpanContextValid(currentSpan.spanContext())) {\n console.warn(\"Laminar().evaluateEvent()\\` called outside of span context.\" +\n ` Evaluate event '${name}' will not be recorded in the trace.` +\n \" Make sure to annotate the function with a decorator\"\n );\n return;\n }\n\n const event = {\n \"lmnr.event.type\": \"evaluate\",\n \"lmnr.event.evaluator\": evaluator,\n \"lmnr.event.data\": JSON.stringify(data),\n \"lmnr.event.env\": JSON.stringify(env ?? {}),\n }\n\n currentSpan.addEvent(name, event, timestamp);\n }\n\n /**\n * Sets the session information for the current span and returns the context to use for the following spans.\n * \n * Example:\n * ```typescript\n * import { context as contextApi } from '@opentelemetry/api';\n * import { Laminar } from '@lmnr-ai/laminar';\n * const context = Laminar.contextWithSession({ sessionId: \"1234\", userId: \"5678\" });\n * contextApi.with(context, () => {\n * // Your code here\n * });\n * ```\n * \n * @param sessionId - The session ID to associate with the span.\n * @param userId - The user ID to associate with the span.\n * @returns The updated context with the association properties.\n */\n public static contextWithSession({ sessionId, userId }: { sessionId?: string, userId?: string }) {\n\n const currentSpan = trace.getActiveSpan();\n if (currentSpan !== undefined && isSpanContextValid(currentSpan.spanContext())) {\n if (sessionId) {\n currentSpan.setAttribute(\"traceloop.association.properties.session_id\", sessionId);\n }\n if (userId) {\n currentSpan.setAttribute(\"traceloop.association.properties.user_id\", userId);\n }\n }\n let associationProperties = {};\n if (sessionId) {\n associationProperties = { ...associationProperties, \"session_id\": sessionId };\n }\n if (userId) {\n associationProperties = { ...associationProperties, \"user_id\": userId };\n }\n\n let entityContext = context.active();\n const currentAssociationProperties = entityContext.getValue(ASSOCIATION_PROPERTIES_KEY);\n if (associationProperties) {\n entityContext = entityContext.setValue(\n ASSOCIATION_PROPERTIES_KEY,\n { ...(currentAssociationProperties ?? {}), ...associationProperties },\n );\n }\n\n return entityContext;\n }\n\n public static async createEvaluation(name: string) {\n const response = await fetch(`${this.baseUrl}/v1/evaluations`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify({\n name,\n })\n });\n\n return await response.json();\n }\n\n public static async postEvaluationResults<D, T, O>(\n evaluationName: string,\n data: EvaluationDatapoint<D, T, O>[]\n ): Promise<void> {\n const body = JSON.stringify({\n name: evaluationName,\n points: data,\n });\n const headers = this.getHeaders();\n const url = `${this.baseUrl}/v1/evaluation-datapoints`;\n try {\n const response = await fetch(url, {\n method: \"POST\",\n headers,\n body,\n });\n if (!response.ok) {\n console.error(\"Failed to send evaluation results. Response: \");\n response.text().then((text) => console.error(text));\n }\n } catch (error) {\n console.error(\"Failed to send evaluation results. Error: \", error);\n };\n }\n\n public static async updateEvaluationStatus(\n evaluationName: string,\n status: EvaluationStatus,\n ): Promise<void> {\n const body = JSON.stringify({\n name: evaluationName,\n status,\n });\n const headers = this.getHeaders();\n const url = `${this.baseUrl}/v1/evaluations`;\n try {\n const response = await fetch(url, {\n method: \"PUT\",\n headers,\n body,\n });\n if (!response.ok) {\n console.error(\"Failed to update evaluation status. Response: \");\n response.text().then((text) => console.error(text));\n }\n } catch (error) {\n console.error(\"Failed to update evaluation status. Error: \", error);\n }\n }\n\n private static getHeaders() {\n return {\n \"Content-Type\": \"application/json\",\n \"Authorization\": `Bearer ${this.projectApiKey}`,\n };\n };\n}\n","/**\n * The severity of an error.\n */\nexport const SEVERITY = {\n Warning: \"Warning\",\n Error: \"Error\",\n Critical: \"Critical\",\n} as const;\n\nexport type Severity = (typeof SEVERITY)[keyof typeof SEVERITY];\n\n/**\n * Base class for all Traceloop errors.\n */\nexport class TraceloopError extends Error {\n /**\n * The severity of the error.\n */\n severity: Severity;\n /**\n * The underlying cause of the error.\n */\n underlyingCause?: Error;\n\n constructor(message: string, severity: Severity = SEVERITY.Error) {\n super(message);\n this.severity = severity;\n }\n}\n\nexport class NotInitializedError extends TraceloopError {\n constructor() {\n super(\n `The Traceloop SDK must be initialized by calling the \"initialize\" function prior to use.`,\n SEVERITY.Critical,\n );\n }\n}\n\nexport class InitializationError extends TraceloopError {\n constructor(message?: string, cause?: Error) {\n super(message ?? \"Failed to initialize Traceloop SDK\", SEVERITY.Critical);\n this.underlyingCause = cause;\n }\n}\n\nexport class ArgumentNotProvidedError extends TraceloopError {\n constructor(argumentName: string) {\n super(`The \"${argumentName}\" argument is required and must be a string.`);\n }\n}\n\nexport class PromptNotFoundError extends TraceloopError {\n constructor(key: string) {\n super(`The prompt \"${key}\" was not found in the registry.`);\n }\n}\n","/* eslint-disable @typescript-eslint/no-var-requires */\nimport { NodeSDK } from \"@opentelemetry/sdk-node\";\nimport {\n SimpleSpanProcessor,\n BatchSpanProcessor,\n SpanProcessor,\n} from \"@opentelemetry/sdk-trace-node\";\nimport { baggageUtils } from \"@opentelemetry/core\";\nimport { Span, context, diag } from \"@opentelemetry/api\";\nimport { OTLPTraceExporter } from \"@opentelemetry/exporter-trace-otlp-proto\";\nimport { Resource } from \"@opentelemetry/resources\";\nimport { SEMRESATTRS_SERVICE_NAME } from \"@opentelemetry/semantic-conventions\";\nimport { Instrumentation } from \"@opentelemetry/instrumentation\";\nimport { InitializeOptions } from \"../interfaces\";\nimport {\n Detector,\n DetectorSync,\n IResource,\n ResourceDetectionConfig,\n envDetectorSync,\n hostDetectorSync,\n processDetectorSync,\n} from \"@opentelemetry/resources\"\nimport {\n ASSOCIATION_PROPERTIES_KEY,\n} from \"./tracing\";\nimport { Telemetry } from \"../telemetry/telemetry\";\nimport { _configuration } from \"../configuration\";\nimport {\n SpanAttributes,\n} from \"@traceloop/ai-semantic-conventions\";\nimport { AnthropicInstrumentation } from \"@traceloop/instrumentation-anthropic\";\nimport { OpenAIInstrumentation } from \"@traceloop/instrumentation-openai\";\nimport { AzureOpenAIInstrumentation } from \"@traceloop/instrumentation-azure\";\nimport { LlamaIndexInstrumentation } from \"@traceloop/instrumentation-llamaindex\";\nimport {\n AIPlatformInstrumentation,\n VertexAIInstrumentation,\n} from \"@traceloop/instrumentation-vertexai\";\nimport { BedrockInstrumentation } from \"@traceloop/instrumentation-bedrock\";\nimport { CohereInstrumentation } from \"@traceloop/instrumentation-cohere\";\nimport { PineconeInstrumentation } from \"@traceloop/instrumentation-pinecone\";\nimport { LangChainInstrumentation } from \"@traceloop/instrumentation-langchain\";\nimport { ChromaDBInstrumentation } from \"@traceloop/instrumentation-chromadb\";\nimport { QdrantInstrumentation } from \"@traceloop/instrumentation-qdrant\";\n\nlet _sdk: NodeSDK;\nlet _spanProcessor: SimpleSpanProcessor | BatchSpanProcessor;\nlet openAIInstrumentation: OpenAIInstrumentation | undefined;\nlet anthropicInstrumentation: AnthropicInstrumentation | undefined;\nlet azureOpenAIInstrumentation: AzureOpenAIInstrumentation | undefined;\nlet cohereInstrumentation: CohereInstrumentation | undefined;\nlet vertexaiInstrumentation: VertexAIInstrumentation | undefined;\nlet aiplatformInstrumentation: AIPlatformInstrumentation | undefined;\nlet bedrockInstrumentation: BedrockInstrumentation | undefined;\nlet langchainInstrumentation: LangChainInstrumentation | undefined;\nlet llamaIndexInstrumentation: LlamaIndexInstrumentation | undefined;\nlet pineconeInstrumentation: PineconeInstrumentation | undefined;\nlet chromadbInstrumentation: ChromaDBInstrumentation | undefined;\nlet qdrantInstrumentation: QdrantInstrumentation | undefined;\n\n\nconst instrumentations: Instrumentation[] = [];\n\nconst initInstrumentations = () => {\n const exceptionLogger = (e: Error) => Telemetry.getInstance().logException(e);\n const enrichTokens =\n (process.env.TRACELOOP_ENRICH_TOKENS || \"true\").toLowerCase() === \"true\";\n\n openAIInstrumentation = new OpenAIInstrumentation({\n enrichTokens,\n exceptionLogger,\n });\n instrumentations.push(openAIInstrumentation);\n\n anthropicInstrumentation = new AnthropicInstrumentation({ exceptionLogger });\n instrumentations.push(anthropicInstrumentation);\n\n azureOpenAIInstrumentation = new AzureOpenAIInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(azureOpenAIInstrumentation);\n\n cohereInstrumentation = new CohereInstrumentation({ exceptionLogger });\n instrumentations.push(cohereInstrumentation);\n\n vertexaiInstrumentation = new VertexAIInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(vertexaiInstrumentation);\n\n aiplatformInstrumentation = new AIPlatformInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(aiplatformInstrumentation);\n\n bedrockInstrumentation = new BedrockInstrumentation({ exceptionLogger });\n instrumentations.push(bedrockInstrumentation);\n\n pineconeInstrumentation = new PineconeInstrumentation({ exceptionLogger });\n instrumentations.push(pineconeInstrumentation);\n\n langchainInstrumentation = new LangChainInstrumentation({ exceptionLogger });\n instrumentations.push(langchainInstrumentation);\n\n llamaIndexInstrumentation = new LlamaIndexInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(llamaIndexInstrumentation);\n\n chromadbInstrumentation = new ChromaDBInstrumentation({ exceptionLogger });\n instrumentations.push(chromadbInstrumentation);\n\n qdrantInstrumentation = new QdrantInstrumentation({ exceptionLogger });\n instrumentations.push(qdrantInstrumentation);\n};\n\nconst manuallyInitInstrumentations = (\n instrumentModules: InitializeOptions[\"instrumentModules\"],\n) => {\n const exceptionLogger = (e: Error) => Telemetry.getInstance().logException(e);\n const enrichTokens =\n (process.env.TRACELOOP_ENRICH_TOKENS || \"true\").toLowerCase() === \"true\";\n\n instrumentations.length = 0;\n\n if (instrumentModules?.openAI) {\n openAIInstrumentation = new OpenAIInstrumentation({\n enrichTokens,\n exceptionLogger,\n });\n instrumentations.push(openAIInstrumentation);\n openAIInstrumentation.manuallyInstrument(instrumentModules.openAI);\n }\n\n if (instrumentModules?.anthropic) {\n anthropicInstrumentation = new AnthropicInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(anthropicInstrumentation);\n anthropicInstrumentation.manuallyInstrument(instrumentModules.anthropic);\n }\n\n if (instrumentModules?.azureOpenAI) {\n const instrumentation = new AzureOpenAIInstrumentation({ exceptionLogger });\n instrumentations.push(instrumentation as Instrumentation);\n azureOpenAIInstrumentation = instrumentation;\n instrumentation.manuallyInstrument(instrumentModules.azureOpenAI);\n }\n\n if (instrumentModules?.cohere) {\n cohereInstrumentation = new CohereInstrumentation({ exceptionLogger });\n instrumentations.push(cohereInstrumentation);\n cohereInstrumentation.manuallyInstrument(instrumentModules.cohere);\n }\n\n if (instrumentModules?.google_vertexai) {\n vertexaiInstrumentation = new VertexAIInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(vertexaiInstrumentation);\n vertexaiInstrumentation.manuallyInstrument(\n instrumentModules.google_vertexai,\n );\n }\n\n if (instrumentModules?.google_aiplatform) {\n aiplatformInstrumentation = new AIPlatformInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(aiplatformInstrumentation);\n aiplatformInstrumentation.manuallyInstrument(\n instrumentModules.google_aiplatform,\n );\n }\n\n if (instrumentModules?.bedrock) {\n bedrockInstrumentation = new BedrockInstrumentation({ exceptionLogger });\n instrumentations.push(bedrockInstrumentation);\n bedrockInstrumentation.manuallyInstrument(instrumentModules.bedrock);\n }\n\n if (instrumentModules?.pinecone) {\n const instrumentation = new PineconeInstrumentation({ exceptionLogger });\n instrumentations.push(instrumentation as Instrumentation);\n instrumentation.manuallyInstrument(instrumentModules.pinecone);\n }\n\n if (instrumentModules?.langchain) {\n langchainInstrumentation = new LangChainInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(langchainInstrumentation);\n langchainInstrumentation.manuallyInstrument(instrumentModules.langchain);\n }\n\n if (instrumentModules?.llamaIndex) {\n llamaIndexInstrumentation = new LlamaIndexInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(llamaIndexInstrumentation);\n llamaIndexInstrumentation.manuallyInstrument(instrumentModules.llamaIndex);\n }\n\n if (instrumentModules?.chromadb) {\n chromadbInstrumentation = new ChromaDBInstrumentation({ exceptionLogger });\n instrumentations.push(chromadbInstrumentation);\n chromadbInstrumentation.manuallyInstrument(instrumentModules.chromadb);\n }\n\n if (instrumentModules?.qdrant) {\n qdrantInstrumentation = new QdrantInstrumentation({ exceptionLogger });\n instrumentations.push(qdrantInstrumentation);\n qdrantInstrumentation.manuallyInstrument(instrumentModules.qdrant);\n }\n};\n\nfunction awaitAttributes(detector: DetectorSync): Detector {\n return {\n async detect(config?: ResourceDetectionConfig): Promise<IResource> {\n const resource = detector.detect(config)\n await resource.waitForAsyncAttributes?.()\n\n return resource\n },\n }\n}\n\n/**\n * Initializes the Traceloop SDK.\n * Must be called once before any other SDK methods.\n *\n * @param options - The options to initialize the SDK. See the {@link InitializeOptions} for details.\n */\nexport const startTracing = (options: InitializeOptions) => {\n if (options.instrumentModules !== undefined) {\n // If options.instrumentModules is empty, it will not initialize anything,\n // so empty dict can essentially be passed to disable any kind of automatic instrumentation.\n manuallyInitInstrumentations(options.instrumentModules);\n } else {\n initInstrumentations();\n }\n\n if (!shouldSendTraces()) {\n openAIInstrumentation?.setConfig({\n traceContent: false,\n });\n azureOpenAIInstrumentation?.setConfig({\n traceContent: false,\n });\n llamaIndexInstrumentation?.setConfig({\n traceContent: false,\n });\n vertexaiInstrumentation?.setConfig({\n traceContent: false,\n });\n aiplatformInstrumentation?.setConfig({\n traceContent: false,\n });\n bedrockInstrumentation?.setConfig({\n traceContent: false,\n });\n cohereInstrumentation?.setConfig({\n traceContent: false,\n });\n chromadbInstrumentation?.setConfig({\n traceContent: false,\n });\n }\n\n const headers = process.env.TRACELOOP_HEADERS\n ? baggageUtils.parseKeyPairsIntoRecord(process.env.TRACELOOP_HEADERS)\n : { Authorization: `Bearer ${options.apiKey}` };\n\n const traceExporter =\n options.exporter ??\n new OTLPTraceExporter({\n url: `${options.baseUrl}/v1/traces`,\n headers,\n });\n _spanProcessor = options.disableBatch\n ? new SimpleSpanProcessor(traceExporter)\n : new BatchSpanProcessor(traceExporter);\n\n _spanProcessor.onStart = (span: Span) => {\n // This sets the properties only if the context has them\n const associationProperties = context\n .active()\n .getValue(ASSOCIATION_PROPERTIES_KEY);\n if (associationProperties) {\n for (const [key, value] of Object.entries(associationProperties)) {\n span.setAttribute(\n `${SpanAttributes.TRACELOOP_ASSOCIATION_PROPERTIES}.${key}`,\n value,\n );\n }\n }\n };\n\n if (options.exporter) {\n Telemetry.getInstance().capture(\"tracer:init\", {\n exporter: \"custom\",\n processor: options.disableBatch ? \"simple\" : \"batch\",\n });\n } else {\n Telemetry.getInstance().capture(\"tracer:init\", {\n exporter: options.baseUrl ?? \"\",\n processor: options.disableBatch ? \"simple\" : \"batch\",\n });\n }\n\n const spanProcessors: SpanProcessor[] = [_spanProcessor];\n if (options.processor) {\n spanProcessors.push(options.processor);\n }\n\n _sdk = new NodeSDK({\n resource: new Resource({\n [SEMRESATTRS_SERVICE_NAME]:\n options.appName || process.env.npm_package_name,\n }),\n spanProcessors,\n contextManager: options.contextManager,\n textMapPropagator: options.propagator,\n traceExporter,\n instrumentations,\n // We should re-consider removing irrelevant spans here in the future\n // sampler: new TraceloopSampler(),\n resourceDetectors: [\n awaitAttributes(envDetectorSync),\n awaitAttributes(processDetectorSync),\n awaitAttributes(hostDetectorSync),\n ],\n });\n\n _sdk.start();\n};\n\nexport const shouldSendTraces = () => {\n if (!_configuration) {\n diag.warn(\"Traceloop not initialized\");\n return false;\n }\n\n if (\n _configuration.traceContent === false ||\n (process.env.TRACELOOP_TRACE_CONTENT || \"true\").toLowerCase() === \"false\"\n ) {\n return false;\n }\n\n return true;\n};\n\nexport const forceFlush = async () => {\n await _spanProcessor.forceFlush();\n};\n","import { trace, createContextKey } from \"@opentelemetry/api\";\nimport { Context } from \"@opentelemetry/api/build/src/context/types\";\n\nconst TRACER_NAME = \"traceloop.tracer\";\nexport const WORKFLOW_NAME_KEY = createContextKey(\"workflow_name\");\nexport const ENTITY_NAME_KEY = createContextKey(\"entity_name\");\nexport const ASSOCIATION_PROPERTIES_KEY = createContextKey(\n \"association_properties\",\n);\n\nexport const getTracer = () => {\n return trace.getTracer(TRACER_NAME);\n};\n\nexport const getEntityPath = (entityContext: Context): string | undefined => {\n const path = entityContext.getValue(ENTITY_NAME_KEY);\n\n return path ? `${path}` : undefined;\n};\n","import * as os from \"os\";\nimport * as fs from \"fs\";\nimport * as path from \"path\";\nimport { v4 as uuid } from \"uuid\";\nimport { PostHog } from \"posthog-node\";\nconst { version } = require('../../../package.json');\n\nexport class Telemetry {\n private static instance: Telemetry;\n\n private static readonly ANON_ID_PATH = `${os.homedir()}/.cache/lmnr/telemetry_anon_id`;\n private static readonly UNKNOWN_ANON_ID = \"UNKNOWN\";\n\n private telemetryEnabled: boolean;\n private posthog: PostHog | undefined;\n private anonId: string | undefined;\n\n public static getInstance(): Telemetry {\n if (!Telemetry.instance) {\n Telemetry.instance = new Telemetry();\n }\n return Telemetry.instance;\n }\n\n private constructor() {\n this.telemetryEnabled =\n !process.env.LMNR_TELEMETRY ||\n process.env.LMNR_TELEMETRY.toLowerCase() === \"true\";\n\n if (this.telemetryEnabled) {\n this.posthog = new PostHog(\n \"phc_dUMdjfNKf11jcHgtn7juSnT4P1pO0tafsPUWt4PuwG7\",\n );\n }\n }\n\n private getAnonId() {\n if (this.anonId) {\n return this.anonId;\n }\n\n try {\n if (!fs.existsSync(Telemetry.ANON_ID_PATH)) {\n fs.mkdirSync(path.dirname(Telemetry.ANON_ID_PATH), { recursive: true });\n const anonIdFile = fs.openSync(Telemetry.ANON_ID_PATH, \"w\");\n this.anonId = uuid();\n fs.writeSync(anonIdFile, this.anonId);\n fs.closeSync(anonIdFile);\n } else {\n const anonIdFile = fs.openSync(Telemetry.ANON_ID_PATH, \"r\");\n this.anonId = fs.readFileSync(anonIdFile, \"utf8\");\n fs.closeSync(anonIdFile);\n }\n return this.anonId;\n } catch (e) {\n return Telemetry.UNKNOWN_ANON_ID;\n }\n }\n\n private getContext() {\n return {\n sdk: \"typescript\",\n sdk_version: version,\n };\n }\n\n public capture(event: string, properties?: Record<string, string>) {\n if (this.telemetryEnabled && this.posthog) {\n this.posthog.capture({\n distinctId: this.getAnonId(),\n event,\n properties: {\n ...properties,\n ...this.getContext(),\n },\n });\n this.posthog.flush();\n }\n }\n\n public logException(error: Error) {\n if (this.telemetryEnabled) {\n this.capture(\"error\", { error: error.message, stack: error.stack || \"\" });\n }\n }\n}\n","import { InitializeOptions } from \"../interfaces\";\nimport { startTracing } from \"../tracing\";\nimport { diag, DiagConsoleLogger, DiagLogLevel } from \"@opentelemetry/api\";\nimport { InitializationError } from \"../errors\";\n\nexport let _configuration: InitializeOptions | undefined;\n\n/**\n * Initializes the SDK.\n * Must be called once before any other SDK methods.\n *\n * @param options - The options to initialize the SDK. See the {@link InitializeOptions} for details.\n * @throws {InitializationError} if the configuration is invalid or if failed to fetch feature data.\n */\nexport const initialize = (options: InitializeOptions) => {\n if (_configuration) {\n return;\n }\n\n if (!options.baseUrl) {\n options.baseUrl =\n process.env.LMNR_BASE_URL || \"https://api.lmnr.ai:8443\";\n }\n if (!options.apiKey) {\n options.apiKey = process.env.LMNR_PROJECT_API_KEY;\n }\n if (options.apiKey && typeof options.apiKey !== \"string\") {\n throw new InitializationError('\"apiKey\" must be a string');\n }\n\n if (!options.appName) {\n options.appName = process.env.npm_package_name;\n }\n\n _configuration = Object.freeze(options);\n\n if (options.logLevel) {\n diag.setLogger(\n new DiagConsoleLogger(),\n logLevelToOtelLogLevel(options.logLevel),\n );\n }\n\n if (!options.silenceInitializationMessage) {\n console.log(\n `Laminar exporting traces to ${\n _configuration.exporter ? \"a custom exporter\" : _configuration.baseUrl\n }`,\n );\n }\n\n startTracing(_configuration);\n};\n\nconst logLevelToOtelLogLevel = (\n logLevel: \"debug\" | \"info\" | \"warn\" | \"error\",\n) => {\n switch (logLevel) {\n case \"debug\":\n return DiagLogLevel.DEBUG;\n case \"info\":\n return DiagLogLevel.INFO;\n case \"warn\":\n return DiagLogLevel.WARN;\n case \"error\":\n return DiagLogLevel.ERROR;\n }\n};\n","import { Span, context } from \"@opentelemetry/api\";\nimport { suppressTracing } from \"@opentelemetry/core\";\nimport {\n ASSOCIATION_PROPERTIES_KEY,\n getTracer,\n} from \"./tracing\";\nimport {\n SpanAttributes,\n} from \"@traceloop/ai-semantic-conventions\";\nimport { shouldSendTraces } from \".\";\nimport { Telemetry } from \"../telemetry/telemetry\";\n\nexport type DecoratorConfig = {\n name: string;\n associationProperties?: { [name: string]: string };\n inputParameters?: unknown[];\n suppressTracing?: boolean;\n};\n\nexport function withEntity<\n A extends unknown[],\n F extends (...args: A) => ReturnType<F>,\n>(\n {\n name,\n associationProperties,\n inputParameters,\n suppressTracing: shouldSuppressTracing,\n }: DecoratorConfig,\n fn: F,\n thisArg?: ThisParameterType<F>,\n ...args: A\n) {\n let entityContext = context.active();\n\n const currentAssociationProperties = entityContext.getValue(ASSOCIATION_PROPERTIES_KEY);\n\n if (associationProperties) {\n entityContext = entityContext.setValue(\n ASSOCIATION_PROPERTIES_KEY,\n { ...(currentAssociationProperties ?? {}), ...associationProperties },\n );\n }\n\n if (shouldSuppressTracing) {\n entityContext = suppressTracing(entityContext);\n }\n\n return context.with(entityContext, () =>\n getTracer().startActiveSpan(\n name,\n {},\n entityContext,\n async (span: Span) => {\n if (shouldSendTraces()) {\n try {\n const input = inputParameters ?? args;\n if (\n input.length === 1 &&\n typeof input[0] === \"object\" &&\n !(input[0] instanceof Map)\n ) {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_INPUT,\n serialize({ args: [], kwargs: input[0] }),\n );\n } else {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_INPUT,\n serialize({\n args: input,\n kwargs: {},\n }),\n );\n }\n } catch (error) {\n Telemetry.getInstance().logException(error as any);\n }\n }\n\n const res = fn.apply(thisArg, args);\n if (res instanceof Promise) {\n return res.then((resolvedRes) => {\n try {\n if (shouldSendTraces()) {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_OUTPUT,\n serialize(resolvedRes),\n );\n }\n } catch (error) {\n Telemetry.getInstance().logException(error as any);\n } finally {\n span.end();\n }\n\n return resolvedRes;\n });\n }\n try {\n if (shouldSendTraces()) {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_OUTPUT,\n serialize(res),\n );\n }\n } catch (error) {\n Telemetry.getInstance().logException(error as any);\n } finally {\n span.end();\n }\n\n return res;\n },\n ),\n );\n}\n\nfunction cleanInput(input: unknown): unknown {\n if (input instanceof Map) {\n return Array.from(input.entries());\n } else if (Array.isArray(input)) {\n return input.map((value) => cleanInput(value));\n } else if (!input) {\n return input;\n } else if (typeof input === \"object\") {\n // serialize object one by one\n const output: any = {};\n Object.entries(input as any).forEach(([key, value]) => {\n output[key] = cleanInput(value);\n });\n return output;\n }\n\n return input;\n}\n\nfunction serialize(input: unknown): string {\n return JSON.stringify(cleanInput(input));\n}\n","import { Span, context, trace } from \"@opentelemetry/api\";\nimport { getTracer } from \"./tracing\";\nimport {\n Events,\n EventAttributes,\n SpanAttributes,\n} from \"@traceloop/ai-semantic-conventions\";\nimport { shouldSendTraces } from \".\";\n\ntype VectorDBCallConfig = {\n vendor: string;\n type: \"query\" | \"upsert\" | \"delete\";\n};\n\ntype LLMCallConfig = {\n vendor: string;\n type: \"chat\" | \"completion\";\n};\n\nexport class VectorSpan {\n private span: Span;\n\n constructor(span: Span) {\n this.span = span;\n }\n\n reportQuery({ queryVector }: { queryVector: number[] }) {\n if (!shouldSendTraces()) {\n this.span.addEvent(Events.DB_QUERY_EMBEDDINGS);\n }\n\n this.span.addEvent(Events.DB_QUERY_EMBEDDINGS, {\n [EventAttributes.DB_QUERY_EMBEDDINGS_VECTOR]: JSON.stringify(queryVector),\n });\n }\n\n reportResults({\n results,\n }: {\n results: {\n ids?: string;\n scores?: number;\n distances?: number;\n metadata?: Record<string, unknown>;\n vectors?: number[];\n documents?: string;\n }[];\n }) {\n for (let i = 0; i < results.length; i++) {\n this.span.addEvent(Events.DB_QUERY_RESULT, {\n [EventAttributes.DB_QUERY_RESULT_ID]: results[i].ids,\n [EventAttributes.DB_QUERY_RESULT_SCORE]: results[i].scores,\n [EventAttributes.DB_QUERY_RESULT_DISTANCE]: results[i].distances,\n [EventAttributes.DB_QUERY_RESULT_METADATA]: JSON.stringify(\n results[i].metadata,\n ),\n [EventAttributes.DB_QUERY_RESULT_VECTOR]: results[i].vectors,\n [EventAttributes.DB_QUERY_RESULT_DOCUMENT]: results[i].documents,\n });\n }\n }\n}\n\nexport class LLMSpan {\n private span: Span;\n\n constructor(span: Span) {\n this.span = span;\n }\n\n reportRequest({\n model,\n messages,\n }: {\n model: string;\n messages: {\n role: string;\n content?: string | unknown;\n }[];\n }) {\n this.span.setAttributes({\n [SpanAttributes.LLM_REQUEST_MODEL]: model,\n });\n\n messages.forEach((message, index) => {\n this.span.setAttributes({\n [`${SpanAttributes.LLM_PROMPTS}.${index}.role`]: message.role,\n [`${SpanAttributes.LLM_PROMPTS}.${index}.content`]:\n typeof message.content === \"string\"\n ? message.content\n : JSON.stringify(message.content),\n });\n });\n }\n\n reportResponse({\n model,\n usage,\n completions,\n }: {\n model: string;\n usage?: {\n prompt_tokens: number;\n completion_tokens: number;\n total_tokens: number;\n };\n completions?: {\n finish_reason: string;\n message: {\n role: \"system\" | \"user\" | \"assistant\";\n content: string | null;\n };\n }[];\n }) {\n this.span.setAttribute(SpanAttributes.LLM_RESPONSE_MODEL, model);\n\n if (usage) {\n this.span.setAttributes({\n [SpanAttributes.LLM_USAGE_PROMPT_TOKENS]: usage.prompt_tokens,\n [SpanAttributes.LLM_USAGE_COMPLETION_TOKENS]: usage.completion_tokens,\n [SpanAttributes.LLM_USAGE_TOTAL_TOKENS]: usage.total_tokens,\n });\n }\n\n completions?.forEach((completion, index) => {\n this.span.setAttributes({\n [`${SpanAttributes.LLM_COMPLETIONS}.${index}.finish_reason`]:\n completion.finish_reason,\n [`${SpanAttributes.LLM_COMPLETIONS}.${index}.role`]:\n completion.message.role,\n [`${SpanAttributes.LLM_COMPLETIONS}.${index}.content`]:\n completion.message.content || \"\",\n });\n });\n }\n}\n\nexport function withVectorDBCall<\n F extends ({ span }: { span: VectorSpan }) => ReturnType<F>,\n>({ vendor, type }: VectorDBCallConfig, fn: F, thisArg?: ThisParameterType<F>) {\n const entityContext = context.active();\n\n return getTracer().startActiveSpan(\n `${vendor}.${type}`,\n { [SpanAttributes.LLM_REQUEST_TYPE]: type },\n entityContext,\n (span: Span) => {\n const res = fn.apply(thisArg, [{ span: new VectorSpan(span) }]);\n if (res instanceof Promise) {\n return res.then((resolvedRes) => {\n span.end();\n return resolvedRes;\n });\n }\n\n span.end();\n return res;\n },\n );\n}\n\nexport function withLLMCall<\n F extends ({ span }: { span: LLMSpan }) => ReturnType<F>,\n>({ vendor, type }: LLMCallConfig, fn: F, thisArg?: ThisParameterType<F>) {\n const span = getTracer().startSpan(`${vendor}.${type}`, {}, context.active());\n span.setAttribute(SpanAttributes.LLM_REQUEST_TYPE, type);\n trace.setSpan(context.active(), span);\n\n const res = fn.apply(thisArg, [{ span: new LLMSpan(span) }]);\n if (res instanceof Promise) {\n return res.then((resolvedRes) => {\n span.end();\n return resolvedRes;\n });\n }\n\n span.end();\n return res;\n}\n","import { context } from \"@opentelemetry/api\";\nimport { ASSOCIATION_PROPERTIES_KEY } from \"./tracing\";\n\nexport function withAssociationProperties<\n A extends unknown[],\n F extends (...args: A) => ReturnType<F>,\n>(\n properties: { [name: string]: string },\n fn: F,\n thisArg?: ThisParameterType<F>,\n ...args: A\n) {\n if (Object.keys(properties).length === 0) {\n return fn.apply(thisArg, args);\n }\n\n const newContext = context\n .active()\n .setValue(ASSOCIATION_PROPERTIES_KEY, properties);\n return context.with(newContext, fn, thisArg, ...args);\n}\n","import { v4 as uuidv4 } from 'uuid';\n\nexport type StringUUID = `${string}-${string}-${string}-${string}-${string}`;\n\nexport const newUUID = (): StringUUID => {\n // crypto.randomUUID is available in most of the modern browsers and node,\n // but is not available in \"insecure\" contexts, e.g. not https, not localhost\n // so we fallback to uuidv4 in those cases, which is less secure, but works\n // just fine.\n if (typeof crypto !== 'undefined' && typeof crypto.randomUUID === 'function') {\n return crypto.randomUUID();\n } else {\n return uuidv4() as `${string}-${string}-${string}-${string}-${string}`;\n }\n}\n\nexport const otelSpanIdToUUID = (spanId: string): string => {\n let id = spanId.toLowerCase();\n if (id.startsWith('0x')) {\n id = id.slice(2);\n }\n if (id.length !== 16) {\n console.warn(`Span ID ${spanId} is not 16 hex chars long. This is not a valid OpenTelemetry span ID.`);\n }\n\n if (!/^[0-9a-f]+$/.test(id)) {\n console.error(`Span ID ${spanId} is not a valid hex string. Generating a random UUID instead.`);\n return newUUID();\n }\n\n return id.padStart(32, '0').replace(/^(.{8})(.{4})(.{4})(.{4})(.{12})$/, '$1-$2-$3-$4-$5');\n}\n\nexport const otelTraceIdToUUID = (traceId: string): string => {\n let id = traceId.toLowerCase();\n if (id.startsWith('0x')) {\n id = id.slice(2);\n }\n if (id.length !== 32) {\n console.warn(`Trace ID ${traceId} is not 32 hex chars long. This is not a valid OpenTelemetry trace ID.`);\n }\n if (!/^[0-9a-f]+$/.test(id)) {\n console.error(`Trace ID ${traceId} is not a valid hex string. Generating a random UUID instead.`);\n return newUUID();\n }\n\n return id.replace(/^(.{8})(.{4})(.{4})(.{4})(.{12})$/, '$1-$2-$3-$4-$5');\n}\n","import { Laminar } from \"./laminar\";\nimport { CreateEvaluationResponse, EvaluationDatapoint } from \"./types\";\n\nconst DEFAULT_BATCH_SIZE = 5;\n\n/**\n * Configuration for the Evaluator\n */\ninterface EvaluatorConfig {\n batchSize?: number;\n projectApiKey?: string;\n baseUrl?: string;\n}\n\nexport abstract class Dataset<D, T> {\n public slice(start: number, end: number): Datapoint<D, T>[] {\n const result = [];\n for (let i = Math.max(start, 0); i < Math.min(end, this.size()); i++) {\n result.push(this.get(i));\n }\n return result;\n }\n public abstract size(): number;\n public abstract get(index: number): Datapoint<D, T>;\n}\n\n/**\n * Datapoint is a single data point in the evaluation. `D` is the type of the input data, `T` is the type of the target data.\n */\nexport type Datapoint<D, T> = {\n /**\n * input to the executor function. Must be a record with string keys and any values.\n */\n data: Record<string, any> & D;\n /**\n * input to the evaluator function (alongside the executor output).\n * Must be a record with string keys and any values.\n */\n target: Record<string, any> & T;\n}\n\ntype EvaluatorFunctionReturn = number | Record<string, number>;\n\n/**\n * EvaluatorFunction is a function that takes the output of the executor and the target data, and returns a score.\n * The score can be a single number or a record of string keys and number values. The latter is useful for evaluating\n * multiple criteria in one go instead of running multiple evaluators.\n */\ntype EvaluatorFunction<O, T> = (output: O, target: T, ...args: any[]) => EvaluatorFunctionReturn | Promise<EvaluatorFunctionReturn>;\n\ninterface EvaluatorConstructorProps<D, T, O> {\n /**\n * List of data points to evaluate. `data` is the input to the executor function, `target` is the input to the evaluator function.\n */\n data: (Datapoint<D, T>[]) | Dataset<D, T>;\n /**\n * The executor function. Takes the data point + any additional arguments and returns the output to evaluate.\n */\n executor: (data: D, ...args: any[]) => O | Promise<O>;\n /**\n * List of evaluator functions. Each evaluator function takes the output of the executor _and_ the target data, and returns\n * a score. The score can be a single number or a record of string keys and number values.\n * If the score is a single number, it will be named after the evaluator function. If the function is anonymous, it will be named\n * `evaluator_${index}`, where index is the index of the evaluator function in the list starting from 1.\n */\n evaluators: EvaluatorFunction<O, T>[];\n /**\n * Optional override configurations for the evaluator.\n */\n config?: EvaluatorConfig;\n}\n\nexport class Evaluation<D, T, O> {\n private name: string;\n private data: Datapoint<D, T>[] | Dataset<D, T>;\n private executor: (data: D, ...args: any[]) => O | Promise<O>;\n private evaluators: Record<string, EvaluatorFunction<O, T>>;\n private evaluatorNames: string[];\n private batchSize: number = DEFAULT_BATCH_SIZE;\n\n /**\n * Create a new evaluation and prepare data.\n * @param name Name of the evaluation.\n * @param props.data List of data points to evaluate. `data` is the input to the executor function, `target` is the input to the evaluator function.\n * @param props.executor The executor function. Takes the data point + any additional arguments and returns the output to evaluate.\n * @param props.evaluators List of evaluator functions. Each evaluator function takes the output of the executor and the target data, and returns.\n */\n constructor(name: string, {\n data, executor, evaluators, config\n }: EvaluatorConstructorProps<D, T, O>) {\n this.name = name;\n this.data = data;\n this.executor = executor;\n this.evaluators = Object.fromEntries(evaluators.map((e, i) => [e.name.length > 0 ? e.name : `evaluator_${i + 1}`, e]));\n this.evaluatorNames = evaluators.map((e, i) => e.name.length > 0 ? e.name : `evaluator_${i + 1}`);\n if (config) {\n this.batchSize = config.batchSize ?? DEFAULT_BATCH_SIZE;\n }\n Laminar.initialize({ projectApiKey: config?.projectApiKey, baseUrl: config?.baseUrl });\n }\n\n /** \n * Runs the evaluation.\n *\n * Creates a new evaluation if no evaluation with such name exists, or adds data to an existing one otherwise.\n * Evaluates data points in batches of `batchSize`. The executor function is called on each data point\n * to get the output, and then evaluate it by each evaluator function.\n */\n public async run(): Promise<void> {\n const response = await Laminar.createEvaluation(this.name) as CreateEvaluationResponse;\n const length = this.data instanceof Dataset ? this.data.size() : this.data.length;\n for (let i = 0; i < length; i += this.batchSize) {\n const batch = this.data.slice(i, i + this.batchSize);\n try {\n await this.evaluateBatch(batch);\n } catch (e) {\n console.error(`Error evaluating batch: ${e}`);\n }\n }\n try {\n // After all batches are completed, update the evaluation status\n await Laminar.updateEvaluationStatus(response.name, 'Finished');\n } catch (e) {\n console.error(`Error updating evaluation status: ${e}`);\n }\n }\n \n private async evaluateBatch(batch: Datapoint<D, T>[]): Promise<void> {\n const batchPromises = batch.map(async (datapoint) => {\n const output = await this.executor(datapoint.data);\n const target = datapoint.target;\n \n let scores: Record<string, EvaluatorFunctionReturn> = {};\n for (const evaluatorName of this.evaluatorNames) {\n const evaluator = this.evaluators[evaluatorName];\n const value = await evaluator(output, target);\n \n // If the evaluator returns a single number, use the evaluator name as the key\n if (typeof value === 'number') {\n scores[evaluatorName] = value;\n } else {\n // If the evaluator returns an object, merge its keys with the existing scores (flatten)\n scores = { ...scores, ...value };\n }\n }\n \n return {\n executorOutput: output,\n data: datapoint.data,\n target,\n scores,\n } as EvaluationDatapoint<D, T, O>;\n });\n \n const results = await Promise.all(batchPromises);\n \n return Laminar.postEvaluationResults(this.name, results);\n }\n \n}\n","import { withEntity } from './sdk/node-server-sdk'\n\ninterface ObserveOptions {\n name?: string;\n sessionId?: string;\n userId?: string;\n}\n\n/**\n * The main decorator entrypoint for Laminar. This is used to wrap\n * functions and methods to create spans.\n *\n * @param name - Name of the span. Function name is used if not specified.\n * @param user_id - User ID to associate with the span and the following context.\n * @param session_id - Session ID to associate with the span and the following context.\n * @returns Returns the result of the wrapped function.\n * @throws Exception - Re-throws the exception if the wrapped function throws an exception.\n * \n * @example\n * ```typescript\n * import { observe } from '@lmnr-ai/lmnr';\n * \n * await observe({ name: 'my_function' }, () => {\n * // Your code here\n * });\n */\nexport async function observe<A extends unknown[], F extends (...args: A) => ReturnType<F>>(\n {\n name,\n sessionId,\n userId,\n }: ObserveOptions, fn: F, ...args: A): Promise<ReturnType<F>> {\n\n let associationProperties = {};\n if (sessionId) {\n associationProperties = { ...associationProperties, \"session_id\": sessionId };\n }\n if (userId) {\n associationProperties = { ...associationProperties, \"user_id\": userId };\n }\n\n return await withEntity<A, F>({ name: name ?? fn.name, associationProperties }, fn, undefined, ...args);\n}\n"],"mappings":"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","names":["context","trace","diag","diag","context","SpanAttributes","context","SpanAttributes","context","trace","SpanAttributes","context","OTLPTraceExporter","OTLPTraceExporter","trace","context"]}
1
+ {"version":3,"sources":["../package.json","../src/laminar.ts","../src/sdk/errors/index.ts","../src/sdk/tracing/index.ts","../src/sdk/tracing/tracing.ts","../src/sdk/telemetry/telemetry.ts","../src/sdk/configuration/index.ts","../src/sdk/tracing/decorators.ts","../src/sdk/tracing/manual.ts","../src/sdk/tracing/association.ts","../src/utils.ts","../src/evaluations.ts","../src/decorators.ts"],"sourcesContent":["{\n \"name\": \"@lmnr-ai/lmnr\",\n \"version\": \"0.4.9-alpha\",\n \"description\": \"TypeScript SDK for Laminar AI\",\n \"main\": \"dist/index.js\",\n \"types\": \"dist/index.d.ts\",\n \"scripts\": {\n \"build\": \"tsup src/index.ts --format esm,cjs --dts\",\n \"test\": \"echo \\\"Error: no test specified\\\" && exit 1\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git+https://github.com/lmnr-ai/lmnr-ts.git\"\n },\n \"keywords\": [\n \"laminar\",\n \"lmnr\",\n \"sdk\",\n \"lmnr.ai\"\n ],\n \"author\": \"founders@lmnr.ai\",\n \"license\": \"Apache-2.0\",\n \"bugs\": {\n \"url\": \"https://github.com/lmnr-ai/lmnr-ts/issues\"\n },\n \"homepage\": \"https://github.com/lmnr-ai/lmnr-ts#README\",\n \"devDependencies\": {\n \"@anthropic-ai/sdk\": \"^0.27.3\",\n \"@aws-sdk/client-bedrock-runtime\": \"^3.649.0\",\n \"@azure/openai\": \"2.0.0-beta.2\",\n \"@google-cloud/aiplatform\": \"^3.29.0\",\n \"@google-cloud/vertexai\": \"^1.7.0\",\n \"@langchain/core\": \"^0.2.32\",\n \"@pinecone-database/pinecone\": \"^3.0.2\",\n \"@qdrant/js-client-rest\": \"^1.11.0\",\n \"@types/node\": \"^22.5.4\",\n \"@types/uuid\": \"^10.0.0\",\n \"bufferutil\": \"^4.0.8\",\n \"chromadb\": \"^1.8.1\",\n \"cohere-ai\": \"^7.13.0\",\n \"langchain\": \"^0.2.18\",\n \"llamaindex\": \"^0.5.23\",\n \"openai\": \"^4.58.2\",\n \"runnables\": \"link:@langchain/core/runnables\",\n \"tsup\": \"^8.2.4\",\n \"typescript\": \"^5.5.4\",\n \"vectorstores\": \"link:@langchain/core/vectorstores\"\n },\n \"dependencies\": {\n \"@grpc/grpc-js\": \"^1.11.2\",\n \"@opentelemetry/api\": \"^1.9.0\",\n \"@opentelemetry/core\": \"^1.26.0\",\n \"@opentelemetry/exporter-trace-otlp-grpc\": \"^0.53.0\",\n \"@opentelemetry/exporter-trace-otlp-proto\": \"^0.53.0\",\n \"@opentelemetry/instrumentation\": \"^0.53.0\",\n \"@opentelemetry/resources\": \"^1.26.0\",\n \"@opentelemetry/sdk-node\": \"^0.53.0\",\n \"@opentelemetry/sdk-trace-base\": \"^1.26.0\",\n \"@opentelemetry/sdk-trace-node\": \"^1.26.0\",\n \"@opentelemetry/semantic-conventions\": \"^1.27.0\",\n \"@traceloop/ai-semantic-conventions\": \"^0.11.0\",\n \"@traceloop/instrumentation-anthropic\": \"^0.11.1\",\n \"@traceloop/instrumentation-azure\": \"^0.11.1\",\n \"@traceloop/instrumentation-bedrock\": \"^0.11.1\",\n \"@traceloop/instrumentation-chromadb\": \"^0.11.1\",\n \"@traceloop/instrumentation-cohere\": \"^0.11.1\",\n \"@traceloop/instrumentation-langchain\": \"^0.11.1\",\n \"@traceloop/instrumentation-llamaindex\": \"^0.11.1\",\n \"@traceloop/instrumentation-openai\": \"^0.11.1\",\n \"@traceloop/instrumentation-pinecone\": \"^0.11.1\",\n \"@traceloop/instrumentation-qdrant\": \"^0.11.1\",\n \"@traceloop/instrumentation-vertexai\": \"^0.11.1\",\n \"posthog-node\": \"^4.2.0\",\n \"uuid\": \"^10.0.0\"\n }\n}","import { PipelineRunResponse, PipelineRunRequest, EvaluationDatapoint, EvaluationStatus } from './types';\nimport { Attributes, AttributeValue, context, createContextKey, isSpanContextValid, TimeInput, trace } from '@opentelemetry/api';\nimport { InitializeOptions, initialize as traceloopInitialize } from './sdk/node-server-sdk'\nimport { otelSpanIdToUUID, otelTraceIdToUUID } from './utils';\nimport { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-grpc';\nimport { Metadata } from '@grpc/grpc-js';\nimport { ASSOCIATION_PROPERTIES_KEY } from './sdk/tracing/tracing';\nimport { forceFlush } from './sdk/node-server-sdk';\n\n// quick patch to get the traceloop's default tracer, since their \n// `getTracer` function is not exported.\n// Another option would be to import directly \n// like so: `import { getTracer } from '@traceloop/node-server-sdk/dist/src/lib/tracing/tracing';`\n// which isn't too nice either.\nconst DEFAULT_TRACER_NAME = 'traceloop.tracer';\n\ninterface LaminarInitializeProps {\n projectApiKey?: string;\n env?: Record<string, string>;\n baseUrl?: string;\n instrumentModules?: InitializeOptions[\"instrumentModules\"];\n}\n\nexport class Laminar {\n private static baseUrl: string = 'https://api.lmnr.ai:8443';\n private static projectApiKey: string;\n private static env: Record<string, string> = {};\n private static isInitialized: boolean = false;\n\n /**\n * Initialize Laminar context across the application.\n * This method must be called before using any other Laminar methods or decorators.\n *\n * @param project_api_key - Laminar project api key. You can generate one by going\n * to the projects settings page on the Laminar dashboard.\n * If not specified, it will try to read from the LMNR_PROJECT_API_KEY environment variable.\n * @param env - Default environment passed to `run` and `evaluateEvent` requests,\n * unless overriden at request time. Usually, model provider keys are stored here.\n * @param baseUrl - Url of Laminar endpoint, or the custom open telemetry ingester.\n * If not specified, defaults to https://api.lmnr.ai:8443. For locally hosted Laminar,\n * default setting must be http://localhost:8001.\n * @param instrumentModules - List of modules to instrument.\n * If not specified, all auto-instrumentable modules will be instrumented, which include\n * LLM calls (OpenAI, Anthropic, etc), Langchain, VectorDB calls (Pinecone, Qdrant, etc).\n * Pass an empty object {} to disable any kind of automatic instrumentation.\n * If you only want to auto-instrument specific modules, then pass them in the object.\n * \n * Example:\n * ```typescript\n * import { Laminar as L } from '@lmnr-ai/lmnr';\n * import { OpenAI } from 'openai';\n * import * as ChainsModule from \"langchain/chains\";\n * \n * // Initialize Laminar while auto-instrumenting Langchain and OpenAI modules.\n * L.initialize({ projectApiKey: \"<LMNR_PROJECT_API_KEY>\", instrumentModules: {\n * langchain: {\n * chainsModule: ChainsModule\n * },\n * openAI: OpenAI\n * } });\n * ```\n *\n * @throws {Error} - If project API key is not set\n */\n public static initialize({\n projectApiKey,\n env,\n baseUrl,\n instrumentModules\n }: LaminarInitializeProps) {\n\n let key = projectApiKey ?? process.env.LMNR_PROJECT_API_KEY;\n if (key === undefined) {\n throw new Error(\n 'Please initialize the Laminar object with your project API key ' +\n 'or set the LMNR_PROJECT_API_KEY environment variable'\n );\n }\n this.projectApiKey = key;\n if (baseUrl) {\n this.baseUrl = baseUrl;\n }\n this.isInitialized = true;\n this.env = env ?? {};\n\n const metadata = new Metadata();\n metadata.set('authorization', `Bearer ${this.projectApiKey}`);\n const exporter = new OTLPTraceExporter({\n url: this.baseUrl,\n metadata,\n });\n\n traceloopInitialize({\n exporter,\n silenceInitializationMessage: true,\n instrumentModules,\n disableBatch: false,\n });\n }\n\n /**\n * Check if Laminar has been initialized. Utility to make sure other methods\n * are called after initialization.\n */\n public static initialized(): boolean {\n return this.isInitialized;\n }\n\n /**\n * Sets the environment that will be sent to Laminar requests.\n * \n * @param env - The environment variables to override. If not provided, the current environment will not be modified.\n */\n public static setEnv(env?: Record<string, string>) {\n if (env) {\n this.env = env;\n }\n }\n\n /**\n * Sets the project API key for authentication with Laminar.\n *\n * @param projectApiKey - The API key to be set. If not provided, the existing API key will not be modified.\n */\n public static setProjectApiKey(projectApiKey?: string) {\n if (projectApiKey) {\n this.projectApiKey = projectApiKey;\n }\n }\n\n /**\n * Runs the pipeline with the given inputs\n *\n * @param pipeline - The name of the Laminar pipeline. Pipeline must have a target version.\n * @param inputs - The inputs for the pipeline. Map from an input node name to input data.\n * @param env - The environment variables for the pipeline execution. Typically used for model provider keys.\n * @param metadata - Additional metadata for the pipeline run.\n * @param currentSpanId - The ID of the current span.\n * @param currentTraceId - The ID of the current trace.\n * @returns A promise that resolves to the response of the pipeline run.\n * @throws An error if the Laminar object is not initialized with a project API key. Or if the request fails.\n */\n public static async run({\n pipeline,\n inputs,\n env,\n metadata = {},\n currentSpanId,\n currentTraceId,\n }: PipelineRunRequest): Promise<PipelineRunResponse> {\n const currentSpan = trace.getActiveSpan();\n let parentSpanId: string | undefined;\n let traceId: string | undefined;\n if (currentSpan !== undefined && isSpanContextValid(currentSpan.spanContext())) {\n parentSpanId = currentSpanId ?? otelSpanIdToUUID(currentSpan.spanContext().spanId);\n traceId = currentTraceId ?? otelTraceIdToUUID(currentSpan.spanContext().traceId);\n } else {\n parentSpanId = currentSpanId;\n traceId = currentTraceId;\n }\n if (this.projectApiKey === undefined) {\n throw new Error(\n 'Please initialize the Laminar object with your project API key ' +\n 'or set the LMNR_PROJECT_API_KEY environment variable'\n );\n }\n const envirionment = env === undefined ? this.env : env;\n\n const response = await fetch(`${this.baseUrl}/v1/pipeline/run`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify({\n inputs,\n pipeline,\n env: envirionment,\n metadata,\n parentSpanId,\n traceId,\n })\n });\n\n if (!response.ok) {\n throw new Error(`Failed to run pipeline ${pipeline}. Response: ${response.statusText}`);\n }\n try {\n return await response.json() as PipelineRunResponse;\n } catch (error) {\n throw new Error(`Failed to parse response from pipeline ${pipeline}. Error: ${error}`);\n }\n }\n\n /**\n * Associates an event with the current span. If event with such name never\n * existed, Laminar will create a new event and infer its type from the value.\n * If the event already exists, Laminar will append the value to the event\n * if and only if the value is of a matching type. Otherwise, the event won't\n * be recorded. Supported types are string, number, and boolean. If the value\n * is `null`, event is considered a boolean tag with the value of `true`.\n *\n * @param name - The name of the event.\n * @param value - The value of the event. Must be a primitive type. If not specified, boolean true is assumed in the backend.\n * @param timestamp - The timestamp of the event. If not specified, relies on the underlying OpenTelemetry implementation.\n * If specified as an integer, it must be epoch nanoseconds.\n */\n public static event(\n name: string,\n value?: AttributeValue,\n timestamp?: TimeInput,\n ) {\n const currentSpan = trace.getActiveSpan();\n if (currentSpan === undefined || !isSpanContextValid(currentSpan.spanContext())) {\n console.warn(\"Laminar().event()\\` called outside of span context.\" +\n ` Event '${name}' will not be recorded in the trace.` +\n \" Make sure to annotate the function with a decorator\"\n );\n return;\n }\n\n const event: Attributes = {\n \"lmnr.event.type\": \"default\",\n }\n if (value !== undefined) {\n event[\"lmnr.event.value\"] = value;\n }\n\n currentSpan.addEvent(name, event, timestamp);\n }\n\n /**\n * Sends an event for evaluation to the Laminar backend.\n * \n * @param name - The name of the event.\n * @param evaluator - The name of the pipeline that evaluates the event.\n * @param data - A map from input node name to its value in the evaluator pipeline.\n * @param env - Environment variables required to run the pipeline.\n * @param timestamp - If specified as an integer, it must be epoch nanoseconds.\n * If not specified, relies on the underlying OpenTelemetry implementation.\n */\n public static evaluateEvent(\n name: string,\n evaluator: string,\n data: Record<string, any>,\n env?: Record<string, string>,\n timestamp?: TimeInput,\n ) {\n const currentSpan = trace.getActiveSpan();\n\n if (currentSpan === undefined || !isSpanContextValid(currentSpan.spanContext())) {\n console.warn(\"Laminar().evaluateEvent()\\` called outside of span context.\" +\n ` Evaluate event '${name}' will not be recorded in the trace.` +\n \" Make sure to annotate the function with a decorator\"\n );\n return;\n }\n\n const event = {\n \"lmnr.event.type\": \"evaluate\",\n \"lmnr.event.evaluator\": evaluator,\n \"lmnr.event.data\": JSON.stringify(data),\n \"lmnr.event.env\": JSON.stringify(env ?? {}),\n }\n\n currentSpan.addEvent(name, event, timestamp);\n }\n\n /**\n * Sets the session information for the current span and returns the context to use for the following spans.\n * \n * Example:\n * ```typescript\n * import { context as contextApi } from '@opentelemetry/api';\n * import { Laminar } from '@lmnr-ai/laminar';\n * const context = Laminar.contextWithSession({ sessionId: \"1234\", userId: \"5678\" });\n * contextApi.with(context, () => {\n * // Your code here\n * });\n * ```\n * \n * @param sessionId - The session ID to associate with the span.\n * @param userId - The user ID to associate with the span.\n * @returns The updated context with the association properties.\n */\n public static contextWithSession({ sessionId, userId }: { sessionId?: string, userId?: string }) {\n\n const currentSpan = trace.getActiveSpan();\n if (currentSpan !== undefined && isSpanContextValid(currentSpan.spanContext())) {\n if (sessionId) {\n currentSpan.setAttribute(\"traceloop.association.properties.session_id\", sessionId);\n }\n if (userId) {\n currentSpan.setAttribute(\"traceloop.association.properties.user_id\", userId);\n }\n }\n let associationProperties = {};\n if (sessionId) {\n associationProperties = { ...associationProperties, \"session_id\": sessionId };\n }\n if (userId) {\n associationProperties = { ...associationProperties, \"user_id\": userId };\n }\n\n let entityContext = context.active();\n const currentAssociationProperties = entityContext.getValue(ASSOCIATION_PROPERTIES_KEY);\n if (associationProperties) {\n entityContext = entityContext.setValue(\n ASSOCIATION_PROPERTIES_KEY,\n { ...(currentAssociationProperties ?? {}), ...associationProperties },\n );\n }\n\n return entityContext;\n }\n\n public static async shutdown() {\n await forceFlush();\n }\n\n public static async createEvaluation(name: string) {\n const response = await fetch(`${this.baseUrl}/v1/evaluations`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify({\n name,\n })\n });\n\n return await response.json();\n }\n\n public static async postEvaluationResults<D, T, O>(\n evaluationName: string,\n data: EvaluationDatapoint<D, T, O>[]\n ): Promise<void> {\n const body = JSON.stringify({\n name: evaluationName,\n points: data,\n });\n const headers = this.getHeaders();\n const url = `${this.baseUrl}/v1/evaluation-datapoints`;\n try {\n const response = await fetch(url, {\n method: \"POST\",\n headers,\n body,\n });\n if (!response.ok) {\n console.error(\"Failed to send evaluation results. Response: \");\n response.text().then((text) => console.error(text));\n }\n } catch (error) {\n console.error(\"Failed to send evaluation results. Error: \", error);\n };\n }\n\n public static async updateEvaluationStatus(\n evaluationName: string,\n status: EvaluationStatus,\n ): Promise<void> {\n const body = JSON.stringify({\n name: evaluationName,\n status,\n });\n const headers = this.getHeaders();\n const url = `${this.baseUrl}/v1/evaluations`;\n try {\n const response = await fetch(url, {\n method: \"PUT\",\n headers,\n body,\n });\n if (!response.ok) {\n console.error(\"Failed to update evaluation status. Response: \");\n response.text().then((text) => console.error(text));\n }\n } catch (error) {\n console.error(\"Failed to update evaluation status. Error: \", error);\n }\n }\n\n private static getHeaders() {\n return {\n \"Content-Type\": \"application/json\",\n \"Authorization\": `Bearer ${this.projectApiKey}`,\n };\n };\n}\n","/**\n * The severity of an error.\n */\nexport const SEVERITY = {\n Warning: \"Warning\",\n Error: \"Error\",\n Critical: \"Critical\",\n} as const;\n\nexport type Severity = (typeof SEVERITY)[keyof typeof SEVERITY];\n\n/**\n * Base class for all Traceloop errors.\n */\nexport class TraceloopError extends Error {\n /**\n * The severity of the error.\n */\n severity: Severity;\n /**\n * The underlying cause of the error.\n */\n underlyingCause?: Error;\n\n constructor(message: string, severity: Severity = SEVERITY.Error) {\n super(message);\n this.severity = severity;\n }\n}\n\nexport class NotInitializedError extends TraceloopError {\n constructor() {\n super(\n `The Traceloop SDK must be initialized by calling the \"initialize\" function prior to use.`,\n SEVERITY.Critical,\n );\n }\n}\n\nexport class InitializationError extends TraceloopError {\n constructor(message?: string, cause?: Error) {\n super(message ?? \"Failed to initialize Traceloop SDK\", SEVERITY.Critical);\n this.underlyingCause = cause;\n }\n}\n\nexport class ArgumentNotProvidedError extends TraceloopError {\n constructor(argumentName: string) {\n super(`The \"${argumentName}\" argument is required and must be a string.`);\n }\n}\n\nexport class PromptNotFoundError extends TraceloopError {\n constructor(key: string) {\n super(`The prompt \"${key}\" was not found in the registry.`);\n }\n}\n","/* eslint-disable @typescript-eslint/no-var-requires */\nimport { NodeSDK } from \"@opentelemetry/sdk-node\";\nimport {\n SimpleSpanProcessor,\n BatchSpanProcessor,\n SpanProcessor,\n} from \"@opentelemetry/sdk-trace-node\";\nimport { baggageUtils } from \"@opentelemetry/core\";\nimport { Span, context, diag } from \"@opentelemetry/api\";\nimport { OTLPTraceExporter } from \"@opentelemetry/exporter-trace-otlp-proto\";\nimport { Resource } from \"@opentelemetry/resources\";\nimport { SEMRESATTRS_SERVICE_NAME } from \"@opentelemetry/semantic-conventions\";\nimport { Instrumentation } from \"@opentelemetry/instrumentation\";\nimport { InitializeOptions } from \"../interfaces\";\nimport {\n Detector,\n DetectorSync,\n IResource,\n ResourceDetectionConfig,\n envDetectorSync,\n hostDetectorSync,\n processDetectorSync,\n} from \"@opentelemetry/resources\"\nimport {\n ASSOCIATION_PROPERTIES_KEY,\n} from \"./tracing\";\nimport { Telemetry } from \"../telemetry/telemetry\";\nimport { _configuration } from \"../configuration\";\nimport {\n SpanAttributes,\n} from \"@traceloop/ai-semantic-conventions\";\nimport { AnthropicInstrumentation } from \"@traceloop/instrumentation-anthropic\";\nimport { OpenAIInstrumentation } from \"@traceloop/instrumentation-openai\";\nimport { AzureOpenAIInstrumentation } from \"@traceloop/instrumentation-azure\";\nimport { LlamaIndexInstrumentation } from \"@traceloop/instrumentation-llamaindex\";\nimport {\n AIPlatformInstrumentation,\n VertexAIInstrumentation,\n} from \"@traceloop/instrumentation-vertexai\";\nimport { BedrockInstrumentation } from \"@traceloop/instrumentation-bedrock\";\nimport { CohereInstrumentation } from \"@traceloop/instrumentation-cohere\";\nimport { PineconeInstrumentation } from \"@traceloop/instrumentation-pinecone\";\nimport { LangChainInstrumentation } from \"@traceloop/instrumentation-langchain\";\nimport { ChromaDBInstrumentation } from \"@traceloop/instrumentation-chromadb\";\nimport { QdrantInstrumentation } from \"@traceloop/instrumentation-qdrant\";\n\nlet _sdk: NodeSDK;\nlet _spanProcessor: SimpleSpanProcessor | BatchSpanProcessor;\nlet openAIInstrumentation: OpenAIInstrumentation | undefined;\nlet anthropicInstrumentation: AnthropicInstrumentation | undefined;\nlet azureOpenAIInstrumentation: AzureOpenAIInstrumentation | undefined;\nlet cohereInstrumentation: CohereInstrumentation | undefined;\nlet vertexaiInstrumentation: VertexAIInstrumentation | undefined;\nlet aiplatformInstrumentation: AIPlatformInstrumentation | undefined;\nlet bedrockInstrumentation: BedrockInstrumentation | undefined;\nlet langchainInstrumentation: LangChainInstrumentation | undefined;\nlet llamaIndexInstrumentation: LlamaIndexInstrumentation | undefined;\nlet pineconeInstrumentation: PineconeInstrumentation | undefined;\nlet chromadbInstrumentation: ChromaDBInstrumentation | undefined;\nlet qdrantInstrumentation: QdrantInstrumentation | undefined;\n\n\nconst instrumentations: Instrumentation[] = [];\n\nconst initInstrumentations = () => {\n const exceptionLogger = (e: Error) => Telemetry.getInstance().logException(e);\n const enrichTokens =\n (process.env.TRACELOOP_ENRICH_TOKENS || \"true\").toLowerCase() === \"true\";\n\n openAIInstrumentation = new OpenAIInstrumentation({\n enrichTokens,\n exceptionLogger,\n });\n instrumentations.push(openAIInstrumentation);\n\n anthropicInstrumentation = new AnthropicInstrumentation({ exceptionLogger });\n instrumentations.push(anthropicInstrumentation);\n\n azureOpenAIInstrumentation = new AzureOpenAIInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(azureOpenAIInstrumentation);\n\n cohereInstrumentation = new CohereInstrumentation({ exceptionLogger });\n instrumentations.push(cohereInstrumentation);\n\n vertexaiInstrumentation = new VertexAIInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(vertexaiInstrumentation);\n\n aiplatformInstrumentation = new AIPlatformInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(aiplatformInstrumentation);\n\n bedrockInstrumentation = new BedrockInstrumentation({ exceptionLogger });\n instrumentations.push(bedrockInstrumentation);\n\n pineconeInstrumentation = new PineconeInstrumentation({ exceptionLogger });\n instrumentations.push(pineconeInstrumentation);\n\n langchainInstrumentation = new LangChainInstrumentation({ exceptionLogger });\n instrumentations.push(langchainInstrumentation);\n\n llamaIndexInstrumentation = new LlamaIndexInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(llamaIndexInstrumentation);\n\n chromadbInstrumentation = new ChromaDBInstrumentation({ exceptionLogger });\n instrumentations.push(chromadbInstrumentation);\n\n qdrantInstrumentation = new QdrantInstrumentation({ exceptionLogger });\n instrumentations.push(qdrantInstrumentation);\n};\n\nconst manuallyInitInstrumentations = (\n instrumentModules: InitializeOptions[\"instrumentModules\"],\n) => {\n const exceptionLogger = (e: Error) => Telemetry.getInstance().logException(e);\n const enrichTokens =\n (process.env.TRACELOOP_ENRICH_TOKENS || \"true\").toLowerCase() === \"true\";\n\n instrumentations.length = 0;\n\n if (instrumentModules?.openAI) {\n openAIInstrumentation = new OpenAIInstrumentation({\n enrichTokens,\n exceptionLogger,\n });\n instrumentations.push(openAIInstrumentation);\n openAIInstrumentation.manuallyInstrument(instrumentModules.openAI);\n }\n\n if (instrumentModules?.anthropic) {\n anthropicInstrumentation = new AnthropicInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(anthropicInstrumentation);\n anthropicInstrumentation.manuallyInstrument(instrumentModules.anthropic);\n }\n\n if (instrumentModules?.azureOpenAI) {\n const instrumentation = new AzureOpenAIInstrumentation({ exceptionLogger });\n instrumentations.push(instrumentation as Instrumentation);\n azureOpenAIInstrumentation = instrumentation;\n instrumentation.manuallyInstrument(instrumentModules.azureOpenAI);\n }\n\n if (instrumentModules?.cohere) {\n cohereInstrumentation = new CohereInstrumentation({ exceptionLogger });\n instrumentations.push(cohereInstrumentation);\n cohereInstrumentation.manuallyInstrument(instrumentModules.cohere);\n }\n\n if (instrumentModules?.google_vertexai) {\n vertexaiInstrumentation = new VertexAIInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(vertexaiInstrumentation);\n vertexaiInstrumentation.manuallyInstrument(\n instrumentModules.google_vertexai,\n );\n }\n\n if (instrumentModules?.google_aiplatform) {\n aiplatformInstrumentation = new AIPlatformInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(aiplatformInstrumentation);\n aiplatformInstrumentation.manuallyInstrument(\n instrumentModules.google_aiplatform,\n );\n }\n\n if (instrumentModules?.bedrock) {\n bedrockInstrumentation = new BedrockInstrumentation({ exceptionLogger });\n instrumentations.push(bedrockInstrumentation);\n bedrockInstrumentation.manuallyInstrument(instrumentModules.bedrock);\n }\n\n if (instrumentModules?.pinecone) {\n const instrumentation = new PineconeInstrumentation({ exceptionLogger });\n instrumentations.push(instrumentation as Instrumentation);\n instrumentation.manuallyInstrument(instrumentModules.pinecone);\n }\n\n if (instrumentModules?.langchain) {\n langchainInstrumentation = new LangChainInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(langchainInstrumentation);\n langchainInstrumentation.manuallyInstrument(instrumentModules.langchain);\n }\n\n if (instrumentModules?.llamaIndex) {\n llamaIndexInstrumentation = new LlamaIndexInstrumentation({\n exceptionLogger,\n });\n instrumentations.push(llamaIndexInstrumentation);\n llamaIndexInstrumentation.manuallyInstrument(instrumentModules.llamaIndex);\n }\n\n if (instrumentModules?.chromadb) {\n chromadbInstrumentation = new ChromaDBInstrumentation({ exceptionLogger });\n instrumentations.push(chromadbInstrumentation);\n chromadbInstrumentation.manuallyInstrument(instrumentModules.chromadb);\n }\n\n if (instrumentModules?.qdrant) {\n qdrantInstrumentation = new QdrantInstrumentation({ exceptionLogger });\n instrumentations.push(qdrantInstrumentation);\n qdrantInstrumentation.manuallyInstrument(instrumentModules.qdrant);\n }\n};\n\nfunction awaitAttributes(detector: DetectorSync): Detector {\n return {\n async detect(config?: ResourceDetectionConfig): Promise<IResource> {\n const resource = detector.detect(config)\n await resource.waitForAsyncAttributes?.()\n\n return resource\n },\n }\n}\n\n/**\n * Initializes the Traceloop SDK.\n * Must be called once before any other SDK methods.\n *\n * @param options - The options to initialize the SDK. See the {@link InitializeOptions} for details.\n */\nexport const startTracing = (options: InitializeOptions) => {\n if (options.instrumentModules !== undefined) {\n // If options.instrumentModules is empty, it will not initialize anything,\n // so empty dict can essentially be passed to disable any kind of automatic instrumentation.\n manuallyInitInstrumentations(options.instrumentModules);\n } else {\n initInstrumentations();\n }\n\n if (!shouldSendTraces()) {\n openAIInstrumentation?.setConfig({\n traceContent: false,\n });\n azureOpenAIInstrumentation?.setConfig({\n traceContent: false,\n });\n llamaIndexInstrumentation?.setConfig({\n traceContent: false,\n });\n vertexaiInstrumentation?.setConfig({\n traceContent: false,\n });\n aiplatformInstrumentation?.setConfig({\n traceContent: false,\n });\n bedrockInstrumentation?.setConfig({\n traceContent: false,\n });\n cohereInstrumentation?.setConfig({\n traceContent: false,\n });\n chromadbInstrumentation?.setConfig({\n traceContent: false,\n });\n }\n\n const headers = process.env.TRACELOOP_HEADERS\n ? baggageUtils.parseKeyPairsIntoRecord(process.env.TRACELOOP_HEADERS)\n : { Authorization: `Bearer ${options.apiKey}` };\n\n const traceExporter =\n options.exporter ??\n new OTLPTraceExporter({\n url: `${options.baseUrl}/v1/traces`,\n headers,\n });\n _spanProcessor = options.disableBatch\n ? new SimpleSpanProcessor(traceExporter)\n : new BatchSpanProcessor(traceExporter);\n\n _spanProcessor.onStart = (span: Span) => {\n // This sets the properties only if the context has them\n const associationProperties = context\n .active()\n .getValue(ASSOCIATION_PROPERTIES_KEY);\n if (associationProperties) {\n for (const [key, value] of Object.entries(associationProperties)) {\n span.setAttribute(\n `${SpanAttributes.TRACELOOP_ASSOCIATION_PROPERTIES}.${key}`,\n value,\n );\n }\n }\n };\n\n if (options.exporter) {\n Telemetry.getInstance().capture(\"tracer:init\", {\n exporter: \"custom\",\n processor: options.disableBatch ? \"simple\" : \"batch\",\n });\n } else {\n Telemetry.getInstance().capture(\"tracer:init\", {\n exporter: options.baseUrl ?? \"\",\n processor: options.disableBatch ? \"simple\" : \"batch\",\n });\n }\n\n const spanProcessors: SpanProcessor[] = [_spanProcessor];\n if (options.processor) {\n spanProcessors.push(options.processor);\n }\n\n _sdk = new NodeSDK({\n resource: new Resource({\n [SEMRESATTRS_SERVICE_NAME]:\n options.appName || process.env.npm_package_name,\n }),\n spanProcessors,\n contextManager: options.contextManager,\n textMapPropagator: options.propagator,\n traceExporter,\n instrumentations,\n // We should re-consider removing irrelevant spans here in the future\n // sampler: new TraceloopSampler(),\n resourceDetectors: [\n awaitAttributes(envDetectorSync),\n awaitAttributes(processDetectorSync),\n awaitAttributes(hostDetectorSync),\n ],\n });\n\n _sdk.start();\n};\n\nexport const shouldSendTraces = () => {\n if (!_configuration) {\n diag.warn(\"Traceloop not initialized\");\n return false;\n }\n\n if (\n _configuration.traceContent === false ||\n (process.env.TRACELOOP_TRACE_CONTENT || \"true\").toLowerCase() === \"false\"\n ) {\n return false;\n }\n\n return true;\n};\n\nexport const forceFlush = async () => {\n await _spanProcessor.forceFlush();\n};\n","import { trace, createContextKey } from \"@opentelemetry/api\";\nimport { Context } from \"@opentelemetry/api/build/src/context/types\";\n\nconst TRACER_NAME = \"traceloop.tracer\";\nexport const WORKFLOW_NAME_KEY = createContextKey(\"workflow_name\");\nexport const ENTITY_NAME_KEY = createContextKey(\"entity_name\");\nexport const ASSOCIATION_PROPERTIES_KEY = createContextKey(\n \"association_properties\",\n);\n\nexport const getTracer = () => {\n return trace.getTracer(TRACER_NAME);\n};\n\nexport const getEntityPath = (entityContext: Context): string | undefined => {\n const path = entityContext.getValue(ENTITY_NAME_KEY);\n\n return path ? `${path}` : undefined;\n};\n","import * as os from \"os\";\nimport * as fs from \"fs\";\nimport * as path from \"path\";\nimport { v4 as uuid } from \"uuid\";\nimport { PostHog } from \"posthog-node\";\nconst { version } = require('../../../package.json');\n\nexport class Telemetry {\n private static instance: Telemetry;\n\n private static readonly ANON_ID_PATH = `${os.homedir()}/.cache/lmnr/telemetry_anon_id`;\n private static readonly UNKNOWN_ANON_ID = \"UNKNOWN\";\n\n private telemetryEnabled: boolean;\n private posthog: PostHog | undefined;\n private anonId: string | undefined;\n\n public static getInstance(): Telemetry {\n if (!Telemetry.instance) {\n Telemetry.instance = new Telemetry();\n }\n return Telemetry.instance;\n }\n\n private constructor() {\n this.telemetryEnabled =\n !process.env.LMNR_TELEMETRY ||\n process.env.LMNR_TELEMETRY.toLowerCase() === \"true\";\n\n if (this.telemetryEnabled) {\n this.posthog = new PostHog(\n \"phc_dUMdjfNKf11jcHgtn7juSnT4P1pO0tafsPUWt4PuwG7\",\n );\n }\n }\n\n private getAnonId() {\n if (this.anonId) {\n return this.anonId;\n }\n\n try {\n if (!fs.existsSync(Telemetry.ANON_ID_PATH)) {\n fs.mkdirSync(path.dirname(Telemetry.ANON_ID_PATH), { recursive: true });\n const anonIdFile = fs.openSync(Telemetry.ANON_ID_PATH, \"w\");\n this.anonId = uuid();\n fs.writeSync(anonIdFile, this.anonId);\n fs.closeSync(anonIdFile);\n } else {\n const anonIdFile = fs.openSync(Telemetry.ANON_ID_PATH, \"r\");\n this.anonId = fs.readFileSync(anonIdFile, \"utf8\");\n fs.closeSync(anonIdFile);\n }\n return this.anonId;\n } catch (e) {\n return Telemetry.UNKNOWN_ANON_ID;\n }\n }\n\n private getContext() {\n return {\n sdk: \"typescript\",\n sdk_version: version,\n };\n }\n\n public capture(event: string, properties?: Record<string, string>) {\n if (this.telemetryEnabled && this.posthog) {\n this.posthog.capture({\n distinctId: this.getAnonId(),\n event,\n properties: {\n ...properties,\n ...this.getContext(),\n },\n });\n this.posthog.flush();\n }\n }\n\n public logException(error: Error) {\n if (this.telemetryEnabled) {\n this.capture(\"error\", { error: error.message, stack: error.stack || \"\" });\n }\n }\n}\n","import { InitializeOptions } from \"../interfaces\";\nimport { startTracing } from \"../tracing\";\nimport { diag, DiagConsoleLogger, DiagLogLevel } from \"@opentelemetry/api\";\nimport { InitializationError } from \"../errors\";\n\nexport let _configuration: InitializeOptions | undefined;\n\n/**\n * Initializes the SDK.\n * Must be called once before any other SDK methods.\n *\n * @param options - The options to initialize the SDK. See the {@link InitializeOptions} for details.\n * @throws {InitializationError} if the configuration is invalid or if failed to fetch feature data.\n */\nexport const initialize = (options: InitializeOptions) => {\n if (_configuration) {\n return;\n }\n\n if (!options.baseUrl) {\n options.baseUrl =\n process.env.LMNR_BASE_URL || \"https://api.lmnr.ai:8443\";\n }\n if (!options.apiKey) {\n options.apiKey = process.env.LMNR_PROJECT_API_KEY;\n }\n if (options.apiKey && typeof options.apiKey !== \"string\") {\n throw new InitializationError('\"apiKey\" must be a string');\n }\n\n if (!options.appName) {\n options.appName = process.env.npm_package_name;\n }\n\n _configuration = Object.freeze(options);\n\n if (options.logLevel) {\n diag.setLogger(\n new DiagConsoleLogger(),\n logLevelToOtelLogLevel(options.logLevel),\n );\n }\n\n if (!options.silenceInitializationMessage) {\n console.log(\n `Laminar exporting traces to ${\n _configuration.exporter ? \"a custom exporter\" : _configuration.baseUrl\n }`,\n );\n }\n\n startTracing(_configuration);\n};\n\nconst logLevelToOtelLogLevel = (\n logLevel: \"debug\" | \"info\" | \"warn\" | \"error\",\n) => {\n switch (logLevel) {\n case \"debug\":\n return DiagLogLevel.DEBUG;\n case \"info\":\n return DiagLogLevel.INFO;\n case \"warn\":\n return DiagLogLevel.WARN;\n case \"error\":\n return DiagLogLevel.ERROR;\n }\n};\n","import { Span, context } from \"@opentelemetry/api\";\nimport { suppressTracing } from \"@opentelemetry/core\";\nimport {\n ASSOCIATION_PROPERTIES_KEY,\n getTracer,\n} from \"./tracing\";\nimport {\n SpanAttributes,\n} from \"@traceloop/ai-semantic-conventions\";\nimport { shouldSendTraces } from \".\";\nimport { Telemetry } from \"../telemetry/telemetry\";\n\nexport type DecoratorConfig = {\n name: string;\n associationProperties?: { [name: string]: string };\n inputParameters?: unknown[];\n suppressTracing?: boolean;\n};\n\nexport function withEntity<\n A extends unknown[],\n F extends (...args: A) => ReturnType<F>,\n>(\n {\n name,\n associationProperties,\n inputParameters,\n suppressTracing: shouldSuppressTracing,\n }: DecoratorConfig,\n fn: F,\n thisArg?: ThisParameterType<F>,\n ...args: A\n) {\n let entityContext = context.active();\n\n const currentAssociationProperties = entityContext.getValue(ASSOCIATION_PROPERTIES_KEY);\n\n if (associationProperties) {\n entityContext = entityContext.setValue(\n ASSOCIATION_PROPERTIES_KEY,\n { ...(currentAssociationProperties ?? {}), ...associationProperties },\n );\n }\n\n if (shouldSuppressTracing) {\n entityContext = suppressTracing(entityContext);\n }\n\n return context.with(entityContext, () =>\n getTracer().startActiveSpan(\n name,\n {},\n entityContext,\n async (span: Span) => {\n if (shouldSendTraces()) {\n try {\n const input = inputParameters ?? args;\n if (\n input.length === 1 &&\n typeof input[0] === \"object\" &&\n !(input[0] instanceof Map)\n ) {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_INPUT,\n serialize({ args: [], kwargs: input[0] }),\n );\n } else {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_INPUT,\n serialize({\n args: input,\n kwargs: {},\n }),\n );\n }\n } catch (error) {\n Telemetry.getInstance().logException(error as any);\n }\n }\n\n const res = fn.apply(thisArg, args);\n if (res instanceof Promise) {\n return res.then((resolvedRes) => {\n try {\n if (shouldSendTraces()) {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_OUTPUT,\n serialize(resolvedRes),\n );\n }\n } catch (error) {\n Telemetry.getInstance().logException(error as any);\n } finally {\n span.end();\n }\n\n return resolvedRes;\n });\n }\n try {\n if (shouldSendTraces()) {\n span.setAttribute(\n SpanAttributes.TRACELOOP_ENTITY_OUTPUT,\n serialize(res),\n );\n }\n } catch (error) {\n Telemetry.getInstance().logException(error as any);\n } finally {\n span.end();\n }\n\n return res;\n },\n ),\n );\n}\n\nfunction cleanInput(input: unknown): unknown {\n if (input instanceof Map) {\n return Array.from(input.entries());\n } else if (Array.isArray(input)) {\n return input.map((value) => cleanInput(value));\n } else if (!input) {\n return input;\n } else if (typeof input === \"object\") {\n // serialize object one by one\n const output: any = {};\n Object.entries(input as any).forEach(([key, value]) => {\n output[key] = cleanInput(value);\n });\n return output;\n }\n\n return input;\n}\n\nfunction serialize(input: unknown): string {\n return JSON.stringify(cleanInput(input));\n}\n","import { Span, context, trace } from \"@opentelemetry/api\";\nimport { getTracer } from \"./tracing\";\nimport {\n Events,\n EventAttributes,\n SpanAttributes,\n} from \"@traceloop/ai-semantic-conventions\";\nimport { shouldSendTraces } from \".\";\n\ntype VectorDBCallConfig = {\n vendor: string;\n type: \"query\" | \"upsert\" | \"delete\";\n};\n\ntype LLMCallConfig = {\n vendor: string;\n type: \"chat\" | \"completion\";\n};\n\nexport class VectorSpan {\n private span: Span;\n\n constructor(span: Span) {\n this.span = span;\n }\n\n reportQuery({ queryVector }: { queryVector: number[] }) {\n if (!shouldSendTraces()) {\n this.span.addEvent(Events.DB_QUERY_EMBEDDINGS);\n }\n\n this.span.addEvent(Events.DB_QUERY_EMBEDDINGS, {\n [EventAttributes.DB_QUERY_EMBEDDINGS_VECTOR]: JSON.stringify(queryVector),\n });\n }\n\n reportResults({\n results,\n }: {\n results: {\n ids?: string;\n scores?: number;\n distances?: number;\n metadata?: Record<string, unknown>;\n vectors?: number[];\n documents?: string;\n }[];\n }) {\n for (let i = 0; i < results.length; i++) {\n this.span.addEvent(Events.DB_QUERY_RESULT, {\n [EventAttributes.DB_QUERY_RESULT_ID]: results[i].ids,\n [EventAttributes.DB_QUERY_RESULT_SCORE]: results[i].scores,\n [EventAttributes.DB_QUERY_RESULT_DISTANCE]: results[i].distances,\n [EventAttributes.DB_QUERY_RESULT_METADATA]: JSON.stringify(\n results[i].metadata,\n ),\n [EventAttributes.DB_QUERY_RESULT_VECTOR]: results[i].vectors,\n [EventAttributes.DB_QUERY_RESULT_DOCUMENT]: results[i].documents,\n });\n }\n }\n}\n\nexport class LLMSpan {\n private span: Span;\n\n constructor(span: Span) {\n this.span = span;\n }\n\n reportRequest({\n model,\n messages,\n }: {\n model: string;\n messages: {\n role: string;\n content?: string | unknown;\n }[];\n }) {\n this.span.setAttributes({\n [SpanAttributes.LLM_REQUEST_MODEL]: model,\n });\n\n messages.forEach((message, index) => {\n this.span.setAttributes({\n [`${SpanAttributes.LLM_PROMPTS}.${index}.role`]: message.role,\n [`${SpanAttributes.LLM_PROMPTS}.${index}.content`]:\n typeof message.content === \"string\"\n ? message.content\n : JSON.stringify(message.content),\n });\n });\n }\n\n reportResponse({\n model,\n usage,\n completions,\n }: {\n model: string;\n usage?: {\n prompt_tokens: number;\n completion_tokens: number;\n total_tokens: number;\n };\n completions?: {\n finish_reason: string;\n message: {\n role: \"system\" | \"user\" | \"assistant\";\n content: string | null;\n };\n }[];\n }) {\n this.span.setAttribute(SpanAttributes.LLM_RESPONSE_MODEL, model);\n\n if (usage) {\n this.span.setAttributes({\n [SpanAttributes.LLM_USAGE_PROMPT_TOKENS]: usage.prompt_tokens,\n [SpanAttributes.LLM_USAGE_COMPLETION_TOKENS]: usage.completion_tokens,\n [SpanAttributes.LLM_USAGE_TOTAL_TOKENS]: usage.total_tokens,\n });\n }\n\n completions?.forEach((completion, index) => {\n this.span.setAttributes({\n [`${SpanAttributes.LLM_COMPLETIONS}.${index}.finish_reason`]:\n completion.finish_reason,\n [`${SpanAttributes.LLM_COMPLETIONS}.${index}.role`]:\n completion.message.role,\n [`${SpanAttributes.LLM_COMPLETIONS}.${index}.content`]:\n completion.message.content || \"\",\n });\n });\n }\n}\n\nexport function withVectorDBCall<\n F extends ({ span }: { span: VectorSpan }) => ReturnType<F>,\n>({ vendor, type }: VectorDBCallConfig, fn: F, thisArg?: ThisParameterType<F>) {\n const entityContext = context.active();\n\n return getTracer().startActiveSpan(\n `${vendor}.${type}`,\n { [SpanAttributes.LLM_REQUEST_TYPE]: type },\n entityContext,\n (span: Span) => {\n const res = fn.apply(thisArg, [{ span: new VectorSpan(span) }]);\n if (res instanceof Promise) {\n return res.then((resolvedRes) => {\n span.end();\n return resolvedRes;\n });\n }\n\n span.end();\n return res;\n },\n );\n}\n\nexport function withLLMCall<\n F extends ({ span }: { span: LLMSpan }) => ReturnType<F>,\n>({ vendor, type }: LLMCallConfig, fn: F, thisArg?: ThisParameterType<F>) {\n const span = getTracer().startSpan(`${vendor}.${type}`, {}, context.active());\n span.setAttribute(SpanAttributes.LLM_REQUEST_TYPE, type);\n trace.setSpan(context.active(), span);\n\n const res = fn.apply(thisArg, [{ span: new LLMSpan(span) }]);\n if (res instanceof Promise) {\n return res.then((resolvedRes) => {\n span.end();\n return resolvedRes;\n });\n }\n\n span.end();\n return res;\n}\n","import { context } from \"@opentelemetry/api\";\nimport { ASSOCIATION_PROPERTIES_KEY } from \"./tracing\";\n\nexport function withAssociationProperties<\n A extends unknown[],\n F extends (...args: A) => ReturnType<F>,\n>(\n properties: { [name: string]: string },\n fn: F,\n thisArg?: ThisParameterType<F>,\n ...args: A\n) {\n if (Object.keys(properties).length === 0) {\n return fn.apply(thisArg, args);\n }\n\n const newContext = context\n .active()\n .setValue(ASSOCIATION_PROPERTIES_KEY, properties);\n return context.with(newContext, fn, thisArg, ...args);\n}\n","import { v4 as uuidv4 } from 'uuid';\n\nexport type StringUUID = `${string}-${string}-${string}-${string}-${string}`;\n\nexport const newUUID = (): StringUUID => {\n // crypto.randomUUID is available in most of the modern browsers and node,\n // but is not available in \"insecure\" contexts, e.g. not https, not localhost\n // so we fallback to uuidv4 in those cases, which is less secure, but works\n // just fine.\n if (typeof crypto !== 'undefined' && typeof crypto.randomUUID === 'function') {\n return crypto.randomUUID();\n } else {\n return uuidv4() as `${string}-${string}-${string}-${string}-${string}`;\n }\n}\n\nexport const otelSpanIdToUUID = (spanId: string): string => {\n let id = spanId.toLowerCase();\n if (id.startsWith('0x')) {\n id = id.slice(2);\n }\n if (id.length !== 16) {\n console.warn(`Span ID ${spanId} is not 16 hex chars long. This is not a valid OpenTelemetry span ID.`);\n }\n\n if (!/^[0-9a-f]+$/.test(id)) {\n console.error(`Span ID ${spanId} is not a valid hex string. Generating a random UUID instead.`);\n return newUUID();\n }\n\n return id.padStart(32, '0').replace(/^(.{8})(.{4})(.{4})(.{4})(.{12})$/, '$1-$2-$3-$4-$5');\n}\n\nexport const otelTraceIdToUUID = (traceId: string): string => {\n let id = traceId.toLowerCase();\n if (id.startsWith('0x')) {\n id = id.slice(2);\n }\n if (id.length !== 32) {\n console.warn(`Trace ID ${traceId} is not 32 hex chars long. This is not a valid OpenTelemetry trace ID.`);\n }\n if (!/^[0-9a-f]+$/.test(id)) {\n console.error(`Trace ID ${traceId} is not a valid hex string. Generating a random UUID instead.`);\n return newUUID();\n }\n\n return id.replace(/^(.{8})(.{4})(.{4})(.{4})(.{12})$/, '$1-$2-$3-$4-$5');\n}\n","import { Laminar } from \"./laminar\";\nimport { CreateEvaluationResponse, EvaluationDatapoint } from \"./types\";\n\nconst DEFAULT_BATCH_SIZE = 5;\n\n/**\n * Configuration for the Evaluator\n */\ninterface EvaluatorConfig {\n batchSize?: number;\n projectApiKey?: string;\n baseUrl?: string;\n}\n\nexport abstract class Dataset<D, T> {\n public slice(start: number, end: number): Datapoint<D, T>[] {\n const result = [];\n for (let i = Math.max(start, 0); i < Math.min(end, this.size()); i++) {\n result.push(this.get(i));\n }\n return result;\n }\n public abstract size(): number;\n public abstract get(index: number): Datapoint<D, T>;\n}\n\n/**\n * Datapoint is a single data point in the evaluation. `D` is the type of the input data, `T` is the type of the target data.\n */\nexport type Datapoint<D, T> = {\n /**\n * input to the executor function. Must be a record with string keys and any values.\n */\n data: Record<string, any> & D;\n /**\n * input to the evaluator function (alongside the executor output).\n * Must be a record with string keys and any values.\n */\n target: Record<string, any> & T;\n}\n\ntype EvaluatorFunctionReturn = number | Record<string, number>;\n\n/**\n * EvaluatorFunction is a function that takes the output of the executor and the target data, and returns a score.\n * The score can be a single number or a record of string keys and number values. The latter is useful for evaluating\n * multiple criteria in one go instead of running multiple evaluators.\n */\ntype EvaluatorFunction<O, T> = (output: O, target: T, ...args: any[]) => EvaluatorFunctionReturn | Promise<EvaluatorFunctionReturn>;\n\ninterface EvaluatorConstructorProps<D, T, O> {\n /**\n * List of data points to evaluate. `data` is the input to the executor function, `target` is the input to the evaluator function.\n */\n data: (Datapoint<D, T>[]) | Dataset<D, T>;\n /**\n * The executor function. Takes the data point + any additional arguments and returns the output to evaluate.\n */\n executor: (data: D, ...args: any[]) => O | Promise<O>;\n /**\n * List of evaluator functions. Each evaluator function takes the output of the executor _and_ the target data, and returns\n * a score. The score can be a single number or a record of string keys and number values.\n * If the score is a single number, it will be named after the evaluator function. If the function is anonymous, it will be named\n * `evaluator_${index}`, where index is the index of the evaluator function in the list starting from 1.\n */\n evaluators: EvaluatorFunction<O, T>[];\n /**\n * Optional override configurations for the evaluator.\n */\n config?: EvaluatorConfig;\n}\n\nexport class Evaluation<D, T, O> {\n private name: string;\n private data: Datapoint<D, T>[] | Dataset<D, T>;\n private executor: (data: D, ...args: any[]) => O | Promise<O>;\n private evaluators: Record<string, EvaluatorFunction<O, T>>;\n private evaluatorNames: string[];\n private batchSize: number = DEFAULT_BATCH_SIZE;\n\n /**\n * Create a new evaluation and prepare data.\n * @param name Name of the evaluation.\n * @param props.data List of data points to evaluate. `data` is the input to the executor function, `target` is the input to the evaluator function.\n * @param props.executor The executor function. Takes the data point + any additional arguments and returns the output to evaluate.\n * @param props.evaluators List of evaluator functions. Each evaluator function takes the output of the executor and the target data, and returns.\n */\n constructor(name: string, {\n data, executor, evaluators, config\n }: EvaluatorConstructorProps<D, T, O>) {\n this.name = name;\n this.data = data;\n this.executor = executor;\n this.evaluators = Object.fromEntries(evaluators.map((e, i) => [e.name.length > 0 ? e.name : `evaluator_${i + 1}`, e]));\n this.evaluatorNames = evaluators.map((e, i) => e.name.length > 0 ? e.name : `evaluator_${i + 1}`);\n if (config) {\n this.batchSize = config.batchSize ?? DEFAULT_BATCH_SIZE;\n }\n Laminar.initialize({ projectApiKey: config?.projectApiKey, baseUrl: config?.baseUrl });\n }\n\n /** \n * Runs the evaluation.\n *\n * Creates a new evaluation if no evaluation with such name exists, or adds data to an existing one otherwise.\n * Evaluates data points in batches of `batchSize`. The executor function is called on each data point\n * to get the output, and then evaluate it by each evaluator function.\n */\n public async run(): Promise<void> {\n const response = await Laminar.createEvaluation(this.name) as CreateEvaluationResponse;\n const length = this.data instanceof Dataset ? this.data.size() : this.data.length;\n for (let i = 0; i < length; i += this.batchSize) {\n const batch = this.data.slice(i, i + this.batchSize);\n try {\n await this.evaluateBatch(batch);\n } catch (e) {\n console.error(`Error evaluating batch: ${e}`);\n }\n }\n try {\n // After all batches are completed, update the evaluation status\n await Laminar.updateEvaluationStatus(response.name, 'Finished');\n } catch (e) {\n console.error(`Error updating evaluation status: ${e}`);\n }\n }\n \n private async evaluateBatch(batch: Datapoint<D, T>[]): Promise<void> {\n const batchPromises = batch.map(async (datapoint) => {\n const output = await this.executor(datapoint.data);\n const target = datapoint.target;\n \n let scores: Record<string, EvaluatorFunctionReturn> = {};\n for (const evaluatorName of this.evaluatorNames) {\n const evaluator = this.evaluators[evaluatorName];\n const value = await evaluator(output, target);\n \n // If the evaluator returns a single number, use the evaluator name as the key\n if (typeof value === 'number') {\n scores[evaluatorName] = value;\n } else {\n // If the evaluator returns an object, merge its keys with the existing scores (flatten)\n scores = { ...scores, ...value };\n }\n }\n \n return {\n executorOutput: output,\n data: datapoint.data,\n target,\n scores,\n } as EvaluationDatapoint<D, T, O>;\n });\n \n const results = await Promise.all(batchPromises);\n \n return Laminar.postEvaluationResults(this.name, results);\n }\n \n}\n","import { withEntity } from './sdk/node-server-sdk'\n\ninterface ObserveOptions {\n name?: string;\n sessionId?: string;\n userId?: string;\n}\n\n/**\n * The main decorator entrypoint for Laminar. This is used to wrap\n * functions and methods to create spans.\n *\n * @param name - Name of the span. Function name is used if not specified.\n * @param user_id - User ID to associate with the span and the following context.\n * @param session_id - Session ID to associate with the span and the following context.\n * @returns Returns the result of the wrapped function.\n * @throws Exception - Re-throws the exception if the wrapped function throws an exception.\n * \n * @example\n * ```typescript\n * import { observe } from '@lmnr-ai/lmnr';\n * \n * await observe({ name: 'my_function' }, () => {\n * // Your code here\n * });\n */\nexport async function observe<A extends unknown[], F extends (...args: A) => ReturnType<F>>(\n {\n name,\n sessionId,\n userId,\n }: ObserveOptions, fn: F, ...args: A): Promise<ReturnType<F>> {\n\n let associationProperties = {};\n if (sessionId) {\n associationProperties = { ...associationProperties, \"session_id\": sessionId };\n }\n if (userId) {\n associationProperties = { ...associationProperties, \"user_id\": userId };\n }\n\n return await withEntity<A, F>({ name: name ?? fn.name, associationProperties }, fn, undefined, ...args);\n}\n"],"mappings":"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","names":["context","trace","diag","diag","context","SpanAttributes","context","SpanAttributes","context","trace","SpanAttributes","context","OTLPTraceExporter","OTLPTraceExporter","trace","context"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lmnr-ai/lmnr",
3
- "version": "0.4.8",
3
+ "version": "0.4.9-alpha",
4
4
  "description": "TypeScript SDK for Laminar AI",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
package/src/laminar.ts CHANGED
@@ -5,6 +5,7 @@ import { otelSpanIdToUUID, otelTraceIdToUUID } from './utils';
5
5
  import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-grpc';
6
6
  import { Metadata } from '@grpc/grpc-js';
7
7
  import { ASSOCIATION_PROPERTIES_KEY } from './sdk/tracing/tracing';
8
+ import { forceFlush } from './sdk/node-server-sdk';
8
9
 
9
10
  // quick patch to get the traceloop's default tracer, since their
10
11
  // `getTracer` function is not exported.
@@ -93,7 +94,7 @@ export class Laminar {
93
94
  exporter,
94
95
  silenceInitializationMessage: true,
95
96
  instrumentModules,
96
- disableBatch: true,
97
+ disableBatch: false,
97
98
  });
98
99
  }
99
100
 
@@ -310,6 +311,10 @@ export class Laminar {
310
311
  return entityContext;
311
312
  }
312
313
 
314
+ public static async shutdown() {
315
+ await forceFlush();
316
+ }
317
+
313
318
  public static async createEvaluation(name: string) {
314
319
  const response = await fetch(`${this.baseUrl}/v1/evaluations`, {
315
320
  method: 'POST',