Documentation Index
Fetch the complete documentation index at: https://docs.latitude.so/llms.txt
Use this file to discover all available pages before exploring further.
TypeScript SDK
Use@latitude-data/telemetry to send LLM traces from TypeScript and JavaScript applications to Latitude. The SDK is built on OpenTelemetry and can attach to an existing tracing setup when your app already uses one.
Installation
Bootstrap
Initialize Latitude once, before your LLM calls run. Pass the LLM SDK modules your app uses throughinstrumentations so Latitude can auto-instrument them.
new Latitude() starts instrumentation in the background and returns immediately. You can start using your LLM clients right away.
Add context with capture()
Auto-instrumentation creates spans for supported LLM calls. Use capture() to attach Latitude context to the spans created inside a request, conversation turn, or agent run.
You can use capture() to:
- group traces by user
- group traces into a session
- route traces to a specific project
- add tags and metadata for filtering
- mark the boundary of an agent run
capture() does not create spans by itself. It only adds context to spans created by auto-instrumentation inside the callback. In most apps, wrap the outer request handler, conversation turn, or agent entrypoint once.
Nested capture() calls inherit parent context and can override local values. Metadata is shallow-merged, and tags are appended and deduplicated.
Existing Sentry or OpenTelemetry setup
If your app already uses Sentry, Datadog, New Relic, Honeycomb, or another OpenTelemetry-compatible SDK, initialize that SDK first and constructLatitude second. Latitude will attach its span processor to the existing provider when possible.
latitude.shutdown() only shuts down Latitude-owned processing. It does not shut down your existing observability SDK.
If you need lower-level OpenTelemetry wiring or a non-TypeScript runtime, see the OpenTelemetry Exporter guide.
Supported integrations
Set the integration key oninstrumentations to the SDK module your app imports.
| Integration | Package | Example |
|---|---|---|
| OpenAI | openai | { openai: OpenAI } |
| OpenAI Agents SDK | @openai/agents | { "openai-agents": OpenAIAgentsSDK } |
| Anthropic | @anthropic-ai/sdk | { anthropic: AnthropicSDK } |
| Amazon Bedrock | @aws-sdk/client-bedrock-runtime | { bedrock: BedrockSDK } |
| Cohere | cohere-ai | { cohere: CohereSDK } |
| LangChain | langchain | { langchain: LangChain } |
| LlamaIndex | llamaindex | { llamaindex: LlamaIndex } |
| Together AI | together-ai | { togetherai: TogetherSDK } |
| Vertex AI | @google-cloud/vertexai | { vertexai: VertexAISDK } |
| Google AI Platform | @google-cloud/aiplatform | { aiplatform: AIPlatformSDK } |
Troubleshooting
Spans are not appearing in Latitude
Start with the most common setup issues.Check the API key and project slug
Make sure both values are present in the runtime where your app is executing:Pass the same SDK module your app uses
The module passed toinstrumentations should be the same package import used for the actual LLM call.
Flush before short-lived processes exit
Servers can usually export spans in the background. Scripts, CLIs, tests, and jobs that exit immediately should flush before shutdown:Wrap the actual LLM call with capture()
If you use capture(), the instrumented operation must happen inside the callback:
capture() starts:
Consume streaming responses inside capture()
For streaming responses, create and consume the stream inside the capture() callback. This keeps the full streamed operation inside the active OpenTelemetry context.
capture() and consuming it later. Once the callback has finished, the Latitude context is no longer active for the remaining stream consumption.
First request is missing after startup
await latitude.ready is optional. Most applications do not need it.
Use it only during startup if your app makes an LLM call immediately after constructing Latitude and that first call is missing from Latitude:
ready around individual requests.
No spans are created inside capture()
capture() only attaches context. You still need a supported instrumentation, and the code inside the callback must make an instrumented LLM call.
Context is not propagating
new Latitude() registers the OpenTelemetry context manager automatically. If you provide your own OpenTelemetry setup, make sure it has a working context manager before Latitude attaches to it.