@lmnr-ai/lmnr 0.7.13 → 0.7.15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.mjs CHANGED
@@ -1,5 +1,5 @@
1
- import { a as CONTEXT_SPAN_PATH_KEY, c as createResource, d as TracingLevel, f as __require, i as ASSOCIATION_PROPERTIES_KEY, l as getParentSpanId, n as getLangVersion, o as LaminarContextManager, r as version, s as LaminarSpan, t as LaminarClient, u as makeSpanOtelV2Compatible } from "./client-D_P5R4sW.mjs";
2
- import { A as SPAN_SDK_VERSION, C as SESSION_ID, D as SPAN_LANGUAGE_VERSION, E as SPAN_INSTRUMENTATION_SOURCE, M as TRACE_HAS_BROWSER_SESSION, N as TRACE_TYPE, O as SPAN_OUTPUT, P as USER_ID, S as PARENT_SPAN_PATH, T as SPAN_INPUT, _ as ASSOCIATION_PROPERTIES, a as getOtelEnvVar, b as LaminarAttributes, d as otelSpanIdToUUID, f as otelTraceIdToUUID, g as validateTracingConfig, h as tryToOtelSpanContext, j as SPAN_TYPE, k as SPAN_PATH, l as metadataToAttributes, n as Semaphore, o as initializeLogger, p as parseOtelHeaders, r as deserializeLaminarSpanContext, s as isOtelAttributeValueType, t as NIL_UUID, u as newUUID, v as ASSOCIATION_PROPERTIES_OVERRIDES, w as SPAN_IDS_PATH, x as PARENT_SPAN_IDS_PATH, y as HUMAN_EVALUATOR_OPTIONS } from "./utils-viuxL6V7.mjs";
1
+ import { a as CONTEXT_SPAN_PATH_KEY, c as createResource, d as TracingLevel, f as __require, i as ASSOCIATION_PROPERTIES_KEY, l as getParentSpanId, n as getLangVersion, o as LaminarContextManager, r as version, s as LaminarSpan, t as LaminarClient, u as makeSpanOtelV2Compatible } from "./client-Bp0oS3Ur.mjs";
2
+ import { A as SPAN_SDK_VERSION, C as SESSION_ID, D as SPAN_LANGUAGE_VERSION, E as SPAN_INSTRUMENTATION_SOURCE, M as TRACE_HAS_BROWSER_SESSION, N as TRACE_TYPE, O as SPAN_OUTPUT, P as USER_ID, S as PARENT_SPAN_PATH, T as SPAN_INPUT, _ as ASSOCIATION_PROPERTIES, a as getOtelEnvVar, b as LaminarAttributes, d as otelSpanIdToUUID, f as otelTraceIdToUUID, g as validateTracingConfig, h as tryToOtelSpanContext, j as SPAN_TYPE, k as SPAN_PATH, l as metadataToAttributes, n as Semaphore, o as initializeLogger, p as parseOtelHeaders, r as deserializeLaminarSpanContext, s as isOtelAttributeValueType, t as NIL_UUID, u as newUUID, v as ASSOCIATION_PROPERTIES_OVERRIDES, w as SPAN_IDS_PATH, x as PARENT_SPAN_IDS_PATH, y as HUMAN_EVALUATOR_OPTIONS } from "./utils-ChSbRj0P.mjs";
3
3
  import { config } from "dotenv";
4
4
  import { DiagConsoleLogger, DiagLogLevel, ROOT_CONTEXT, context, createContextKey, diag, isSpanContextValid, trace } from "@opentelemetry/api";
5
5
  import { AsyncLocalStorageContextManager } from "@opentelemetry/context-async-hooks";
@@ -80,7 +80,7 @@ var LaminarDataset = class extends EvaluationDataset {
80
80
  */
81
81
  async push(paths, recursive = false) {
82
82
  if (!this.client) throw new Error("Client not set");
83
- const { loadFromPaths } = await import("./file-utils-D3qI1vPq.mjs");
83
+ const { loadFromPaths } = await import("./file-utils-ACjf7y05.mjs");
84
84
  const data = await loadFromPaths(Array.isArray(paths) ? paths : [paths], recursive);
85
85
  if (data.length === 0) {
86
86
  console.warn("No data to push. Skipping");
@@ -166,6 +166,7 @@ function waitForPort(port, timeoutMs = 5e3) {
166
166
  function stopCcProxy() {
167
167
  try {
168
168
  const { stopServer } = __require("@lmnr-ai/claude-code-proxy");
169
+ logger$11.debug("Stopping cc-proxy...");
169
170
  stopServer();
170
171
  } catch (e) {
171
172
  logger$11.debug(`Unable to stop cc-proxy: ${e instanceof Error ? e.message : String(e)}`);
@@ -182,6 +183,7 @@ function stopCcProxy() {
182
183
  function registerProxyShutdown() {
183
184
  if (!ccProxyShutdownRegistered) {
184
185
  process.on("exit", () => {
186
+ logger$11.debug("process.on(\"exit\") called");
185
187
  stopCcProxy();
186
188
  });
187
189
  ccProxyShutdownRegistered = true;
@@ -196,7 +198,7 @@ function getProxyBaseUrl() {
196
198
  /**
197
199
  * Start the claude-code proxy server with reference counting
198
200
  */
199
- async function startProxy() {
201
+ async function startProxy({ env }) {
200
202
  if (ccProxyStartupPromise !== null) {
201
203
  logger$11.debug("Waiting for ongoing proxy startup to complete");
202
204
  await ccProxyStartupPromise;
@@ -213,7 +215,7 @@ async function startProxy() {
213
215
  logger$11.warn("Unable to allocate port for cc-proxy.");
214
216
  return null;
215
217
  }
216
- const targetUrl = ccProxyTargetUrl || process.env.ANTHROPIC_ORIGINAL_BASE_URL || process.env.ANTHROPIC_BASE_URL || DEFAULT_ANTHROPIC_BASE_URL;
218
+ const targetUrl = ccProxyTargetUrl || process.env.ANTHROPIC_ORIGINAL_BASE_URL || env.ANTHROPIC_BASE_URL || process.env.ANTHROPIC_BASE_URL || DEFAULT_ANTHROPIC_BASE_URL;
217
219
  ccProxyTargetUrl = targetUrl;
218
220
  process.env.ANTHROPIC_ORIGINAL_BASE_URL = targetUrl;
219
221
  try {
@@ -340,11 +342,16 @@ function instrumentClaudeAgentQuery(originalQuery) {
340
342
  const generator = async function* () {
341
343
  const collected = [];
342
344
  try {
343
- await startProxy();
344
- if (getProxyBaseUrl()) await Laminar.withSpan(span, () => {
345
- setTraceToProxy();
346
- });
347
- else logger$10.debug("No claude proxy server found. Skipping span context publication.");
345
+ await startProxy({ env: params.options?.env ?? process.env });
346
+ const proxyBaseUrl = getProxyBaseUrl();
347
+ logger$10.debug(`getProxyBaseUrl() result: ${proxyBaseUrl}`);
348
+ if (proxyBaseUrl) {
349
+ await Laminar.withSpan(span, () => {
350
+ logger$10.debug("Setting trace to proxy...");
351
+ setTraceToProxy();
352
+ });
353
+ if (params.options?.env) params.options.env.ANTHROPIC_BASE_URL = proxyBaseUrl;
354
+ } else logger$10.debug("No claude proxy server found. Skipping span context publication.");
348
355
  const originalGenerator = originalQuery(params);
349
356
  for await (const message of originalGenerator) {
350
357
  collected.push(message);