@librechat/agents 3.1.91 → 3.1.93

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/dist/cjs/graphs/Graph.cjs +5 -3
  2. package/dist/cjs/graphs/Graph.cjs.map +1 -1
  3. package/dist/cjs/instrumentation.cjs +2 -7
  4. package/dist/cjs/instrumentation.cjs.map +1 -1
  5. package/dist/cjs/langfuse.cjs +62 -11
  6. package/dist/cjs/langfuse.cjs.map +1 -1
  7. package/dist/cjs/run.cjs +33 -19
  8. package/dist/cjs/run.cjs.map +1 -1
  9. package/dist/cjs/tools/cloudflare/CloudflareBridgeRuntime.cjs +1 -0
  10. package/dist/cjs/tools/cloudflare/CloudflareBridgeRuntime.cjs.map +1 -1
  11. package/dist/cjs/tools/cloudflare/CloudflareSandboxExecutionEngine.cjs +13 -7
  12. package/dist/cjs/tools/cloudflare/CloudflareSandboxExecutionEngine.cjs.map +1 -1
  13. package/dist/cjs/utils/callbacks.cjs +27 -0
  14. package/dist/cjs/utils/callbacks.cjs.map +1 -0
  15. package/dist/esm/graphs/Graph.mjs +6 -4
  16. package/dist/esm/graphs/Graph.mjs.map +1 -1
  17. package/dist/esm/instrumentation.mjs +2 -7
  18. package/dist/esm/instrumentation.mjs.map +1 -1
  19. package/dist/esm/langfuse.mjs +63 -14
  20. package/dist/esm/langfuse.mjs.map +1 -1
  21. package/dist/esm/run.mjs +34 -20
  22. package/dist/esm/run.mjs.map +1 -1
  23. package/dist/esm/tools/cloudflare/CloudflareBridgeRuntime.mjs +1 -0
  24. package/dist/esm/tools/cloudflare/CloudflareBridgeRuntime.mjs.map +1 -1
  25. package/dist/esm/tools/cloudflare/CloudflareSandboxExecutionEngine.mjs +13 -7
  26. package/dist/esm/tools/cloudflare/CloudflareSandboxExecutionEngine.mjs.map +1 -1
  27. package/dist/esm/utils/callbacks.mjs +24 -0
  28. package/dist/esm/utils/callbacks.mjs.map +1 -0
  29. package/dist/types/langfuse.d.ts +13 -4
  30. package/dist/types/types/run.d.ts +2 -2
  31. package/dist/types/types/tools.d.ts +6 -0
  32. package/dist/types/utils/callbacks.d.ts +5 -0
  33. package/package.json +4 -4
  34. package/src/graphs/Graph.ts +10 -6
  35. package/src/instrumentation.ts +2 -7
  36. package/src/langfuse.ts +98 -15
  37. package/src/run.ts +53 -29
  38. package/src/specs/langfuse-callbacks.test.ts +75 -0
  39. package/src/specs/langfuse-config.test.ts +58 -1
  40. package/src/tools/__tests__/CloudflareSandboxExecution.test.ts +87 -8
  41. package/src/tools/cloudflare/CloudflareBridgeRuntime.ts +1 -0
  42. package/src/tools/cloudflare/CloudflareSandboxExecutionEngine.ts +13 -7
  43. package/src/types/run.ts +2 -7
  44. package/src/types/tools.ts +6 -0
  45. package/src/utils/callbacks.ts +39 -0
@@ -1 +1 @@
1
- {"version":3,"file":"CloudflareSandboxExecutionEngine.mjs","sources":["../../../../src/tools/cloudflare/CloudflareSandboxExecutionEngine.ts"],"sourcesContent":["import { EventEmitter } from 'events';\nimport { PassThrough } from 'stream';\nimport { posix as path } from 'path';\nimport type { ChildProcessWithoutNullStreams } from 'child_process';\nimport type { WriteFileOptions, MakeDirectoryOptions, Stats } from 'fs';\nimport type { FileHandle } from 'fs/promises';\nimport type * as t from '@/types';\nimport {\n LOCAL_SPAWN_TIMEOUT_MS,\n validateBashCommand,\n} from '@/tools/local/LocalExecutionEngine';\nimport type { WorkspaceFS, ReaddirEntry } from '@/tools/local/workspaceFS';\n\nconst DEFAULT_WORKSPACE_ROOT = '/workspace';\nconst DEFAULT_TIMEOUT_MS = 60000;\nconst DEFAULT_MAX_OUTPUT_CHARS = 200000;\nconst PROTECTED_TARGET_ARG_RE = /^(?:\\/|~|\\$\\{?HOME\\}?|\\.)(?:\\/?\\.?\\*|\\/)?$/;\nconst DESTRUCTIVE_OP_IN_COMMAND_RE =\n /\\b(?:rm\\s+-[^\\s]*[rf]|chmod\\s+-R|chown\\s+-R)\\b/;\n\ntype SpawnResult = {\n stdout: string;\n stderr: string;\n exitCode: number | null;\n timedOut: boolean;\n};\n\ntype RuntimeCommand = {\n fileName: string;\n source?: string;\n command: string;\n};\n\ntype SandboxRuntimeContext = {\n sandbox: t.CloudflareSandboxRuntime;\n workspaceRoot: string;\n env?: Record<string, string | undefined>;\n timeoutMs: number;\n maxOutputChars: number;\n shell: string;\n};\n\nconst sandboxFactoryCache = new WeakMap<\n t.CloudflareSandboxExecutionConfig,\n Promise<t.CloudflareSandboxRuntime>\n>();\n\nfunction normalizeWorkspaceRoot(workspaceRoot: string): string {\n const normalized = path.normalize(workspaceRoot);\n return normalized === '/' ? normalized : normalized.replace(/\\/+$/, '');\n}\n\nexport function getCloudflareWorkspaceRoot(\n config?: t.CloudflareSandboxExecutionConfig\n): string {\n return normalizeWorkspaceRoot(\n config?.workspaceRoot ?? DEFAULT_WORKSPACE_ROOT\n );\n}\n\nexport async function resolveCloudflareSandbox(\n config: t.CloudflareSandboxExecutionConfig\n): Promise<t.CloudflareSandboxRuntime> {\n const sandbox = config.sandbox;\n if (typeof sandbox !== 'function') {\n return sandbox;\n }\n let cached = sandboxFactoryCache.get(config);\n if (cached == null) {\n cached = Promise.resolve()\n .then(() => sandbox())\n .catch((error: unknown) => {\n sandboxFactoryCache.delete(config);\n throw error;\n });\n sandboxFactoryCache.set(config, cached);\n }\n return cached;\n}\n\nasync function getRuntimeContext(\n config: t.CloudflareSandboxExecutionConfig\n): Promise<SandboxRuntimeContext> {\n return {\n sandbox: await resolveCloudflareSandbox(config),\n workspaceRoot: getCloudflareWorkspaceRoot(config),\n env: config.env,\n timeoutMs: config.timeoutMs ?? DEFAULT_TIMEOUT_MS,\n maxOutputChars: config.maxOutputChars ?? DEFAULT_MAX_OUTPUT_CHARS,\n shell: config.shell ?? 'bash',\n };\n}\n\nfunction toSandboxPath(filePath: string, workspaceRoot: string): string {\n const raw = filePath === '' ? '.' : filePath;\n const root = normalizeWorkspaceRoot(workspaceRoot);\n const resolved = raw.startsWith('/')\n ? path.normalize(raw)\n : path.resolve(root, raw);\n if (root === '/') {\n return resolved;\n }\n if (resolved === root || resolved.startsWith(`${root}/`)) {\n return resolved;\n }\n throw new Error(\n `Path is outside the Cloudflare sandbox workspace: ${filePath}`\n );\n}\n\nfunction quote(value: string): string {\n if (value === '') {\n return '\\'\\'';\n }\n if (/^[A-Za-z0-9_/:=.,@%+-]+$/.test(value)) {\n return value;\n }\n return `'${value.replace(/'/g, '\\'\\\\\\'\\'')}'`;\n}\n\nfunction withInSandboxTimeout(command: string, timeoutMs: number): string {\n const timeoutSeconds = Math.max(1, Math.ceil(timeoutMs / 1000));\n return `timeout -k 2s ${timeoutSeconds}s ${command}`;\n}\n\nfunction outerTimeoutMs(timeoutMs: number): number {\n return timeoutMs + 5000;\n}\n\nfunction isInSandboxTimeoutExit(exitCode: number | null): boolean {\n return exitCode === 124 || exitCode === 137;\n}\n\nfunction truncateOutput(value: string, maxChars: number): string {\n if (maxChars <= 0 || value.length <= maxChars) {\n return value;\n }\n const head = Math.max(Math.floor(maxChars / 2), 0);\n const tail = Math.max(maxChars - head, 0);\n return `${value.slice(0, head)}\\n...[truncated ${value.length - maxChars} chars]...\\n${value.slice(value.length - tail)}`;\n}\n\nasync function readStream(stream: ReadableStream<Uint8Array>): Promise<Buffer> {\n const reader = stream.getReader();\n const chunks: Uint8Array[] = [];\n try {\n for (;;) {\n const { done, value } = await reader.read();\n if (done) break;\n chunks.push(value);\n }\n } finally {\n reader.releaseLock();\n }\n return Buffer.concat(chunks.map((chunk) => Buffer.from(chunk)));\n}\n\nasync function normalizeReadFileContent(\n result: t.CloudflareSandboxReadFileResult\n): Promise<Buffer> {\n if (typeof result === 'string') {\n return Buffer.from(result, 'utf8');\n }\n if (Buffer.isBuffer(result)) {\n return result;\n }\n if (result instanceof Uint8Array) {\n return Buffer.from(result);\n }\n const content = result.content;\n if (typeof content === 'string') {\n if (result.encoding === 'base64') {\n return Buffer.from(content, 'base64');\n }\n return Buffer.from(content, 'utf8');\n }\n if (Buffer.isBuffer(content)) {\n return content;\n }\n if (content instanceof Uint8Array) {\n return Buffer.from(content);\n }\n return readStream(content);\n}\n\nfunction bytesToStream(bytes: Uint8Array): ReadableStream<Uint8Array> {\n return new ReadableStream<Uint8Array>({\n start(controller): void {\n controller.enqueue(bytes);\n controller.close();\n },\n });\n}\n\nfunction normalizeWriteFileContent(content: string | Buffer | Uint8Array): {\n content: string | ReadableStream<Uint8Array>;\n options?: { encoding?: string };\n} {\n if (typeof content === 'string') {\n return { content, options: { encoding: 'utf8' } };\n }\n return { content: bytesToStream(content) };\n}\n\nfunction createStats(info: {\n size?: number;\n type?: t.CloudflareSandboxFileInfo['type'];\n}): Stats {\n const type = info.type ?? 'file';\n const now = new Date();\n return {\n size: info.size ?? 0,\n isFile: () => type === 'file',\n isDirectory: () => type === 'directory',\n isSymbolicLink: () => type === 'symlink',\n isBlockDevice: () => false,\n isCharacterDevice: () => false,\n isFIFO: () => false,\n isSocket: () => false,\n dev: 0,\n ino: 0,\n mode: 0,\n nlink: 1,\n uid: 0,\n gid: 0,\n rdev: 0,\n blksize: 0,\n blocks: 0,\n atimeMs: now.getTime(),\n mtimeMs: now.getTime(),\n ctimeMs: now.getTime(),\n birthtimeMs: now.getTime(),\n atime: now,\n mtime: now,\n ctime: now,\n birthtime: now,\n } as Stats;\n}\n\nfunction normalizeFileList(\n result: t.CloudflareSandboxListFilesResult\n): t.CloudflareSandboxFileInfo[] {\n return Array.isArray(result) ? result : result.files;\n}\n\nfunction entryNameFor(\n info: t.CloudflareSandboxFileInfo,\n parentPath: string\n): string {\n if (info.name !== '') {\n return info.name.includes('/') ? path.basename(info.name) : info.name;\n }\n if (info.absolutePath != null && info.absolutePath !== '') {\n return path.basename(info.absolutePath);\n }\n if (info.relativePath != null && info.relativePath !== '') {\n return path.basename(info.relativePath);\n }\n return path.basename(parentPath);\n}\n\nfunction entryAbsolutePath(\n info: t.CloudflareSandboxFileInfo,\n parentPath: string\n): string {\n if (info.absolutePath != null && info.absolutePath !== '') {\n return path.normalize(info.absolutePath);\n }\n if (info.relativePath != null && info.relativePath !== '') {\n return path.resolve(parentPath, info.relativePath);\n }\n return path.resolve(parentPath, info.name);\n}\n\nfunction createDirent(info: t.CloudflareSandboxFileInfo): ReaddirEntry {\n return {\n name: entryNameFor(info, ''),\n isFile: () => (info.type ?? 'file') === 'file',\n isDirectory: () => info.type === 'directory',\n isSymbolicLink: () => info.type === 'symlink',\n };\n}\n\nasync function findChildInfo(\n sandbox: t.CloudflareSandboxRuntime,\n filePath: string\n): Promise<t.CloudflareSandboxFileInfo | undefined> {\n const parent = path.dirname(filePath);\n const basename = path.basename(filePath);\n const entries = normalizeFileList(\n await sandbox.listFiles(parent, { includeHidden: true })\n );\n return entries.find((entry) => {\n const absolute = entryAbsolutePath(entry, parent);\n return absolute === filePath || entryNameFor(entry, parent) === basename;\n });\n}\n\nexport function createCloudflareWorkspaceFS(\n config: t.CloudflareSandboxExecutionConfig\n): WorkspaceFS {\n const workspaceRoot = getCloudflareWorkspaceRoot(config);\n\n const fs: WorkspaceFS = {\n readFile: (async (filePath: string, encoding?: 'utf8') => {\n const sandbox = await resolveCloudflareSandbox(config);\n const resolved = toSandboxPath(filePath, workspaceRoot);\n const buffer = await normalizeReadFileContent(\n await sandbox.readFile(resolved, encoding ? { encoding } : undefined)\n );\n return encoding != null ? buffer.toString(encoding) : buffer;\n }) as WorkspaceFS['readFile'],\n writeFile: async (\n filePath: string,\n content: string | Buffer,\n _options?: WriteFileOptions\n ) => {\n const sandbox = await resolveCloudflareSandbox(config);\n const resolved = toSandboxPath(filePath, workspaceRoot);\n const normalized = normalizeWriteFileContent(content);\n await sandbox.writeFile(resolved, normalized.content, normalized.options);\n },\n stat: async (filePath: string) => {\n const sandbox = await resolveCloudflareSandbox(config);\n const resolved = toSandboxPath(filePath, workspaceRoot);\n if (resolved === workspaceRoot) {\n const entries = normalizeFileList(\n await sandbox.listFiles(resolved, { includeHidden: true })\n );\n return createStats({ size: entries.length, type: 'directory' });\n }\n const info = await findChildInfo(sandbox, resolved);\n if (info != null) {\n return createStats({ size: info.size, type: info.type });\n }\n try {\n const entries = normalizeFileList(\n await sandbox.listFiles(resolved, { includeHidden: true })\n );\n return createStats({ size: entries.length, type: 'directory' });\n } catch {\n const buffer = await normalizeReadFileContent(\n await sandbox.readFile(resolved)\n );\n return createStats({ size: buffer.length, type: 'file' });\n }\n },\n readdir: (async (filePath: string, options?: { withFileTypes: true }) => {\n const sandbox = await resolveCloudflareSandbox(config);\n const resolved = toSandboxPath(filePath, workspaceRoot);\n const entries = normalizeFileList(\n await sandbox.listFiles(resolved, { includeHidden: true })\n );\n if (options?.withFileTypes === true) {\n return entries.map(createDirent);\n }\n return entries.map((entry) => entryNameFor(entry, resolved));\n }) as WorkspaceFS['readdir'],\n mkdir: async (filePath: string, options?: MakeDirectoryOptions) => {\n const sandbox = await resolveCloudflareSandbox(config);\n await sandbox.mkdir(toSandboxPath(filePath, workspaceRoot), {\n recursive: options?.recursive,\n });\n },\n realpath: async (filePath: string) =>\n toSandboxPath(filePath, workspaceRoot),\n unlink: async (filePath: string) => {\n const sandbox = await resolveCloudflareSandbox(config);\n await sandbox.deleteFile(toSandboxPath(filePath, workspaceRoot));\n },\n open: async (filePath: string, _flags: 'r') => {\n const sandbox = await resolveCloudflareSandbox(config);\n const resolved = toSandboxPath(filePath, workspaceRoot);\n const buffer = await normalizeReadFileContent(\n await sandbox.readFile(resolved)\n );\n return {\n read: async (\n target: Buffer,\n offset: number,\n length: number,\n position: number\n ) => {\n const start = Math.max(position, 0);\n const slice = buffer.subarray(start, start + length);\n slice.copy(target, offset);\n return { bytesRead: slice.length, buffer: target };\n },\n close: async () => undefined,\n } as unknown as FileHandle;\n },\n };\n\n return fs;\n}\n\nfunction createCloudflareSpawn(\n config: t.CloudflareSandboxExecutionConfig\n): t.LocalSpawn {\n return (command, args, options) => {\n const stdout = new PassThrough();\n const stderr = new PassThrough();\n const abortController = new AbortController();\n const child = new EventEmitter() as ChildProcessWithoutNullStreams;\n const state = { closed: false };\n const closeOnce = (\n exitCode: number | null,\n signal: NodeJS.Signals | null\n ): void => {\n if (state.closed) {\n return;\n }\n state.closed = true;\n stdout.end();\n stderr.end();\n Object.assign(child, {\n exitCode,\n signalCode: signal,\n });\n child.emit('close', exitCode, signal);\n };\n Object.assign(child, {\n stdout,\n stderr,\n stdin: new PassThrough(),\n stdio: [null, stdout, stderr],\n killed: false,\n exitCode: null,\n signalCode: null,\n pid: undefined,\n kill: (signal: NodeJS.Signals = 'SIGTERM') => {\n Object.assign(child, { killed: true, signalCode: signal });\n abortController.abort();\n closeOnce(null, signal);\n return true;\n },\n });\n\n void (async (): Promise<void> => {\n const ctx = await getRuntimeContext(config);\n const rendered = [command, ...args].map(quote).join(' ');\n const spawnTimeoutMs = (\n options as {\n [LOCAL_SPAWN_TIMEOUT_MS]?: number;\n }\n )[LOCAL_SPAWN_TIMEOUT_MS];\n const timeoutMs =\n typeof spawnTimeoutMs === 'number' && Number.isFinite(spawnTimeoutMs)\n ? spawnTimeoutMs\n : ctx.timeoutMs;\n const timedCommand = withInSandboxTimeout(rendered, timeoutMs);\n const cwd =\n options.cwd == null ? ctx.workspaceRoot : options.cwd.toString();\n try {\n const result = await ctx.sandbox.exec(timedCommand, {\n cwd,\n env: ctx.env,\n timeout: outerTimeoutMs(timeoutMs),\n signal: abortController.signal,\n });\n if (state.closed) {\n return;\n }\n if (result.stdout) stdout.write(result.stdout);\n if (result.stderr) stderr.write(result.stderr);\n closeOnce(result.exitCode, null);\n } catch (error) {\n if (state.closed) {\n return;\n }\n stderr.write((error as Error).message);\n closeOnce(1, null);\n }\n })();\n\n return child;\n };\n}\n\nexport function createCloudflareLocalExecutionConfig(\n config: t.CloudflareSandboxExecutionConfig\n): t.LocalExecutionConfig {\n const workspaceRoot = getCloudflareWorkspaceRoot(config);\n return {\n cwd: workspaceRoot,\n workspace: { root: workspaceRoot },\n exec: {\n spawn: createCloudflareSpawn(config),\n fs: createCloudflareWorkspaceFS(config),\n sandboxed: true,\n },\n shell: config.shell ?? 'bash',\n timeoutMs: config.timeoutMs,\n maxOutputChars: config.maxOutputChars,\n env: config.env,\n includeCodingTools: config.includeCodingTools,\n compileCheck: config.compileCheck,\n readOnly: config.readOnly,\n allowDangerousCommands: config.allowDangerousCommands,\n bashAst: config.bashAst,\n fileCheckpointing: config.fileCheckpointing,\n maxReadBytes: config.maxReadBytes,\n attachReadAttachments: config.attachReadAttachments,\n maxAttachmentBytes: config.maxAttachmentBytes,\n postEditSyntaxCheck: config.postEditSyntaxCheck,\n };\n}\n\nexport async function validateCloudflareBashCommand(\n command: string,\n args: readonly string[],\n config: t.CloudflareSandboxExecutionConfig\n): Promise<void> {\n const localConfig = createCloudflareLocalExecutionConfig(config);\n const validation = await validateBashCommand(command, localConfig);\n if (!validation.valid) {\n throw new Error(validation.errors.join('\\n'));\n }\n\n if (\n args.length > 0 &&\n config.allowDangerousCommands !== true &&\n DESTRUCTIVE_OP_IN_COMMAND_RE.test(command)\n ) {\n const offending = args.find((arg) => PROTECTED_TARGET_ARG_RE.test(arg));\n if (offending !== undefined) {\n throw new Error(\n `Command matches a destructive command pattern (protected target \"${offending}\" passed via positional arg).`\n );\n }\n }\n}\n\nexport async function executeCloudflareBash(\n command: string,\n config: t.CloudflareSandboxExecutionConfig,\n args: readonly string[] = []\n): Promise<SpawnResult> {\n await validateCloudflareBashCommand(command, args, config);\n const ctx = await getRuntimeContext(config);\n const shellCommand =\n args.length > 0\n ? `${ctx.shell} -lc ${quote(command)} -- ${args.map(quote).join(' ')}`\n : `${ctx.shell} -lc ${quote(command)}`;\n const result = await ctx.sandbox.exec(\n withInSandboxTimeout(shellCommand, ctx.timeoutMs),\n {\n cwd: ctx.workspaceRoot,\n env: ctx.env,\n timeout: outerTimeoutMs(ctx.timeoutMs),\n }\n );\n return {\n stdout: truncateOutput(result.stdout, ctx.maxOutputChars),\n stderr: truncateOutput(result.stderr, ctx.maxOutputChars),\n exitCode: result.exitCode,\n timedOut: isInSandboxTimeoutExit(result.exitCode),\n };\n}\n\nfunction runtimeForCode(\n lang: string,\n tempDir: string,\n code: string,\n args: string[] = [],\n shell = 'bash'\n): RuntimeCommand {\n const fileFor = (name: string): string => path.join(tempDir, name);\n const argText = args.map(quote).join(' ');\n switch (lang) {\n case 'py':\n case 'python':\n return {\n fileName: 'main.py',\n source: code,\n command: `python3 ${quote(fileFor('main.py'))} ${argText}`,\n };\n case 'js':\n case 'javascript':\n return {\n fileName: 'main.js',\n source: code,\n command: `node ${quote(fileFor('main.js'))} ${argText}`,\n };\n case 'ts':\n case 'typescript':\n return {\n fileName: 'main.ts',\n source: code,\n command: `npx --no-install tsx ${quote(fileFor('main.ts'))} ${argText}`,\n };\n case 'php':\n return {\n fileName: 'main.php',\n source: code,\n command: `php ${quote(fileFor('main.php'))} ${argText}`,\n };\n case 'go':\n return {\n fileName: 'main.go',\n source: code,\n command: `go run ${quote(fileFor('main.go'))} ${argText}`,\n };\n case 'rs':\n return {\n fileName: 'main.rs',\n source: code,\n command: `${shell} -lc ${quote(\n `rustc ${quote(fileFor('main.rs'))} -o ${quote(fileFor('main-rs'))} && ${quote(fileFor('main-rs'))} ${argText}`\n )}`,\n };\n case 'c':\n return {\n fileName: 'main.c',\n source: code,\n command: `${shell} -lc ${quote(\n `cc ${quote(fileFor('main.c'))} -o ${quote(fileFor('main-c'))} && ${quote(fileFor('main-c'))} ${argText}`\n )}`,\n };\n case 'cpp':\n return {\n fileName: 'main.cpp',\n source: code,\n command: `${shell} -lc ${quote(\n `c++ ${quote(fileFor('main.cpp'))} -o ${quote(fileFor('main-cpp'))} && ${quote(fileFor('main-cpp'))} ${argText}`\n )}`,\n };\n case 'java':\n return {\n fileName: 'Main.java',\n source: code,\n command: `${shell} -lc ${quote(\n `javac ${quote(fileFor('Main.java'))} && java -cp ${quote(tempDir)} Main ${argText}`\n )}`,\n };\n case 'r':\n return {\n fileName: 'main.R',\n source: code,\n command: `Rscript ${quote(fileFor('main.R'))} ${argText}`,\n };\n case 'd':\n return {\n fileName: 'main.d',\n source: code,\n command: `${shell} -lc ${quote(\n `dmd ${quote(fileFor('main.d'))} -of=${quote(fileFor('main-d'))} && ${quote(fileFor('main-d'))} ${argText}`\n )}`,\n };\n case 'f90':\n return {\n fileName: 'main.f90',\n source: code,\n command: `${shell} -lc ${quote(\n `gfortran ${quote(fileFor('main.f90'))} -o ${quote(fileFor('main-f90'))} && ${quote(fileFor('main-f90'))} ${argText}`\n )}`,\n };\n case 'bash':\n case 'sh':\n return {\n fileName: 'main.sh',\n source: code,\n command: `${shell} -lc ${quote(code)} -- ${argText}`,\n };\n default:\n throw new Error(`Unsupported Cloudflare sandbox runtime: ${lang}`);\n }\n}\n\nexport async function executeCloudflareCode(\n input: { lang: string; code: string; args?: string[] },\n config: t.CloudflareSandboxExecutionConfig\n): Promise<SpawnResult> {\n if (input.lang === 'bash' || input.lang === 'sh') {\n return executeCloudflareBash(input.code, config, input.args ?? []);\n }\n const ctx = await getRuntimeContext(config);\n const id = globalThis.crypto.randomUUID();\n const tempDir = path.join(ctx.workspaceRoot, '.lc-exec', id);\n const runtime = runtimeForCode(\n input.lang,\n tempDir,\n input.code,\n input.args,\n ctx.shell\n );\n await ctx.sandbox.mkdir(tempDir, { recursive: true });\n if (runtime.source != null) {\n await ctx.sandbox.writeFile(\n path.join(tempDir, runtime.fileName),\n runtime.source,\n {\n encoding: 'utf8',\n }\n );\n }\n try {\n const result = await ctx.sandbox.exec(\n withInSandboxTimeout(runtime.command, ctx.timeoutMs),\n {\n cwd: ctx.workspaceRoot,\n env: ctx.env,\n timeout: outerTimeoutMs(ctx.timeoutMs),\n }\n );\n return {\n stdout: truncateOutput(result.stdout, ctx.maxOutputChars),\n stderr: truncateOutput(result.stderr, ctx.maxOutputChars),\n exitCode: result.exitCode,\n timedOut: isInSandboxTimeoutExit(result.exitCode),\n };\n } finally {\n await ctx.sandbox\n .exec(`rm -rf ${quote(tempDir)}`, {\n cwd: ctx.workspaceRoot,\n env: ctx.env,\n timeout: 10000,\n })\n .catch(() => undefined);\n }\n}\n\nexport function formatCloudflareOutput(\n result: SpawnResult,\n cwd: string\n): string {\n let formatted = '';\n if (result.stdout !== '') {\n formatted += `stdout:\\n${result.stdout}\\n`;\n } else {\n formatted += 'stdout: Empty. Ensure you\\'re writing output explicitly.\\n';\n }\n if (result.stderr !== '') {\n formatted += `stderr:\\n${result.stderr}\\n`;\n }\n if (result.exitCode != null && result.exitCode !== 0) {\n formatted += `exit_code: ${result.exitCode}\\n`;\n }\n if (result.timedOut) {\n formatted += 'timed_out: true\\n';\n }\n formatted += `working_directory: ${cwd}`;\n return formatted.trim();\n}\n"],"names":["path"],"mappings":"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"}
1
+ {"version":3,"file":"CloudflareSandboxExecutionEngine.mjs","sources":["../../../../src/tools/cloudflare/CloudflareSandboxExecutionEngine.ts"],"sourcesContent":["import { EventEmitter } from 'events';\nimport { PassThrough } from 'stream';\nimport { posix as path } from 'path';\nimport type { ChildProcessWithoutNullStreams } from 'child_process';\nimport type { WriteFileOptions, MakeDirectoryOptions, Stats } from 'fs';\nimport type { FileHandle } from 'fs/promises';\nimport type * as t from '@/types';\nimport {\n LOCAL_SPAWN_TIMEOUT_MS,\n validateBashCommand,\n} from '@/tools/local/LocalExecutionEngine';\nimport type { WorkspaceFS, ReaddirEntry } from '@/tools/local/workspaceFS';\n\nconst DEFAULT_WORKSPACE_ROOT = '/workspace';\nconst DEFAULT_TIMEOUT_MS = 60000;\nconst DEFAULT_MAX_OUTPUT_CHARS = 200000;\nconst PROTECTED_TARGET_ARG_RE = /^(?:\\/|~|\\$\\{?HOME\\}?|\\.)(?:\\/?\\.?\\*|\\/)?$/;\nconst DESTRUCTIVE_OP_IN_COMMAND_RE =\n /\\b(?:rm\\s+-[^\\s]*[rf]|chmod\\s+-R|chown\\s+-R)\\b/;\n\ntype SpawnResult = {\n stdout: string;\n stderr: string;\n exitCode: number | null;\n timedOut: boolean;\n};\n\ntype RuntimeCommand = {\n fileName: string;\n source?: string;\n command: string;\n};\n\ntype SandboxRuntimeContext = {\n sandbox: t.CloudflareSandboxRuntime;\n workspaceRoot: string;\n env?: Record<string, string | undefined>;\n timeoutMs: number;\n maxOutputChars: number;\n shell: string;\n};\n\nconst sandboxFactoryCache = new WeakMap<\n t.CloudflareSandboxExecutionConfig,\n Promise<t.CloudflareSandboxRuntime>\n>();\n\nfunction normalizeWorkspaceRoot(workspaceRoot: string): string {\n const normalized = path.normalize(workspaceRoot);\n return normalized === '/' ? normalized : normalized.replace(/\\/+$/, '');\n}\n\nexport function getCloudflareWorkspaceRoot(\n config?: t.CloudflareSandboxExecutionConfig\n): string {\n return normalizeWorkspaceRoot(\n config?.workspaceRoot ?? DEFAULT_WORKSPACE_ROOT\n );\n}\n\nexport async function resolveCloudflareSandbox(\n config: t.CloudflareSandboxExecutionConfig\n): Promise<t.CloudflareSandboxRuntime> {\n const sandbox = config.sandbox;\n if (typeof sandbox !== 'function') {\n return sandbox;\n }\n let cached = sandboxFactoryCache.get(config);\n if (cached == null) {\n cached = Promise.resolve()\n .then(() => sandbox())\n .catch((error: unknown) => {\n sandboxFactoryCache.delete(config);\n throw error;\n });\n sandboxFactoryCache.set(config, cached);\n }\n return cached;\n}\n\nasync function getRuntimeContext(\n config: t.CloudflareSandboxExecutionConfig\n): Promise<SandboxRuntimeContext> {\n return {\n sandbox: await resolveCloudflareSandbox(config),\n workspaceRoot: getCloudflareWorkspaceRoot(config),\n env: config.env,\n timeoutMs: config.timeoutMs ?? DEFAULT_TIMEOUT_MS,\n maxOutputChars: config.maxOutputChars ?? DEFAULT_MAX_OUTPUT_CHARS,\n shell: config.shell ?? 'bash',\n };\n}\n\nfunction toSandboxPath(filePath: string, workspaceRoot: string): string {\n const raw = filePath === '' ? '.' : filePath;\n const root = normalizeWorkspaceRoot(workspaceRoot);\n const resolved = raw.startsWith('/')\n ? path.normalize(raw)\n : path.resolve(root, raw);\n if (root === '/') {\n return resolved;\n }\n if (resolved === root || resolved.startsWith(`${root}/`)) {\n return resolved;\n }\n throw new Error(\n `Path is outside the Cloudflare sandbox workspace: ${filePath}`\n );\n}\n\nfunction quote(value: string): string {\n if (value === '') {\n return '\\'\\'';\n }\n if (/^[A-Za-z0-9_/:=.,@%+-]+$/.test(value)) {\n return value;\n }\n return `'${value.replace(/'/g, '\\'\\\\\\'\\'')}'`;\n}\n\nfunction withInSandboxTimeout(command: string, timeoutMs: number): string {\n const timeoutSeconds = Math.max(1, Math.ceil(timeoutMs / 1000));\n return `timeout -k 2s ${timeoutSeconds}s ${command}`;\n}\n\nfunction outerTimeoutMs(timeoutMs: number): number {\n return timeoutMs + 5000;\n}\n\nfunction isInSandboxTimeoutExit(exitCode: number | null): boolean {\n return exitCode === 124 || exitCode === 137;\n}\n\nfunction truncateOutput(value: string, maxChars: number): string {\n if (maxChars <= 0 || value.length <= maxChars) {\n return value;\n }\n const head = Math.max(Math.floor(maxChars / 2), 0);\n const tail = Math.max(maxChars - head, 0);\n return `${value.slice(0, head)}\\n...[truncated ${value.length - maxChars} chars]...\\n${value.slice(value.length - tail)}`;\n}\n\nasync function readStream(stream: ReadableStream<Uint8Array>): Promise<Buffer> {\n const reader = stream.getReader();\n const chunks: Uint8Array[] = [];\n try {\n for (;;) {\n const { done, value } = await reader.read();\n if (done) break;\n chunks.push(value);\n }\n } finally {\n reader.releaseLock();\n }\n return Buffer.concat(chunks.map((chunk) => Buffer.from(chunk)));\n}\n\nasync function normalizeReadFileContent(\n result: t.CloudflareSandboxReadFileResult\n): Promise<Buffer> {\n if (typeof result === 'string') {\n return Buffer.from(result, 'utf8');\n }\n if (Buffer.isBuffer(result)) {\n return result;\n }\n if (result instanceof Uint8Array) {\n return Buffer.from(result);\n }\n const content = result.content;\n if (typeof content === 'string') {\n if (result.encoding === 'base64') {\n return Buffer.from(content, 'base64');\n }\n return Buffer.from(content, 'utf8');\n }\n if (Buffer.isBuffer(content)) {\n return content;\n }\n if (content instanceof Uint8Array) {\n return Buffer.from(content);\n }\n return readStream(content);\n}\n\nfunction bytesToStream(bytes: Uint8Array): ReadableStream<Uint8Array> {\n return new ReadableStream<Uint8Array>({\n start(controller): void {\n controller.enqueue(bytes);\n controller.close();\n },\n });\n}\n\nfunction normalizeWriteFileContent(content: string | Buffer | Uint8Array): {\n content: string | ReadableStream<Uint8Array>;\n options?: { encoding?: string };\n} {\n if (typeof content === 'string') {\n return { content, options: { encoding: 'utf8' } };\n }\n return { content: bytesToStream(content) };\n}\n\nfunction createStats(info: {\n size?: number;\n type?: t.CloudflareSandboxFileInfo['type'];\n}): Stats {\n const type = info.type ?? 'file';\n const now = new Date();\n return {\n size: info.size ?? 0,\n isFile: () => type === 'file',\n isDirectory: () => type === 'directory',\n isSymbolicLink: () => type === 'symlink',\n isBlockDevice: () => false,\n isCharacterDevice: () => false,\n isFIFO: () => false,\n isSocket: () => false,\n dev: 0,\n ino: 0,\n mode: 0,\n nlink: 1,\n uid: 0,\n gid: 0,\n rdev: 0,\n blksize: 0,\n blocks: 0,\n atimeMs: now.getTime(),\n mtimeMs: now.getTime(),\n ctimeMs: now.getTime(),\n birthtimeMs: now.getTime(),\n atime: now,\n mtime: now,\n ctime: now,\n birthtime: now,\n } as Stats;\n}\n\nfunction normalizeFileList(\n result: t.CloudflareSandboxListFilesResult\n): t.CloudflareSandboxFileInfo[] {\n return Array.isArray(result) ? result : result.files;\n}\n\nfunction entryNameFor(\n info: t.CloudflareSandboxFileInfo,\n parentPath: string\n): string {\n if (info.name !== '') {\n return info.name.includes('/') ? path.basename(info.name) : info.name;\n }\n if (info.absolutePath != null && info.absolutePath !== '') {\n return path.basename(info.absolutePath);\n }\n if (info.relativePath != null && info.relativePath !== '') {\n return path.basename(info.relativePath);\n }\n return path.basename(parentPath);\n}\n\nfunction entryAbsolutePath(\n info: t.CloudflareSandboxFileInfo,\n parentPath: string\n): string {\n if (info.absolutePath != null && info.absolutePath !== '') {\n return path.normalize(info.absolutePath);\n }\n if (info.relativePath != null && info.relativePath !== '') {\n return path.resolve(parentPath, info.relativePath);\n }\n return path.resolve(parentPath, info.name);\n}\n\nfunction createDirent(info: t.CloudflareSandboxFileInfo): ReaddirEntry {\n return {\n name: entryNameFor(info, ''),\n isFile: () => (info.type ?? 'file') === 'file',\n isDirectory: () => info.type === 'directory',\n isSymbolicLink: () => info.type === 'symlink',\n };\n}\n\nasync function findChildInfo(\n sandbox: t.CloudflareSandboxRuntime,\n filePath: string\n): Promise<t.CloudflareSandboxFileInfo | undefined> {\n const parent = path.dirname(filePath);\n const basename = path.basename(filePath);\n const entries = normalizeFileList(\n await sandbox.listFiles(parent, { includeHidden: true })\n );\n return entries.find((entry) => {\n const absolute = entryAbsolutePath(entry, parent);\n return absolute === filePath || entryNameFor(entry, parent) === basename;\n });\n}\n\nexport function createCloudflareWorkspaceFS(\n config: t.CloudflareSandboxExecutionConfig\n): WorkspaceFS {\n const workspaceRoot = getCloudflareWorkspaceRoot(config);\n\n const fs: WorkspaceFS = {\n readFile: (async (filePath: string, encoding?: 'utf8') => {\n const sandbox = await resolveCloudflareSandbox(config);\n const resolved = toSandboxPath(filePath, workspaceRoot);\n const buffer = await normalizeReadFileContent(\n await sandbox.readFile(resolved, encoding ? { encoding } : undefined)\n );\n return encoding != null ? buffer.toString(encoding) : buffer;\n }) as WorkspaceFS['readFile'],\n writeFile: async (\n filePath: string,\n content: string | Buffer,\n _options?: WriteFileOptions\n ) => {\n const sandbox = await resolveCloudflareSandbox(config);\n const resolved = toSandboxPath(filePath, workspaceRoot);\n const normalized = normalizeWriteFileContent(content);\n await sandbox.writeFile(resolved, normalized.content, normalized.options);\n },\n stat: async (filePath: string) => {\n const sandbox = await resolveCloudflareSandbox(config);\n const resolved = toSandboxPath(filePath, workspaceRoot);\n if (resolved === workspaceRoot) {\n const entries = normalizeFileList(\n await sandbox.listFiles(resolved, { includeHidden: true })\n );\n return createStats({ size: entries.length, type: 'directory' });\n }\n const info = await findChildInfo(sandbox, resolved);\n if (info != null) {\n return createStats({ size: info.size, type: info.type });\n }\n try {\n const entries = normalizeFileList(\n await sandbox.listFiles(resolved, { includeHidden: true })\n );\n return createStats({ size: entries.length, type: 'directory' });\n } catch {\n const buffer = await normalizeReadFileContent(\n await sandbox.readFile(resolved)\n );\n return createStats({ size: buffer.length, type: 'file' });\n }\n },\n readdir: (async (filePath: string, options?: { withFileTypes: true }) => {\n const sandbox = await resolveCloudflareSandbox(config);\n const resolved = toSandboxPath(filePath, workspaceRoot);\n const entries = normalizeFileList(\n await sandbox.listFiles(resolved, { includeHidden: true })\n );\n if (options?.withFileTypes === true) {\n return entries.map(createDirent);\n }\n return entries.map((entry) => entryNameFor(entry, resolved));\n }) as WorkspaceFS['readdir'],\n mkdir: async (filePath: string, options?: MakeDirectoryOptions) => {\n const sandbox = await resolveCloudflareSandbox(config);\n await sandbox.mkdir(toSandboxPath(filePath, workspaceRoot), {\n recursive: options?.recursive,\n });\n },\n realpath: async (filePath: string) =>\n toSandboxPath(filePath, workspaceRoot),\n unlink: async (filePath: string) => {\n const sandbox = await resolveCloudflareSandbox(config);\n await sandbox.deleteFile(toSandboxPath(filePath, workspaceRoot));\n },\n open: async (filePath: string, _flags: 'r') => {\n const sandbox = await resolveCloudflareSandbox(config);\n const resolved = toSandboxPath(filePath, workspaceRoot);\n const buffer = await normalizeReadFileContent(\n await sandbox.readFile(resolved)\n );\n return {\n read: async (\n target: Buffer,\n offset: number,\n length: number,\n position: number\n ) => {\n const start = Math.max(position, 0);\n const slice = buffer.subarray(start, start + length);\n slice.copy(target, offset);\n return { bytesRead: slice.length, buffer: target };\n },\n close: async () => undefined,\n } as unknown as FileHandle;\n },\n };\n\n return fs;\n}\n\nfunction createCloudflareSpawn(\n config: t.CloudflareSandboxExecutionConfig\n): t.LocalSpawn {\n return (command, args, options) => {\n const stdout = new PassThrough();\n const stderr = new PassThrough();\n const child = new EventEmitter() as ChildProcessWithoutNullStreams;\n const abortController = new AbortController();\n const state = { closed: false };\n const closeOnce = (\n exitCode: number | null,\n signal: NodeJS.Signals | null\n ): void => {\n if (state.closed) {\n return;\n }\n state.closed = true;\n stdout.end();\n stderr.end();\n Object.assign(child, {\n exitCode,\n signalCode: signal,\n });\n child.emit('close', exitCode, signal);\n };\n Object.assign(child, {\n stdout,\n stderr,\n stdin: new PassThrough(),\n stdio: [null, stdout, stderr],\n killed: false,\n exitCode: null,\n signalCode: null,\n pid: undefined,\n kill: (signal: NodeJS.Signals = 'SIGTERM') => {\n Object.assign(child, { killed: true, signalCode: signal });\n abortController.abort();\n closeOnce(null, signal);\n return true;\n },\n });\n\n void (async (): Promise<void> => {\n const ctx = await getRuntimeContext(config);\n const rendered = [command, ...args].map(quote).join(' ');\n const spawnTimeoutMs = (\n options as {\n [LOCAL_SPAWN_TIMEOUT_MS]?: number;\n }\n )[LOCAL_SPAWN_TIMEOUT_MS];\n const timeoutMs =\n typeof spawnTimeoutMs === 'number' && Number.isFinite(spawnTimeoutMs)\n ? spawnTimeoutMs\n : ctx.timeoutMs;\n const timedCommand = withInSandboxTimeout(rendered, timeoutMs);\n const cwd =\n options.cwd == null ? ctx.workspaceRoot : options.cwd.toString();\n if (state.closed) {\n return;\n }\n const execOptions: t.CloudflareSandboxExecOptions = {\n cwd,\n env: ctx.env,\n timeout: outerTimeoutMs(timeoutMs),\n };\n if (ctx.sandbox.supportsExecSignal === true) {\n execOptions.signal = abortController.signal;\n }\n try {\n const result = await ctx.sandbox.exec(timedCommand, execOptions);\n if (state.closed) {\n return;\n }\n if (result.stdout) stdout.write(result.stdout);\n if (result.stderr) stderr.write(result.stderr);\n closeOnce(result.exitCode, null);\n } catch (error) {\n if (state.closed) {\n return;\n }\n stderr.write((error as Error).message);\n closeOnce(1, null);\n }\n })();\n\n return child;\n };\n}\n\nexport function createCloudflareLocalExecutionConfig(\n config: t.CloudflareSandboxExecutionConfig\n): t.LocalExecutionConfig {\n const workspaceRoot = getCloudflareWorkspaceRoot(config);\n return {\n cwd: workspaceRoot,\n workspace: { root: workspaceRoot },\n exec: {\n spawn: createCloudflareSpawn(config),\n fs: createCloudflareWorkspaceFS(config),\n sandboxed: true,\n },\n shell: config.shell ?? 'bash',\n timeoutMs: config.timeoutMs,\n maxOutputChars: config.maxOutputChars,\n env: config.env,\n includeCodingTools: config.includeCodingTools,\n compileCheck: config.compileCheck,\n readOnly: config.readOnly,\n allowDangerousCommands: config.allowDangerousCommands,\n bashAst: config.bashAst,\n fileCheckpointing: config.fileCheckpointing,\n maxReadBytes: config.maxReadBytes,\n attachReadAttachments: config.attachReadAttachments,\n maxAttachmentBytes: config.maxAttachmentBytes,\n postEditSyntaxCheck: config.postEditSyntaxCheck,\n };\n}\n\nexport async function validateCloudflareBashCommand(\n command: string,\n args: readonly string[],\n config: t.CloudflareSandboxExecutionConfig\n): Promise<void> {\n const localConfig = createCloudflareLocalExecutionConfig(config);\n const validation = await validateBashCommand(command, localConfig);\n if (!validation.valid) {\n throw new Error(validation.errors.join('\\n'));\n }\n\n if (\n args.length > 0 &&\n config.allowDangerousCommands !== true &&\n DESTRUCTIVE_OP_IN_COMMAND_RE.test(command)\n ) {\n const offending = args.find((arg) => PROTECTED_TARGET_ARG_RE.test(arg));\n if (offending !== undefined) {\n throw new Error(\n `Command matches a destructive command pattern (protected target \"${offending}\" passed via positional arg).`\n );\n }\n }\n}\n\nexport async function executeCloudflareBash(\n command: string,\n config: t.CloudflareSandboxExecutionConfig,\n args: readonly string[] = []\n): Promise<SpawnResult> {\n await validateCloudflareBashCommand(command, args, config);\n const ctx = await getRuntimeContext(config);\n const shellCommand =\n args.length > 0\n ? `${ctx.shell} -lc ${quote(command)} -- ${args.map(quote).join(' ')}`\n : `${ctx.shell} -lc ${quote(command)}`;\n const result = await ctx.sandbox.exec(\n withInSandboxTimeout(shellCommand, ctx.timeoutMs),\n {\n cwd: ctx.workspaceRoot,\n env: ctx.env,\n timeout: outerTimeoutMs(ctx.timeoutMs),\n }\n );\n return {\n stdout: truncateOutput(result.stdout, ctx.maxOutputChars),\n stderr: truncateOutput(result.stderr, ctx.maxOutputChars),\n exitCode: result.exitCode,\n timedOut: isInSandboxTimeoutExit(result.exitCode),\n };\n}\n\nfunction runtimeForCode(\n lang: string,\n tempDir: string,\n code: string,\n args: string[] = [],\n shell = 'bash'\n): RuntimeCommand {\n const fileFor = (name: string): string => path.join(tempDir, name);\n const argText = args.map(quote).join(' ');\n switch (lang) {\n case 'py':\n case 'python':\n return {\n fileName: 'main.py',\n source: code,\n command: `python3 ${quote(fileFor('main.py'))} ${argText}`,\n };\n case 'js':\n case 'javascript':\n return {\n fileName: 'main.js',\n source: code,\n command: `node ${quote(fileFor('main.js'))} ${argText}`,\n };\n case 'ts':\n case 'typescript':\n return {\n fileName: 'main.ts',\n source: code,\n command: `npx --no-install tsx ${quote(fileFor('main.ts'))} ${argText}`,\n };\n case 'php':\n return {\n fileName: 'main.php',\n source: code,\n command: `php ${quote(fileFor('main.php'))} ${argText}`,\n };\n case 'go':\n return {\n fileName: 'main.go',\n source: code,\n command: `go run ${quote(fileFor('main.go'))} ${argText}`,\n };\n case 'rs':\n return {\n fileName: 'main.rs',\n source: code,\n command: `${shell} -lc ${quote(\n `rustc ${quote(fileFor('main.rs'))} -o ${quote(fileFor('main-rs'))} && ${quote(fileFor('main-rs'))} ${argText}`\n )}`,\n };\n case 'c':\n return {\n fileName: 'main.c',\n source: code,\n command: `${shell} -lc ${quote(\n `cc ${quote(fileFor('main.c'))} -o ${quote(fileFor('main-c'))} && ${quote(fileFor('main-c'))} ${argText}`\n )}`,\n };\n case 'cpp':\n return {\n fileName: 'main.cpp',\n source: code,\n command: `${shell} -lc ${quote(\n `c++ ${quote(fileFor('main.cpp'))} -o ${quote(fileFor('main-cpp'))} && ${quote(fileFor('main-cpp'))} ${argText}`\n )}`,\n };\n case 'java':\n return {\n fileName: 'Main.java',\n source: code,\n command: `${shell} -lc ${quote(\n `javac ${quote(fileFor('Main.java'))} && java -cp ${quote(tempDir)} Main ${argText}`\n )}`,\n };\n case 'r':\n return {\n fileName: 'main.R',\n source: code,\n command: `Rscript ${quote(fileFor('main.R'))} ${argText}`,\n };\n case 'd':\n return {\n fileName: 'main.d',\n source: code,\n command: `${shell} -lc ${quote(\n `dmd ${quote(fileFor('main.d'))} -of=${quote(fileFor('main-d'))} && ${quote(fileFor('main-d'))} ${argText}`\n )}`,\n };\n case 'f90':\n return {\n fileName: 'main.f90',\n source: code,\n command: `${shell} -lc ${quote(\n `gfortran ${quote(fileFor('main.f90'))} -o ${quote(fileFor('main-f90'))} && ${quote(fileFor('main-f90'))} ${argText}`\n )}`,\n };\n case 'bash':\n case 'sh':\n return {\n fileName: 'main.sh',\n source: code,\n command: `${shell} -lc ${quote(code)} -- ${argText}`,\n };\n default:\n throw new Error(`Unsupported Cloudflare sandbox runtime: ${lang}`);\n }\n}\n\nexport async function executeCloudflareCode(\n input: { lang: string; code: string; args?: string[] },\n config: t.CloudflareSandboxExecutionConfig\n): Promise<SpawnResult> {\n if (input.lang === 'bash' || input.lang === 'sh') {\n return executeCloudflareBash(input.code, config, input.args ?? []);\n }\n const ctx = await getRuntimeContext(config);\n const id = globalThis.crypto.randomUUID();\n const tempDir = path.join(ctx.workspaceRoot, '.lc-exec', id);\n const runtime = runtimeForCode(\n input.lang,\n tempDir,\n input.code,\n input.args,\n ctx.shell\n );\n await ctx.sandbox.mkdir(tempDir, { recursive: true });\n if (runtime.source != null) {\n await ctx.sandbox.writeFile(\n path.join(tempDir, runtime.fileName),\n runtime.source,\n {\n encoding: 'utf8',\n }\n );\n }\n try {\n const result = await ctx.sandbox.exec(\n withInSandboxTimeout(runtime.command, ctx.timeoutMs),\n {\n cwd: ctx.workspaceRoot,\n env: ctx.env,\n timeout: outerTimeoutMs(ctx.timeoutMs),\n }\n );\n return {\n stdout: truncateOutput(result.stdout, ctx.maxOutputChars),\n stderr: truncateOutput(result.stderr, ctx.maxOutputChars),\n exitCode: result.exitCode,\n timedOut: isInSandboxTimeoutExit(result.exitCode),\n };\n } finally {\n await ctx.sandbox\n .exec(`rm -rf ${quote(tempDir)}`, {\n cwd: ctx.workspaceRoot,\n env: ctx.env,\n timeout: 10000,\n })\n .catch(() => undefined);\n }\n}\n\nexport function formatCloudflareOutput(\n result: SpawnResult,\n cwd: string\n): string {\n let formatted = '';\n if (result.stdout !== '') {\n formatted += `stdout:\\n${result.stdout}\\n`;\n } else {\n formatted += 'stdout: Empty. Ensure you\\'re writing output explicitly.\\n';\n }\n if (result.stderr !== '') {\n formatted += `stderr:\\n${result.stderr}\\n`;\n }\n if (result.exitCode != null && result.exitCode !== 0) {\n formatted += `exit_code: ${result.exitCode}\\n`;\n }\n if (result.timedOut) {\n formatted += 'timed_out: true\\n';\n }\n formatted += `working_directory: ${cwd}`;\n return formatted.trim();\n}\n"],"names":["path"],"mappings":";;;;;AAaA,MAAM,sBAAsB,GAAG,YAAY;AAC3C,MAAM,kBAAkB,GAAG,KAAK;AAChC,MAAM,wBAAwB,GAAG,MAAM;AACvC,MAAM,uBAAuB,GAAG,4CAA4C;AAC5E,MAAM,4BAA4B,GAChC,gDAAgD;AAwBlD,MAAM,mBAAmB,GAAG,IAAI,OAAO,EAGpC;AAEH,SAAS,sBAAsB,CAAC,aAAqB,EAAA;IACnD,MAAM,UAAU,GAAGA,KAAI,CAAC,SAAS,CAAC,aAAa,CAAC;AAChD,IAAA,OAAO,UAAU,KAAK,GAAG,GAAG,UAAU,GAAG,UAAU,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;AACzE;AAEM,SAAU,0BAA0B,CACxC,MAA2C,EAAA;IAE3C,OAAO,sBAAsB,CAC3B,MAAM,EAAE,aAAa,IAAI,sBAAsB,CAChD;AACH;AAEO,eAAe,wBAAwB,CAC5C,MAA0C,EAAA;AAE1C,IAAA,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO;AAC9B,IAAA,IAAI,OAAO,OAAO,KAAK,UAAU,EAAE;AACjC,QAAA,OAAO,OAAO;IAChB;IACA,IAAI,MAAM,GAAG,mBAAmB,CAAC,GAAG,CAAC,MAAM,CAAC;AAC5C,IAAA,IAAI,MAAM,IAAI,IAAI,EAAE;AAClB,QAAA,MAAM,GAAG,OAAO,CAAC,OAAO;AACrB,aAAA,IAAI,CAAC,MAAM,OAAO,EAAE;AACpB,aAAA,KAAK,CAAC,CAAC,KAAc,KAAI;AACxB,YAAA,mBAAmB,CAAC,MAAM,CAAC,MAAM,CAAC;AAClC,YAAA,MAAM,KAAK;AACb,QAAA,CAAC,CAAC;AACJ,QAAA,mBAAmB,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC;IACzC;AACA,IAAA,OAAO,MAAM;AACf;AAEA,eAAe,iBAAiB,CAC9B,MAA0C,EAAA;IAE1C,OAAO;AACL,QAAA,OAAO,EAAE,MAAM,wBAAwB,CAAC,MAAM,CAAC;AAC/C,QAAA,aAAa,EAAE,0BAA0B,CAAC,MAAM,CAAC;QACjD,GAAG,EAAE,MAAM,CAAC,GAAG;AACf,QAAA,SAAS,EAAE,MAAM,CAAC,SAAS,IAAI,kBAAkB;AACjD,QAAA,cAAc,EAAE,MAAM,CAAC,cAAc,IAAI,wBAAwB;AACjE,QAAA,KAAK,EAAE,MAAM,CAAC,KAAK,IAAI,MAAM;KAC9B;AACH;AAEA,SAAS,aAAa,CAAC,QAAgB,EAAE,aAAqB,EAAA;AAC5D,IAAA,MAAM,GAAG,GAAG,QAAQ,KAAK,EAAE,GAAG,GAAG,GAAG,QAAQ;AAC5C,IAAA,MAAM,IAAI,GAAG,sBAAsB,CAAC,aAAa,CAAC;AAClD,IAAA,MAAM,QAAQ,GAAG,GAAG,CAAC,UAAU,CAAC,GAAG;AACjC,UAAEA,KAAI,CAAC,SAAS,CAAC,GAAG;UAClBA,KAAI,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC;AAC3B,IAAA,IAAI,IAAI,KAAK,GAAG,EAAE;AAChB,QAAA,OAAO,QAAQ;IACjB;AACA,IAAA,IAAI,QAAQ,KAAK,IAAI,IAAI,QAAQ,CAAC,UAAU,CAAC,CAAA,EAAG,IAAI,CAAA,CAAA,CAAG,CAAC,EAAE;AACxD,QAAA,OAAO,QAAQ;IACjB;AACA,IAAA,MAAM,IAAI,KAAK,CACb,qDAAqD,QAAQ,CAAA,CAAE,CAChE;AACH;AAEA,SAAS,KAAK,CAAC,KAAa,EAAA;AAC1B,IAAA,IAAI,KAAK,KAAK,EAAE,EAAE;AAChB,QAAA,OAAO,MAAM;IACf;AACA,IAAA,IAAI,0BAA0B,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;AAC1C,QAAA,OAAO,KAAK;IACd;IACA,OAAO,CAAA,CAAA,EAAI,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,UAAU,CAAC,CAAA,CAAA,CAAG;AAC/C;AAEA,SAAS,oBAAoB,CAAC,OAAe,EAAE,SAAiB,EAAA;AAC9D,IAAA,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,CAAC;AAC/D,IAAA,OAAO,CAAA,cAAA,EAAiB,cAAc,CAAA,EAAA,EAAK,OAAO,EAAE;AACtD;AAEA,SAAS,cAAc,CAAC,SAAiB,EAAA;IACvC,OAAO,SAAS,GAAG,IAAI;AACzB;AAEA,SAAS,sBAAsB,CAAC,QAAuB,EAAA;AACrD,IAAA,OAAO,QAAQ,KAAK,GAAG,IAAI,QAAQ,KAAK,GAAG;AAC7C;AAEA,SAAS,cAAc,CAAC,KAAa,EAAE,QAAgB,EAAA;IACrD,IAAI,QAAQ,IAAI,CAAC,IAAI,KAAK,CAAC,MAAM,IAAI,QAAQ,EAAE;AAC7C,QAAA,OAAO,KAAK;IACd;AACA,IAAA,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;AAClD,IAAA,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,GAAG,IAAI,EAAE,CAAC,CAAC;IACzC,OAAO,CAAA,EAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,CAAA,gBAAA,EAAmB,KAAK,CAAC,MAAM,GAAG,QAAQ,CAAA,YAAA,EAAe,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,CAAA,CAAE;AAC3H;AAEA,eAAe,UAAU,CAAC,MAAkC,EAAA;AAC1D,IAAA,MAAM,MAAM,GAAG,MAAM,CAAC,SAAS,EAAE;IACjC,MAAM,MAAM,GAAiB,EAAE;AAC/B,IAAA,IAAI;AACF,QAAA,SAAS;YACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,MAAM,CAAC,IAAI,EAAE;AAC3C,YAAA,IAAI,IAAI;gBAAE;AACV,YAAA,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC;QACpB;IACF;YAAU;QACR,MAAM,CAAC,WAAW,EAAE;IACtB;IACA,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,KAAK,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;AACjE;AAEA,eAAe,wBAAwB,CACrC,MAAyC,EAAA;AAEzC,IAAA,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE;QAC9B,OAAO,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC;IACpC;AACA,IAAA,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;AAC3B,QAAA,OAAO,MAAM;IACf;AACA,IAAA,IAAI,MAAM,YAAY,UAAU,EAAE;AAChC,QAAA,OAAO,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC;IAC5B;AACA,IAAA,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO;AAC9B,IAAA,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE;AAC/B,QAAA,IAAI,MAAM,CAAC,QAAQ,KAAK,QAAQ,EAAE;YAChC,OAAO,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC;QACvC;QACA,OAAO,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC;IACrC;AACA,IAAA,IAAI,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;AAC5B,QAAA,OAAO,OAAO;IAChB;AACA,IAAA,IAAI,OAAO,YAAY,UAAU,EAAE;AACjC,QAAA,OAAO,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;IAC7B;AACA,IAAA,OAAO,UAAU,CAAC,OAAO,CAAC;AAC5B;AAEA,SAAS,aAAa,CAAC,KAAiB,EAAA;IACtC,OAAO,IAAI,cAAc,CAAa;AACpC,QAAA,KAAK,CAAC,UAAU,EAAA;AACd,YAAA,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC;YACzB,UAAU,CAAC,KAAK,EAAE;QACpB,CAAC;AACF,KAAA,CAAC;AACJ;AAEA,SAAS,yBAAyB,CAAC,OAAqC,EAAA;AAItE,IAAA,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE;QAC/B,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE;IACnD;IACA,OAAO,EAAE,OAAO,EAAE,aAAa,CAAC,OAAO,CAAC,EAAE;AAC5C;AAEA,SAAS,WAAW,CAAC,IAGpB,EAAA;AACC,IAAA,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,MAAM;AAChC,IAAA,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE;IACtB,OAAO;AACL,QAAA,IAAI,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC;AACpB,QAAA,MAAM,EAAE,MAAM,IAAI,KAAK,MAAM;AAC7B,QAAA,WAAW,EAAE,MAAM,IAAI,KAAK,WAAW;AACvC,QAAA,cAAc,EAAE,MAAM,IAAI,KAAK,SAAS;AACxC,QAAA,aAAa,EAAE,MAAM,KAAK;AAC1B,QAAA,iBAAiB,EAAE,MAAM,KAAK;AAC9B,QAAA,MAAM,EAAE,MAAM,KAAK;AACnB,QAAA,QAAQ,EAAE,MAAM,KAAK;AACrB,QAAA,GAAG,EAAE,CAAC;AACN,QAAA,GAAG,EAAE,CAAC;AACN,QAAA,IAAI,EAAE,CAAC;AACP,QAAA,KAAK,EAAE,CAAC;AACR,QAAA,GAAG,EAAE,CAAC;AACN,QAAA,GAAG,EAAE,CAAC;AACN,QAAA,IAAI,EAAE,CAAC;AACP,QAAA,OAAO,EAAE,CAAC;AACV,QAAA,MAAM,EAAE,CAAC;AACT,QAAA,OAAO,EAAE,GAAG,CAAC,OAAO,EAAE;AACtB,QAAA,OAAO,EAAE,GAAG,CAAC,OAAO,EAAE;AACtB,QAAA,OAAO,EAAE,GAAG,CAAC,OAAO,EAAE;AACtB,QAAA,WAAW,EAAE,GAAG,CAAC,OAAO,EAAE;AAC1B,QAAA,KAAK,EAAE,GAAG;AACV,QAAA,KAAK,EAAE,GAAG;AACV,QAAA,KAAK,EAAE,GAAG;AACV,QAAA,SAAS,EAAE,GAAG;KACN;AACZ;AAEA,SAAS,iBAAiB,CACxB,MAA0C,EAAA;AAE1C,IAAA,OAAO,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,MAAM,GAAG,MAAM,CAAC,KAAK;AACtD;AAEA,SAAS,YAAY,CACnB,IAAiC,EACjC,UAAkB,EAAA;AAElB,IAAA,IAAI,IAAI,CAAC,IAAI,KAAK,EAAE,EAAE;QACpB,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAGA,KAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI;IACvE;AACA,IAAA,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,IAAI,IAAI,CAAC,YAAY,KAAK,EAAE,EAAE;QACzD,OAAOA,KAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC;IACzC;AACA,IAAA,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,IAAI,IAAI,CAAC,YAAY,KAAK,EAAE,EAAE;QACzD,OAAOA,KAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC;IACzC;AACA,IAAA,OAAOA,KAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;AAClC;AAEA,SAAS,iBAAiB,CACxB,IAAiC,EACjC,UAAkB,EAAA;AAElB,IAAA,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,IAAI,IAAI,CAAC,YAAY,KAAK,EAAE,EAAE;QACzD,OAAOA,KAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC;IAC1C;AACA,IAAA,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,IAAI,IAAI,CAAC,YAAY,KAAK,EAAE,EAAE;QACzD,OAAOA,KAAI,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC;IACpD;IACA,OAAOA,KAAI,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC;AAC5C;AAEA,SAAS,YAAY,CAAC,IAAiC,EAAA;IACrD,OAAO;AACL,QAAA,IAAI,EAAE,YAAY,CAAC,IAAI,EAAE,EAAE,CAAC;AAC5B,QAAA,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,MAAM,MAAM,MAAM;QAC9C,WAAW,EAAE,MAAM,IAAI,CAAC,IAAI,KAAK,WAAW;QAC5C,cAAc,EAAE,MAAM,IAAI,CAAC,IAAI,KAAK,SAAS;KAC9C;AACH;AAEA,eAAe,aAAa,CAC1B,OAAmC,EACnC,QAAgB,EAAA;IAEhB,MAAM,MAAM,GAAGA,KAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;IACrC,MAAM,QAAQ,GAAGA,KAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;AACxC,IAAA,MAAM,OAAO,GAAG,iBAAiB,CAC/B,MAAM,OAAO,CAAC,SAAS,CAAC,MAAM,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CACzD;AACD,IAAA,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,KAAI;QAC5B,MAAM,QAAQ,GAAG,iBAAiB,CAAC,KAAK,EAAE,MAAM,CAAC;AACjD,QAAA,OAAO,QAAQ,KAAK,QAAQ,IAAI,YAAY,CAAC,KAAK,EAAE,MAAM,CAAC,KAAK,QAAQ;AAC1E,IAAA,CAAC,CAAC;AACJ;AAEM,SAAU,2BAA2B,CACzC,MAA0C,EAAA;AAE1C,IAAA,MAAM,aAAa,GAAG,0BAA0B,CAAC,MAAM,CAAC;AAExD,IAAA,MAAM,EAAE,GAAgB;QACtB,QAAQ,GAAG,OAAO,QAAgB,EAAE,QAAiB,KAAI;AACvD,YAAA,MAAM,OAAO,GAAG,MAAM,wBAAwB,CAAC,MAAM,CAAC;YACtD,MAAM,QAAQ,GAAG,aAAa,CAAC,QAAQ,EAAE,aAAa,CAAC;YACvD,MAAM,MAAM,GAAG,MAAM,wBAAwB,CAC3C,MAAM,OAAO,CAAC,QAAQ,CAAC,QAAQ,EAAE,QAAQ,GAAG,EAAE,QAAQ,EAAE,GAAG,SAAS,CAAC,CACtE;AACD,YAAA,OAAO,QAAQ,IAAI,IAAI,GAAG,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,MAAM;AAC9D,QAAA,CAAC,CAA4B;QAC7B,SAAS,EAAE,OACT,QAAgB,EAChB,OAAwB,EACxB,QAA2B,KACzB;AACF,YAAA,MAAM,OAAO,GAAG,MAAM,wBAAwB,CAAC,MAAM,CAAC;YACtD,MAAM,QAAQ,GAAG,aAAa,CAAC,QAAQ,EAAE,aAAa,CAAC;AACvD,YAAA,MAAM,UAAU,GAAG,yBAAyB,CAAC,OAAO,CAAC;AACrD,YAAA,MAAM,OAAO,CAAC,SAAS,CAAC,QAAQ,EAAE,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,OAAO,CAAC;QAC3E,CAAC;AACD,QAAA,IAAI,EAAE,OAAO,QAAgB,KAAI;AAC/B,YAAA,MAAM,OAAO,GAAG,MAAM,wBAAwB,CAAC,MAAM,CAAC;YACtD,MAAM,QAAQ,GAAG,aAAa,CAAC,QAAQ,EAAE,aAAa,CAAC;AACvD,YAAA,IAAI,QAAQ,KAAK,aAAa,EAAE;AAC9B,gBAAA,MAAM,OAAO,GAAG,iBAAiB,CAC/B,MAAM,OAAO,CAAC,SAAS,CAAC,QAAQ,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAC3D;AACD,gBAAA,OAAO,WAAW,CAAC,EAAE,IAAI,EAAE,OAAO,CAAC,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;YACjE;YACA,MAAM,IAAI,GAAG,MAAM,aAAa,CAAC,OAAO,EAAE,QAAQ,CAAC;AACnD,YAAA,IAAI,IAAI,IAAI,IAAI,EAAE;AAChB,gBAAA,OAAO,WAAW,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC;YAC1D;AACA,YAAA,IAAI;AACF,gBAAA,MAAM,OAAO,GAAG,iBAAiB,CAC/B,MAAM,OAAO,CAAC,SAAS,CAAC,QAAQ,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAC3D;AACD,gBAAA,OAAO,WAAW,CAAC,EAAE,IAAI,EAAE,OAAO,CAAC,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;YACjE;AAAE,YAAA,MAAM;AACN,gBAAA,MAAM,MAAM,GAAG,MAAM,wBAAwB,CAC3C,MAAM,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CACjC;AACD,gBAAA,OAAO,WAAW,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;YAC3D;QACF,CAAC;QACD,OAAO,GAAG,OAAO,QAAgB,EAAE,OAAiC,KAAI;AACtE,YAAA,MAAM,OAAO,GAAG,MAAM,wBAAwB,CAAC,MAAM,CAAC;YACtD,MAAM,QAAQ,GAAG,aAAa,CAAC,QAAQ,EAAE,aAAa,CAAC;AACvD,YAAA,MAAM,OAAO,GAAG,iBAAiB,CAC/B,MAAM,OAAO,CAAC,SAAS,CAAC,QAAQ,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAC3D;AACD,YAAA,IAAI,OAAO,EAAE,aAAa,KAAK,IAAI,EAAE;AACnC,gBAAA,OAAO,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC;YAClC;AACA,YAAA,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,KAAK,YAAY,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;AAC9D,QAAA,CAAC,CAA2B;AAC5B,QAAA,KAAK,EAAE,OAAO,QAAgB,EAAE,OAA8B,KAAI;AAChE,YAAA,MAAM,OAAO,GAAG,MAAM,wBAAwB,CAAC,MAAM,CAAC;YACtD,MAAM,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,QAAQ,EAAE,aAAa,CAAC,EAAE;gBAC1D,SAAS,EAAE,OAAO,EAAE,SAAS;AAC9B,aAAA,CAAC;QACJ,CAAC;AACD,QAAA,QAAQ,EAAE,OAAO,QAAgB,KAC/B,aAAa,CAAC,QAAQ,EAAE,aAAa,CAAC;AACxC,QAAA,MAAM,EAAE,OAAO,QAAgB,KAAI;AACjC,YAAA,MAAM,OAAO,GAAG,MAAM,wBAAwB,CAAC,MAAM,CAAC;YACtD,MAAM,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,EAAE,aAAa,CAAC,CAAC;QAClE,CAAC;AACD,QAAA,IAAI,EAAE,OAAO,QAAgB,EAAE,MAAW,KAAI;AAC5C,YAAA,MAAM,OAAO,GAAG,MAAM,wBAAwB,CAAC,MAAM,CAAC;YACtD,MAAM,QAAQ,GAAG,aAAa,CAAC,QAAQ,EAAE,aAAa,CAAC;AACvD,YAAA,MAAM,MAAM,GAAG,MAAM,wBAAwB,CAC3C,MAAM,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CACjC;YACD,OAAO;gBACL,IAAI,EAAE,OACJ,MAAc,EACd,MAAc,EACd,MAAc,EACd,QAAgB,KACd;oBACF,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC;AACnC,oBAAA,MAAM,KAAK,GAAG,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,KAAK,GAAG,MAAM,CAAC;AACpD,oBAAA,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC;oBAC1B,OAAO,EAAE,SAAS,EAAE,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE;gBACpD,CAAC;AACD,gBAAA,KAAK,EAAE,YAAY,SAAS;aACJ;QAC5B,CAAC;KACF;AAED,IAAA,OAAO,EAAE;AACX;AAEA,SAAS,qBAAqB,CAC5B,MAA0C,EAAA;AAE1C,IAAA,OAAO,CAAC,OAAO,EAAE,IAAI,EAAE,OAAO,KAAI;AAChC,QAAA,MAAM,MAAM,GAAG,IAAI,WAAW,EAAE;AAChC,QAAA,MAAM,MAAM,GAAG,IAAI,WAAW,EAAE;AAChC,QAAA,MAAM,KAAK,GAAG,IAAI,YAAY,EAAoC;AAClE,QAAA,MAAM,eAAe,GAAG,IAAI,eAAe,EAAE;AAC7C,QAAA,MAAM,KAAK,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE;AAC/B,QAAA,MAAM,SAAS,GAAG,CAChB,QAAuB,EACvB,MAA6B,KACrB;AACR,YAAA,IAAI,KAAK,CAAC,MAAM,EAAE;gBAChB;YACF;AACA,YAAA,KAAK,CAAC,MAAM,GAAG,IAAI;YACnB,MAAM,CAAC,GAAG,EAAE;YACZ,MAAM,CAAC,GAAG,EAAE;AACZ,YAAA,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE;gBACnB,QAAQ;AACR,gBAAA,UAAU,EAAE,MAAM;AACnB,aAAA,CAAC;YACF,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,CAAC;AACvC,QAAA,CAAC;AACD,QAAA,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE;YACnB,MAAM;YACN,MAAM;YACN,KAAK,EAAE,IAAI,WAAW,EAAE;AACxB,YAAA,KAAK,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC;AAC7B,YAAA,MAAM,EAAE,KAAK;AACb,YAAA,QAAQ,EAAE,IAAI;AACd,YAAA,UAAU,EAAE,IAAI;AAChB,YAAA,GAAG,EAAE,SAAS;AACd,YAAA,IAAI,EAAE,CAAC,MAAA,GAAyB,SAAS,KAAI;AAC3C,gBAAA,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC;gBAC1D,eAAe,CAAC,KAAK,EAAE;AACvB,gBAAA,SAAS,CAAC,IAAI,EAAE,MAAM,CAAC;AACvB,gBAAA,OAAO,IAAI;YACb,CAAC;AACF,SAAA,CAAC;QAEF,KAAK,CAAC,YAA0B;AAC9B,YAAA,MAAM,GAAG,GAAG,MAAM,iBAAiB,CAAC,MAAM,CAAC;AAC3C,YAAA,MAAM,QAAQ,GAAG,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;AACxD,YAAA,MAAM,cAAc,GAClB,OAGD,CAAC,sBAAsB,CAAC;AACzB,YAAA,MAAM,SAAS,GACb,OAAO,cAAc,KAAK,QAAQ,IAAI,MAAM,CAAC,QAAQ,CAAC,cAAc;AAClE,kBAAE;AACF,kBAAE,GAAG,CAAC,SAAS;YACnB,MAAM,YAAY,GAAG,oBAAoB,CAAC,QAAQ,EAAE,SAAS,CAAC;YAC9D,MAAM,GAAG,GACP,OAAO,CAAC,GAAG,IAAI,IAAI,GAAG,GAAG,CAAC,aAAa,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE;AAClE,YAAA,IAAI,KAAK,CAAC,MAAM,EAAE;gBAChB;YACF;AACA,YAAA,MAAM,WAAW,GAAmC;gBAClD,GAAG;gBACH,GAAG,EAAE,GAAG,CAAC,GAAG;AACZ,gBAAA,OAAO,EAAE,cAAc,CAAC,SAAS,CAAC;aACnC;YACD,IAAI,GAAG,CAAC,OAAO,CAAC,kBAAkB,KAAK,IAAI,EAAE;AAC3C,gBAAA,WAAW,CAAC,MAAM,GAAG,eAAe,CAAC,MAAM;YAC7C;AACA,YAAA,IAAI;AACF,gBAAA,MAAM,MAAM,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE,WAAW,CAAC;AAChE,gBAAA,IAAI,KAAK,CAAC,MAAM,EAAE;oBAChB;gBACF;gBACA,IAAI,MAAM,CAAC,MAAM;AAAE,oBAAA,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC;gBAC9C,IAAI,MAAM,CAAC,MAAM;AAAE,oBAAA,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC;AAC9C,gBAAA,SAAS,CAAC,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC;YAClC;YAAE,OAAO,KAAK,EAAE;AACd,gBAAA,IAAI,KAAK,CAAC,MAAM,EAAE;oBAChB;gBACF;AACA,gBAAA,MAAM,CAAC,KAAK,CAAE,KAAe,CAAC,OAAO,CAAC;AACtC,gBAAA,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC;YACpB;QACF,CAAC,GAAG;AAEJ,QAAA,OAAO,KAAK;AACd,IAAA,CAAC;AACH;AAEM,SAAU,oCAAoC,CAClD,MAA0C,EAAA;AAE1C,IAAA,MAAM,aAAa,GAAG,0BAA0B,CAAC,MAAM,CAAC;IACxD,OAAO;AACL,QAAA,GAAG,EAAE,aAAa;AAClB,QAAA,SAAS,EAAE,EAAE,IAAI,EAAE,aAAa,EAAE;AAClC,QAAA,IAAI,EAAE;AACJ,YAAA,KAAK,EAAE,qBAAqB,CAAC,MAAM,CAAC;AACpC,YAAA,EAAE,EAAE,2BAA2B,CAAC,MAAM,CAAC;AACvC,YAAA,SAAS,EAAE,IAAI;AAChB,SAAA;AACD,QAAA,KAAK,EAAE,MAAM,CAAC,KAAK,IAAI,MAAM;QAC7B,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,cAAc,EAAE,MAAM,CAAC,cAAc;QACrC,GAAG,EAAE,MAAM,CAAC,GAAG;QACf,kBAAkB,EAAE,MAAM,CAAC,kBAAkB;QAC7C,YAAY,EAAE,MAAM,CAAC,YAAY;QACjC,QAAQ,EAAE,MAAM,CAAC,QAAQ;QACzB,sBAAsB,EAAE,MAAM,CAAC,sBAAsB;QACrD,OAAO,EAAE,MAAM,CAAC,OAAO;QACvB,iBAAiB,EAAE,MAAM,CAAC,iBAAiB;QAC3C,YAAY,EAAE,MAAM,CAAC,YAAY;QACjC,qBAAqB,EAAE,MAAM,CAAC,qBAAqB;QACnD,kBAAkB,EAAE,MAAM,CAAC,kBAAkB;QAC7C,mBAAmB,EAAE,MAAM,CAAC,mBAAmB;KAChD;AACH;AAEO,eAAe,6BAA6B,CACjD,OAAe,EACf,IAAuB,EACvB,MAA0C,EAAA;AAE1C,IAAA,MAAM,WAAW,GAAG,oCAAoC,CAAC,MAAM,CAAC;IAChE,MAAM,UAAU,GAAG,MAAM,mBAAmB,CAAC,OAAO,EAAE,WAAW,CAAC;AAClE,IAAA,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE;AACrB,QAAA,MAAM,IAAI,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/C;AAEA,IAAA,IACE,IAAI,CAAC,MAAM,GAAG,CAAC;QACf,MAAM,CAAC,sBAAsB,KAAK,IAAI;AACtC,QAAA,4BAA4B,CAAC,IAAI,CAAC,OAAO,CAAC,EAC1C;AACA,QAAA,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,KAAK,uBAAuB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACvE,QAAA,IAAI,SAAS,KAAK,SAAS,EAAE;AAC3B,YAAA,MAAM,IAAI,KAAK,CACb,oEAAoE,SAAS,CAAA,6BAAA,CAA+B,CAC7G;QACH;IACF;AACF;AAEO,eAAe,qBAAqB,CACzC,OAAe,EACf,MAA0C,EAC1C,IAAA,GAA0B,EAAE,EAAA;IAE5B,MAAM,6BAA6B,CAAC,OAAO,EAAE,IAAI,EAAE,MAAM,CAAC;AAC1D,IAAA,MAAM,GAAG,GAAG,MAAM,iBAAiB,CAAC,MAAM,CAAC;AAC3C,IAAA,MAAM,YAAY,GAChB,IAAI,CAAC,MAAM,GAAG;UACV,GAAG,GAAG,CAAC,KAAK,CAAA,KAAA,EAAQ,KAAK,CAAC,OAAO,CAAC,CAAA,IAAA,EAAO,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;UAClE,CAAA,EAAG,GAAG,CAAC,KAAK,CAAA,KAAA,EAAQ,KAAK,CAAC,OAAO,CAAC,CAAA,CAAE;AAC1C,IAAA,MAAM,MAAM,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,IAAI,CACnC,oBAAoB,CAAC,YAAY,EAAE,GAAG,CAAC,SAAS,CAAC,EACjD;QACE,GAAG,EAAE,GAAG,CAAC,aAAa;QACtB,GAAG,EAAE,GAAG,CAAC,GAAG;AACZ,QAAA,OAAO,EAAE,cAAc,CAAC,GAAG,CAAC,SAAS,CAAC;AACvC,KAAA,CACF;IACD,OAAO;QACL,MAAM,EAAE,cAAc,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,cAAc,CAAC;QACzD,MAAM,EAAE,cAAc,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,cAAc,CAAC;QACzD,QAAQ,EAAE,MAAM,CAAC,QAAQ;AACzB,QAAA,QAAQ,EAAE,sBAAsB,CAAC,MAAM,CAAC,QAAQ,CAAC;KAClD;AACH;AAEA,SAAS,cAAc,CACrB,IAAY,EACZ,OAAe,EACf,IAAY,EACZ,IAAA,GAAiB,EAAE,EACnB,KAAK,GAAG,MAAM,EAAA;AAEd,IAAA,MAAM,OAAO,GAAG,CAAC,IAAY,KAAaA,KAAI,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC;AAClE,IAAA,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;IACzC,QAAQ,IAAI;AACZ,QAAA,KAAK,IAAI;AACT,QAAA,KAAK,QAAQ;YACX,OAAO;AACL,gBAAA,QAAQ,EAAE,SAAS;AACnB,gBAAA,MAAM,EAAE,IAAI;gBACZ,OAAO,EAAE,CAAA,QAAA,EAAW,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAA,CAAA,EAAI,OAAO,CAAA,CAAE;aAC3D;AACH,QAAA,KAAK,IAAI;AACT,QAAA,KAAK,YAAY;YACf,OAAO;AACL,gBAAA,QAAQ,EAAE,SAAS;AACnB,gBAAA,MAAM,EAAE,IAAI;gBACZ,OAAO,EAAE,CAAA,KAAA,EAAQ,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAA,CAAA,EAAI,OAAO,CAAA,CAAE;aACxD;AACH,QAAA,KAAK,IAAI;AACT,QAAA,KAAK,YAAY;YACf,OAAO;AACL,gBAAA,QAAQ,EAAE,SAAS;AACnB,gBAAA,MAAM,EAAE,IAAI;gBACZ,OAAO,EAAE,CAAA,qBAAA,EAAwB,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAA,CAAA,EAAI,OAAO,CAAA,CAAE;aACxE;AACH,QAAA,KAAK,KAAK;YACR,OAAO;AACL,gBAAA,QAAQ,EAAE,UAAU;AACpB,gBAAA,MAAM,EAAE,IAAI;gBACZ,OAAO,EAAE,CAAA,IAAA,EAAO,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAA,CAAA,EAAI,OAAO,CAAA,CAAE;aACxD;AACH,QAAA,KAAK,IAAI;YACP,OAAO;AACL,gBAAA,QAAQ,EAAE,SAAS;AACnB,gBAAA,MAAM,EAAE,IAAI;gBACZ,OAAO,EAAE,CAAA,OAAA,EAAU,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAA,CAAA,EAAI,OAAO,CAAA,CAAE;aAC1D;AACH,QAAA,KAAK,IAAI;YACP,OAAO;AACL,gBAAA,QAAQ,EAAE,SAAS;AACnB,gBAAA,MAAM,EAAE,IAAI;AACZ,gBAAA,OAAO,EAAE,CAAA,EAAG,KAAK,CAAA,KAAA,EAAQ,KAAK,CAC5B,CAAA,MAAA,EAAS,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,OAAO,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAA,IAAA,EAAO,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAA,CAAA,EAAI,OAAO,CAAA,CAAE,CAChH,CAAA,CAAE;aACJ;AACH,QAAA,KAAK,GAAG;YACN,OAAO;AACL,gBAAA,QAAQ,EAAE,QAAQ;AAClB,gBAAA,MAAM,EAAE,IAAI;AACZ,gBAAA,OAAO,EAAE,CAAA,EAAG,KAAK,CAAA,KAAA,EAAQ,KAAK,CAC5B,CAAA,GAAA,EAAM,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,OAAO,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAA,IAAA,EAAO,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAA,CAAA,EAAI,OAAO,CAAA,CAAE,CAC1G,CAAA,CAAE;aACJ;AACH,QAAA,KAAK,KAAK;YACR,OAAO;AACL,gBAAA,QAAQ,EAAE,UAAU;AACpB,gBAAA,MAAM,EAAE,IAAI;AACZ,gBAAA,OAAO,EAAE,CAAA,EAAG,KAAK,CAAA,KAAA,EAAQ,KAAK,CAC5B,CAAA,IAAA,EAAO,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,OAAO,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAA,IAAA,EAAO,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAA,CAAA,EAAI,OAAO,CAAA,CAAE,CACjH,CAAA,CAAE;aACJ;AACH,QAAA,KAAK,MAAM;YACT,OAAO;AACL,gBAAA,QAAQ,EAAE,WAAW;AACrB,gBAAA,MAAM,EAAE,IAAI;gBACZ,OAAO,EAAE,GAAG,KAAK,CAAA,KAAA,EAAQ,KAAK,CAC5B,CAAA,MAAA,EAAS,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAA,aAAA,EAAgB,KAAK,CAAC,OAAO,CAAC,CAAA,MAAA,EAAS,OAAO,CAAA,CAAE,CACrF,CAAA,CAAE;aACJ;AACH,QAAA,KAAK,GAAG;YACN,OAAO;AACL,gBAAA,QAAQ,EAAE,QAAQ;AAClB,gBAAA,MAAM,EAAE,IAAI;gBACZ,OAAO,EAAE,CAAA,QAAA,EAAW,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAA,CAAA,EAAI,OAAO,CAAA,CAAE;aAC1D;AACH,QAAA,KAAK,GAAG;YACN,OAAO;AACL,gBAAA,QAAQ,EAAE,QAAQ;AAClB,gBAAA,MAAM,EAAE,IAAI;AACZ,gBAAA,OAAO,EAAE,CAAA,EAAG,KAAK,CAAA,KAAA,EAAQ,KAAK,CAC5B,CAAA,IAAA,EAAO,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAA,IAAA,EAAO,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAA,CAAA,EAAI,OAAO,CAAA,CAAE,CAC5G,CAAA,CAAE;aACJ;AACH,QAAA,KAAK,KAAK;YACR,OAAO;AACL,gBAAA,QAAQ,EAAE,UAAU;AACpB,gBAAA,MAAM,EAAE,IAAI;AACZ,gBAAA,OAAO,EAAE,CAAA,EAAG,KAAK,CAAA,KAAA,EAAQ,KAAK,CAC5B,CAAA,SAAA,EAAY,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,OAAO,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAA,IAAA,EAAO,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAA,CAAA,EAAI,OAAO,CAAA,CAAE,CACtH,CAAA,CAAE;aACJ;AACH,QAAA,KAAK,MAAM;AACX,QAAA,KAAK,IAAI;YACP,OAAO;AACL,gBAAA,QAAQ,EAAE,SAAS;AACnB,gBAAA,MAAM,EAAE,IAAI;gBACZ,OAAO,EAAE,CAAA,EAAG,KAAK,CAAA,KAAA,EAAQ,KAAK,CAAC,IAAI,CAAC,CAAA,IAAA,EAAO,OAAO,CAAA,CAAE;aACrD;AACH,QAAA;AACE,YAAA,MAAM,IAAI,KAAK,CAAC,2CAA2C,IAAI,CAAA,CAAE,CAAC;;AAEtE;AAEO,eAAe,qBAAqB,CACzC,KAAsD,EACtD,MAA0C,EAAA;AAE1C,IAAA,IAAI,KAAK,CAAC,IAAI,KAAK,MAAM,IAAI,KAAK,CAAC,IAAI,KAAK,IAAI,EAAE;AAChD,QAAA,OAAO,qBAAqB,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC;IACpE;AACA,IAAA,MAAM,GAAG,GAAG,MAAM,iBAAiB,CAAC,MAAM,CAAC;IAC3C,MAAM,EAAE,GAAG,UAAU,CAAC,MAAM,CAAC,UAAU,EAAE;AACzC,IAAA,MAAM,OAAO,GAAGA,KAAI,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,UAAU,EAAE,EAAE,CAAC;IAC5D,MAAM,OAAO,GAAG,cAAc,CAC5B,KAAK,CAAC,IAAI,EACV,OAAO,EACP,KAAK,CAAC,IAAI,EACV,KAAK,CAAC,IAAI,EACV,GAAG,CAAC,KAAK,CACV;AACD,IAAA,MAAM,GAAG,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;AACrD,IAAA,IAAI,OAAO,CAAC,MAAM,IAAI,IAAI,EAAE;QAC1B,MAAM,GAAG,CAAC,OAAO,CAAC,SAAS,CACzBA,KAAI,CAAC,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAC,EACpC,OAAO,CAAC,MAAM,EACd;AACE,YAAA,QAAQ,EAAE,MAAM;AACjB,SAAA,CACF;IACH;AACA,IAAA,IAAI;AACF,QAAA,MAAM,MAAM,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,IAAI,CACnC,oBAAoB,CAAC,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,SAAS,CAAC,EACpD;YACE,GAAG,EAAE,GAAG,CAAC,aAAa;YACtB,GAAG,EAAE,GAAG,CAAC,GAAG;AACZ,YAAA,OAAO,EAAE,cAAc,CAAC,GAAG,CAAC,SAAS,CAAC;AACvC,SAAA,CACF;QACD,OAAO;YACL,MAAM,EAAE,cAAc,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,cAAc,CAAC;YACzD,MAAM,EAAE,cAAc,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,cAAc,CAAC;YACzD,QAAQ,EAAE,MAAM,CAAC,QAAQ;AACzB,YAAA,QAAQ,EAAE,sBAAsB,CAAC,MAAM,CAAC,QAAQ,CAAC;SAClD;IACH;YAAU;QACR,MAAM,GAAG,CAAC;AACP,aAAA,IAAI,CAAC,CAAA,OAAA,EAAU,KAAK,CAAC,OAAO,CAAC,EAAE,EAAE;YAChC,GAAG,EAAE,GAAG,CAAC,aAAa;YACtB,GAAG,EAAE,GAAG,CAAC,GAAG;AACZ,YAAA,OAAO,EAAE,KAAK;SACf;AACA,aAAA,KAAK,CAAC,MAAM,SAAS,CAAC;IAC3B;AACF;AAEM,SAAU,sBAAsB,CACpC,MAAmB,EACnB,GAAW,EAAA;IAEX,IAAI,SAAS,GAAG,EAAE;AAClB,IAAA,IAAI,MAAM,CAAC,MAAM,KAAK,EAAE,EAAE;AACxB,QAAA,SAAS,IAAI,CAAA,SAAA,EAAY,MAAM,CAAC,MAAM,IAAI;IAC5C;SAAO;QACL,SAAS,IAAI,4DAA4D;IAC3E;AACA,IAAA,IAAI,MAAM,CAAC,MAAM,KAAK,EAAE,EAAE;AACxB,QAAA,SAAS,IAAI,CAAA,SAAA,EAAY,MAAM,CAAC,MAAM,IAAI;IAC5C;AACA,IAAA,IAAI,MAAM,CAAC,QAAQ,IAAI,IAAI,IAAI,MAAM,CAAC,QAAQ,KAAK,CAAC,EAAE;AACpD,QAAA,SAAS,IAAI,CAAA,WAAA,EAAc,MAAM,CAAC,QAAQ,IAAI;IAChD;AACA,IAAA,IAAI,MAAM,CAAC,QAAQ,EAAE;QACnB,SAAS,IAAI,mBAAmB;IAClC;AACA,IAAA,SAAS,IAAI,CAAA,mBAAA,EAAsB,GAAG,CAAA,CAAE;AACxC,IAAA,OAAO,SAAS,CAAC,IAAI,EAAE;AACzB;;;;"}
@@ -0,0 +1,24 @@
1
+ import { ensureHandler } from '@langchain/core/callbacks/manager';
2
+
3
+ function appendCallbacks(callbacks, additions) {
4
+ if (additions.length === 0) {
5
+ return callbacks ?? [];
6
+ }
7
+ if (callbacks == null) {
8
+ return [...additions];
9
+ }
10
+ if (Array.isArray(callbacks)) {
11
+ return callbacks.concat(additions);
12
+ }
13
+ return callbacks.copy(additions.map(ensureHandler));
14
+ }
15
+ function findCallback(callbacks, predicate) {
16
+ if (callbacks == null) {
17
+ return undefined;
18
+ }
19
+ const handlers = Array.isArray(callbacks) ? callbacks : callbacks.handlers;
20
+ return handlers.find(predicate);
21
+ }
22
+
23
+ export { appendCallbacks, findCallback };
24
+ //# sourceMappingURL=callbacks.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"callbacks.mjs","sources":["../../../src/utils/callbacks.ts"],"sourcesContent":["import { ensureHandler } from '@langchain/core/callbacks/manager';\nimport type {\n BaseCallbackHandler,\n CallbackHandlerMethods,\n} from '@langchain/core/callbacks/base';\nimport type { Callbacks } from '@langchain/core/callbacks/manager';\n\nexport type CallbackEntry = BaseCallbackHandler | CallbackHandlerMethods;\n\nexport function appendCallbacks(\n callbacks: Callbacks | undefined,\n additions: readonly CallbackEntry[]\n): Callbacks {\n if (additions.length === 0) {\n return callbacks ?? [];\n }\n\n if (callbacks == null) {\n return [...additions];\n }\n\n if (Array.isArray(callbacks)) {\n return callbacks.concat(additions);\n }\n\n return callbacks.copy(additions.map(ensureHandler));\n}\n\nexport function findCallback(\n callbacks: Callbacks | undefined,\n predicate: (callback: CallbackEntry) => boolean\n): CallbackEntry | undefined {\n if (callbacks == null) {\n return undefined;\n }\n\n const handlers = Array.isArray(callbacks) ? callbacks : callbacks.handlers;\n return handlers.find(predicate);\n}\n"],"names":[],"mappings":";;AASM,SAAU,eAAe,CAC7B,SAAgC,EAChC,SAAmC,EAAA;AAEnC,IAAA,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;QAC1B,OAAO,SAAS,IAAI,EAAE;IACxB;AAEA,IAAA,IAAI,SAAS,IAAI,IAAI,EAAE;AACrB,QAAA,OAAO,CAAC,GAAG,SAAS,CAAC;IACvB;AAEA,IAAA,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;AAC5B,QAAA,OAAO,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC;IACpC;IAEA,OAAO,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;AACrD;AAEM,SAAU,YAAY,CAC1B,SAAgC,EAChC,SAA+C,EAAA;AAE/C,IAAA,IAAI,SAAS,IAAI,IAAI,EAAE;AACrB,QAAA,OAAO,SAAS;IAClB;AAEA,IAAA,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,SAAS,GAAG,SAAS,CAAC,QAAQ;AAC1E,IAAA,OAAO,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC;AACjC;;;;"}
@@ -4,11 +4,12 @@ import type { Serialized } from '@langchain/core/load/serializable';
4
4
  import type { BaseMessage } from '@langchain/core/messages';
5
5
  import type { LLMResult } from '@langchain/core/outputs';
6
6
  import type * as t from '@/types';
7
- type TraceMetadata = Record<string, unknown>;
7
+ export type LangfuseTraceMetadata = Record<string, string>;
8
8
  type LangfuseHandlerParams = {
9
9
  userId?: string;
10
10
  sessionId?: string;
11
- traceMetadata?: TraceMetadata;
11
+ traceMetadata?: LangfuseTraceMetadata;
12
+ tags?: string[];
12
13
  };
13
14
  type AgentLangfuseHandlerParams = LangfuseHandlerParams & {
14
15
  langfuse?: t.LangfuseConfig;
@@ -18,6 +19,13 @@ type ResolvedLangfuseConfig = t.LangfuseConfig & {
18
19
  publicKey: string;
19
20
  secretKey: string;
20
21
  };
22
+ export declare function createLangfuseTraceMetadata({ messageId, parentMessageId, agentId, agentName, }: {
23
+ messageId?: unknown;
24
+ parentMessageId?: unknown;
25
+ agentId?: unknown;
26
+ agentName?: unknown;
27
+ }): LangfuseTraceMetadata;
28
+ export declare function getLangfuseTraceName(traceMetadata?: LangfuseTraceMetadata, fallback?: string): string;
21
29
  export declare class LangfuseAgentCallbackHandler extends BaseCallbackHandler {
22
30
  name: string;
23
31
  private readonly provider;
@@ -25,8 +33,9 @@ export declare class LangfuseAgentCallbackHandler extends BaseCallbackHandler {
25
33
  private readonly userId?;
26
34
  private readonly sessionId?;
27
35
  private readonly traceMetadata?;
36
+ private readonly tags?;
28
37
  private readonly spans;
29
- constructor({ langfuse, userId, sessionId, traceMetadata, }: LangfuseHandlerParams & {
38
+ constructor({ langfuse, userId, sessionId, traceMetadata, tags, }: LangfuseHandlerParams & {
30
39
  langfuse: ResolvedLangfuseConfig;
31
40
  });
32
41
  private startGenerationSpan;
@@ -38,7 +47,7 @@ export declare class LangfuseAgentCallbackHandler extends BaseCallbackHandler {
38
47
  dispose(): Promise<void>;
39
48
  }
40
49
  export declare function createLegacyLangfuseHandler(params: LangfuseHandlerParams): CallbackHandler;
41
- export declare function createLangfuseHandler({ langfuse, userId, sessionId, traceMetadata, }: AgentLangfuseHandlerParams): LangfuseAgentCallbackHandler | undefined;
50
+ export declare function createLangfuseHandler({ langfuse, userId, sessionId, traceMetadata, tags, }: AgentLangfuseHandlerParams): LangfuseAgentCallbackHandler | undefined;
42
51
  export declare function hasExplicitLangfuseConfig(contexts: Iterable<{
43
52
  langfuse?: t.LangfuseConfig;
44
53
  }>): boolean;
@@ -2,7 +2,7 @@ import type * as z from 'zod';
2
2
  import type { BaseMessage } from '@langchain/core/messages';
3
3
  import type { StructuredTool } from '@langchain/core/tools';
4
4
  import type { RunnableConfig } from '@langchain/core/runnables';
5
- import type { BaseCallbackHandler, CallbackHandlerMethods } from '@langchain/core/callbacks/base';
5
+ import type { Callbacks } from '@langchain/core/callbacks/manager';
6
6
  import type * as s from '@/types/stream';
7
7
  import type * as e from '@/common/enum';
8
8
  import type * as g from '@/types/graph';
@@ -195,7 +195,7 @@ export type RunConfig = {
195
195
  */
196
196
  humanInTheLoop?: HumanInTheLoopConfig;
197
197
  };
198
- export type ProvidedCallbacks = (BaseCallbackHandler | CallbackHandlerMethods)[] | undefined;
198
+ export type ProvidedCallbacks = Callbacks | undefined;
199
199
  export type TokenCounter = (message: BaseMessage) => number;
200
200
  /** Structured breakdown of how context token budget is consumed. */
201
201
  export type TokenBudgetBreakdown = {
@@ -791,6 +791,12 @@ export type CloudflareSandboxListFilesResult = CloudflareSandboxFileInfo[] | {
791
791
  success?: boolean;
792
792
  };
793
793
  export interface CloudflareSandboxRuntime {
794
+ /**
795
+ * True when this runtime can consume AbortSignal values in exec options.
796
+ * Native Cloudflare Sandbox Durable Object RPC cannot clone AbortSignal,
797
+ * but HTTP bridge runtimes can use it to abort the underlying fetch.
798
+ */
799
+ supportsExecSignal?: boolean;
794
800
  exec(command: string, options?: CloudflareSandboxExecOptions): Promise<CloudflareSandboxExecResult>;
795
801
  readFile(path: string, options?: {
796
802
  encoding?: string;
@@ -0,0 +1,5 @@
1
+ import type { BaseCallbackHandler, CallbackHandlerMethods } from '@langchain/core/callbacks/base';
2
+ import type { Callbacks } from '@langchain/core/callbacks/manager';
3
+ export type CallbackEntry = BaseCallbackHandler | CallbackHandlerMethods;
4
+ export declare function appendCallbacks(callbacks: Callbacks | undefined, additions: readonly CallbackEntry[]): Callbacks;
5
+ export declare function findCallback(callbacks: Callbacks | undefined, predicate: (callback: CallbackEntry) => boolean): CallbackEntry | undefined;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@librechat/agents",
3
- "version": "3.1.91",
3
+ "version": "3.1.93",
4
4
  "main": "./dist/cjs/main.cjs",
5
5
  "module": "./dist/esm/main.mjs",
6
6
  "types": "./dist/types/index.d.ts",
@@ -227,9 +227,9 @@
227
227
  "@langchain/openai": "1.4.5",
228
228
  "@langchain/textsplitters": "^1.0.1",
229
229
  "@langchain/xai": "^1.3.17",
230
- "@langfuse/langchain": "^4.6.1",
231
- "@langfuse/otel": "^4.6.1",
232
- "@langfuse/tracing": "^4.6.1",
230
+ "@langfuse/langchain": "^5.3.0",
231
+ "@langfuse/otel": "^5.3.0",
232
+ "@langfuse/tracing": "^5.3.0",
233
233
  "@opentelemetry/sdk-node": "^0.218.0",
234
234
  "@scarf/scarf": "^1.4.0",
235
235
  "@types/diff": "^7.0.2",
@@ -52,6 +52,7 @@ import { attemptInvoke, tryFallbackProviders } from '@/llm/invoke';
52
52
  import { shouldTriggerSummarization } from '@/summarization';
53
53
  import { createSummarizeNode } from '@/summarization/node';
54
54
  import { messagesStateReducer } from '@/messages/reducer';
55
+ import { appendCallbacks } from '@/utils/callbacks';
55
56
  import { createSchemaOnlyTools } from '@/tools/schema';
56
57
  import { AgentContext } from '@/agents/AgentContext';
57
58
  import { createFakeStreamingLLM } from '@/llm/fake';
@@ -61,7 +62,11 @@ import { createLocalCodingToolBundle } from '@/tools/local/LocalCodingTools';
61
62
  import { createCloudflareCodingToolBundle } from '@/tools/cloudflare';
62
63
  import { isThinkingEnabled } from '@/llm/request';
63
64
  import { initializeModel } from '@/llm/init';
64
- import { createLangfuseHandler, disposeLangfuseHandler } from '@/langfuse';
65
+ import {
66
+ createLangfuseHandler,
67
+ disposeLangfuseHandler,
68
+ createLangfuseTraceMetadata,
69
+ } from '@/langfuse';
65
70
  import { HandlerRegistry } from '@/events';
66
71
  import { ChatOpenAI } from '@/llm/openai';
67
72
  import { partitionAndMarkOpenRouterToolCache } from '@/llm/openrouter/toolCache';
@@ -1337,19 +1342,18 @@ export class StandardGraph extends Graph<t.BaseGraphState, t.GraphNode> {
1337
1342
  langfuse: agentContext.langfuse,
1338
1343
  userId: config.configurable?.user_id as string | undefined,
1339
1344
  sessionId: config.configurable?.thread_id as string | undefined,
1340
- traceMetadata: {
1345
+ traceMetadata: createLangfuseTraceMetadata({
1341
1346
  messageId: this.runId,
1342
1347
  parentMessageId: config.configurable?.requestBody?.parentMessageId,
1343
1348
  agentId,
1344
1349
  agentName: agentContext.name,
1345
- },
1350
+ }),
1351
+ tags: ['librechat', 'agent'],
1346
1352
  });
1347
1353
  const invokeConfig = langfuseHandler
1348
1354
  ? {
1349
1355
  ...config,
1350
- callbacks: ((config.callbacks as t.ProvidedCallbacks) ?? []).concat(
1351
- [langfuseHandler]
1352
- ),
1356
+ callbacks: appendCallbacks(config.callbacks, [langfuseHandler]),
1353
1357
  }
1354
1358
  : config;
1355
1359
 
@@ -5,14 +5,9 @@ import { isPresent } from '@/utils/misc';
5
5
  if (
6
6
  isPresent(process.env.LANGFUSE_SECRET_KEY) &&
7
7
  isPresent(process.env.LANGFUSE_PUBLIC_KEY) &&
8
- isPresent(process.env.LANGFUSE_BASE_URL)
8
+ isPresent(process.env.LANGFUSE_BASE_URL ?? process.env.LANGFUSE_BASEURL)
9
9
  ) {
10
- const langfuseSpanProcessor = new LangfuseSpanProcessor({
11
- publicKey: process.env.LANGFUSE_PUBLIC_KEY,
12
- secretKey: process.env.LANGFUSE_SECRET_KEY,
13
- baseUrl: process.env.LANGFUSE_BASE_URL,
14
- environment: process.env.LANGFUSE_TRACING_ENVIRONMENT ?? process.env.NODE_ENV ?? 'development',
15
- });
10
+ const langfuseSpanProcessor = new LangfuseSpanProcessor();
16
11
 
17
12
  const sdk = new NodeSDK({
18
13
  spanProcessors: [langfuseSpanProcessor],
package/src/langfuse.ts CHANGED
@@ -1,8 +1,8 @@
1
1
  import { CallbackHandler } from '@langfuse/langchain';
2
- import { LangfuseSpanProcessor } from '@langfuse/otel';
2
+ import { isDefaultExportSpan, LangfuseSpanProcessor } from '@langfuse/otel';
3
3
  import {
4
+ LangfuseOtelSpanAttributes,
4
5
  createObservationAttributes,
5
- createTraceAttributes,
6
6
  } from '@langfuse/tracing';
7
7
  import { BaseCallbackHandler } from '@langchain/core/callbacks/base';
8
8
  import { BasicTracerProvider } from '@opentelemetry/sdk-trace-base';
@@ -10,16 +10,20 @@ import { SpanStatusCode } from '@opentelemetry/api';
10
10
  import type { Serialized } from '@langchain/core/load/serializable';
11
11
  import type { BaseMessage } from '@langchain/core/messages';
12
12
  import type { LLMResult } from '@langchain/core/outputs';
13
- import type { Span } from '@opentelemetry/api';
13
+ import type { Attributes, Span } from '@opentelemetry/api';
14
14
  import type * as t from '@/types';
15
15
  import { isPresent } from '@/utils/misc';
16
16
 
17
- type TraceMetadata = Record<string, unknown>;
17
+ const TRACE_METADATA_MAX_LENGTH = 200;
18
+ const LANGFUSE_TRACER_NAME = 'langfuse-sdk';
19
+
20
+ export type LangfuseTraceMetadata = Record<string, string>;
18
21
 
19
22
  type LangfuseHandlerParams = {
20
23
  userId?: string;
21
24
  sessionId?: string;
22
- traceMetadata?: TraceMetadata;
25
+ traceMetadata?: LangfuseTraceMetadata;
26
+ tags?: string[];
23
27
  };
24
28
 
25
29
  type AgentLangfuseHandlerParams = LangfuseHandlerParams & {
@@ -32,6 +36,49 @@ type ResolvedLangfuseConfig = t.LangfuseConfig & {
32
36
  secretKey: string;
33
37
  };
34
38
 
39
+ function getEnvLangfuseBaseUrl(): string | undefined {
40
+ return process.env.LANGFUSE_BASE_URL ?? process.env.LANGFUSE_BASEURL;
41
+ }
42
+
43
+ function createTraceMetadata(
44
+ metadata: Record<string, unknown>
45
+ ): LangfuseTraceMetadata {
46
+ const traceMetadata: LangfuseTraceMetadata = {};
47
+ for (const [key, value] of Object.entries(metadata)) {
48
+ if (value == null) {
49
+ continue;
50
+ }
51
+ const stringValue = typeof value === 'string' ? value : String(value);
52
+ if (
53
+ stringValue.trim() === '' ||
54
+ stringValue.length > TRACE_METADATA_MAX_LENGTH
55
+ ) {
56
+ continue;
57
+ }
58
+ traceMetadata[key] = stringValue;
59
+ }
60
+ return traceMetadata;
61
+ }
62
+
63
+ export function createLangfuseTraceMetadata({
64
+ messageId,
65
+ parentMessageId,
66
+ agentId,
67
+ agentName,
68
+ }: {
69
+ messageId?: unknown;
70
+ parentMessageId?: unknown;
71
+ agentId?: unknown;
72
+ agentName?: unknown;
73
+ }): LangfuseTraceMetadata {
74
+ return createTraceMetadata({
75
+ messageId,
76
+ parentMessageId,
77
+ agentId,
78
+ agentName,
79
+ });
80
+ }
81
+
35
82
  function getModelName(serialized: Serialized): string {
36
83
  const serializedRecord = serialized as unknown as Record<string, unknown>;
37
84
  const kwargs = serializedRecord.kwargs as Record<string, unknown> | undefined;
@@ -99,11 +146,39 @@ function getUsageDetails(
99
146
  : undefined;
100
147
  }
101
148
 
102
- function getTraceName(traceMetadata?: TraceMetadata): string {
149
+ export function getLangfuseTraceName(
150
+ traceMetadata?: LangfuseTraceMetadata,
151
+ fallback: string = 'LibreChat Agent'
152
+ ): string {
103
153
  const agentName = traceMetadata?.agentName;
104
- return typeof agentName === 'string' && agentName.trim() !== ''
105
- ? `LibreChat Agent: ${agentName}`
106
- : 'LibreChat Agent';
154
+ return isPresent(agentName) ? `${fallback}: ${agentName}` : fallback;
155
+ }
156
+
157
+ function getTraceAttributes({
158
+ userId,
159
+ sessionId,
160
+ traceMetadata,
161
+ tags,
162
+ }: LangfuseHandlerParams): Attributes {
163
+ const attributes: Attributes = {
164
+ [LangfuseOtelSpanAttributes.TRACE_NAME]:
165
+ getLangfuseTraceName(traceMetadata),
166
+ };
167
+
168
+ if (isPresent(userId)) {
169
+ attributes[LangfuseOtelSpanAttributes.TRACE_USER_ID] = userId;
170
+ }
171
+ if (isPresent(sessionId)) {
172
+ attributes[LangfuseOtelSpanAttributes.TRACE_SESSION_ID] = sessionId;
173
+ }
174
+ if (tags != null && tags.length > 0) {
175
+ attributes[LangfuseOtelSpanAttributes.TRACE_TAGS] = tags;
176
+ }
177
+ for (const [key, value] of Object.entries(traceMetadata ?? {})) {
178
+ attributes[`${LangfuseOtelSpanAttributes.TRACE_METADATA}.${key}`] = value;
179
+ }
180
+
181
+ return attributes;
107
182
  }
108
183
 
109
184
  export class LangfuseAgentCallbackHandler extends BaseCallbackHandler {
@@ -113,7 +188,8 @@ export class LangfuseAgentCallbackHandler extends BaseCallbackHandler {
113
188
  private readonly processor: LangfuseSpanProcessor;
114
189
  private readonly userId?: string;
115
190
  private readonly sessionId?: string;
116
- private readonly traceMetadata?: TraceMetadata;
191
+ private readonly traceMetadata?: LangfuseTraceMetadata;
192
+ private readonly tags?: string[];
117
193
  private readonly spans = new Map<string, Span>();
118
194
 
119
195
  constructor({
@@ -121,11 +197,13 @@ export class LangfuseAgentCallbackHandler extends BaseCallbackHandler {
121
197
  userId,
122
198
  sessionId,
123
199
  traceMetadata,
200
+ tags,
124
201
  }: LangfuseHandlerParams & { langfuse: ResolvedLangfuseConfig }) {
125
202
  super();
126
203
  this.userId = userId;
127
204
  this.sessionId = sessionId;
128
205
  this.traceMetadata = traceMetadata;
206
+ this.tags = tags;
129
207
  this.processor = new LangfuseSpanProcessor({
130
208
  publicKey: langfuse.publicKey,
131
209
  secretKey: langfuse.secretKey,
@@ -135,6 +213,9 @@ export class LangfuseAgentCallbackHandler extends BaseCallbackHandler {
135
213
  process.env.NODE_ENV ??
136
214
  'development',
137
215
  exportMode: 'immediate',
216
+ shouldExportSpan: ({ otelSpan }): boolean =>
217
+ isDefaultExportSpan(otelSpan) ||
218
+ otelSpan.instrumentationScope.name === LANGFUSE_TRACER_NAME,
138
219
  });
139
220
  this.provider = new BasicTracerProvider({
140
221
  spanProcessors: [this.processor],
@@ -160,16 +241,16 @@ export class LangfuseAgentCallbackHandler extends BaseCallbackHandler {
160
241
  return;
161
242
  }
162
243
 
163
- const tracer = this.provider.getTracer('librechat-agents-langfuse');
244
+ const tracer = this.provider.getTracer(LANGFUSE_TRACER_NAME);
164
245
  const spanName =
165
246
  typeof name === 'string' && name.trim() !== '' ? name : getModelName(llm);
166
247
  const span = tracer.startSpan(spanName, {
167
248
  attributes: {
168
- ...createTraceAttributes({
169
- name: getTraceName(this.traceMetadata),
249
+ ...getTraceAttributes({
170
250
  userId: this.userId,
171
251
  sessionId: this.sessionId,
172
- metadata: this.traceMetadata,
252
+ traceMetadata: this.traceMetadata,
253
+ tags: this.tags,
173
254
  }),
174
255
  ...createObservationAttributes('generation', {
175
256
  input,
@@ -312,6 +393,7 @@ export function createLangfuseHandler({
312
393
  userId,
313
394
  sessionId,
314
395
  traceMetadata,
396
+ tags,
315
397
  }: AgentLangfuseHandlerParams): LangfuseAgentCallbackHandler | undefined {
316
398
  if (!hasRequiredLangfuseConfig(langfuse)) {
317
399
  return undefined;
@@ -322,6 +404,7 @@ export function createLangfuseHandler({
322
404
  userId,
323
405
  sessionId,
324
406
  traceMetadata,
407
+ tags,
325
408
  });
326
409
  }
327
410
 
@@ -340,7 +423,7 @@ export function hasLangfuseEnvConfig(): boolean {
340
423
  return (
341
424
  isPresent(process.env.LANGFUSE_SECRET_KEY) &&
342
425
  isPresent(process.env.LANGFUSE_PUBLIC_KEY) &&
343
- isPresent(process.env.LANGFUSE_BASE_URL)
426
+ isPresent(getEnvLangfuseBaseUrl())
344
427
  );
345
428
  }
346
429