@helicone/async
Version:
A Node.js wrapper for logging llm traces directly to Helicone, bypassing the proxy, with OpenLLMetry
78 lines • 3.54 kB
JavaScript
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.HeliconeAsyncLogger = void 0;
const traceloop = __importStar(require("@traceloop/node-server-sdk"));
const exporter_trace_otlp_http_1 = require("@opentelemetry/exporter-trace-otlp-http");
class HeliconeAsyncLogger {
constructor(opts) {
this.apiKey = opts.apiKey;
this.baseUrl = opts.baseUrl ?? "https://api.helicone.ai/v1/trace/log";
this.openAI = opts.providers?.openAI ?? undefined;
this.anthropic = opts.providers?.anthropic ?? undefined;
this.azureOpenAI = opts.providers?.azureOpenAI ?? undefined;
this.cohere = opts.providers?.cohere ?? undefined;
this.bedrock = opts.providers?.bedrock ?? undefined;
this.google_aiplatform = opts.providers?.google_aiplatform ?? undefined;
this.together = opts.providers?.together ?? undefined;
this.chainsModule = opts.providers?.langchain?.chainsModule ?? undefined;
this.agentsModule = opts.providers?.langchain?.agentsModule ?? undefined;
this.toolsModule = opts.providers?.langchain?.toolsModule ?? undefined;
this.headers = opts.headers;
}
init() {
traceloop.initialize({
apiKey: this.apiKey,
baseUrl: this.baseUrl,
disableBatch: true,
exporter: new exporter_trace_otlp_http_1.OTLPTraceExporter({
url: this.baseUrl,
headers: {
Authorization: `Bearer ${this.apiKey}`,
...this.headers,
},
}),
instrumentModules: {
openAI: this.openAI ?? undefined,
anthropic: this.anthropic ?? undefined,
azureOpenAI: this.azureOpenAI ?? undefined,
cohere: this.cohere ?? undefined,
bedrock: this.bedrock ?? undefined,
google_aiplatform: this.google_aiplatform ?? undefined,
together: this.together ?? undefined,
langchain: {
chainsModule: this.chainsModule ?? undefined,
agentsModule: this.agentsModule ?? undefined,
toolsModule: this.toolsModule ?? undefined,
},
},
});
}
withProperties(properties, fn) {
return traceloop.withAssociationProperties(properties, fn);
}
}
exports.HeliconeAsyncLogger = HeliconeAsyncLogger;
//# sourceMappingURL=HeliconeAsyncLogger.js.map