mirror of
https://github.com/DayuanJiang/next-ai-draw-io.git
synced 2026-01-02 22:32:27 +08:00
* debug: add log to verify instrumentation initialization * fix: improve Langfuse span filter to exclude all Next.js infrastructure traces
44 lines
1.6 KiB
TypeScript
44 lines
1.6 KiB
TypeScript
import { LangfuseSpanProcessor } from "@langfuse/otel"
|
|
import { NodeTracerProvider } from "@opentelemetry/sdk-trace-node"
|
|
|
|
export function register() {
|
|
// Skip telemetry if Langfuse env vars are not configured
|
|
if (!process.env.LANGFUSE_PUBLIC_KEY || !process.env.LANGFUSE_SECRET_KEY) {
|
|
console.warn(
|
|
"[Langfuse] Environment variables not configured - telemetry disabled",
|
|
)
|
|
return
|
|
}
|
|
|
|
const langfuseSpanProcessor = new LangfuseSpanProcessor({
|
|
publicKey: process.env.LANGFUSE_PUBLIC_KEY,
|
|
secretKey: process.env.LANGFUSE_SECRET_KEY,
|
|
baseUrl: process.env.LANGFUSE_BASEURL,
|
|
// Filter out Next.js HTTP request spans so AI SDK spans become root traces
|
|
shouldExportSpan: ({ otelSpan }) => {
|
|
const spanName = otelSpan.name
|
|
// Skip Next.js HTTP infrastructure spans
|
|
if (
|
|
spanName.startsWith("POST") ||
|
|
spanName.startsWith("GET") ||
|
|
spanName.startsWith("RSC") ||
|
|
spanName.includes("BaseServer") ||
|
|
spanName.includes("handleRequest") ||
|
|
spanName.includes("resolve page") ||
|
|
spanName.includes("start response")
|
|
) {
|
|
return false
|
|
}
|
|
return true
|
|
},
|
|
})
|
|
|
|
const tracerProvider = new NodeTracerProvider({
|
|
spanProcessors: [langfuseSpanProcessor],
|
|
})
|
|
|
|
// Register globally so AI SDK's telemetry also uses this processor
|
|
tracerProvider.register()
|
|
console.log("[Langfuse] Instrumentation initialized successfully")
|
|
}
|