0
# Langfuse Core
1
2
The @langfuse/core package is the foundation of the Langfuse JavaScript SDK, providing the core API client for interacting with the Langfuse observability platform. It includes essential utilities for logging, media handling, OpenTelemetry integration, and type-safe access to 23 API resources for managing traces, observations, prompts, datasets, and more.
3
4
## Package Information
5
6
- **Package Name**: @langfuse/core
7
- **Package Type**: npm
8
- **Language**: TypeScript
9
- **Installation**: `npm install @langfuse/core`
10
- **Version**: 4.2.0
11
- **License**: MIT
12
13
## Core Imports
14
15
```typescript
16
import { LangfuseAPIClient } from '@langfuse/core';
17
```
18
19
For logger utilities:
20
21
```typescript
22
import { Logger, LogLevel, configureGlobalLogger } from '@langfuse/core';
23
```
24
25
For media handling:
26
27
```typescript
28
import { LangfuseMedia } from '@langfuse/core';
29
```
30
31
For constants and utilities:
32
33
```typescript
34
import {
35
LANGFUSE_SDK_VERSION,
36
LangfuseOtelSpanAttributes,
37
generateUUID,
38
getEnv
39
} from '@langfuse/core';
40
```
41
42
CommonJS:
43
44
```javascript
45
const { LangfuseAPIClient, Logger, LangfuseMedia } = require('@langfuse/core');
46
```
47
48
## Basic Usage
49
50
```typescript
51
import { LangfuseAPIClient } from '@langfuse/core';
52
53
// Initialize the API client
54
const client = new LangfuseAPIClient({
55
environment: 'https://cloud.langfuse.com',
56
username: 'your-public-key',
57
password: 'your-secret-key',
58
xLangfuseSdkName: 'javascript',
59
xLangfuseSdkVersion: '4.2.0'
60
});
61
62
// Fetch a trace
63
const trace = await client.trace.get('trace-id');
64
65
// List traces with filters
66
const traces = await client.trace.list({
67
page: 1,
68
limit: 50,
69
userId: 'user-123',
70
fromTimestamp: '2024-01-01T00:00:00Z'
71
});
72
73
// Get a prompt
74
const prompt = await client.prompts.get('my-prompt', {
75
version: 1,
76
label: 'production'
77
});
78
79
// Create media content
80
import { LangfuseMedia } from '@langfuse/core';
81
82
const media = new LangfuseMedia({
83
source: 'base64_data_uri',
84
base64DataUri: '...'
85
});
86
87
const mediaTag = await media.getTag();
88
// Use mediaTag in trace input/output
89
```
90
91
## Architecture
92
93
The @langfuse/core package is organized around these key components:
94
95
### API Client Architecture
96
97
- **LangfuseAPIClient**: Main client class providing lazy-loaded access to 23 resource clients
98
- **Resource Clients**: Specialized clients for different API domains (traces, prompts, datasets, etc.)
99
- **Auto-Generated Types**: Complete TypeScript type definitions generated from Fern API specifications
100
- **Authentication**: Basic Auth with public key (username) and secret key (password)
101
- **Error Handling**: Structured error types for HTTP status codes (400, 401, 403, 404, 405)
102
- **Retry Logic**: Built-in retry mechanism (default: 2 retries) with configurable timeouts
103
104
### Core Utilities
105
106
- **Logger System**: Configurable logging with levels (DEBUG, INFO, WARN, ERROR) and global singleton
107
- **Media Handler**: SHA-256 hashing, content-addressable storage, and media reference tags
108
- **UUID Generation**: Cross-platform UUID v4 generation for Node.js and browser environments
109
- **Base64 Utilities**: Encoding/decoding for both environments with UTF-8 support
110
- **Environment Variables**: Helper for reading Langfuse configuration from environment
111
112
### OpenTelemetry Integration
113
114
- **Span Attributes**: Standardized attribute keys for trace and observation metadata
115
- **SDK Identifiers**: Constants for tracer name, SDK version, and platform identification
116
- **Compatibility**: Support for both current and legacy attribute naming conventions
117
118
## Capabilities
119
120
### Logger System
121
122
Configurable logging infrastructure with multiple severity levels, timestamps, and global configuration.
123
124
```typescript { .api }
125
enum LogLevel {
126
DEBUG = 0,
127
INFO = 1,
128
WARN = 2,
129
ERROR = 3
130
}
131
132
class Logger {
133
constructor(config?: LoggerConfig);
134
error(message: string, ...args: unknown[]): void;
135
warn(message: string, ...args: unknown[]): void;
136
info(message: string, ...args: unknown[]): void;
137
debug(message: string, ...args: unknown[]): void;
138
setLevel(level: LogLevel): void;
139
getLevel(): LogLevel;
140
}
141
142
interface LoggerConfig {
143
level: LogLevel;
144
prefix?: string;
145
enableTimestamp?: boolean;
146
}
147
148
function configureGlobalLogger(config: LoggerConfig): void;
149
function getGlobalLogger(): Logger;
150
```
151
152
[Logger System](./logger.md)
153
154
### API Client
155
156
Type-safe API client for all Langfuse platform resources with built-in authentication, retry logic, and comprehensive error handling.
157
158
```typescript { .api }
159
class LangfuseAPIClient {
160
constructor(options: LangfuseAPIClient.Options);
161
162
// Resource accessors (23 total)
163
readonly trace: Trace;
164
readonly prompts: Prompts;
165
readonly datasets: Datasets;
166
readonly observations: Observations;
167
readonly score: Score;
168
readonly sessions: Sessions;
169
readonly media: Media;
170
// ... and 16 more resources
171
}
172
173
interface Options {
174
environment: core.Supplier<string>;
175
baseUrl?: core.Supplier<string>;
176
username?: core.Supplier<string | undefined>;
177
password?: core.Supplier<string | undefined>;
178
xLangfuseSdkName?: core.Supplier<string | undefined>;
179
xLangfuseSdkVersion?: core.Supplier<string | undefined>;
180
xLangfusePublicKey?: core.Supplier<string | undefined>;
181
headers?: Record<string, string | core.Supplier<string | null | undefined> | null | undefined>;
182
}
183
```
184
185
[API Client and Core Concepts](./api-client.md)
186
187
### API Resources
188
189
Comprehensive access to Langfuse platform features through 19+ specialized resource clients.
190
191
**Core Observability:**
192
- Traces: Trace lifecycle management and querying
193
- Observations: Detailed observation queries (spans, generations, events)
194
- Sessions: Session grouping and analytics
195
196
**Prompt Management:**
197
- Prompts: Version-controlled prompt templates
198
- Prompt Versions: Specific version operations
199
200
**Evaluation & Scoring:**
201
- Datasets: Test dataset management
202
- Dataset Items: Individual dataset entries
203
- Dataset Runs: Evaluation run tracking
204
- Score: Score creation
205
- Score Configs: Score configuration management
206
207
**Platform Management:**
208
- Projects: Project administration
209
- Organizations: Multi-tenant organization management
210
- Models: Model configuration and pricing
211
- Media: Media upload and retrieval
212
213
[API Resources](./api-resources.md)
214
215
### Constants and OpenTelemetry
216
217
SDK identifiers and standardized OpenTelemetry span attribute keys for tracing integration.
218
219
```typescript { .api }
220
const LANGFUSE_TRACER_NAME: string;
221
const LANGFUSE_SDK_VERSION: string;
222
const LANGFUSE_SDK_NAME: string;
223
224
enum LangfuseOtelSpanAttributes {
225
TRACE_NAME = "langfuse.trace.name",
226
TRACE_USER_ID = "user.id",
227
OBSERVATION_TYPE = "langfuse.observation.type",
228
OBSERVATION_MODEL = "langfuse.observation.model.name",
229
// ... 20+ more attributes
230
}
231
```
232
233
[Constants and OpenTelemetry Attributes](./constants.md)
234
235
### Media Handling
236
237
Rich media support with content-addressable storage, SHA-256 hashing, and media reference tags for embedding in traces.
238
239
```typescript { .api }
240
class LangfuseMedia {
241
constructor(params: LangfuseMediaParams);
242
async getId(): Promise<string | null>;
243
async getSha256Hash(): Promise<string | undefined>;
244
async getTag(): Promise<string | null>;
245
get contentLength(): number | undefined;
246
get base64DataUri(): string | null;
247
toJSON(): string | null;
248
}
249
250
type LangfuseMediaParams =
251
| {
252
source: "base64_data_uri";
253
base64DataUri: string;
254
}
255
| {
256
source: "bytes";
257
contentBytes: Uint8Array;
258
contentType: MediaContentType;
259
};
260
```
261
262
[Media Handling](./media.md)
263
264
### Utilities
265
266
Cross-platform utility functions for UUID generation, base64 encoding, environment variables, and safe timeouts.
267
268
```typescript { .api }
269
function generateUUID(globalThis?: any): string;
270
function getEnv(key: LangfuseEnvVar): string | undefined;
271
function base64Encode(input: string): string;
272
function base64Decode(input: string): string;
273
function safeSetTimeout(fn: () => void, timeout: number): any;
274
```
275
276
[Utilities](./utils.md)
277
278
### Error Handling
279
280
Structured error classes for API interactions with status codes, response bodies, and timeout handling.
281
282
```typescript { .api }
283
class LangfuseAPIError extends Error {
284
readonly statusCode?: number;
285
readonly body?: unknown;
286
readonly rawResponse?: RawResponse;
287
288
constructor(params: {
289
message?: string;
290
statusCode?: number;
291
body?: unknown;
292
rawResponse?: RawResponse;
293
});
294
}
295
296
class LangfuseAPITimeoutError extends Error {
297
constructor(message: string);
298
}
299
```
300
301
[Error Handling](./errors.md)
302
303
## Type Safety
304
305
The @langfuse/core package provides complete TypeScript type definitions for all APIs, with over 200 exported types including:
306
307
- **Core Entities**: `Trace`, `Observation`, `Session`, `Score`, `Prompt`, `Dataset`, `Model`
308
- **Request Types**: Query parameters, creation requests, update requests for all operations
309
- **Response Types**: Paginated lists, single entities, deletion confirmations
310
- **Enums**: Status codes, observation types, model usage units, data types
311
- **Utility Types**: Usage metrics, metadata structures, pagination metadata
312
313
All types are auto-generated from Fern API specifications ensuring consistency with the Langfuse platform.
314
315
## Environment Variables
316
317
The SDK reads configuration from these environment variables:
318
319
- `LANGFUSE_PUBLIC_KEY` - Public API key for authentication
320
- `LANGFUSE_SECRET_KEY` - Secret API key for authentication
321
- `LANGFUSE_BASE_URL` - Base API URL (default: https://cloud.langfuse.com)
322
- `LANGFUSE_LOG_LEVEL` - Logging level (DEBUG, INFO, WARN, ERROR)
323
- `LANGFUSE_TIMEOUT` - Request timeout in milliseconds
324
- `LANGFUSE_FLUSH_AT` - Batch size for flushing operations
325
- `LANGFUSE_FLUSH_INTERVAL` - Flush interval in milliseconds
326
- `LANGFUSE_RELEASE` - Release identifier for traces
327
- `LANGFUSE_TRACING_ENVIRONMENT` - Environment identifier for traces
328
329
## Best Practices
330
331
1. **Authentication**: Store API keys securely using environment variables, never hardcode them
332
2. **Error Handling**: Catch specific error types (`UnauthorizedError`, `NotFoundError`) for better UX
333
3. **Pagination**: Always implement pagination for list operations to handle large datasets
334
4. **Field Selection**: Use the `fields` parameter on trace queries to reduce payload size
335
5. **Media Optimization**: Use media references rather than embedding large content directly in traces
336
6. **Environment Naming**: Use lowercase alphanumeric with hyphens/underscores, avoid 'langfuse' prefix
337
7. **Cost Tracking**: Prefer `usageDetails` and `costDetails` over deprecated `usage` field
338
8. **OpenTelemetry**: Prefer OpenTelemetry endpoint over legacy batch ingestion for new integrations
339
9. **Logger Configuration**: Configure global logger early in application initialization
340
10. **Type Safety**: Leverage TypeScript types for compile-time validation and IDE autocompletion
341
342
## Platform Compatibility
343
344
The @langfuse/core package is designed for universal JavaScript compatibility:
345
346
- **Node.js**: Full support for Node.js environments (v20+)
347
- **Browser**: Compatible with modern browsers via bundlers (webpack, vite, etc.)
348
- **Edge Runtime**: Compatible with edge computing platforms (Cloudflare Workers, Vercel Edge)
349
- **Build System**: Available as ESM (.mjs) and CommonJS (.cjs) with TypeScript definitions
350
351
## Related Documentation
352
353
- **Official Docs**: https://langfuse.com/docs/sdk/typescript
354
- **API Reference**: https://js.reference.langfuse.com
355
- **GitHub Repository**: https://github.com/langfuse/langfuse-js
356
- **OpenTelemetry Integration**: https://langfuse.com/integrations/native/opentelemetry
357