@prefactor/core 0.2.5 → 0.2.7
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.
- package/README.md +1 -1
- package/dist/config.d.ts +10 -156
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +2 -2
- package/dist/config.js.map +1 -1
- package/dist/index.cjs +80 -26
- package/dist/index.cjs.map +10 -9
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +80 -26
- package/dist/index.js.map +10 -9
- package/dist/queue/actions.d.ts +2 -2
- package/dist/queue/actions.d.ts.map +1 -1
- package/dist/tracing/result-payload.d.ts +3 -0
- package/dist/tracing/result-payload.d.ts.map +1 -0
- package/dist/tracing/result-payload.js +11 -0
- package/dist/tracing/result-payload.js.map +1 -0
- package/dist/tracing/span.d.ts +1 -0
- package/dist/tracing/span.d.ts.map +1 -1
- package/dist/tracing/span.js +3 -0
- package/dist/tracing/span.js.map +1 -1
- package/dist/tracing/tracer.d.ts.map +1 -1
- package/dist/tracing/tracer.js +6 -1
- package/dist/tracing/tracer.js.map +1 -1
- package/dist/tracing/with-span.js +18 -2
- package/dist/tracing/with-span.js.map +1 -1
- package/dist/transport/http/agent-span-client.d.ts +7 -1
- package/dist/transport/http/agent-span-client.d.ts.map +1 -1
- package/dist/transport/http/agent-span-client.js +5 -2
- package/dist/transport/http/agent-span-client.js.map +1 -1
- package/dist/transport/http.d.ts +7 -2
- package/dist/transport/http.d.ts.map +1 -1
- package/dist/transport/http.js +34 -18
- package/dist/transport/http.js.map +1 -1
- package/package.json +6 -4
package/dist/index.cjs.map
CHANGED
|
@@ -1,27 +1,28 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../src/agent/instance-manager.ts", "../src/config.ts", "../src/create-core.ts", "../src/tracing/active-tracer.ts", "../src/lifecycle.ts", "../src/tracing/tracer.ts", "../src/tracing/context.ts", "../src/tracing/span.ts", "../src/queue/in-memory-queue.ts", "../src/queue/task-executor.ts", "../src/utils/logging.ts", "../src/transport/http/agent-instance-client.ts", "../src/transport/http/retry-policy.ts", "../src/transport/http/http-client.ts", "../src/transport/http/agent-span-client.ts", "../src/transport/http.ts", "../src/tracing/with-span.ts", "../src/utils/serialization.ts"],
|
|
3
|
+
"sources": ["../src/agent/instance-manager.ts", "../src/config.ts", "../src/create-core.ts", "../src/tracing/active-tracer.ts", "../src/lifecycle.ts", "../src/tracing/tracer.ts", "../src/tracing/context.ts", "../src/tracing/result-payload.ts", "../src/tracing/span.ts", "../src/queue/in-memory-queue.ts", "../src/queue/task-executor.ts", "../src/utils/logging.ts", "../src/transport/http/agent-instance-client.ts", "../src/transport/http/retry-policy.ts", "../src/transport/http/http-client.ts", "../src/transport/http/agent-span-client.ts", "../src/transport/http.ts", "../src/tracing/with-span.ts", "../src/utils/serialization.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import type { AgentInstanceOptions, Transport } from '../transport/http.js';\n\nexport type AgentInstanceManagerOptions = {\n allowUnregisteredSchema?: boolean;\n};\n\ntype AgentInstanceStartOptions = AgentInstanceOptions;\n\nexport class AgentInstanceManager {\n private registeredSchema: Record<string, unknown> | null = null;\n\n constructor(\n private transport: Transport,\n private options: AgentInstanceManagerOptions\n ) {}\n\n registerSchema(schema: Record<string, unknown>): void {\n if (this.registeredSchema === null) {\n this.registeredSchema = schema;\n this.transport.registerSchema(schema);\n return;\n }\n\n const existingSchema = stableStringify(this.registeredSchema);\n const incomingSchema = stableStringify(schema);\n if (existingSchema !== incomingSchema) {\n console.warn(\n 'A different schema was provided after registration; ignoring subsequent schema.'\n );\n }\n }\n\n startInstance(options: AgentInstanceStartOptions = {}): void {\n if (!this.options.allowUnregisteredSchema && this.registeredSchema === null) {\n console.warn('Schema must be registered before starting an agent instance.');\n return;\n }\n\n this.transport.startAgentInstance(options);\n }\n\n finishInstance(): void {\n this.transport.finishAgentInstance();\n }\n}\n\nfunction stableStringify(value: unknown): string {\n return JSON.stringify(normalizeValue(value));\n}\n\nfunction normalizeValue(value: unknown): unknown {\n if (Array.isArray(value)) {\n return value.map((entry) => normalizeValue(entry));\n }\n\n if (value && typeof value === 'object') {\n const normalized: Record<string, unknown> = {};\n const objectValue = value as Record<string, unknown>;\n const keys = Object.keys(objectValue).sort((a, b) => a.localeCompare(b));\n for (const key of keys) {\n normalized[key] = normalizeValue(objectValue[key]);\n }\n return normalized;\n }\n\n return value;\n}\n",
|
|
6
|
-
"import { z } from 'zod';\n\nconst DEFAULT_RETRY_ON_STATUS_CODES = [\n 429,\n ...Array.from({ length: 100 }, (_, index) => 500 + index),\n];\nconst HttpStatusCodeSchema = z.number().int().min(100).max(599);\n\n/**\n * Configuration schema for HTTP transport\n */\nexport const HttpTransportConfigSchema = z.object({\n /** API endpoint URL */\n apiUrl: z.string().url(),\n\n /** Authentication token */\n apiToken: z.string().min(1),\n\n /** Optional agent instance identifier (internal ID) */\n agentId: z.string().optional(),\n\n /** Agent identifier (external identifier); defaults to v1.0.0 when omitted */\n agentIdentifier: z.string().default('v1.0.0'),\n\n /** Optional agent name */\n agentName: z.string().optional(),\n\n /** Optional agent description */\n agentDescription: z.string().optional(),\n\n /** Optional agent schema for validation (full schema object) */\n agentSchema: z.record(z.unknown()).optional(),\n\n /** Request timeout in milliseconds */\n requestTimeout: z.number().positive().default(30000),\n\n /** Maximum number of retry attempts */\n maxRetries: z.number().int().nonnegative().default(3),\n\n /** Initial delay between retries in milliseconds */\n initialRetryDelay: z.number().positive().default(1000),\n\n /** Maximum delay between retries in milliseconds */\n maxRetryDelay: z.number().positive().default(60000),\n\n /** Multiplier for exponential backoff */\n retryMultiplier: z.number().positive().default(2.0),\n\n /** Status codes that should trigger retries */\n retryOnStatusCodes: z.array(HttpStatusCodeSchema).default([...DEFAULT_RETRY_ON_STATUS_CODES]),\n});\n\nexport type HttpTransportConfig = z.infer<typeof HttpTransportConfigSchema>;\n\n/**\n * Partial HTTP config schema for user input (before defaults are applied)\n */\nexport const PartialHttpConfigSchema = z.object({\n apiUrl: z.string().url(),\n apiToken: z.string().min(1),\n agentId: z.string().optional(),\n agentIdentifier: z.string().optional(),\n agentName: z.string().optional(),\n agentDescription: z.string().optional(),\n agentSchema: z.record(z.unknown()).optional(),\n requestTimeout: z.number().positive().optional(),\n maxRetries: z.number().int().nonnegative().optional(),\n initialRetryDelay: z.number().positive().optional(),\n maxRetryDelay: z.number().positive().optional(),\n retryMultiplier: z.number().positive().optional(),\n retryOnStatusCodes: z.array(HttpStatusCodeSchema).optional(),\n});\n\nexport type PartialHttpConfig = z.infer<typeof PartialHttpConfigSchema>;\n\n/**\n * Main SDK configuration schema\n */\nexport const ConfigSchema = z.object({\n /** Transport type to use for span emission */\n transportType: z.enum(['http']).default('http'),\n\n /** Sampling rate (0.0 to 1.0) */\n sampleRate: z.number().min(0).max(1).default(1.0),\n\n /** Whether to capture span inputs */\n captureInputs: z.boolean().default(true),\n\n /** Whether to capture span outputs */\n captureOutputs: z.boolean().default(true),\n\n /** Maximum length for input strings */\n maxInputLength: z.number().int().positive().default(10000),\n\n /** Maximum length for output strings */\n maxOutputLength: z.number().int().positive().default(10000),\n\n /** HTTP transport configuration (required if transportType is 'http') */\n httpConfig: PartialHttpConfigSchema.optional(),\n});\n\nexport type Config = z.infer<typeof ConfigSchema>;\n\n/**\n * Creates a validated configuration object by merging provided options with\n * environment variables and defaults.\n *\n * @param options - Partial configuration options\n * @returns Validated configuration object\n * @throws {z.ZodError} If configuration is invalid\n *\n * @example\n * ```typescript\n * const config = createConfig({\n * transportType: 'http',\n * httpConfig: {\n * apiUrl: 'https://api.prefactor.ai',\n * apiToken: process.env.PREFACTOR_API_TOKEN!,\n * }\n * });\n * ```\n */\nexport function createConfig(options?: Partial<Config>): Config {\n const retryOnStatusCodesFromEnv = parseRetryOnStatusCodesEnv(\n process.env.PREFACTOR_RETRY_ON_STATUS_CODES\n );\n\n const config = {\n transportType:\n options?.transportType ?? (process.env.PREFACTOR_TRANSPORT as 'http' | undefined) ?? 'http',\n sampleRate: options?.sampleRate ?? parseFloat(process.env.PREFACTOR_SAMPLE_RATE ?? '1.0'),\n captureInputs: options?.captureInputs ?? process.env.PREFACTOR_CAPTURE_INPUTS !== 'false',\n captureOutputs: options?.captureOutputs ?? process.env.PREFACTOR_CAPTURE_OUTPUTS !== 'false',\n maxInputLength:\n options?.maxInputLength ?? parseInt(process.env.PREFACTOR_MAX_INPUT_LENGTH ?? '10000', 10),\n maxOutputLength:\n options?.maxOutputLength ?? parseInt(process.env.PREFACTOR_MAX_OUTPUT_LENGTH ?? '10000', 10),\n httpConfig: options?.httpConfig\n ? {\n ...options.httpConfig,\n retryOnStatusCodes: options.httpConfig.retryOnStatusCodes ?? retryOnStatusCodesFromEnv,\n }\n : undefined,\n };\n\n // Validate and return\n return ConfigSchema.parse(config);\n}\n\nfunction parseRetryOnStatusCodesEnv(value: string | undefined): number[] | undefined {\n if (!value) {\n return undefined;\n }\n\n const parsedCodes = value\n .split(',')\n .map((status) => status.trim())\n .filter((status) => /^\\d{3}$/.test(status))\n .map((status) => Number(status))\n .filter((status) => status >= 100 && status <= 599);\n\n return parsedCodes.length > 0 ? parsedCodes : undefined;\n}\n",
|
|
6
|
+
"import { z } from 'zod';\n\nconst DEFAULT_RETRY_ON_STATUS_CODES = [\n 429,\n ...Array.from({ length: 100 }, (_, index) => 500 + index),\n];\nconst HttpStatusCodeSchema = z.number().int().min(100).max(599);\n\n/**\n * Configuration schema for HTTP transport\n */\nexport const HttpTransportConfigSchema = z.object({\n /** API endpoint URL */\n apiUrl: z.string().url(),\n\n /** Authentication token */\n apiToken: z.string().min(1),\n\n /** Optional agent instance identifier (internal ID) */\n agentId: z.string().optional(),\n\n /** Agent identifier (external identifier); defaults to v1.0.0 when omitted */\n agentIdentifier: z.string().default('v1.0.0'),\n\n /** Optional agent name */\n agentName: z.string().optional(),\n\n /** Optional agent description */\n agentDescription: z.string().optional(),\n\n /** Optional agent schema for validation (full schema object) */\n agentSchema: z.record(z.string(), z.unknown()).optional(),\n\n /** Request timeout in milliseconds */\n requestTimeout: z.number().positive().default(30000),\n\n /** Maximum number of retry attempts */\n maxRetries: z.number().int().nonnegative().default(3),\n\n /** Initial delay between retries in milliseconds */\n initialRetryDelay: z.number().positive().default(1000),\n\n /** Maximum delay between retries in milliseconds */\n maxRetryDelay: z.number().positive().default(60000),\n\n /** Multiplier for exponential backoff */\n retryMultiplier: z.number().positive().default(2.0),\n\n /** Status codes that should trigger retries */\n retryOnStatusCodes: z.array(HttpStatusCodeSchema).default([...DEFAULT_RETRY_ON_STATUS_CODES]),\n});\n\nexport type HttpTransportConfig = z.infer<typeof HttpTransportConfigSchema>;\n\n/**\n * Partial HTTP config schema for user input (before defaults are applied)\n */\nexport const PartialHttpConfigSchema = z.object({\n apiUrl: z.string().url(),\n apiToken: z.string().min(1),\n agentId: z.string().optional(),\n agentIdentifier: z.string().optional(),\n agentName: z.string().optional(),\n agentDescription: z.string().optional(),\n agentSchema: z.record(z.string(), z.unknown()).optional(),\n requestTimeout: z.number().positive().optional(),\n maxRetries: z.number().int().nonnegative().optional(),\n initialRetryDelay: z.number().positive().optional(),\n maxRetryDelay: z.number().positive().optional(),\n retryMultiplier: z.number().positive().optional(),\n retryOnStatusCodes: z.array(HttpStatusCodeSchema).optional(),\n});\n\nexport type PartialHttpConfig = z.infer<typeof PartialHttpConfigSchema>;\n\n/**\n * Main SDK configuration schema\n */\nexport const ConfigSchema = z.object({\n /** Transport type to use for span emission */\n transportType: z.enum(['http']).default('http'),\n\n /** Sampling rate (0.0 to 1.0) */\n sampleRate: z.number().min(0).max(1).default(1.0),\n\n /** Whether to capture span inputs */\n captureInputs: z.boolean().default(true),\n\n /** Whether to capture span outputs */\n captureOutputs: z.boolean().default(true),\n\n /** Maximum length for input strings */\n maxInputLength: z.number().int().positive().default(10000),\n\n /** Maximum length for output strings */\n maxOutputLength: z.number().int().positive().default(10000),\n\n /** HTTP transport configuration (required if transportType is 'http') */\n httpConfig: PartialHttpConfigSchema.optional(),\n});\n\nexport type Config = z.infer<typeof ConfigSchema>;\n\n/**\n * Creates a validated configuration object by merging provided options with\n * environment variables and defaults.\n *\n * @param options - Partial configuration options\n * @returns Validated configuration object\n * @throws {z.ZodError} If configuration is invalid\n *\n * @example\n * ```typescript\n * const config = createConfig({\n * transportType: 'http',\n * httpConfig: {\n * apiUrl: 'https://api.prefactor.ai',\n * apiToken: process.env.PREFACTOR_API_TOKEN!,\n * }\n * });\n * ```\n */\nexport function createConfig(options?: Partial<Config>): Config {\n const retryOnStatusCodesFromEnv = parseRetryOnStatusCodesEnv(\n process.env.PREFACTOR_RETRY_ON_STATUS_CODES\n );\n\n const config = {\n transportType:\n options?.transportType ?? (process.env.PREFACTOR_TRANSPORT as 'http' | undefined) ?? 'http',\n sampleRate: options?.sampleRate ?? parseFloat(process.env.PREFACTOR_SAMPLE_RATE ?? '1.0'),\n captureInputs: options?.captureInputs ?? process.env.PREFACTOR_CAPTURE_INPUTS !== 'false',\n captureOutputs: options?.captureOutputs ?? process.env.PREFACTOR_CAPTURE_OUTPUTS !== 'false',\n maxInputLength:\n options?.maxInputLength ?? parseInt(process.env.PREFACTOR_MAX_INPUT_LENGTH ?? '10000', 10),\n maxOutputLength:\n options?.maxOutputLength ?? parseInt(process.env.PREFACTOR_MAX_OUTPUT_LENGTH ?? '10000', 10),\n httpConfig: options?.httpConfig\n ? {\n ...options.httpConfig,\n retryOnStatusCodes: options.httpConfig.retryOnStatusCodes ?? retryOnStatusCodesFromEnv,\n }\n : undefined,\n };\n\n // Validate and return\n return ConfigSchema.parse(config);\n}\n\nfunction parseRetryOnStatusCodesEnv(value: string | undefined): number[] | undefined {\n if (!value) {\n return undefined;\n }\n\n const parsedCodes = value\n .split(',')\n .map((status) => status.trim())\n .filter((status) => /^\\d{3}$/.test(status))\n .map((status) => Number(status))\n .filter((status) => status >= 100 && status <= 599);\n\n return parsedCodes.length > 0 ? parsedCodes : undefined;\n}\n",
|
|
7
7
|
"import { extractPartition, type Partition } from '@prefactor/pfid';\nimport { AgentInstanceManager } from './agent/instance-manager.js';\nimport type { Config } from './config.js';\nimport { HttpTransportConfigSchema } from './config.js';\nimport { setActiveCoreRuntime } from './lifecycle.js';\nimport { clearActiveTracer, setActiveTracer } from './tracing/active-tracer.js';\nimport { Tracer } from './tracing/tracer.js';\nimport { HttpTransport } from './transport/http.js';\n\nexport type CoreRuntime = {\n tracer: Tracer;\n agentManager: AgentInstanceManager;\n shutdown: () => Promise<void>;\n};\n\nexport function createCore(config: Config): CoreRuntime {\n if (!config.httpConfig) {\n throw new Error('HTTP transport requires httpConfig to be provided in configuration');\n }\n\n const httpConfig = HttpTransportConfigSchema.parse(config.httpConfig);\n const transport = new HttpTransport(httpConfig);\n\n let partition: Partition | undefined;\n if (config.httpConfig.agentId) {\n try {\n partition = extractPartition(config.httpConfig.agentId);\n } catch {\n partition = undefined;\n }\n }\n\n const tracer = new Tracer(transport, partition);\n setActiveTracer(tracer);\n\n const allowUnregisteredSchema = Boolean(config.httpConfig.agentSchema);\n const agentManager = new AgentInstanceManager(transport, {\n allowUnregisteredSchema,\n });\n\n const shutdown = async (): Promise<void> => {\n await tracer.close();\n clearActiveTracer(tracer);\n setActiveCoreRuntime(null);\n };\n const runtime: CoreRuntime = { tracer, agentManager, shutdown };\n setActiveCoreRuntime(runtime);\n return runtime;\n}\n",
|
|
8
8
|
"import type { Tracer } from './tracer.js';\n\nlet activeTracer: Tracer | undefined;\n\nexport function setActiveTracer(tracer: Tracer): void {\n activeTracer = tracer;\n}\n\nexport function getActiveTracer(): Tracer | undefined {\n return activeTracer;\n}\n\nexport function clearActiveTracer(tracer?: Tracer): void {\n if (!tracer || activeTracer === tracer) {\n activeTracer = undefined;\n }\n}\n",
|
|
9
9
|
"import type { CoreRuntime } from './create-core.js';\nimport { clearActiveTracer } from './tracing/active-tracer.js';\n\nconst shutdownHandlers = new Map<string, () => void | Promise<void>>();\nlet activeCoreRuntime: CoreRuntime | null = null;\n\nexport function setActiveCoreRuntime(runtime: CoreRuntime | null): void {\n activeCoreRuntime = runtime;\n}\n\nexport function registerShutdownHandler(\n key: string,\n handler: () => void | Promise<void>\n): () => void {\n shutdownHandlers.set(key, handler);\n return () => shutdownHandlers.delete(key);\n}\n\nexport async function shutdown(): Promise<void> {\n for (const handler of shutdownHandlers.values()) {\n try {\n await handler();\n } catch (error) {\n console.error('Error during shutdown handler execution:', error);\n }\n }\n\n if (activeCoreRuntime) {\n const runtime = activeCoreRuntime;\n activeCoreRuntime = null;\n await runtime.shutdown();\n }\n\n clearActiveTracer();\n}\n",
|
|
10
|
-
"import { generate, generatePartition, type Partition } from '@prefactor/pfid';\nimport type { Transport } from '../transport/http.js';\nimport { SpanContext } from './context.js';\nimport type { Span, TokenUsage } from './span.js';\nimport { SpanStatus, SpanType } from './span.js';\n\n/**\n * Options for starting a new span\n */\nexport interface StartSpanOptions {\n /** Name of the span */\n name: string;\n\n /** Type of operation this span represents */\n spanType: SpanType;\n\n /** Input data for this operation */\n inputs: Record<string, unknown>;\n\n /** Additional metadata (optional) */\n metadata?: Record<string, unknown>;\n}\n\n/**\n * Options for ending a span\n */\nexport interface EndSpanOptions {\n /** Output data from the operation */\n outputs?: Record<string, unknown>;\n\n /** Error that occurred (if any) */\n error?: Error;\n\n /** Token usage information (for LLM calls) */\n tokenUsage?: TokenUsage;\n}\n\n/**\n * Tracer manages the lifecycle of spans.\n *\n * The tracer is responsible for:\n * - Creating spans with unique IDs\n * - Managing span lifecycle (start/end)\n * - Delegating to the transport layer for span emission\n * - Handling agent instance lifecycle\n *\n * @example\n * ```typescript\n * const tracer = new Tracer(transport);\n *\n * const span = tracer.startSpan({\n * name: 'llm-call',\n * spanType: SpanType.LLM,\n * inputs: { prompt: 'Hello' }\n * });\n *\n * try {\n * // ... do work ...\n * tracer.endSpan(span, { outputs: { response: 'Hi!' } });\n * } catch (error) {\n * tracer.endSpan(span, { error });\n * }\n * ```\n */\nexport class Tracer {\n private partition: Partition;\n\n /**\n * Initialize the tracer.\n *\n * @param transport - The transport to use for emitting spans\n * @param partition - The partition for ID generation. If not provided, a random partition will be generated.\n */\n constructor(\n private transport: Transport,\n partition?: Partition\n ) {\n this.partition = partition ?? generatePartition();\n }\n\n /**\n * Start a new span\n *\n * @param options - Span configuration options\n * @returns The created span\n */\n startSpan(options: StartSpanOptions): Span {\n const parentSpan = SpanContext.getCurrent();\n const spanId = generate(this.partition);\n const traceId = parentSpan?.traceId ?? generate(this.partition);\n\n const span: Span = {\n spanId,\n parentSpanId: parentSpan?.spanId ?? null,\n traceId,\n name: options.name,\n spanType: options.spanType,\n startTime: Date.now(),\n endTime: null,\n status: SpanStatus.RUNNING,\n inputs: options.inputs,\n outputs: null,\n tokenUsage: null,\n error: null,\n metadata: options.metadata ?? {},\n };\n\n // AGENT spans are emitted immediately for real-time tracking\n // They will be finished later with finishSpan()\n if (options.spanType === SpanType.AGENT) {\n try {\n this.transport.emit(span);\n } catch (error) {\n console.error('Failed to emit agent span:', error);\n }\n }\n\n return span;\n }\n\n /**\n * End a span and emit it to the transport\n *\n * @param span - The span to end\n * @param options - End span options (outputs, error, token usage)\n */\n endSpan(span: Span, options?: EndSpanOptions): void {\n const endTime = Date.now();\n span.endTime = endTime;\n span.outputs = options?.outputs ?? null;\n span.tokenUsage = options?.tokenUsage ?? null;\n\n if (options?.error) {\n span.status = SpanStatus.ERROR;\n span.error = {\n errorType: options.error.constructor.name,\n message: options.error.message,\n stacktrace: options.error.stack ?? '',\n };\n } else {\n span.status = SpanStatus.SUCCESS;\n }\n\n try {\n // AGENT spans use finishSpan API (they were already emitted on start)\n // Other span types are emitted here\n if (span.spanType === SpanType.AGENT) {\n this.transport.finishSpan(span.spanId, endTime);\n } else {\n this.transport.emit(span);\n }\n } catch (error) {\n console.error('Failed to emit span action:', error);\n }\n }\n\n /**\n * Close the tracer and flush any pending spans\n *\n * @returns Promise that resolves when the tracer is closed\n */\n async close(): Promise<void> {\n try {\n await this.transport.close();\n } catch (error) {\n console.error('Failed to close transport:', error);\n }\n }\n\n startAgentInstance(): void {\n try {\n this.transport.startAgentInstance();\n } catch (error) {\n console.error('Failed to start agent instance:', error);\n }\n }\n\n finishAgentInstance(): void {\n try {\n this.transport.finishAgentInstance();\n } catch (error) {\n console.error('Failed to finish agent instance:', error);\n }\n }\n}\n",
|
|
10
|
+
"import { generate, generatePartition, type Partition } from '@prefactor/pfid';\nimport type { Transport } from '../transport/http.js';\nimport { SpanContext } from './context.js';\nimport { buildSpanResultPayload } from './result-payload.js';\nimport type { Span, TokenUsage } from './span.js';\nimport { SpanStatus, SpanType } from './span.js';\n\n/**\n * Options for starting a new span\n */\nexport interface StartSpanOptions {\n /** Name of the span */\n name: string;\n\n /** Type of operation this span represents */\n spanType: SpanType;\n\n /** Input data for this operation */\n inputs: Record<string, unknown>;\n\n /** Additional metadata (optional) */\n metadata?: Record<string, unknown>;\n}\n\n/**\n * Options for ending a span\n */\nexport interface EndSpanOptions {\n /** Output data from the operation */\n outputs?: Record<string, unknown>;\n\n /** Error that occurred (if any) */\n error?: Error;\n\n /** Token usage information (for LLM calls) */\n tokenUsage?: TokenUsage;\n}\n\n/**\n * Tracer manages the lifecycle of spans.\n *\n * The tracer is responsible for:\n * - Creating spans with unique IDs\n * - Managing span lifecycle (start/end)\n * - Delegating to the transport layer for span emission\n * - Handling agent instance lifecycle\n *\n * @example\n * ```typescript\n * const tracer = new Tracer(transport);\n *\n * const span = tracer.startSpan({\n * name: 'llm-call',\n * spanType: SpanType.LLM,\n * inputs: { prompt: 'Hello' }\n * });\n *\n * try {\n * // ... do work ...\n * tracer.endSpan(span, { outputs: { response: 'Hi!' } });\n * } catch (error) {\n * tracer.endSpan(span, { error });\n * }\n * ```\n */\nexport class Tracer {\n private partition: Partition;\n\n /**\n * Initialize the tracer.\n *\n * @param transport - The transport to use for emitting spans\n * @param partition - The partition for ID generation. If not provided, a random partition will be generated.\n */\n constructor(\n private transport: Transport,\n partition?: Partition\n ) {\n this.partition = partition ?? generatePartition();\n }\n\n /**\n * Start a new span\n *\n * @param options - Span configuration options\n * @returns The created span\n */\n startSpan(options: StartSpanOptions): Span {\n const parentSpan = SpanContext.getCurrent();\n const spanId = generate(this.partition);\n const traceId = parentSpan?.traceId ?? generate(this.partition);\n\n const span: Span = {\n spanId,\n parentSpanId: parentSpan?.spanId ?? null,\n traceId,\n name: options.name,\n spanType: options.spanType,\n startTime: Date.now(),\n endTime: null,\n status: SpanStatus.RUNNING,\n inputs: options.inputs,\n outputs: null,\n tokenUsage: null,\n error: null,\n metadata: options.metadata ?? {},\n };\n\n // AGENT spans are emitted immediately for real-time tracking\n // They will be finished later with finishSpan()\n if (options.spanType === SpanType.AGENT) {\n try {\n this.transport.emit(span);\n } catch (error) {\n console.error('Failed to emit agent span:', error);\n }\n }\n\n return span;\n }\n\n /**\n * End a span and emit it to the transport\n *\n * @param span - The span to end\n * @param options - End span options (outputs, error, token usage)\n */\n endSpan(span: Span, options?: EndSpanOptions): void {\n const endTime = Date.now();\n span.endTime = endTime;\n span.outputs = options?.outputs ?? null;\n span.tokenUsage = options?.tokenUsage ?? null;\n\n if (options?.error) {\n span.status = SpanStatus.ERROR;\n span.error = {\n errorType: options.error.constructor.name,\n message: options.error.message,\n stacktrace: options.error.stack ?? '',\n };\n } else {\n span.status = SpanStatus.SUCCESS;\n }\n\n try {\n // AGENT spans use finishSpan API (they were already emitted on start)\n // Other span types are emitted here\n if (span.spanType === SpanType.AGENT) {\n const status = span.status === SpanStatus.ERROR ? 'failed' : 'complete';\n\n this.transport.finishSpan(span.spanId, endTime, {\n status,\n resultPayload: buildSpanResultPayload(span),\n });\n } else {\n this.transport.emit(span);\n }\n } catch (error) {\n console.error('Failed to emit span action:', error);\n }\n }\n\n /**\n * Close the tracer and flush any pending spans\n *\n * @returns Promise that resolves when the tracer is closed\n */\n async close(): Promise<void> {\n try {\n await this.transport.close();\n } catch (error) {\n console.error('Failed to close transport:', error);\n }\n }\n\n startAgentInstance(): void {\n try {\n this.transport.startAgentInstance();\n } catch (error) {\n console.error('Failed to start agent instance:', error);\n }\n }\n\n finishAgentInstance(): void {\n try {\n this.transport.finishAgentInstance();\n } catch (error) {\n console.error('Failed to finish agent instance:', error);\n }\n }\n}\n",
|
|
11
11
|
"import { AsyncLocalStorage, AsyncResource } from 'node:async_hooks';\nimport type { Span } from './span.js';\n\n/**\n * Storage for the current span stack in async context\n */\nconst spanStorage = new AsyncLocalStorage<Span[]>();\n\n/**\n * SpanContext manages the current span in async execution contexts.\n * This enables automatic parent-child span relationships without manual tracking.\n *\n * Uses Node.js AsyncLocalStorage which provides async-safe context propagation.\n *\n * @example\n * ```typescript\n * const span = tracer.startSpan({ name: 'parent', ... });\n *\n * await SpanContext.runAsync(span, async () => {\n * // Inside this function, getCurrent() returns the parent span\n * const parent = SpanContext.getCurrent();\n *\n * const child = tracer.startSpan({\n * name: 'child',\n * parentSpanId: parent?.spanId,\n * traceId: parent?.traceId,\n * });\n * // ...\n * });\n * ```\n */\n// biome-ignore lint/complexity/noStaticOnlyClass: Intentional API design for namespacing context operations\nexport class SpanContext {\n /**\n * Get the current span from the async context\n *\n * @returns The current span, or undefined if no span is active\n */\n static getCurrent(): Span | undefined {\n const stack = spanStorage.getStore() ?? [];\n return stack[stack.length - 1];\n }\n\n /**\n * Get the full span stack from the async context\n */\n static getStack(): Span[] {\n return [...(spanStorage.getStore() ?? [])];\n }\n\n /**\n * Push a span onto the stack for the current async context\n */\n static enter(span: Span): void {\n const stack = [...(spanStorage.getStore() ?? []), span];\n spanStorage.enterWith(stack);\n }\n\n /**\n * Pop the current span from the stack for the current async context\n */\n static exit(): void {\n const stack = [...(spanStorage.getStore() ?? [])];\n stack.pop();\n spanStorage.enterWith(stack);\n }\n\n /**\n * Run a synchronous function with the given span as the current context\n *\n * @param span - The span to set as current\n * @param fn - The function to execute\n * @returns The return value of the function\n */\n static run<T>(span: Span, fn: () => T): T {\n const stack = spanStorage.getStore() ?? [];\n const resource = new AsyncResource('SpanContext.run');\n\n try {\n return resource.runInAsyncScope(() => spanStorage.run([...stack, span], fn));\n } finally {\n resource.emitDestroy();\n }\n }\n\n /**\n * Run an asynchronous function with the given span as the current context\n *\n * @param span - The span to set as current\n * @param fn - The async function to execute\n * @returns A promise resolving to the return value of the function\n */\n static async runAsync<T>(span: Span, fn: () => Promise<T>): Promise<T> {\n const stack = spanStorage.getStore() ?? [];\n const resource = new AsyncResource('SpanContext.runAsync');\n\n try {\n return await resource.runInAsyncScope(() => spanStorage.run([...stack, span], fn));\n } finally {\n resource.emitDestroy();\n }\n }\n\n /**\n * Clear the current context (primarily for testing)\n */\n static clear(): void {\n spanStorage.disable();\n }\n}\n",
|
|
12
|
-
"
|
|
12
|
+
"import type { Span } from './span.js';\n\nexport function buildSpanResultPayload(\n span: Pick<Span, 'outputs' | 'error'>\n): Record<string, unknown> {\n if (span.error) {\n return {\n error_type: span.error.errorType,\n message: span.error.message,\n stacktrace: span.error.stacktrace,\n };\n }\n\n return span.outputs ?? {};\n}\n",
|
|
13
|
+
"/**\n * Types of spans that can be traced\n */\nexport const SpanType = {\n AGENT: 'agent',\n LLM: 'llm',\n TOOL: 'tool',\n CHAIN: 'chain',\n} as const;\n\nexport type SpanType = (typeof SpanType)[keyof typeof SpanType] | string;\n\nexport function createSpanTypePrefixer(namespace: string): (spanType: string) => string {\n return (spanType: string) => `${namespace}:${spanType}`;\n}\n\n/**\n * Status of a span\n */\nexport enum SpanStatus {\n RUNNING = 'running',\n SUCCESS = 'success',\n ERROR = 'error',\n}\n\n/**\n * Token usage information for LLM calls\n */\nexport interface TokenUsage {\n promptTokens: number;\n completionTokens: number;\n totalTokens: number;\n}\n\n/**\n * Error information captured when a span fails\n */\nexport interface ErrorInfo {\n errorType: string;\n message: string;\n stacktrace: string;\n}\n\n/**\n * A span represents a single operation in a trace\n */\nexport interface Span {\n /** Unique identifier for this span */\n spanId: string;\n\n /** ID of the parent span, or null if this is a root span */\n parentSpanId: string | null;\n\n /** Trace ID shared by all spans in a single trace */\n traceId: string;\n\n /** Human-readable name for this span */\n name: string;\n\n /** Type of operation this span represents */\n spanType: SpanType;\n\n /** Start time in milliseconds since Unix epoch */\n startTime: number;\n\n /** End time in milliseconds since Unix epoch, or null if still running */\n endTime: number | null;\n\n /** Current status of the span */\n status: SpanStatus;\n\n /** Input data for this operation */\n inputs: Record<string, unknown>;\n\n /** Output data from this operation, or null if not completed */\n outputs: Record<string, unknown> | null;\n\n /** Token usage for LLM calls, or null if not applicable */\n tokenUsage: TokenUsage | null;\n\n /** Error information if the span failed, or null if successful */\n error: ErrorInfo | null;\n\n /** Additional metadata about this span */\n metadata: Record<string, unknown>;\n}\n",
|
|
13
14
|
"import type { Queue, QueueGetResult } from './base.js';\n\ntype QueueEntry<T> = {\n item: T;\n};\n\nexport class InMemoryQueue<T> implements Queue<T> {\n private items: QueueEntry<T>[] = [];\n private waiters: Array<(result: QueueGetResult<T>) => void> = [];\n private isClosed = false;\n\n async put(item: T): Promise<void> {\n if (this.isClosed) {\n throw new Error('Cannot put item into a closed queue');\n }\n\n const waiter = this.waiters.shift();\n if (waiter) {\n waiter({ done: false, item });\n return;\n }\n\n this.items.push({ item });\n }\n\n async get(): Promise<QueueGetResult<T>> {\n if (this.items.length > 0) {\n const entry = this.items.shift();\n if (entry) {\n return { done: false, item: entry.item };\n }\n }\n\n if (this.isClosed) {\n return { done: true };\n }\n\n return new Promise<QueueGetResult<T>>((resolve) => {\n this.waiters.push(resolve);\n });\n }\n\n close(): void {\n if (this.isClosed) {\n return;\n }\n\n this.isClosed = true;\n while (this.waiters.length > 0) {\n const waiter = this.waiters.shift();\n if (waiter) {\n waiter({ done: true });\n }\n }\n }\n\n size(): number {\n return this.items.length;\n }\n}\n",
|
|
14
15
|
"import type { Queue, TaskExecutorOptions } from './base.js';\n\nconst DEFAULT_WORKER_COUNT = 1;\nconst DEFAULT_MAX_RETRIES = 0;\nconst DEFAULT_RETRY_DELAY_MS = 0;\n\nexport class TaskExecutor<T> {\n private isRunning = false;\n private workerPromises: Promise<void>[] = [];\n private workerCount: number;\n private maxRetries: number;\n private retryDelayMs: number;\n private onError?: (error: unknown, item: T) => void | Promise<void>;\n\n constructor(\n private queue: Queue<T>,\n private handler: (item: T) => Promise<void>,\n options: TaskExecutorOptions<T> = {}\n ) {\n this.workerCount = Math.max(options.workerCount ?? DEFAULT_WORKER_COUNT, 1);\n this.maxRetries = Math.max(options.maxRetries ?? DEFAULT_MAX_RETRIES, 0);\n this.retryDelayMs = Math.max(options.retryDelayMs ?? DEFAULT_RETRY_DELAY_MS, 0);\n this.onError = options.onError;\n }\n\n start(): void {\n if (this.isRunning) {\n return;\n }\n\n this.isRunning = true;\n this.workerPromises = Array.from({ length: this.workerCount }, () => this.runWorker());\n }\n\n async stop(): Promise<void> {\n if (!this.isRunning) {\n return;\n }\n\n this.isRunning = false;\n this.queue.close();\n await Promise.all(this.workerPromises);\n this.workerPromises = [];\n }\n\n private async runWorker(): Promise<void> {\n while (true) {\n const result = await this.queue.get();\n if (result.done) {\n return;\n }\n\n await this.executeWithRetry(result.item);\n }\n }\n\n private async executeWithRetry(item: T): Promise<void> {\n let attempt = 0;\n\n while (attempt <= this.maxRetries) {\n try {\n await this.handler(item);\n return;\n } catch (error) {\n if (attempt >= this.maxRetries) {\n await this.safeOnError(error, item);\n return;\n }\n\n if (this.retryDelayMs > 0) {\n await new Promise((resolve) => setTimeout(resolve, this.retryDelayMs));\n }\n }\n\n attempt += 1;\n }\n }\n\n private async safeOnError(error: unknown, item: T): Promise<void> {\n if (!this.onError) {\n return;\n }\n\n try {\n await this.onError(error, item);\n } catch {\n return;\n }\n }\n}\n",
|
|
15
16
|
"/**\n * Log levels for the SDK\n */\nenum LogLevel {\n DEBUG = 0,\n INFO = 1,\n WARN = 2,\n ERROR = 3,\n}\n\n/**\n * Logger class for the Prefactor SDK\n */\nclass Logger {\n private static level: LogLevel = (() => {\n const level = process.env.PREFACTOR_LOG_LEVEL?.toUpperCase();\n if (level && level in LogLevel) {\n return LogLevel[level as keyof typeof LogLevel];\n }\n return LogLevel.INFO;\n })();\n\n constructor(private namespace: string) {}\n\n debug(message: string, ...args: unknown[]): void {\n if (Logger.level <= LogLevel.DEBUG) {\n console.debug(`[prefactor:${this.namespace}] ${message}`, ...args);\n }\n }\n\n info(message: string, ...args: unknown[]): void {\n if (Logger.level <= LogLevel.INFO) {\n console.info(`[prefactor:${this.namespace}] ${message}`, ...args);\n }\n }\n\n warn(message: string, ...args: unknown[]): void {\n if (Logger.level <= LogLevel.WARN) {\n console.warn(`[prefactor:${this.namespace}] ${message}`, ...args);\n }\n }\n\n error(message: string, ...args: unknown[]): void {\n if (Logger.level <= LogLevel.ERROR) {\n console.error(`[prefactor:${this.namespace}] ${message}`, ...args);\n }\n }\n\n /**\n * Set the global log level\n */\n static setLevel(level: 'debug' | 'info' | 'warn' | 'error'): void {\n const levelMap = {\n debug: LogLevel.DEBUG,\n info: LogLevel.INFO,\n warn: LogLevel.WARN,\n error: LogLevel.ERROR,\n };\n Logger.level = levelMap[level];\n }\n}\n\n/**\n * Get a logger instance for a specific namespace\n *\n * @param namespace - The namespace for this logger\n * @returns Logger instance\n */\nexport function getLogger(namespace: string): Logger {\n return new Logger(namespace);\n}\n\n/**\n * Configure logging based on environment variables\n */\nexport function configureLogging(): void {\n const level = process.env.PREFACTOR_LOG_LEVEL?.toLowerCase() as\n | 'debug'\n | 'info'\n | 'warn'\n | 'error'\n | undefined;\n\n if (level) {\n Logger.setLevel(level);\n }\n}\n",
|
|
16
17
|
"import type { HttpRequester } from './http-client.js';\n\nexport type AgentInstanceRegisterPayload = {\n agent_id?: string;\n agent_version?: {\n external_identifier: string;\n name: string;\n description: string;\n };\n agent_schema_version?: Record<string, unknown>;\n};\n\nexport type AgentInstanceResponse = {\n details?: {\n id?: string;\n };\n};\n\nexport class AgentInstanceClient {\n constructor(private readonly httpClient: HttpRequester) {}\n\n register(payload: AgentInstanceRegisterPayload): Promise<AgentInstanceResponse> {\n return this.httpClient.request('/api/v1/agent_instance/register', {\n method: 'POST',\n body: payload,\n });\n }\n\n async start(agentInstanceId: string): Promise<void> {\n await this.httpClient.request(`/api/v1/agent_instance/${agentInstanceId}/start`, {\n method: 'POST',\n body: {},\n });\n }\n\n async finish(agentInstanceId: string): Promise<void> {\n await this.httpClient.request(`/api/v1/agent_instance/${agentInstanceId}/finish`, {\n method: 'POST',\n body: {},\n });\n }\n}\n",
|
|
17
18
|
"import type { HttpTransportConfig } from '../../config.js';\n\nconst JITTER_MIN = 0.5;\n\nexport function shouldRetryStatusCode(statusCode: number, retryOnStatusCodes: number[]): boolean {\n return retryOnStatusCodes.includes(statusCode);\n}\n\nexport function calculateRetryDelay(\n attempt: number,\n config: Pick<HttpTransportConfig, 'initialRetryDelay' | 'maxRetryDelay' | 'retryMultiplier'>,\n random: () => number = Math.random\n): number {\n const baseDelay = Math.min(\n config.initialRetryDelay * config.retryMultiplier ** attempt,\n config.maxRetryDelay\n );\n const jitterMultiplier = JITTER_MIN + random() * JITTER_MIN;\n return Math.round(baseDelay * jitterMultiplier);\n}\n",
|
|
18
19
|
"import type { HttpTransportConfig } from '../../config.js';\nimport { calculateRetryDelay, shouldRetryStatusCode } from './retry-policy.js';\n\nexport type FetchLike = (input: string | URL | Request, init?: RequestInit) => Promise<Response>;\n\nexport type HttpClientDependencies = {\n fetchFn?: FetchLike;\n sleep?: (delayMs: number) => Promise<void>;\n random?: () => number;\n};\n\nexport type HttpRequestOptions = Omit<RequestInit, 'body' | 'headers' | 'signal'> & {\n body?: unknown;\n headers?: RequestInit['headers'];\n timeoutMs?: number;\n};\n\nexport interface HttpRequester {\n request<TResponse = unknown>(path: string, options?: HttpRequestOptions): Promise<TResponse>;\n}\n\ntype HttpClientErrorOptions = {\n url: string;\n method: string;\n status?: number;\n statusText?: string;\n responseBody?: unknown;\n retryable: boolean;\n cause?: unknown;\n};\n\nexport class HttpClientError extends Error {\n readonly url: string;\n readonly method: string;\n readonly status?: number;\n readonly statusText?: string;\n readonly responseBody?: unknown;\n readonly retryable: boolean;\n\n constructor(message: string, options: HttpClientErrorOptions) {\n super(message, { cause: options.cause });\n this.name = 'HttpClientError';\n this.url = options.url;\n this.method = options.method;\n this.status = options.status;\n this.statusText = options.statusText;\n this.responseBody = options.responseBody;\n this.retryable = options.retryable;\n }\n}\n\nexport class HttpClient {\n private readonly fetchFn: FetchLike;\n private readonly sleep: (delayMs: number) => Promise<void>;\n private readonly random: () => number;\n\n constructor(\n private readonly config: HttpTransportConfig,\n dependencies: HttpClientDependencies = {}\n ) {\n this.fetchFn = dependencies.fetchFn ?? fetch;\n this.sleep =\n dependencies.sleep ?? ((delayMs) => new Promise((resolve) => setTimeout(resolve, delayMs)));\n this.random = dependencies.random ?? Math.random;\n }\n\n async request<TResponse = unknown>(\n path: string,\n options: HttpRequestOptions = {}\n ): Promise<TResponse> {\n const url = new URL(path, this.config.apiUrl).toString();\n const method = options.method ?? 'GET';\n let attempt = 0;\n\n while (true) {\n const headers = new Headers(options.headers);\n headers.set('Authorization', `Bearer ${this.config.apiToken}`);\n if (options.body !== undefined && !headers.has('Content-Type')) {\n headers.set('Content-Type', 'application/json');\n }\n\n const requestInit: RequestInit = {\n ...options,\n method,\n headers,\n body: options.body === undefined ? undefined : JSON.stringify(options.body),\n signal: AbortSignal.timeout(options.timeoutMs ?? this.config.requestTimeout),\n };\n\n try {\n const response = await this.fetchFn(url, requestInit);\n if (response.ok) {\n return (await parseResponseBody(response)) as TResponse;\n }\n\n const responseBody = await parseResponseBody(response);\n const canRetry =\n attempt < this.config.maxRetries &&\n shouldRetryStatusCode(response.status, this.config.retryOnStatusCodes);\n\n if (canRetry) {\n const delayMs = calculateRetryDelay(attempt, this.config, this.random);\n await this.sleep(delayMs);\n attempt += 1;\n continue;\n }\n\n throw new HttpClientError(`HTTP request failed with status ${response.status}`, {\n url,\n method,\n status: response.status,\n statusText: response.statusText,\n responseBody,\n retryable: shouldRetryStatusCode(response.status, this.config.retryOnStatusCodes),\n });\n } catch (error) {\n if (error instanceof HttpClientError) {\n throw error;\n }\n\n const canRetry = attempt < this.config.maxRetries && isRetryableNetworkError(error);\n if (canRetry) {\n const delayMs = calculateRetryDelay(attempt, this.config, this.random);\n await this.sleep(delayMs);\n attempt += 1;\n continue;\n }\n\n throw new HttpClientError('HTTP request failed due to network error', {\n url,\n method,\n retryable: false,\n cause: error,\n });\n }\n }\n }\n}\n\nfunction isRetryableNetworkError(error: unknown): boolean {\n if (error instanceof TypeError) {\n return true;\n }\n\n if (\n error instanceof DOMException &&\n (error.name === 'AbortError' || error.name === 'TimeoutError')\n ) {\n return true;\n }\n\n if (error instanceof Error && (error.name === 'AbortError' || error.name === 'TimeoutError')) {\n return true;\n }\n\n return false;\n}\n\nasync function parseResponseBody(response: Response): Promise<unknown> {\n const bodyText = await response.text();\n if (!bodyText) {\n return null;\n }\n\n const contentType = response.headers.get('content-type') ?? '';\n if (contentType.includes('application/json')) {\n try {\n return JSON.parse(bodyText) as unknown;\n } catch {\n return bodyText;\n }\n }\n\n try {\n return JSON.parse(bodyText) as unknown;\n } catch {\n return bodyText;\n }\n}\n",
|
|
19
|
-
"import { HttpClientError, type HttpRequester } from './http-client.js';\n\nexport type AgentSpanStatus = 'active' | 'complete' | 'failed';\n\nexport type AgentSpanCreatePayload = {\n details: {\n agent_instance_id: string | null;\n schema_name: string;\n status: AgentSpanStatus;\n payload: Record<string, unknown>;\n parent_span_id: string | null;\n started_at: string;\n finished_at: string | null;\n };\n};\n\nexport type AgentSpanResponse = {\n details?: {\n id?: string;\n };\n};\n\nexport class AgentSpanClient {\n constructor(private readonly httpClient: HttpRequester) {}\n\n create(payload: AgentSpanCreatePayload): Promise<AgentSpanResponse> {\n return this.httpClient.request('/api/v1/agent_spans', {\n method: 'POST',\n body: payload,\n });\n }\n\n async finish(spanId: string
|
|
20
|
-
"import type { HttpTransportConfig } from '../config.js';\nimport type { TransportAction } from '../queue/actions.js';\nimport { InMemoryQueue } from '../queue/in-memory-queue.js';\nimport { TaskExecutor } from '../queue/task-executor.js';\nimport type { Span } from '../tracing/span.js';\nimport { getLogger } from '../utils/logging.js';\nimport { AgentInstanceClient } from './http/agent-instance-client.js';\nimport {\n AgentSpanClient,\n type AgentSpanCreatePayload,\n type AgentSpanStatus,\n} from './http/agent-span-client.js';\nimport { HttpClient } from './http/http-client.js';\n\nexport type AgentInstanceOptions = {\n agentId?: string;\n agentIdentifier?: string;\n agentName?: string;\n agentDescription?: string;\n};\n\nexport interface Transport {\n emit(span: Span): void;\n\n finishSpan(spanId: string, endTime: number): void;\n\n startAgentInstance(options?: AgentInstanceOptions): void;\n\n finishAgentInstance(): void;\n\n registerSchema(schema: Record<string, unknown>): void;\n\n close(): void | Promise<void>;\n}\n\nconst logger = getLogger('http-transport');\n\nexport class HttpTransport implements Transport {\n private closed = false;\n private readonly actionQueue = new InMemoryQueue<TransportAction>();\n private readonly taskExecutor: TaskExecutor<TransportAction>;\n private readonly agentInstanceClient: AgentInstanceClient;\n private readonly agentSpanClient: AgentSpanClient;\n private previousAgentSchema: string | null = null;\n private requiresNewAgentIdentifier = false;\n private previousAgentIdentifier: string | null = null;\n private agentInstanceId: string | null = null;\n private spanIdMap = new Map<string, string>();\n private pendingFinishes = new Map<string, number>();\n private pendingChildren = new Map<string, Span[]>();\n\n constructor(private config: HttpTransportConfig) {\n const httpClient = new HttpClient(config);\n this.agentInstanceClient = new AgentInstanceClient(httpClient);\n this.agentSpanClient = new AgentSpanClient(httpClient);\n this.taskExecutor = new TaskExecutor(this.actionQueue, this.processAction, {\n workerCount: 1,\n onError: async (error) => {\n logger.error('Error processing HTTP action:', error);\n },\n });\n this.taskExecutor.start();\n }\n\n registerSchema(schema: Record<string, unknown>): void {\n this.enqueue({ type: 'schema_register', schema });\n }\n\n startAgentInstance(options?: AgentInstanceOptions): void {\n this.enqueue({ type: 'agent_start', options });\n }\n\n finishAgentInstance(): void {\n this.enqueue({ type: 'agent_finish' });\n }\n\n emit(span: Span): void {\n this.enqueue({ type: 'span_end', span });\n }\n\n finishSpan(spanId: string, endTime: number): void {\n this.enqueue({ type: 'span_finish', spanId, endTime });\n }\n\n async close(): Promise<void> {\n this.closed = true;\n await this.taskExecutor.stop();\n if (this.pendingFinishes.size > 0) {\n logger.warn(\n `Transport closed with ${this.pendingFinishes.size} pending span finish(es) that could not be processed`\n );\n this.pendingFinishes.clear();\n }\n\n if (this.pendingChildren.size > 0) {\n logger.warn(\n `Transport closed with ${this.pendingChildren.size} unresolved parent span reference(s)`\n );\n this.pendingChildren.clear();\n }\n }\n\n private enqueue(action: TransportAction): void {\n if (this.closed) {\n return;\n }\n\n this.actionQueue.put(action).catch((error: unknown) => {\n logger.error('Failed to enqueue HTTP action:', error);\n });\n }\n\n private processAction = async (action: TransportAction): Promise<void> => {\n switch (action.type) {\n case 'schema_register': {\n const incomingSchema = JSON.stringify(action.schema);\n if (this.previousAgentSchema !== null && this.previousAgentSchema !== incomingSchema) {\n this.requiresNewAgentIdentifier = true;\n this.previousAgentIdentifier = this.config.agentIdentifier;\n this.agentInstanceId = null;\n }\n this.previousAgentSchema = incomingSchema;\n this.config.agentSchema = action.schema;\n return;\n }\n case 'agent_start': {\n if (this.requiresNewAgentIdentifier) {\n const nextAgentIdentifier = action.options?.agentIdentifier;\n if (\n nextAgentIdentifier === undefined ||\n nextAgentIdentifier === this.previousAgentIdentifier\n ) {\n logger.error('Schema changed; starting an agent requires a new agentIdentifier value.');\n return;\n }\n\n this.requiresNewAgentIdentifier = false;\n this.previousAgentIdentifier = null;\n }\n\n if (action.options?.agentId !== undefined) this.config.agentId = action.options.agentId;\n if (action.options?.agentIdentifier !== undefined) {\n this.config.agentIdentifier = action.options.agentIdentifier;\n }\n if (action.options?.agentName !== undefined)\n this.config.agentName = action.options.agentName;\n if (action.options?.agentDescription !== undefined) {\n this.config.agentDescription = action.options.agentDescription;\n }\n\n await this.startAgentInstanceHttp();\n return;\n }\n case 'agent_finish':\n await this.finishAgentInstanceHttp();\n return;\n case 'span_end':\n if (!this.agentInstanceId) {\n await this.ensureAgentRegistered();\n }\n\n if (action.span.parentSpanId && !this.spanIdMap.has(action.span.parentSpanId)) {\n this.queuePendingChild(action.span.parentSpanId, action.span);\n return;\n }\n\n await this.sendSpan(action.span);\n return;\n case 'span_finish': {\n const backendSpanId = this.spanIdMap.get(action.spanId);\n if (backendSpanId) {\n const timestamp = new Date(action.endTime).toISOString();\n await this.finishSpanHttp({ spanId: action.spanId, timestamp });\n } else {\n this.pendingFinishes.set(action.spanId, action.endTime);\n }\n return;\n }\n }\n };\n\n private async processPendingFinishes(spanId: string): Promise<void> {\n if (!this.pendingFinishes.has(spanId)) {\n return;\n }\n\n const pendingEndTime = this.pendingFinishes.get(spanId);\n if (pendingEndTime === undefined) {\n return;\n }\n\n try {\n const timestamp = new Date(pendingEndTime).toISOString();\n await this.finishSpanHttp({ spanId, timestamp });\n this.pendingFinishes.delete(spanId);\n } catch (error) {\n logger.error('Error processing pending span finish:', error);\n }\n }\n\n private async sendSpan(span: Span): Promise<void> {\n const payload = this.transformSpanToApiFormat(span);\n\n try {\n const response = await this.agentSpanClient.create(payload);\n const backendSpanId = response.details?.id;\n if (!backendSpanId) {\n return;\n }\n\n this.spanIdMap.set(span.spanId, backendSpanId);\n await this.processPendingFinishes(span.spanId);\n await this.processPendingChildren(span.spanId);\n } catch (error) {\n logger.error('Error sending span:', error);\n }\n }\n\n private queuePendingChild(parentSpanId: string, childSpan: Span): void {\n const existingChildren = this.pendingChildren.get(parentSpanId) ?? [];\n existingChildren.push(childSpan);\n this.pendingChildren.set(parentSpanId, existingChildren);\n }\n\n private async processPendingChildren(parentSpanId: string): Promise<void> {\n const waitingChildren = this.pendingChildren.get(parentSpanId);\n if (!waitingChildren || waitingChildren.length === 0) {\n return;\n }\n\n this.pendingChildren.delete(parentSpanId);\n for (const childSpan of waitingChildren) {\n await this.sendSpan(childSpan);\n }\n }\n\n private transformSpanToApiFormat(span: Span): AgentSpanCreatePayload {\n const startedAt = new Date(span.startTime).toISOString();\n const finishedAt = span.endTime ? new Date(span.endTime).toISOString() : null;\n const apiStatus = this.mapStatusForApi(span.status);\n\n const payload: Record<string, unknown> = {\n span_id: span.spanId,\n trace_id: span.traceId,\n name: span.name,\n status: apiStatus,\n inputs: span.inputs,\n outputs: span.outputs,\n metadata: span.metadata,\n token_usage: null,\n error: null,\n };\n\n if (span.tokenUsage) {\n payload.token_usage = {\n prompt_tokens: span.tokenUsage.promptTokens,\n completion_tokens: span.tokenUsage.completionTokens,\n total_tokens: span.tokenUsage.totalTokens,\n };\n }\n\n if (span.error) {\n payload.error = {\n error_type: span.error.errorType,\n message: span.error.message,\n stacktrace: span.error.stacktrace,\n };\n }\n\n const parentSpanId = span.parentSpanId ? (this.spanIdMap.get(span.parentSpanId) ?? null) : null;\n\n return {\n details: {\n agent_instance_id: this.agentInstanceId,\n schema_name: span.spanType,\n status: apiStatus,\n payload,\n parent_span_id: parentSpanId,\n started_at: startedAt,\n finished_at: finishedAt,\n },\n };\n }\n\n private mapStatusForApi(status: Span['status']): AgentSpanStatus {\n switch (status) {\n case 'running':\n return 'active';\n case 'success':\n return 'complete';\n case 'error':\n return 'failed';\n default:\n return 'active';\n }\n }\n\n private async ensureAgentRegistered(): Promise<boolean> {\n if (this.agentInstanceId) {\n return true;\n }\n\n const payload: Record<string, unknown> = {};\n\n if (this.config.agentId) payload.agent_id = this.config.agentId;\n if (this.config.agentIdentifier) {\n payload.agent_version = {\n external_identifier: this.config.agentIdentifier,\n name: this.config.agentName || 'Agent',\n description: this.config.agentDescription || '',\n };\n }\n\n if (this.config.agentSchema) {\n payload.agent_schema_version = this.config.agentSchema;\n }\n\n try {\n const data = await this.agentInstanceClient.register(payload);\n this.agentInstanceId = data.details?.id ?? null;\n } catch (error) {\n logger.error('Error registering agent:', error);\n }\n\n return this.agentInstanceId !== null;\n }\n\n private async startAgentInstanceHttp(): Promise<void> {\n const isRegistered = await this.ensureAgentRegistered();\n if (!isRegistered || !this.agentInstanceId) {\n logger.error('Cannot start agent instance: not registered');\n return;\n }\n\n try {\n await this.agentInstanceClient.start(this.agentInstanceId);\n } catch (error) {\n logger.error('Error starting agent instance:', error);\n }\n }\n\n private async finishAgentInstanceHttp(): Promise<void> {\n if (!this.agentInstanceId) {\n logger.error('Cannot finish agent instance: not registered');\n return;\n }\n\n try {\n await this.agentInstanceClient.finish(this.agentInstanceId);\n } catch (error) {\n logger.error('Error finishing agent instance:', error);\n }\n\n this.agentInstanceId = null;\n }\n\n private async finishSpanHttp(data: { spanId: string; timestamp: string }): Promise<void> {\n const backendSpanId = this.spanIdMap.get(data.spanId);\n if (!backendSpanId) {\n logger.warn(`Cannot finish span ${data.spanId}: backend ID not found`);\n return;\n }\n\n try {\n await this.agentSpanClient.finish(backendSpanId, data.timestamp);\n } catch (error) {\n logger.error('Error finishing span:', error);\n }\n }\n}\n",
|
|
21
|
-
"import { getActiveTracer } from './active-tracer.js';\nimport { SpanContext } from './context.js';\nimport type { StartSpanOptions, Tracer } from './tracer.js';\n\nexport async function withSpan<T>(\n tracer: Tracer,\n options: StartSpanOptions,\n fn: () => Promise<T> | T\n): Promise<T>;\nexport async function withSpan<T>(options: StartSpanOptions, fn: () => Promise<T> | T): Promise<T>;\nexport async function withSpan<T>(\n tracerOrOptions: Tracer | StartSpanOptions,\n optionsOrFn: StartSpanOptions | (() => Promise<T> | T),\n maybeFn?: () => Promise<T> | T\n): Promise<T> {\n const { tracer, options, fn } = resolveArgs(tracerOrOptions, optionsOrFn, maybeFn);\n const span = tracer.startSpan(options);\n\n try {\n const result = await SpanContext.runAsync(span,
|
|
20
|
+
"import { HttpClientError, type HttpRequester } from './http-client.js';\n\nexport type AgentSpanStatus = 'active' | 'complete' | 'failed';\n\nexport type AgentSpanFinishStatus = 'complete' | 'failed' | 'cancelled';\n\nexport type AgentSpanFinishOptions = {\n status?: AgentSpanFinishStatus;\n result_payload?: Record<string, unknown>;\n};\n\nexport type AgentSpanCreatePayload = {\n details: {\n agent_instance_id: string | null;\n schema_name: string;\n status: AgentSpanStatus;\n payload: Record<string, unknown>;\n result_payload?: Record<string, unknown>;\n parent_span_id: string | null;\n started_at: string;\n finished_at: string | null;\n };\n};\n\nexport type AgentSpanResponse = {\n details?: {\n id?: string;\n };\n};\n\nexport class AgentSpanClient {\n constructor(private readonly httpClient: HttpRequester) {}\n\n create(payload: AgentSpanCreatePayload): Promise<AgentSpanResponse> {\n return this.httpClient.request('/api/v1/agent_spans', {\n method: 'POST',\n body: payload,\n });\n }\n\n async finish(\n spanId: string,\n timestamp: string,\n options: AgentSpanFinishOptions = {}\n ): Promise<void> {\n try {\n await this.httpClient.request(`/api/v1/agent_spans/${spanId}/finish`, {\n method: 'POST',\n body: {\n timestamp,\n ...options,\n },\n });\n } catch (error) {\n if (\n error instanceof HttpClientError &&\n error.status === 409 &&\n isAlreadyFinishedError(error.responseBody)\n ) {\n return;\n }\n\n throw error;\n }\n }\n}\n\nfunction isAlreadyFinishedError(responseBody: unknown): boolean {\n if (!responseBody || typeof responseBody !== 'object') {\n return false;\n }\n\n const payload = responseBody as Record<string, unknown>;\n return payload.code === 'invalid_action';\n}\n",
|
|
21
|
+
"import type { HttpTransportConfig } from '../config.js';\nimport type { TransportAction } from '../queue/actions.js';\nimport { InMemoryQueue } from '../queue/in-memory-queue.js';\nimport { TaskExecutor } from '../queue/task-executor.js';\nimport { buildSpanResultPayload } from '../tracing/result-payload.js';\nimport type { Span } from '../tracing/span.js';\nimport { getLogger } from '../utils/logging.js';\nimport { AgentInstanceClient } from './http/agent-instance-client.js';\nimport {\n AgentSpanClient,\n type AgentSpanCreatePayload,\n type AgentSpanFinishStatus,\n type AgentSpanStatus,\n} from './http/agent-span-client.js';\nimport { HttpClient } from './http/http-client.js';\n\nexport type AgentInstanceOptions = {\n agentId?: string;\n agentIdentifier?: string;\n agentName?: string;\n agentDescription?: string;\n};\n\nexport interface Transport {\n emit(span: Span): void;\n\n finishSpan(spanId: string, endTime: number, options?: FinishSpanOptions): void;\n\n startAgentInstance(options?: AgentInstanceOptions): void;\n\n finishAgentInstance(): void;\n\n registerSchema(schema: Record<string, unknown>): void;\n\n close(): void | Promise<void>;\n}\n\nexport type FinishSpanOptions = {\n status?: AgentSpanFinishStatus;\n resultPayload?: Record<string, unknown>;\n};\n\ntype PendingFinish = {\n endTime: number;\n} & FinishSpanOptions;\n\nconst logger = getLogger('http-transport');\n\nexport class HttpTransport implements Transport {\n private closed = false;\n private readonly actionQueue = new InMemoryQueue<TransportAction>();\n private readonly taskExecutor: TaskExecutor<TransportAction>;\n private readonly agentInstanceClient: AgentInstanceClient;\n private readonly agentSpanClient: AgentSpanClient;\n private previousAgentSchema: string | null = null;\n private requiresNewAgentIdentifier = false;\n private previousAgentIdentifier: string | null = null;\n private agentInstanceId: string | null = null;\n private spanIdMap = new Map<string, string>();\n private pendingFinishes = new Map<string, PendingFinish>();\n private pendingChildren = new Map<string, Span[]>();\n\n constructor(private config: HttpTransportConfig) {\n const httpClient = new HttpClient(config);\n this.agentInstanceClient = new AgentInstanceClient(httpClient);\n this.agentSpanClient = new AgentSpanClient(httpClient);\n this.taskExecutor = new TaskExecutor(this.actionQueue, this.processAction, {\n workerCount: 1,\n onError: async (error) => {\n logger.error('Error processing HTTP action:', error);\n },\n });\n this.taskExecutor.start();\n }\n\n registerSchema(schema: Record<string, unknown>): void {\n this.enqueue({ type: 'schema_register', schema });\n }\n\n startAgentInstance(options?: AgentInstanceOptions): void {\n this.enqueue({ type: 'agent_start', options });\n }\n\n finishAgentInstance(): void {\n this.enqueue({ type: 'agent_finish' });\n }\n\n emit(span: Span): void {\n this.enqueue({ type: 'span_end', span });\n }\n\n finishSpan(spanId: string, endTime: number, options?: FinishSpanOptions): void {\n this.enqueue({\n type: 'span_finish',\n spanId,\n endTime,\n status: options?.status,\n resultPayload: options?.resultPayload,\n });\n }\n\n async close(): Promise<void> {\n this.closed = true;\n await this.taskExecutor.stop();\n if (this.pendingFinishes.size > 0) {\n logger.warn(\n `Transport closed with ${this.pendingFinishes.size} pending span finish(es) that could not be processed`\n );\n this.pendingFinishes.clear();\n }\n\n if (this.pendingChildren.size > 0) {\n logger.warn(\n `Transport closed with ${this.pendingChildren.size} unresolved parent span reference(s)`\n );\n this.pendingChildren.clear();\n }\n }\n\n private enqueue(action: TransportAction): void {\n if (this.closed) {\n return;\n }\n\n this.actionQueue.put(action).catch((error: unknown) => {\n logger.error('Failed to enqueue HTTP action:', error);\n });\n }\n\n private processAction = async (action: TransportAction): Promise<void> => {\n switch (action.type) {\n case 'schema_register': {\n const incomingSchema = JSON.stringify(action.schema);\n if (this.previousAgentSchema !== null && this.previousAgentSchema !== incomingSchema) {\n this.requiresNewAgentIdentifier = true;\n this.previousAgentIdentifier = this.config.agentIdentifier;\n this.agentInstanceId = null;\n }\n this.previousAgentSchema = incomingSchema;\n this.config.agentSchema = action.schema;\n return;\n }\n case 'agent_start': {\n if (this.requiresNewAgentIdentifier) {\n const nextAgentIdentifier = action.options?.agentIdentifier;\n if (\n nextAgentIdentifier === undefined ||\n nextAgentIdentifier === this.previousAgentIdentifier\n ) {\n logger.error('Schema changed; starting an agent requires a new agentIdentifier value.');\n return;\n }\n\n this.requiresNewAgentIdentifier = false;\n this.previousAgentIdentifier = null;\n }\n\n if (action.options?.agentId !== undefined) this.config.agentId = action.options.agentId;\n if (action.options?.agentIdentifier !== undefined) {\n this.config.agentIdentifier = action.options.agentIdentifier;\n }\n if (action.options?.agentName !== undefined)\n this.config.agentName = action.options.agentName;\n if (action.options?.agentDescription !== undefined) {\n this.config.agentDescription = action.options.agentDescription;\n }\n\n await this.startAgentInstanceHttp();\n return;\n }\n case 'agent_finish':\n await this.finishAgentInstanceHttp();\n return;\n case 'span_end':\n if (!this.agentInstanceId) {\n await this.ensureAgentRegistered();\n }\n\n if (action.span.parentSpanId && !this.spanIdMap.has(action.span.parentSpanId)) {\n this.queuePendingChild(action.span.parentSpanId, action.span);\n return;\n }\n\n await this.sendSpan(action.span);\n return;\n case 'span_finish': {\n if (this.spanIdMap.has(action.spanId)) {\n await this.finishSpanHttp(action.spanId, action.endTime, {\n status: action.status,\n resultPayload: action.resultPayload,\n });\n } else {\n this.pendingFinishes.set(action.spanId, {\n endTime: action.endTime,\n status: action.status,\n resultPayload: action.resultPayload,\n });\n }\n return;\n }\n }\n };\n\n private async processPendingFinishes(spanId: string): Promise<void> {\n const pendingFinish = this.pendingFinishes.get(spanId);\n if (pendingFinish === undefined) {\n return;\n }\n\n try {\n await this.finishSpanHttp(spanId, pendingFinish.endTime, {\n status: pendingFinish.status,\n resultPayload: pendingFinish.resultPayload,\n });\n this.pendingFinishes.delete(spanId);\n } catch (error) {\n logger.error('Error processing pending span finish:', error);\n }\n }\n\n private async sendSpan(span: Span): Promise<void> {\n const payload = this.transformSpanToApiFormat(span);\n\n try {\n const response = await this.agentSpanClient.create(payload);\n const backendSpanId = response.details?.id;\n if (!backendSpanId) {\n return;\n }\n\n this.spanIdMap.set(span.spanId, backendSpanId);\n await this.processPendingFinishes(span.spanId);\n await this.processPendingChildren(span.spanId);\n } catch (error) {\n logger.error('Error sending span:', error);\n }\n }\n\n private queuePendingChild(parentSpanId: string, childSpan: Span): void {\n const existingChildren = this.pendingChildren.get(parentSpanId) ?? [];\n existingChildren.push(childSpan);\n this.pendingChildren.set(parentSpanId, existingChildren);\n }\n\n private async processPendingChildren(parentSpanId: string): Promise<void> {\n const waitingChildren = this.pendingChildren.get(parentSpanId);\n if (!waitingChildren || waitingChildren.length === 0) {\n return;\n }\n\n this.pendingChildren.delete(parentSpanId);\n for (const childSpan of waitingChildren) {\n await this.sendSpan(childSpan);\n }\n }\n\n private transformSpanToApiFormat(span: Span): AgentSpanCreatePayload {\n const startedAt = new Date(span.startTime).toISOString();\n const finishedAt = span.endTime ? new Date(span.endTime).toISOString() : null;\n const apiStatus = this.mapStatusForApi(span.status);\n const resultPayload = apiStatus === 'active' ? undefined : buildSpanResultPayload(span);\n\n const payload: Record<string, unknown> = {\n span_id: span.spanId,\n trace_id: span.traceId,\n name: span.name,\n status: apiStatus,\n inputs: span.inputs,\n outputs: span.outputs,\n metadata: span.metadata,\n token_usage: null,\n error: null,\n };\n\n if (span.tokenUsage) {\n payload.token_usage = {\n prompt_tokens: span.tokenUsage.promptTokens,\n completion_tokens: span.tokenUsage.completionTokens,\n total_tokens: span.tokenUsage.totalTokens,\n };\n }\n\n if (span.error) {\n payload.error = {\n error_type: span.error.errorType,\n message: span.error.message,\n stacktrace: span.error.stacktrace,\n };\n }\n\n const parentSpanId = span.parentSpanId ? (this.spanIdMap.get(span.parentSpanId) ?? null) : null;\n\n return {\n details: {\n agent_instance_id: this.agentInstanceId,\n schema_name: span.spanType,\n status: apiStatus,\n payload,\n result_payload: resultPayload,\n parent_span_id: parentSpanId,\n started_at: startedAt,\n finished_at: finishedAt,\n },\n };\n }\n\n private mapStatusForApi(status: Span['status']): AgentSpanStatus {\n switch (status) {\n case 'running':\n return 'active';\n case 'success':\n return 'complete';\n case 'error':\n return 'failed';\n default:\n return 'active';\n }\n }\n\n private async ensureAgentRegistered(): Promise<boolean> {\n if (this.agentInstanceId) {\n return true;\n }\n\n const payload: Record<string, unknown> = {};\n\n if (this.config.agentId) payload.agent_id = this.config.agentId;\n if (this.config.agentIdentifier) {\n payload.agent_version = {\n external_identifier: this.config.agentIdentifier,\n name: this.config.agentName || 'Agent',\n description: this.config.agentDescription || '',\n };\n }\n\n if (this.config.agentSchema) {\n payload.agent_schema_version = this.config.agentSchema;\n }\n\n try {\n const data = await this.agentInstanceClient.register(payload);\n this.agentInstanceId = data.details?.id ?? null;\n } catch (error) {\n logger.error('Error registering agent:', error);\n }\n\n return this.agentInstanceId !== null;\n }\n\n private async startAgentInstanceHttp(): Promise<void> {\n const isRegistered = await this.ensureAgentRegistered();\n if (!isRegistered || !this.agentInstanceId) {\n logger.error('Cannot start agent instance: not registered');\n return;\n }\n\n try {\n await this.agentInstanceClient.start(this.agentInstanceId);\n } catch (error) {\n logger.error('Error starting agent instance:', error);\n }\n }\n\n private async finishAgentInstanceHttp(): Promise<void> {\n if (!this.agentInstanceId) {\n logger.error('Cannot finish agent instance: not registered');\n return;\n }\n\n try {\n await this.agentInstanceClient.finish(this.agentInstanceId);\n } catch (error) {\n logger.error('Error finishing agent instance:', error);\n }\n\n this.agentInstanceId = null;\n }\n\n private async finishSpanHttp(\n spanId: string,\n endTime: number,\n options?: FinishSpanOptions\n ): Promise<void> {\n const backendSpanId = this.spanIdMap.get(spanId);\n if (!backendSpanId) {\n logger.warn(`Cannot finish span ${spanId}: backend ID not found`);\n return;\n }\n\n try {\n await this.agentSpanClient.finish(backendSpanId, new Date(endTime).toISOString(), {\n status: options?.status,\n result_payload: options?.resultPayload ?? {},\n });\n } catch (error) {\n logger.error('Error finishing span:', error);\n }\n }\n}\n",
|
|
22
|
+
"import { getActiveTracer } from './active-tracer.js';\nimport { SpanContext } from './context.js';\nimport type { StartSpanOptions, Tracer } from './tracer.js';\n\nexport async function withSpan<T>(\n tracer: Tracer,\n options: StartSpanOptions,\n fn: () => Promise<T> | T\n): Promise<T>;\nexport async function withSpan<T>(options: StartSpanOptions, fn: () => Promise<T> | T): Promise<T>;\nexport async function withSpan<T>(\n tracerOrOptions: Tracer | StartSpanOptions,\n optionsOrFn: StartSpanOptions | (() => Promise<T> | T),\n maybeFn?: () => Promise<T> | T\n): Promise<T> {\n const { tracer, options, fn } = resolveArgs(tracerOrOptions, optionsOrFn, maybeFn);\n const span = tracer.startSpan(options);\n\n try {\n const result = await SpanContext.runAsync(span, () => Promise.resolve(fn()));\n tracer.endSpan(span, { outputs: toSpanOutputs(result) });\n return result;\n } catch (error) {\n const normalizedError = error instanceof Error ? error : new Error(String(error));\n tracer.endSpan(span, { error: normalizedError });\n throw error;\n }\n}\n\nfunction toSpanOutputs<T>(result: T): Record<string, unknown> {\n if (isRecord(result)) {\n return result;\n }\n\n if (result === undefined) {\n return {};\n }\n\n return { result };\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n if (value === null || typeof value !== 'object') {\n return false;\n }\n\n const prototype = Object.getPrototypeOf(value);\n return prototype === Object.prototype || prototype === null;\n}\n\nfunction resolveArgs<T>(\n tracerOrOptions: Tracer | StartSpanOptions,\n optionsOrFn: StartSpanOptions | (() => Promise<T> | T),\n maybeFn?: () => Promise<T> | T\n): {\n tracer: Tracer;\n options: StartSpanOptions;\n fn: () => Promise<T> | T;\n} {\n if (maybeFn) {\n return {\n tracer: tracerOrOptions as Tracer,\n options: optionsOrFn as StartSpanOptions,\n fn: maybeFn,\n };\n }\n\n const tracer = getActiveTracer();\n if (!tracer) {\n throw new Error(\n 'No active tracer found. Initialize Prefactor first or pass a tracer explicitly.'\n );\n }\n\n return {\n tracer,\n options: tracerOrOptions as StartSpanOptions,\n fn: optionsOrFn as () => Promise<T> | T,\n };\n}\n",
|
|
22
23
|
"/**\n * Truncate a string to a maximum length, adding an ellipsis if truncated\n *\n * @param value - The string to truncate\n * @param maxLength - Maximum length\n * @returns Truncated string\n */\nexport function truncateString(value: string, maxLength: number): string {\n if (value.length <= maxLength) {\n return value;\n }\n return `${value.slice(0, maxLength)}... [truncated]`;\n}\n\n/**\n * Serialize a value for JSON output, handling non-serializable types and\n * truncating long strings\n *\n * @param value - Value to serialize\n * @param maxLength - Maximum length for strings (null for no truncation)\n * @returns Serialized value\n *\n * @example\n * ```typescript\n * const serialized = serializeValue({ message: 'Hello'.repeat(1000) }, 100);\n * // Result: { message: 'HelloHelloHello... [truncated]' }\n * ```\n */\nexport function serializeValue(value: unknown, maxLength: number | null = 10000): unknown {\n // Handle primitives that don't need serialization\n if (value === null || value === undefined) {\n return value;\n }\n\n if (typeof value === 'boolean' || typeof value === 'number') {\n return value;\n }\n\n // Handle strings with truncation\n if (typeof value === 'string') {\n return maxLength !== null ? truncateString(value, maxLength) : value;\n }\n\n // Handle arrays\n if (Array.isArray(value)) {\n return value.map((item) => serializeValue(item, maxLength));\n }\n\n // Handle objects\n if (typeof value === 'object') {\n const result: Record<string, unknown> = {};\n for (const [key, val] of Object.entries(value)) {\n result[key] = serializeValue(val, maxLength);\n }\n return result;\n }\n\n // Handle other types by converting to string\n try {\n return String(value);\n } catch {\n return `<${typeof value} object>`;\n }\n}\n"
|
|
23
24
|
],
|
|
24
|
-
"mappings": "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",
|
|
25
|
-
"debugId": "
|
|
25
|
+
"mappings": "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",
|
|
26
|
+
"debugId": "BA1292FDF3A449CF64756E2164756E21",
|
|
26
27
|
"names": []
|
|
27
28
|
}
|
package/dist/index.d.ts
CHANGED
|
@@ -3,7 +3,7 @@ export { type Config, ConfigSchema, createConfig, type HttpTransportConfig, Http
|
|
|
3
3
|
export { type CoreRuntime, createCore } from './create-core.js';
|
|
4
4
|
export { registerShutdownHandler, shutdown } from './lifecycle.js';
|
|
5
5
|
export { SpanContext } from './tracing/context.js';
|
|
6
|
-
export { type ErrorInfo, type Span, SpanStatus, SpanType, type TokenUsage, } from './tracing/span.js';
|
|
6
|
+
export { createSpanTypePrefixer, type ErrorInfo, type Span, SpanStatus, SpanType, type TokenUsage, } from './tracing/span.js';
|
|
7
7
|
export { type EndSpanOptions, type StartSpanOptions, Tracer } from './tracing/tracer.js';
|
|
8
8
|
export { withSpan } from './tracing/with-span.js';
|
|
9
9
|
export type { AgentInstanceOptions, Transport } from './transport/http.js';
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAEnE,OAAO,EACL,KAAK,MAAM,EACX,YAAY,EACZ,YAAY,EACZ,KAAK,mBAAmB,EACxB,yBAAyB,EACzB,KAAK,iBAAiB,EACtB,uBAAuB,GACxB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,KAAK,WAAW,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAChE,OAAO,EAAE,uBAAuB,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EACL,KAAK,SAAS,EACd,KAAK,IAAI,EACT,UAAU,EACV,QAAQ,EACR,KAAK,UAAU,GAChB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,gBAAgB,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AACzF,OAAO,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAElD,YAAY,EAAE,oBAAoB,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAC3E,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAGpD,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAEnE,OAAO,EACL,KAAK,MAAM,EACX,YAAY,EACZ,YAAY,EACZ,KAAK,mBAAmB,EACxB,yBAAyB,EACzB,KAAK,iBAAiB,EACtB,uBAAuB,GACxB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,KAAK,WAAW,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAChE,OAAO,EAAE,uBAAuB,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EACL,sBAAsB,EACtB,KAAK,SAAS,EACd,KAAK,IAAI,EACT,UAAU,EACV,QAAQ,EACR,KAAK,UAAU,GAChB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,gBAAgB,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AACzF,OAAO,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAElD,YAAY,EAAE,oBAAoB,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAC3E,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAGpD,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -62,7 +62,7 @@ var HttpTransportConfigSchema = z.object({
|
|
|
62
62
|
agentIdentifier: z.string().default("v1.0.0"),
|
|
63
63
|
agentName: z.string().optional(),
|
|
64
64
|
agentDescription: z.string().optional(),
|
|
65
|
-
agentSchema: z.record(z.unknown()).optional(),
|
|
65
|
+
agentSchema: z.record(z.string(), z.unknown()).optional(),
|
|
66
66
|
requestTimeout: z.number().positive().default(30000),
|
|
67
67
|
maxRetries: z.number().int().nonnegative().default(3),
|
|
68
68
|
initialRetryDelay: z.number().positive().default(1000),
|
|
@@ -77,7 +77,7 @@ var PartialHttpConfigSchema = z.object({
|
|
|
77
77
|
agentIdentifier: z.string().optional(),
|
|
78
78
|
agentName: z.string().optional(),
|
|
79
79
|
agentDescription: z.string().optional(),
|
|
80
|
-
agentSchema: z.record(z.unknown()).optional(),
|
|
80
|
+
agentSchema: z.record(z.string(), z.unknown()).optional(),
|
|
81
81
|
requestTimeout: z.number().positive().optional(),
|
|
82
82
|
maxRetries: z.number().int().nonnegative().optional(),
|
|
83
83
|
initialRetryDelay: z.number().positive().optional(),
|
|
@@ -207,6 +207,18 @@ class SpanContext {
|
|
|
207
207
|
}
|
|
208
208
|
}
|
|
209
209
|
|
|
210
|
+
// packages/core/src/tracing/result-payload.ts
|
|
211
|
+
function buildSpanResultPayload(span) {
|
|
212
|
+
if (span.error) {
|
|
213
|
+
return {
|
|
214
|
+
error_type: span.error.errorType,
|
|
215
|
+
message: span.error.message,
|
|
216
|
+
stacktrace: span.error.stacktrace
|
|
217
|
+
};
|
|
218
|
+
}
|
|
219
|
+
return span.outputs ?? {};
|
|
220
|
+
}
|
|
221
|
+
|
|
210
222
|
// packages/core/src/tracing/span.ts
|
|
211
223
|
var SpanType = {
|
|
212
224
|
AGENT: "agent",
|
|
@@ -214,6 +226,9 @@ var SpanType = {
|
|
|
214
226
|
TOOL: "tool",
|
|
215
227
|
CHAIN: "chain"
|
|
216
228
|
};
|
|
229
|
+
function createSpanTypePrefixer(namespace) {
|
|
230
|
+
return (spanType) => `${namespace}:${spanType}`;
|
|
231
|
+
}
|
|
217
232
|
var SpanStatus;
|
|
218
233
|
((SpanStatus2) => {
|
|
219
234
|
SpanStatus2["RUNNING"] = "running";
|
|
@@ -274,7 +289,11 @@ class Tracer {
|
|
|
274
289
|
}
|
|
275
290
|
try {
|
|
276
291
|
if (span.spanType === SpanType.AGENT) {
|
|
277
|
-
|
|
292
|
+
const status = span.status === "error" /* ERROR */ ? "failed" : "complete";
|
|
293
|
+
this.transport.finishSpan(span.spanId, endTime, {
|
|
294
|
+
status,
|
|
295
|
+
resultPayload: buildSpanResultPayload(span)
|
|
296
|
+
});
|
|
278
297
|
} else {
|
|
279
298
|
this.transport.emit(span);
|
|
280
299
|
}
|
|
@@ -661,11 +680,14 @@ class AgentSpanClient {
|
|
|
661
680
|
body: payload
|
|
662
681
|
});
|
|
663
682
|
}
|
|
664
|
-
async finish(spanId, timestamp) {
|
|
683
|
+
async finish(spanId, timestamp, options = {}) {
|
|
665
684
|
try {
|
|
666
685
|
await this.httpClient.request(`/api/v1/agent_spans/${spanId}/finish`, {
|
|
667
686
|
method: "POST",
|
|
668
|
-
body: {
|
|
687
|
+
body: {
|
|
688
|
+
timestamp,
|
|
689
|
+
...options
|
|
690
|
+
}
|
|
669
691
|
});
|
|
670
692
|
} catch (error) {
|
|
671
693
|
if (error instanceof HttpClientError && error.status === 409 && isAlreadyFinishedError(error.responseBody)) {
|
|
@@ -725,8 +747,14 @@ class HttpTransport {
|
|
|
725
747
|
emit(span) {
|
|
726
748
|
this.enqueue({ type: "span_end", span });
|
|
727
749
|
}
|
|
728
|
-
finishSpan(spanId, endTime) {
|
|
729
|
-
this.enqueue({
|
|
750
|
+
finishSpan(spanId, endTime, options) {
|
|
751
|
+
this.enqueue({
|
|
752
|
+
type: "span_finish",
|
|
753
|
+
spanId,
|
|
754
|
+
endTime,
|
|
755
|
+
status: options?.status,
|
|
756
|
+
resultPayload: options?.resultPayload
|
|
757
|
+
});
|
|
730
758
|
}
|
|
731
759
|
async close() {
|
|
732
760
|
this.closed = true;
|
|
@@ -798,28 +826,32 @@ class HttpTransport {
|
|
|
798
826
|
await this.sendSpan(action.span);
|
|
799
827
|
return;
|
|
800
828
|
case "span_finish": {
|
|
801
|
-
|
|
802
|
-
|
|
803
|
-
|
|
804
|
-
|
|
829
|
+
if (this.spanIdMap.has(action.spanId)) {
|
|
830
|
+
await this.finishSpanHttp(action.spanId, action.endTime, {
|
|
831
|
+
status: action.status,
|
|
832
|
+
resultPayload: action.resultPayload
|
|
833
|
+
});
|
|
805
834
|
} else {
|
|
806
|
-
this.pendingFinishes.set(action.spanId,
|
|
835
|
+
this.pendingFinishes.set(action.spanId, {
|
|
836
|
+
endTime: action.endTime,
|
|
837
|
+
status: action.status,
|
|
838
|
+
resultPayload: action.resultPayload
|
|
839
|
+
});
|
|
807
840
|
}
|
|
808
841
|
return;
|
|
809
842
|
}
|
|
810
843
|
}
|
|
811
844
|
};
|
|
812
845
|
async processPendingFinishes(spanId) {
|
|
813
|
-
|
|
814
|
-
|
|
815
|
-
}
|
|
816
|
-
const pendingEndTime = this.pendingFinishes.get(spanId);
|
|
817
|
-
if (pendingEndTime === undefined) {
|
|
846
|
+
const pendingFinish = this.pendingFinishes.get(spanId);
|
|
847
|
+
if (pendingFinish === undefined) {
|
|
818
848
|
return;
|
|
819
849
|
}
|
|
820
850
|
try {
|
|
821
|
-
|
|
822
|
-
|
|
851
|
+
await this.finishSpanHttp(spanId, pendingFinish.endTime, {
|
|
852
|
+
status: pendingFinish.status,
|
|
853
|
+
resultPayload: pendingFinish.resultPayload
|
|
854
|
+
});
|
|
823
855
|
this.pendingFinishes.delete(spanId);
|
|
824
856
|
} catch (error) {
|
|
825
857
|
logger.error("Error processing pending span finish:", error);
|
|
@@ -859,6 +891,7 @@ class HttpTransport {
|
|
|
859
891
|
const startedAt = new Date(span.startTime).toISOString();
|
|
860
892
|
const finishedAt = span.endTime ? new Date(span.endTime).toISOString() : null;
|
|
861
893
|
const apiStatus = this.mapStatusForApi(span.status);
|
|
894
|
+
const resultPayload = apiStatus === "active" ? undefined : buildSpanResultPayload(span);
|
|
862
895
|
const payload = {
|
|
863
896
|
span_id: span.spanId,
|
|
864
897
|
trace_id: span.traceId,
|
|
@@ -891,6 +924,7 @@ class HttpTransport {
|
|
|
891
924
|
schema_name: span.spanType,
|
|
892
925
|
status: apiStatus,
|
|
893
926
|
payload,
|
|
927
|
+
result_payload: resultPayload,
|
|
894
928
|
parent_span_id: parentSpanId,
|
|
895
929
|
started_at: startedAt,
|
|
896
930
|
finished_at: finishedAt
|
|
@@ -958,14 +992,17 @@ class HttpTransport {
|
|
|
958
992
|
}
|
|
959
993
|
this.agentInstanceId = null;
|
|
960
994
|
}
|
|
961
|
-
async finishSpanHttp(
|
|
962
|
-
const backendSpanId = this.spanIdMap.get(
|
|
995
|
+
async finishSpanHttp(spanId, endTime, options) {
|
|
996
|
+
const backendSpanId = this.spanIdMap.get(spanId);
|
|
963
997
|
if (!backendSpanId) {
|
|
964
|
-
logger.warn(`Cannot finish span ${
|
|
998
|
+
logger.warn(`Cannot finish span ${spanId}: backend ID not found`);
|
|
965
999
|
return;
|
|
966
1000
|
}
|
|
967
1001
|
try {
|
|
968
|
-
await this.agentSpanClient.finish(backendSpanId,
|
|
1002
|
+
await this.agentSpanClient.finish(backendSpanId, new Date(endTime).toISOString(), {
|
|
1003
|
+
status: options?.status,
|
|
1004
|
+
result_payload: options?.resultPayload ?? {}
|
|
1005
|
+
});
|
|
969
1006
|
} catch (error) {
|
|
970
1007
|
logger.error("Error finishing span:", error);
|
|
971
1008
|
}
|
|
@@ -1007,8 +1044,8 @@ async function withSpan(tracerOrOptions, optionsOrFn, maybeFn) {
|
|
|
1007
1044
|
const { tracer, options, fn } = resolveArgs(tracerOrOptions, optionsOrFn, maybeFn);
|
|
1008
1045
|
const span = tracer.startSpan(options);
|
|
1009
1046
|
try {
|
|
1010
|
-
const result = await SpanContext.runAsync(span,
|
|
1011
|
-
tracer.endSpan(span);
|
|
1047
|
+
const result = await SpanContext.runAsync(span, () => Promise.resolve(fn()));
|
|
1048
|
+
tracer.endSpan(span, { outputs: toSpanOutputs(result) });
|
|
1012
1049
|
return result;
|
|
1013
1050
|
} catch (error) {
|
|
1014
1051
|
const normalizedError = error instanceof Error ? error : new Error(String(error));
|
|
@@ -1016,6 +1053,22 @@ async function withSpan(tracerOrOptions, optionsOrFn, maybeFn) {
|
|
|
1016
1053
|
throw error;
|
|
1017
1054
|
}
|
|
1018
1055
|
}
|
|
1056
|
+
function toSpanOutputs(result) {
|
|
1057
|
+
if (isRecord(result)) {
|
|
1058
|
+
return result;
|
|
1059
|
+
}
|
|
1060
|
+
if (result === undefined) {
|
|
1061
|
+
return {};
|
|
1062
|
+
}
|
|
1063
|
+
return { result };
|
|
1064
|
+
}
|
|
1065
|
+
function isRecord(value) {
|
|
1066
|
+
if (value === null || typeof value !== "object") {
|
|
1067
|
+
return false;
|
|
1068
|
+
}
|
|
1069
|
+
const prototype = Object.getPrototypeOf(value);
|
|
1070
|
+
return prototype === Object.prototype || prototype === null;
|
|
1071
|
+
}
|
|
1019
1072
|
function resolveArgs(tracerOrOptions, optionsOrFn, maybeFn) {
|
|
1020
1073
|
if (maybeFn) {
|
|
1021
1074
|
return {
|
|
@@ -1074,6 +1127,7 @@ export {
|
|
|
1074
1127
|
serializeValue,
|
|
1075
1128
|
registerShutdownHandler,
|
|
1076
1129
|
getLogger,
|
|
1130
|
+
createSpanTypePrefixer,
|
|
1077
1131
|
createCore,
|
|
1078
1132
|
createConfig,
|
|
1079
1133
|
configureLogging,
|
|
@@ -1088,4 +1142,4 @@ export {
|
|
|
1088
1142
|
AgentInstanceManager
|
|
1089
1143
|
};
|
|
1090
1144
|
|
|
1091
|
-
//# debugId=
|
|
1145
|
+
//# debugId=1119383A046052F064756E2164756E21
|