Manual Logger - TypeScript
Integrate any custom LLM with Helicone using the TypeScript Manual Logger. Step-by-step guide for NodeJS implementation to connect your proprietary or open-source models.
TypeScript Manual Logger
Logging calls to custom models is supported via the Helicone NodeJS SDK.
To get started, install the `@helicone/helpers` package
Set `HELICONE_API_KEY` as an environment variable
Create a new HeliconeManualLogger instance
Log your request
API Reference
HeliconeManualLogger
logRequest
Parameters
request
:HeliconeLogRequest
- The request object to log
operation
:(resultRecorder: HeliconeResultRecorder) => Promise<T>
- The operation to be executed and logged
additionalHeaders
:Record<string, string>
- Additional headers to be sent with the request
- This can be used to use features like session management, custom properties, etc.
Available Methods
The HeliconeManualLogger
class provides several methods for logging different types of requests and responses. Here’s a comprehensive overview of each method:
logRequest
Used for logging non-streaming requests and responses with full control over the operation.
Parameters:
request
: The request object to logoperation
: A function that performs the actual API call and records the resultsadditionalHeaders
: Optional additional headers to include with the log request
Example:
logStream
Used for logging streaming operations with full control over stream handling.
Parameters:
request
: The request object to logoperation
: A function that performs the streaming API call and attaches the stream to the recorderadditionalHeaders
: Optional additional headers to include with the log request
Example:
logSingleStream
A simplified method for logging a single ReadableStream without needing to manage the operation.
Parameters:
request
: The request object to logstream
: The ReadableStream to consume and logadditionalHeaders
: Optional additional headers to include with the log request
Example:
logSingleRequest
Used for logging a single request with a response body without needing to manage the operation.
Parameters:
request
: The request object to logbody
: The response body as a stringadditionalHeaders
: Optional additional headers to include with the log request
Example:
Streaming Examples
Using the Async Stream Parser
Helicone provides an asynchronous stream parser for efficient handling of streamed responses. This is particularly useful when working with custom integrations that support streaming.
Here’s an example of how to use the async stream parser with a custom integration:
The async stream parser offers several benefits:
- Processes stream chunks asynchronously for better performance
- Reduces latency when handling large streamed responses
- Provides more reliable token counting for streamed content
Using Vercel’s after
Function with Streaming
When building applications with Next.js App Router on Vercel, you can use the after
function to log streaming responses without blocking the client response:
For a comprehensive guide on using the Manual Logger with streaming functionality, check out our Manual Logger with Streaming cookbook.
Was this page helpful?