@prefactor/core 0.2.0 → 0.2.1

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 (82) hide show
  1. package/dist/agent/instance-manager.d.ts +5 -8
  2. package/dist/agent/instance-manager.d.ts.map +1 -1
  3. package/dist/agent/instance-manager.js +34 -55
  4. package/dist/agent/instance-manager.js.map +1 -1
  5. package/dist/config.d.ts +15 -63
  6. package/dist/config.d.ts.map +1 -1
  7. package/dist/config.js +29 -20
  8. package/dist/config.js.map +1 -1
  9. package/dist/create-core.d.ts +0 -2
  10. package/dist/create-core.d.ts.map +1 -1
  11. package/dist/create-core.js +10 -28
  12. package/dist/create-core.js.map +1 -1
  13. package/dist/index.cjs +577 -457
  14. package/dist/index.cjs.map +17 -15
  15. package/dist/index.d.ts +2 -7
  16. package/dist/index.d.ts.map +1 -1
  17. package/dist/index.js +577 -457
  18. package/dist/index.js.map +17 -15
  19. package/dist/queue/actions.d.ts +15 -26
  20. package/dist/queue/actions.d.ts.map +1 -1
  21. package/dist/queue/base.d.ts +15 -3
  22. package/dist/queue/base.d.ts.map +1 -1
  23. package/dist/queue/in-memory-queue.d.ts +11 -0
  24. package/dist/queue/in-memory-queue.d.ts.map +1 -0
  25. package/dist/queue/in-memory-queue.js +46 -0
  26. package/dist/queue/in-memory-queue.js.map +1 -0
  27. package/dist/queue/task-executor.d.ts +18 -0
  28. package/dist/queue/task-executor.d.ts.map +1 -0
  29. package/dist/queue/task-executor.js +77 -0
  30. package/dist/queue/task-executor.js.map +1 -0
  31. package/dist/tracing/span.d.ts +7 -14
  32. package/dist/tracing/span.d.ts.map +1 -1
  33. package/dist/tracing/span.js +5 -36
  34. package/dist/tracing/span.js.map +1 -1
  35. package/dist/tracing/tracer.d.ts +6 -7
  36. package/dist/tracing/tracer.d.ts.map +1 -1
  37. package/dist/tracing/tracer.js +27 -12
  38. package/dist/tracing/tracer.js.map +1 -1
  39. package/dist/transport/http/agent-instance-client.d.ts +23 -0
  40. package/dist/transport/http/agent-instance-client.d.ts.map +1 -0
  41. package/dist/transport/http/agent-instance-client.js +25 -0
  42. package/dist/transport/http/agent-instance-client.js.map +1 -0
  43. package/dist/transport/http/agent-span-client.d.ts +25 -0
  44. package/dist/transport/http/agent-span-client.d.ts.map +1 -0
  45. package/dist/transport/http/agent-span-client.js +37 -0
  46. package/dist/transport/http/agent-span-client.js.map +1 -0
  47. package/dist/transport/http/http-client.d.ts +43 -0
  48. package/dist/transport/http/http-client.d.ts.map +1 -0
  49. package/dist/transport/http/http-client.js +127 -0
  50. package/dist/transport/http/http-client.js.map +1 -0
  51. package/dist/transport/http/retry-policy.d.ts +4 -0
  52. package/dist/transport/http/retry-policy.d.ts.map +1 -0
  53. package/dist/transport/http/retry-policy.js +10 -0
  54. package/dist/transport/http/retry-policy.js.map +1 -0
  55. package/dist/transport/http.d.ts +31 -50
  56. package/dist/transport/http.d.ts.map +1 -1
  57. package/dist/transport/http.js +138 -227
  58. package/dist/transport/http.js.map +1 -1
  59. package/dist/utils/logging.d.ts.map +1 -1
  60. package/dist/utils/logging.js +7 -1
  61. package/dist/utils/logging.js.map +1 -1
  62. package/package.json +1 -1
  63. package/dist/agent/schema-registry.d.ts +0 -9
  64. package/dist/agent/schema-registry.d.ts.map +0 -1
  65. package/dist/agent/schema-registry.js +0 -16
  66. package/dist/agent/schema-registry.js.map +0 -1
  67. package/dist/queue/in-memory.d.ts +0 -9
  68. package/dist/queue/in-memory.d.ts.map +0 -1
  69. package/dist/queue/in-memory.js +0 -18
  70. package/dist/queue/in-memory.js.map +0 -1
  71. package/dist/transport/base.d.ts +0 -18
  72. package/dist/transport/base.d.ts.map +0 -1
  73. package/dist/transport/base.js +0 -2
  74. package/dist/transport/base.js.map +0 -1
  75. package/dist/transport/stdio.d.ts +0 -36
  76. package/dist/transport/stdio.d.ts.map +0 -1
  77. package/dist/transport/stdio.js +0 -56
  78. package/dist/transport/stdio.js.map +0 -1
  79. package/dist/transport/worker.d.ts +0 -22
  80. package/dist/transport/worker.d.ts.map +0 -1
  81. package/dist/transport/worker.js +0 -85
  82. package/dist/transport/worker.js.map +0 -1
@@ -1,22 +1,24 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../src/agent/instance-manager.ts", "../src/agent/schema-registry.ts", "../src/config.ts", "../src/create-core.ts", "../src/queue/in-memory.ts", "../src/tracing/tracer.ts", "../src/tracing/context.ts", "../src/tracing/span.ts", "../src/utils/logging.ts", "../src/transport/http.ts", "../src/utils/serialization.ts", "../src/transport/stdio.ts", "../src/transport/worker.ts"],
3
+ "sources": ["../src/agent/instance-manager.ts", "../src/config.ts", "../src/create-core.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/utils/serialization.ts"],
4
4
  "sourcesContent": [
5
- "import { isDeepStrictEqual } from 'node:util';\nimport type { AgentInstanceStart, QueueAction, SchemaRegistration } from '../queue/actions.js';\nimport type { Queue } from '../queue/base.js';\nimport { SchemaRegistry } from './schema-registry.js';\n\nconst orderInsensitiveArrayKeys = new Set(['required', 'enum', 'oneOf', 'allOf', 'anyOf', 'type']);\n\nconst stableStringify = (value: unknown): string => JSON.stringify(value) ?? 'undefined';\n\nconst normalizeSchema = (value: unknown, arrayKey?: string): unknown => {\n if (Array.isArray(value)) {\n const normalizedItems = value.map((item) => normalizeSchema(item));\n if (arrayKey && orderInsensitiveArrayKeys.has(arrayKey)) {\n return normalizedItems\n .map((item) => ({ item, key: stableStringify(item) }))\n .sort((left, right) => left.key.localeCompare(right.key))\n .map(({ item }) => item);\n }\n return normalizedItems;\n }\n\n if (value && typeof value === 'object') {\n const proto = Object.getPrototypeOf(value);\n if (proto === Object.prototype || proto === null) {\n const entries = Object.entries(value as Record<string, unknown>).sort(([left], [right]) =>\n left.localeCompare(right)\n );\n const normalized: Record<string, unknown> = {};\n for (const [key, entryValue] of entries) {\n normalized[key] = normalizeSchema(entryValue, key);\n }\n return normalized;\n }\n }\n\n return value;\n};\n\nexport type AgentInstanceManagerOptions = {\n schemaName: string;\n schemaIdentifier: string;\n allowUnregisteredSchema?: boolean;\n};\n\ntype AgentInstanceStartOptions = Omit<AgentInstanceStart, 'schemaName' | 'schemaIdentifier'>;\n\nexport class AgentInstanceManager {\n private schemaRegistry = new SchemaRegistry();\n\n constructor(\n private queue: Queue<QueueAction>,\n private options: AgentInstanceManagerOptions\n ) {}\n\n registerSchema(schema: Record<string, unknown>): void {\n if (this.schemaRegistry.has(this.options.schemaName, this.options.schemaIdentifier)) {\n const existing = this.schemaRegistry.get(\n this.options.schemaName,\n this.options.schemaIdentifier\n );\n if (\n existing &&\n !isDeepStrictEqual(normalizeSchema(existing.schema), normalizeSchema(schema))\n ) {\n console.warn(\n `Schema ${this.options.schemaName}@${this.options.schemaIdentifier} is already registered with a different payload. Ignoring registration.`\n );\n }\n return;\n }\n\n const registration: SchemaRegistration = {\n schemaName: this.options.schemaName,\n schemaIdentifier: this.options.schemaIdentifier,\n schema,\n };\n\n this.schemaRegistry.register(registration);\n this.queue.enqueue({ type: 'schema_register', data: registration });\n }\n\n startInstance(options: AgentInstanceStartOptions = {}): void {\n if (\n !this.options.allowUnregisteredSchema &&\n !this.schemaRegistry.has(this.options.schemaName, this.options.schemaIdentifier)\n ) {\n console.warn(\n `Schema ${this.options.schemaName}@${this.options.schemaIdentifier} must be registered before starting an agent instance.`\n );\n return;\n }\n\n const startData: AgentInstanceStart = {\n ...options,\n schemaName: this.options.schemaName,\n schemaIdentifier: this.options.schemaIdentifier,\n };\n\n this.queue.enqueue({ type: 'agent_start', data: startData });\n }\n\n finishInstance(): void {\n this.queue.enqueue({ type: 'agent_finish', data: {} });\n }\n}\n",
6
- "import type { SchemaRegistration } from '../queue/actions.js';\n\nexport class SchemaRegistry {\n private schemas = new Map<string, SchemaRegistration>();\n\n register(schema: SchemaRegistration): void {\n this.schemas.set(this.getKey(schema.schemaName, schema.schemaIdentifier), schema);\n }\n\n has(schemaName: string, schemaIdentifier: string): boolean {\n return this.schemas.has(this.getKey(schemaName, schemaIdentifier));\n }\n\n get(schemaName: string, schemaIdentifier: string): SchemaRegistration | undefined {\n return this.schemas.get(this.getKey(schemaName, schemaIdentifier));\n }\n\n private getKey(schemaName: string, schemaIdentifier: string): string {\n return `${schemaName}@${schemaIdentifier}`;\n }\n}\n",
7
- "import { z } from 'zod';\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 schema identifier name (used for registration/agent instance) */\n schemaName: z.string().optional(),\n\n /** Optional schema identifier (used for registration/agent instance) */\n schemaIdentifier: z.string().optional(),\n\n /** Optional agent schema for validation (full schema object) */\n agentSchema: z.record(z.unknown()).optional(),\n\n /** Optional pre-registered schema identifier (external identifier string) */\n agentSchemaIdentifier: z.string().optional(),\n\n /** Skip schema validation */\n skipSchema: z.boolean().default(false),\n\n /** Request timeout in milliseconds */\n requestTimeout: z.number().positive().default(30000),\n\n /** Connection timeout in milliseconds */\n connectTimeout: z.number().positive().default(10000),\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\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 schemaName: z.string().optional(),\n schemaIdentifier: z.string().optional(),\n agentSchema: z.record(z.unknown()).optional(),\n agentSchemaIdentifier: z.string().optional(),\n skipSchema: z.boolean().optional(),\n requestTimeout: z.number().positive().optional(),\n connectTimeout: 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});\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(['stdio', 'http']).default('stdio'),\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 config = {\n transportType:\n options?.transportType ??\n (process.env.PREFACTOR_TRANSPORT as 'stdio' | 'http' | undefined) ??\n 'stdio',\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\n // Validate and return\n return ConfigSchema.parse(config);\n}\n",
8
- "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 type { QueueAction } from './queue/actions.js';\nimport { InMemoryQueue } from './queue/in-memory.js';\nimport { Tracer } from './tracing/tracer.js';\nimport type { Transport } from './transport/base.js';\nimport { HttpTransport } from './transport/http.js';\nimport { StdioTransport } from './transport/stdio.js';\nimport { TransportWorker } from './transport/worker.js';\n\nexport type CoreRuntime = {\n tracer: Tracer;\n agentManager: AgentInstanceManager;\n worker: TransportWorker;\n shutdown: () => Promise<void>;\n};\n\nexport function createCore(config: Config): CoreRuntime {\n let transport: Transport;\n if (config.transportType === 'stdio') {\n transport = new StdioTransport();\n } else {\n if (!config.httpConfig) {\n throw new Error('HTTP transport requires httpConfig to be provided in configuration');\n }\n const httpConfig = HttpTransportConfigSchema.parse(config.httpConfig);\n transport = new HttpTransport(httpConfig);\n }\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 queue = new InMemoryQueue<QueueAction>();\n const worker = new TransportWorker(queue, transport, { batchSize: 25, intervalMs: 50 });\n const tracer = new Tracer(queue, partition);\n\n const schemaName = config.httpConfig?.schemaName ?? 'prefactor:agent';\n const schemaIdentifier = config.httpConfig?.schemaIdentifier ?? '1.0.0';\n const allowUnregisteredSchema =\n config.transportType === 'http' &&\n Boolean(\n config.httpConfig?.skipSchema ||\n config.httpConfig?.agentSchema ||\n config.httpConfig?.agentSchemaIdentifier\n );\n const agentManager = new AgentInstanceManager(queue, {\n schemaName,\n schemaIdentifier,\n allowUnregisteredSchema,\n });\n\n const shutdown = async (): Promise<void> => {\n await worker.close();\n };\n\n return { tracer, agentManager, worker, shutdown };\n}\n",
9
- "import type { Queue } from './base.js';\n\nexport class InMemoryQueue<T> implements Queue<T> {\n private items: T[] = [];\n\n enqueue(item: T): void {\n this.items.push(item);\n }\n\n dequeueBatch(maxItems: number): T[] {\n if (this.items.length === 0) return [];\n return this.items.splice(0, maxItems);\n }\n\n size(): number {\n return this.items.length;\n }\n\n async flush(): Promise<void> {\n return;\n }\n}\n",
10
- "import { generate, generatePartition, type Partition } from '@prefactor/pfid';\nimport type { QueueAction } from '../queue/actions.js';\nimport type { Queue } from '../queue/base.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 /** Tags for categorizing the span (optional) */\n tags?: string[];\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 queue - The queue 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 queue: Queue<QueueAction>,\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 tags: options.tags ?? [],\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.queue.enqueue({ type: 'span_end', data: span });\n } catch (error) {\n console.error('Failed to enqueue 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.queue.enqueue({ type: 'span_finish', data: { spanId: span.spanId, endTime } });\n } else {\n this.queue.enqueue({ type: 'span_end', data: span });\n }\n } catch (error) {\n console.error('Failed to enqueue 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.queue.flush();\n } catch (error) {\n console.error('Failed to flush queue:', error);\n }\n }\n}\n",
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",
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 { 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\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 };\n\n return { tracer, agentManager, shutdown };\n}\n",
8
+ "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",
11
9
  "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
- "/**\n * Types of spans that can be traced\n */\nexport enum SpanType {\n AGENT = 'agent',\n LLM = 'llm',\n TOOL = 'tool',\n CHAIN = 'chain',\n RETRIEVER = 'retriever',\n}\n\n/**\n * Default agent schema (v1.0.0) with span schemas for all supported types.\n * Used when no custom schema is provided during registration.\n */\nexport const DEFAULT_AGENT_SCHEMA: Record<string, unknown> = {\n external_identifier: '1.0.0',\n span_schemas: {\n agent: {\n type: 'object',\n properties: { type: { type: 'string', const: 'agent' } },\n },\n llm: {\n type: 'object',\n properties: { type: { type: 'string', const: 'llm' } },\n },\n tool: {\n type: 'object',\n properties: { type: { type: 'string', const: 'tool' } },\n },\n chain: {\n type: 'object',\n properties: { type: { type: 'string', const: 'chain' } },\n },\n retriever: {\n type: 'object',\n properties: { type: { type: 'string', const: 'retriever' } },\n },\n },\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 /** Tags for categorizing and filtering spans */\n tags: string[];\n}\n",
13
- "/**\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 = LogLevel.INFO;\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",
14
- "import type { HttpTransportConfig } from '../config.js';\nimport type { QueueAction } from '../queue/actions.js';\nimport { DEFAULT_AGENT_SCHEMA, type Span } from '../tracing/span.js';\nimport { getLogger } from '../utils/logging.js';\nimport type { Transport } from './base.js';\n\nconst logger = getLogger('http-transport');\n\n/**\n * HTTP transport sends spans to a remote API endpoint.\n *\n * Features:\n * - Exponential backoff retry logic\n * - Span ID mapping (SDK ID → backend ID)\n * - Agent instance lifecycle management\n *\n * @example\n * ```typescript\n * const transport = new HttpTransport({\n * apiUrl: 'https://api.prefactor.ai',\n * apiToken: process.env.PREFACTOR_API_TOKEN!,\n * });\n * ```\n */\nexport class HttpTransport implements Transport {\n private closed = false;\n private agentInstanceId: string | null = null;\n private spanIdMap = new Map<string, string>();\n // Pending finishes for spans that arrived before their span_end\n private pendingFinishes = new Map<string, number>();\n\n constructor(private config: HttpTransportConfig) {}\n\n async processBatch(items: QueueAction[]): Promise<void> {\n if (this.closed || items.length === 0) {\n return;\n }\n\n // First pass: apply schema updates\n for (const item of items) {\n if (item.type === 'schema_register') {\n this.config.agentSchema = item.data.schema;\n this.config.agentSchemaIdentifier = item.data.schemaIdentifier;\n this.config.schemaName = item.data.schemaName;\n this.config.schemaIdentifier = item.data.schemaIdentifier;\n }\n }\n\n // Second pass: process actions\n for (const item of items) {\n try {\n switch (item.type) {\n case 'schema_register':\n break;\n case 'agent_start':\n this.config.agentId = item.data.agentId;\n if (item.data.agentIdentifier !== undefined)\n this.config.agentIdentifier = item.data.agentIdentifier;\n this.config.agentName = item.data.agentName;\n this.config.agentDescription = item.data.agentDescription;\n await this.startAgentInstanceHttp();\n break;\n case 'agent_finish':\n await this.finishAgentInstanceHttp();\n break;\n case 'span_end':\n if (!this.agentInstanceId) {\n await this.ensureAgentRegistered();\n }\n await this.sendSpan(item.data);\n break;\n case 'span_finish': {\n const spanId = item.data.spanId;\n const backendSpanId = this.spanIdMap.get(spanId);\n if (backendSpanId) {\n // Span mapping exists, finish immediately\n const timestamp = new Date(item.data.endTime).toISOString();\n await this.finishSpanHttp({ spanId, timestamp });\n } else {\n // Defer finish until span_end creates the mapping\n this.pendingFinishes.set(spanId, item.data.endTime);\n }\n break;\n }\n }\n } catch (error) {\n logger.error('Error processing batch item:', error);\n }\n }\n }\n\n /**\n * Process any pending finishes for a span that was just registered.\n */\n private async processPendingFinishes(spanId: string): Promise<void> {\n const pendingEndTime = this.pendingFinishes.get(spanId);\n if (!pendingEndTime) {\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 /**\n * Send a span to the API\n */\n private async sendSpan(span: Span, retry = 0): Promise<void> {\n const url = `${this.config.apiUrl}/api/v1/agent_spans`;\n const payload = this.transformSpanToApiFormat(span);\n\n try {\n const response = await fetch(url, {\n method: 'POST',\n headers: {\n Authorization: `Bearer ${this.config.apiToken}`,\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify(payload),\n signal: AbortSignal.timeout(this.config.requestTimeout),\n });\n\n if (response.ok) {\n const data = (await response.json()) as { details?: { id?: string } };\n const backendSpanId = data?.details?.id;\n if (backendSpanId) {\n this.spanIdMap.set(span.spanId, backendSpanId);\n // Process any pending finishes that arrived before this span_end\n await this.processPendingFinishes(span.spanId);\n }\n return;\n }\n\n // Retry on server errors or rate limiting\n if ((response.status >= 500 || response.status === 429) && retry < this.config.maxRetries) {\n const delay = Math.min(\n this.config.initialRetryDelay * this.config.retryMultiplier ** retry,\n this.config.maxRetryDelay\n );\n logger.debug(`Retrying span send after ${delay}ms (attempt ${retry + 1})`);\n await new Promise((resolve) => setTimeout(resolve, delay));\n return this.sendSpan(span, retry + 1);\n }\n\n logger.error(`Failed to send span: ${response.status} ${response.statusText}`);\n } catch (error) {\n logger.error('Error sending span:', error);\n\n // Retry on network errors\n if (retry < this.config.maxRetries) {\n const delay = Math.min(\n this.config.initialRetryDelay * this.config.retryMultiplier ** retry,\n this.config.maxRetryDelay\n );\n await new Promise((resolve) => setTimeout(resolve, delay));\n return this.sendSpan(span, retry + 1);\n }\n }\n }\n\n /**\n * Transform span to backend API format with nested details/payload structure\n */\n private transformSpanToApiFormat(span: Span): Record<string, unknown> {\n const startedAt = new Date(span.startTime).toISOString();\n const finishedAt = span.endTime ? new Date(span.endTime).toISOString() : null;\n\n // Build payload with span data\n const payload: Record<string, unknown> = {\n span_id: span.spanId,\n trace_id: span.traceId,\n name: span.name,\n status: span.status,\n inputs: span.inputs,\n outputs: span.outputs,\n metadata: span.metadata,\n tags: span.tags,\n token_usage: null,\n error: null,\n };\n\n // Add optional token_usage\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 // Add optional error\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 // Resolve parent span ID to backend ID\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 payload,\n parent_span_id: parentSpanId,\n started_at: startedAt,\n finished_at: finishedAt,\n },\n };\n }\n\n /**\n * Get default schema (v1.0.0) with span schemas for all supported types\n */\n private getDefaultSchema(): Record<string, unknown> {\n return DEFAULT_AGENT_SCHEMA;\n }\n\n /**\n * Ensure an agent instance is registered\n */\n private async ensureAgentRegistered(): Promise<void> {\n if (this.agentInstanceId) {\n return;\n }\n\n const url = `${this.config.apiUrl}/api/v1/agent_instance/register`;\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 // Schema handling - four modes:\n // 1. skipSchema=true: No schema in payload (pre-registered on backend)\n // 2. agentSchema provided: Use full custom schema object\n // 3. agentSchemaIdentifier provided: Use version identifier only\n if (this.config.skipSchema) {\n logger.debug('Skipping schema in registration (skipSchema=true)');\n // Do not add agent_schema_version key\n } else if (this.config.agentSchema) {\n logger.debug('Using custom agent schema');\n payload.agent_schema_version = this.config.agentSchema;\n } else if (this.config.agentSchemaIdentifier) {\n logger.debug(`Using schema version: ${this.config.agentSchemaIdentifier}`);\n payload.agent_schema_version = {\n external_identifier: this.config.agentSchemaIdentifier,\n };\n } else {\n logger.debug('Using default hardcoded schema (v1.0.0)');\n payload.agent_schema_version = this.getDefaultSchema();\n }\n\n try {\n const response = await fetch(url, {\n method: 'POST',\n headers: {\n Authorization: `Bearer ${this.config.apiToken}`,\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify(payload),\n signal: AbortSignal.timeout(this.config.requestTimeout),\n });\n\n if (response.ok) {\n const data = (await response.json()) as { details?: { id?: string } };\n this.agentInstanceId = data?.details?.id ?? null;\n logger.debug(`Registered agent instance: ${this.agentInstanceId}`);\n } else {\n logger.error(`Failed to register agent: ${response.status} ${response.statusText}`);\n }\n } catch (error) {\n logger.error('Error registering agent:', error);\n }\n }\n\n /**\n * Start agent instance execution\n */\n private async startAgentInstanceHttp(): Promise<void> {\n await this.ensureAgentRegistered();\n\n if (!this.agentInstanceId) {\n logger.error('Cannot start agent instance: not registered');\n return;\n }\n\n const url = `${this.config.apiUrl}/api/v1/agent_instance/${this.agentInstanceId}/start`;\n\n try {\n const response = await fetch(url, {\n method: 'POST',\n headers: {\n Authorization: `Bearer ${this.config.apiToken}`,\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({}),\n signal: AbortSignal.timeout(this.config.requestTimeout),\n });\n\n if (!response.ok) {\n logger.error(`Failed to start agent instance: ${response.status} ${response.statusText}`);\n }\n } catch (error) {\n logger.error('Error starting agent instance:', error);\n }\n }\n\n /**\n * Finish agent instance execution\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 const url = `${this.config.apiUrl}/api/v1/agent_instance/${this.agentInstanceId}/finish`;\n\n try {\n const response = await fetch(url, {\n method: 'POST',\n headers: {\n Authorization: `Bearer ${this.config.apiToken}`,\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({}),\n signal: AbortSignal.timeout(this.config.requestTimeout),\n });\n\n if (!response.ok) {\n logger.error(`Failed to finish agent instance: ${response.status} ${response.statusText}`);\n }\n } catch (error) {\n logger.error('Error finishing agent instance:', error);\n }\n\n // Reset so the next agent_start registers a fresh instance\n this.agentInstanceId = null;\n }\n\n /**\n * Finish a span via HTTP\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 const url = `${this.config.apiUrl}/api/v1/agent_spans/${backendSpanId}/finish`;\n\n try {\n const response = await fetch(url, {\n method: 'POST',\n headers: {\n Authorization: `Bearer ${this.config.apiToken}`,\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({ timestamp: data.timestamp }),\n signal: AbortSignal.timeout(this.config.requestTimeout),\n });\n\n if (!response.ok) {\n logger.error(`Failed to finish span: ${response.status} ${response.statusText}`);\n }\n } catch (error) {\n logger.error('Error finishing span:', error);\n }\n }\n\n /**\n * Close the transport and wait for queue to drain\n *\n * @returns Promise that resolves when transport is closed\n */\n async close(): Promise<void> {\n this.closed = true;\n\n // Log warning for any pending finishes that will never be processed\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}\n",
15
- "/**\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",
16
- "import type { QueueAction } from '../queue/actions.js';\nimport { serializeValue } from '../utils/serialization.js';\nimport type { Transport } from './base.js';\n\n/**\n * STDIO transport emits spans as newline-delimited JSON to stdout.\n *\n * This is the default transport and requires no configuration.\n * It's useful for local development and for piping span data to other tools.\n *\n * Features:\n * - Newline-delimited JSON output\n * - Promise-based write locking for ordering\n * - Graceful error handling\n *\n * @example\n * ```typescript\n * const transport = new StdioTransport();\n * const tracer = new Tracer(transport);\n * ```\n */\nexport class StdioTransport implements Transport {\n private closed = false;\n private writeLock = Promise.resolve();\n\n /**\n * Emit a batch of queue actions to stdout as newline-delimited JSON\n *\n * @param items - The queue actions to emit\n */\n async processBatch(items: QueueAction[]): Promise<void> {\n if (this.closed || items.length === 0) {\n return;\n }\n\n // Queue write to maintain ordering\n this.writeLock = this.writeLock.then(async () => {\n for (const item of items) {\n try {\n const serialized = serializeValue(item);\n const json = JSON.stringify(serialized);\n await Bun.write(Bun.stdout, `${json}\\n`);\n } catch (error) {\n console.error('Failed to emit queue action to stdout:', error);\n }\n }\n });\n\n await this.writeLock;\n }\n\n /**\n * Close the transport and wait for pending writes to complete\n *\n * @returns Promise that resolves when all writes are complete\n */\n async close(): Promise<void> {\n this.closed = true;\n await this.writeLock;\n }\n}\n",
17
- "import type { QueueAction } from '../queue/actions.js';\nimport type { Queue } from '../queue/base.js';\nimport type { Transport } from './base.js';\n\ntype WorkerConfig = { batchSize: number; intervalMs: number };\n\nexport class TransportWorker {\n private closed = false;\n private inFlightPromise: Promise<void> | null = null;\n private loopPromise: Promise<void>;\n private pendingBatch: QueueAction[] | null = null;\n\n constructor(\n private queue: Queue<QueueAction>,\n private transport: Transport,\n private config: WorkerConfig\n ) {\n this.loopPromise = this.start();\n }\n\n private async start(): Promise<void> {\n while (!this.closed || this.pendingBatch || this.queue.size() > 0 || this.inFlightPromise) {\n const batch = this.pendingBatch ?? this.queue.dequeueBatch(this.config.batchSize);\n if (batch.length === 0) {\n await new Promise((resolve) => setTimeout(resolve, this.config.intervalMs));\n continue;\n }\n\n try {\n const inFlight = this.transport.processBatch(batch);\n this.inFlightPromise = inFlight;\n await inFlight;\n this.pendingBatch = null;\n } catch (error) {\n this.pendingBatch = batch;\n console.error('TransportWorker.processBatch failed', error);\n await new Promise((resolve) => setTimeout(resolve, this.config.intervalMs));\n } finally {\n this.inFlightPromise = null;\n }\n }\n }\n\n async flush(timeoutMs: number): Promise<void> {\n const start = Date.now();\n while (\n (this.queue.size() > 0 || this.pendingBatch || this.inFlightPromise) &&\n Date.now() - start < timeoutMs\n ) {\n await new Promise((resolve) => setTimeout(resolve, this.config.intervalMs));\n }\n }\n\n async close(timeoutMs = this.config.intervalMs * 50): Promise<void> {\n this.closed = true;\n const deadline = Date.now() + timeoutMs;\n const awaitWithTimeout = async (\n promise: Promise<void> | void,\n label: string,\n timeoutMs: number,\n warnOnTimeout = true\n ): Promise<boolean> => {\n if (timeoutMs <= 0) {\n if (warnOnTimeout) {\n console.warn(`TransportWorker.close timed out waiting for ${label}`);\n }\n return false;\n }\n const resolvedPromise = Promise.resolve(promise);\n let timeoutId: ReturnType<typeof setTimeout> | null = null;\n const timeoutPromise = new Promise<false>((resolve) => {\n timeoutId = setTimeout(() => resolve(false), timeoutMs);\n });\n const completed = await Promise.race([resolvedPromise.then(() => true), timeoutPromise]);\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n if (!completed && warnOnTimeout) {\n console.warn(`TransportWorker.close timed out waiting for ${label}`);\n }\n return completed;\n };\n\n const remainingTime = () => Math.max(0, deadline - Date.now());\n const loopCompleted = await awaitWithTimeout(\n this.loopPromise,\n 'loop to finish',\n remainingTime(),\n false\n );\n if (!loopCompleted) {\n console.warn(\n 'TransportWorker.close timed out waiting for loop to finish; closing transport now may cause potential data loss'\n );\n }\n const safeTransportClose = async (): Promise<void> => {\n try {\n await this.transport.close();\n } catch (error) {\n console.error('TransportWorker.close failed', error);\n }\n };\n await awaitWithTimeout(safeTransportClose(), 'transport to close', remainingTime());\n }\n}\n"
10
+ "/**\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\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",
11
+ "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",
12
+ "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",
13
+ "/**\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",
14
+ "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",
15
+ "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",
16
+ "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",
17
+ "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, timestamp: string): Promise<void> {\n try {\n await this.httpClient.request(`/api/v1/agent_spans/${spanId}/finish`, {\n method: 'POST',\n body: { timestamp },\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",
18
+ "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\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\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 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 } catch (error) {\n logger.error('Error sending span:', error);\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",
19
+ "/**\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"
18
20
  ],
19
- "mappings": "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",
20
- "debugId": "CE5CB6A1D11DF5BA64756E2164756E21",
21
+ "mappings": "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",
22
+ "debugId": "97A3CED64412936764756E2164756E21",
21
23
  "names": []
22
24
  }
package/dist/index.d.ts CHANGED
@@ -1,16 +1,11 @@
1
1
  export { AgentInstanceManager } from './agent/instance-manager.js';
2
- export { SchemaRegistry } from './agent/schema-registry.js';
3
2
  export { type Config, ConfigSchema, createConfig, type HttpTransportConfig, HttpTransportConfigSchema, type PartialHttpConfig, PartialHttpConfigSchema, } from './config.js';
4
3
  export { type CoreRuntime, createCore } from './create-core.js';
5
- export type { AgentInstanceFinish, AgentInstanceStart, QueueAction, SchemaRegistration, } from './queue/actions.js';
6
- export type { Queue } from './queue/base.js';
7
- export { InMemoryQueue } from './queue/in-memory.js';
8
4
  export { SpanContext } from './tracing/context.js';
9
- export { DEFAULT_AGENT_SCHEMA, type ErrorInfo, type Span, SpanStatus, SpanType, type TokenUsage, } from './tracing/span.js';
5
+ export { type ErrorInfo, type Span, SpanStatus, SpanType, type TokenUsage, } from './tracing/span.js';
10
6
  export { type EndSpanOptions, type StartSpanOptions, Tracer } from './tracing/tracer.js';
11
- export type { Transport } from './transport/base.js';
7
+ export type { AgentInstanceOptions, Transport } from './transport/http.js';
12
8
  export { HttpTransport } from './transport/http.js';
13
- export { StdioTransport } from './transport/stdio.js';
14
9
  export { configureLogging, getLogger } from './utils/logging.js';
15
10
  export { serializeValue, truncateString } from './utils/serialization.js';
16
11
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACnE,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAE5D,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;AAEhE,YAAY,EACV,mBAAmB,EACnB,kBAAkB,EAClB,WAAW,EACX,kBAAkB,GACnB,MAAM,oBAAoB,CAAC;AAC5B,YAAY,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EACL,oBAAoB,EACpB,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;AAEzF,YAAY,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAGtD,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,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;AAEzF,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"}