@mochabug/adapt-sdk 0.3.11 → 0.4.0
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/dist/anthropic/index.d.ts +53 -0
- package/dist/anthropic/index.d.ts.map +1 -0
- package/dist/cel/index.d.ts +2 -2
- package/dist/cel/index.d.ts.map +1 -1
- package/dist/cjs/anthropic.cjs +2 -0
- package/dist/cjs/anthropic.cjs.map +7 -0
- package/dist/cjs/cel.cjs +3 -3
- package/dist/cjs/cel.cjs.map +2 -2
- package/dist/cjs/gemini.cjs +2 -0
- package/dist/cjs/gemini.cjs.map +7 -0
- package/dist/cjs/openai.cjs +2 -0
- package/dist/cjs/openai.cjs.map +7 -0
- package/dist/cjs/signals.cjs +1 -1
- package/dist/cjs/signals.cjs.map +3 -3
- package/dist/esm/anthropic.mjs +2 -0
- package/dist/esm/anthropic.mjs.map +7 -0
- package/dist/esm/cel.mjs +3 -3
- package/dist/esm/cel.mjs.map +3 -3
- package/dist/esm/gemini.mjs +2 -0
- package/dist/esm/gemini.mjs.map +7 -0
- package/dist/esm/openai.mjs +2 -0
- package/dist/esm/openai.mjs.map +7 -0
- package/dist/esm/signals.mjs +1 -1
- package/dist/esm/signals.mjs.map +3 -3
- package/dist/gemini/index.d.ts +52 -0
- package/dist/gemini/index.d.ts.map +1 -0
- package/dist/openai/index.d.ts +55 -0
- package/dist/openai/index.d.ts.map +1 -0
- package/dist/signals/index.d.ts +3 -110
- package/dist/signals/index.d.ts.map +1 -1
- package/package.json +19 -3
package/dist/cjs/signals.cjs.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/signals/index.ts"],
|
|
4
|
-
"sourcesContent": ["import type {\n JTDSchemaJson,\n SignalDescriptorJson,\n SignalFormatJson\n} from '../api';\nimport { isSchema, isValidSchema, validate as jtdValidate } from 'jtd';\nimport type { Schema, ValidationError } from 'jtd';\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// JTD FUZZER (generate sample values from JTD schemas)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/** Maximum recursion depth for fuzzJTD to prevent infinite loops on self-referencing schemas. */\nconst FUZZ_MAX_DEPTH = 10;\n\n/** Generate a fuzzed (sample) value from a JTD schema. */\nexport function fuzzJTD(\n schema: JTDSchemaJson,\n definitions?: Record<string, JTDSchemaJson>,\n _depth: number = 0\n): unknown {\n if (_depth > FUZZ_MAX_DEPTH) return null;\n\n if (schema.ref) {\n const def = definitions?.[schema.ref];\n if (def) return fuzzJTD(def, definitions, _depth + 1);\n return null;\n }\n\n if (schema.type) {\n switch (schema.type) {\n case 'string':\n return 'Lorem ipsum';\n case 'timestamp':\n return '2024-01-15T10:30:00Z';\n case 'float32':\n case 'float64':\n return 42.5;\n case 'int8':\n case 'uint8':\n case 'int16':\n case 'uint16':\n case 'int32':\n case 'uint32':\n return BigInt(42);\n case 'boolean':\n return true;\n default:\n return null;\n }\n }\n\n if (schema.enum) {\n return schema.enum[0] ?? null;\n }\n\n if (schema.elements) {\n return [\n fuzzJTD(schema.elements, definitions, _depth + 1),\n fuzzJTD(schema.elements, definitions, _depth + 1)\n ];\n }\n\n if (schema.values) {\n return { key1: fuzzJTD(schema.values, definitions, _depth + 1) };\n }\n\n if (schema.properties || schema.optionalProperties) {\n const obj: Record<string, unknown> = {};\n if (schema.properties) {\n for (const [k, v] of Object.entries(schema.properties)) {\n obj[k] = fuzzJTD(v, definitions, _depth + 1);\n }\n }\n if (schema.optionalProperties) {\n for (const [k, v] of Object.entries(schema.optionalProperties)) {\n obj[k] = fuzzJTD(v, definitions, _depth + 1);\n }\n }\n return obj;\n }\n\n if (schema.discriminator && schema.mapping) {\n const firstKey = Object.keys(schema.mapping)[0];\n if (firstKey) {\n const variant = schema.mapping[firstKey]!;\n const obj = fuzzJTD(variant, definitions, _depth + 1) as Record<\n string,\n unknown\n >;\n obj[schema.discriminator] = firstKey;\n return obj;\n }\n return null;\n }\n\n // Empty schema\n return null;\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// JTD VALUE VALIDATION (delegates to the `jtd` npm package)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\nconst INTEGER_TYPES = new Set([\n 'int8',\n 'uint8',\n 'int16',\n 'uint16',\n 'int32',\n 'uint32'\n]);\n\nfunction formatInstancePath(instancePath: string[]): string {\n if (instancePath.length === 0) return '/';\n return instancePath\n .map((p) => (/^\\d+$/.test(p) ? `[${p}]` : `.${p}`))\n .join('');\n}\n\nfunction resolveSchemaParent(\n schema: Record<string, unknown>,\n schemaPath: string[]\n): Record<string, unknown> {\n let current: any = schema;\n for (let i = 0; i < schemaPath.length - 1; i++) {\n if (current && typeof current === 'object' && schemaPath[i]! in current) {\n current = current[schemaPath[i]!];\n } else {\n break;\n }\n }\n return current as Record<string, unknown>;\n}\n\nfunction resolveInstanceValue(value: unknown, instancePath: string[]): unknown {\n let current = value;\n for (const key of instancePath) {\n if (current && typeof current === 'object') {\n current = (current as Record<string, unknown>)[key];\n } else {\n return undefined;\n }\n }\n return current;\n}\n\nfunction formatValidationError(\n error: ValidationError,\n schema: Record<string, unknown>,\n value: unknown\n): string {\n const { instancePath, schemaPath } = error;\n const path = formatInstancePath(instancePath);\n const lastKey = schemaPath[schemaPath.length - 1];\n\n if (lastKey === 'type') {\n const parent = resolveSchemaParent(schema, schemaPath);\n const jtdType = parent?.type as string;\n if (jtdType === 'boolean') return `${path}: expected boolean`;\n if (jtdType === 'string') return `${path}: expected string`;\n if (jtdType === 'timestamp') return `${path}: expected timestamp string`;\n if (INTEGER_TYPES.has(jtdType)) return `${path}: expected integer`;\n return `${path}: expected number`;\n }\n\n if (lastKey === 'enum') {\n const parent = resolveSchemaParent(schema, schemaPath);\n const enumValues = parent?.enum as string[];\n return `${path}: expected one of [${enumValues.join(', ')}]`;\n }\n\n if (\n schemaPath.length >= 2 &&\n schemaPath[schemaPath.length - 2] === 'properties' &&\n lastKey\n ) {\n const prefix = path === '/' ? '' : path;\n return `${prefix}.${lastKey}: missing required property`;\n }\n\n if (lastKey === 'elements') return `${path}: expected array`;\n\n if (\n lastKey === 'properties' ||\n lastKey === 'optionalProperties' ||\n lastKey === 'values'\n ) {\n return `${path}: expected object`;\n }\n\n if (lastKey === 'discriminator')\n return `${path}: expected string discriminator`;\n\n if (lastKey === 'mapping') {\n const discValue = resolveInstanceValue(value, instancePath);\n return `${path}: unknown variant \"${discValue}\"`;\n }\n\n if (schemaPath.length === 0) return `${path}: unexpected property`;\n\n return `${path}: validation error at /${schemaPath.join('/')}`;\n}\n\n/**\n * Validate a value against a JTD schema, returning an array of error messages.\n * Delegates to the `jtd` npm package for spec-compliant validation.\n */\nexport function validateValueAgainstJTD(\n schema: JTDSchemaJson,\n value: unknown,\n definitions?: Record<string, JTDSchemaJson>\n): string[] {\n const defs =\n definitions ??\n (schema.definitions as Record<string, JTDSchemaJson> | undefined);\n\n const schemaForValidation = defs\n ? ({ ...schema, definitions: defs } as Schema)\n : (schema as Schema);\n\n // The jtd lib throws on invalid schemas (e.g., unresolved refs).\n if (!isValidSchema(schemaForValidation)) {\n if (schema.ref) {\n return [`/: unknown ref \"${schema.ref}\"`];\n }\n return [`/: invalid schema`];\n }\n\n const errors = jtdValidate(schemaForValidation, value, {\n maxDepth: MAX_VALIDATION_DEPTH,\n maxErrors: MAX_VALIDATION_ERRORS\n });\n\n return errors.map((err) =>\n formatValidationError(\n err,\n schemaForValidation as Record<string, unknown>,\n value\n )\n );\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// SIGNAL-LEVEL VALIDATION (JSON values against JTD formats)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/** Validate a JSON value against a single SignalFormatJson. */\nexport function validateValueAgainstSignal(\n format: SignalFormatJson,\n jsonValue: unknown\n): string[];\n/** Validate a JSON value against a SignalDescriptorJson (valid if value matches ANY JTD format). */\nexport function validateValueAgainstSignal(\n descriptor: SignalDescriptorJson,\n jsonValue: unknown\n): string[];\nexport function validateValueAgainstSignal(\n formatOrDescriptor: SignalFormatJson | SignalDescriptorJson,\n jsonValue: unknown\n): string[] {\n // Descriptor path \u2014 has `formats` array\n if (\n 'formats' in formatOrDescriptor &&\n Array.isArray(formatOrDescriptor.formats)\n ) {\n const jtdFormats = (\n formatOrDescriptor.formats as SignalFormatJson[]\n ).filter((f) => f.jtdSchema);\n if (jtdFormats.length === 0) {\n return ['/: no JTD formats in signal descriptor'];\n }\n // Valid if value matches ANY JTD format\n for (const format of jtdFormats) {\n const errors = validateValueAgainstJTD(format.jtdSchema!, jsonValue);\n if (errors.length === 0) return [];\n }\n // None matched \u2014 return errors from last format attempt\n return validateValueAgainstJTD(\n jtdFormats[jtdFormats.length - 1]!.jtdSchema!,\n jsonValue\n );\n }\n\n // Single format path\n const format = formatOrDescriptor as SignalFormatJson;\n if (!format.jtdSchema) {\n return ['/: signal format has no jtdSchema'];\n }\n return validateValueAgainstJTD(format.jtdSchema, jsonValue);\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// JTD \u2192 JSON SCHEMA CONVERTER\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/**\n * Convert JTD (JSON Type Definition) schema to JSON Schema for validation.\n *\n * Supports all 8 JTD schema forms per RFC 8927:\n * - Empty form: {}\n * - Ref form: { ref: \"...\" }\n * - Type form: { type: \"...\" }\n * - Enum form: { enum: [...] }\n * - Elements form: { elements: {...} }\n * - Properties form: { properties: {...}, optionalProperties: {...} }\n * - Values form: { values: {...} }\n * - Discriminator form: { discriminator: \"...\", mapping: {...} }\n */\nexport function jtdToJsonSchema(\n jtdSchema: JTDSchemaJson,\n definitions?: Record<string, JTDSchemaJson>,\n isRoot = true\n): any {\n if (!jtdSchema || typeof jtdSchema !== 'object') {\n return {};\n }\n\n const isNullable = jtdSchema['nullable'];\n const defs =\n definitions ||\n (jtdSchema['definitions'] as Record<string, JTDSchemaJson> | undefined);\n\n const result: any = {};\n\n if (isRoot) {\n result.$schema = 'http://json-schema.org/draft-07/schema#';\n }\n\n // Ref form\n if (jtdSchema['ref']) {\n const refName = jtdSchema['ref'] as string;\n if (defs && defs[refName]) {\n const resolvedSchema = jtdToJsonSchema(\n defs[refName] as JTDSchemaJson,\n defs,\n false\n );\n\n if (isNullable) {\n if (resolvedSchema.type) {\n resolvedSchema.type = Array.isArray(resolvedSchema.type)\n ? [...resolvedSchema.type, 'null']\n : [resolvedSchema.type, 'null'];\n } else {\n return {\n ...resolvedSchema,\n anyOf: [resolvedSchema, { type: 'null' }],\n ...(isRoot\n ? { $schema: 'http://json-schema.org/draft-07/schema#' }\n : {})\n };\n }\n }\n\n return isRoot\n ? {\n ...resolvedSchema,\n $schema: 'http://json-schema.org/draft-07/schema#'\n }\n : resolvedSchema;\n }\n return isRoot ? result : {};\n }\n\n // Type form\n if (jtdSchema['type']) {\n const typeMap: Record<string, string> = {\n boolean: 'boolean',\n string: 'string',\n timestamp: 'string',\n float32: 'number',\n float64: 'number',\n int8: 'integer',\n uint8: 'integer',\n int16: 'integer',\n uint16: 'integer',\n int32: 'integer',\n uint32: 'integer'\n };\n const jtdType = jtdSchema['type'] as string;\n const baseType = typeMap[jtdType] || 'string';\n\n result.type = isNullable ? [baseType, 'null'] : baseType;\n\n if (baseType === 'string' && jtdType === 'timestamp') {\n result.format = 'date-time';\n }\n return result;\n }\n\n // Enum form\n if (jtdSchema['enum']) {\n result.type = isNullable ? ['string', 'null'] : 'string';\n result.enum = isNullable\n ? [...(jtdSchema['enum'] as string[]), null]\n : jtdSchema['enum'];\n return result;\n }\n\n // Elements form\n if (jtdSchema['elements']) {\n result.type = isNullable ? ['array', 'null'] : 'array';\n result.items = jtdToJsonSchema(\n jtdSchema['elements'] as JTDSchemaJson,\n defs,\n false\n );\n return result;\n }\n\n // Properties form\n if (jtdSchema['properties'] || jtdSchema['optionalProperties']) {\n result.type = isNullable ? ['object', 'null'] : 'object';\n result.properties = {};\n result.required = [];\n\n if (jtdSchema['properties']) {\n for (const [key, value] of Object.entries(jtdSchema['properties'])) {\n result.properties[key] = jtdToJsonSchema(\n value as JTDSchemaJson,\n defs,\n false\n );\n result.required.push(key);\n }\n }\n\n if (jtdSchema['optionalProperties']) {\n for (const [key, value] of Object.entries(\n jtdSchema['optionalProperties']\n )) {\n result.properties[key] = jtdToJsonSchema(\n value as JTDSchemaJson,\n defs,\n false\n );\n }\n }\n\n // JTD is strict by default\n if (jtdSchema['additionalProperties'] !== true) {\n result.additionalProperties = false;\n }\n\n return result;\n }\n\n // Values form\n if (jtdSchema['values']) {\n result.type = isNullable ? ['object', 'null'] : 'object';\n result.additionalProperties = jtdToJsonSchema(\n jtdSchema['values'] as JTDSchemaJson,\n defs,\n false\n );\n return result;\n }\n\n // Discriminator form\n if (jtdSchema['discriminator'] && jtdSchema['mapping']) {\n const variants = [];\n const discriminatorKey = jtdSchema['discriminator'] as string;\n\n for (const [tag, schema] of Object.entries(jtdSchema['mapping'])) {\n const variantSchema = jtdToJsonSchema(\n schema as JTDSchemaJson,\n defs,\n false\n );\n\n if (!variantSchema.type) {\n variantSchema.type = 'object';\n } else if (\n variantSchema.type !== 'object' &&\n !Array.isArray(variantSchema.type)\n ) {\n variantSchema.type = 'object';\n }\n\n variantSchema.properties = variantSchema.properties || {};\n variantSchema.properties[discriminatorKey] = { const: tag };\n\n variantSchema.required = variantSchema.required || [];\n if (!variantSchema.required.includes(discriminatorKey)) {\n variantSchema.required.unshift(discriminatorKey);\n }\n\n // JTD discriminator variants are strict by default\n if (variantSchema.additionalProperties === undefined) {\n variantSchema.additionalProperties = false;\n }\n\n variants.push(variantSchema);\n }\n\n if (isNullable) {\n variants.push({ type: 'null' });\n }\n\n result.oneOf = variants;\n return result;\n }\n\n // Empty form\n return result;\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// JTD \u2192 UNIVERSAL JSON SCHEMA (for AI providers: Claude, Gemini, OpenAI)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\nexport interface UniversalJsonSchema {\n type?: string | string[];\n title?: string;\n description?: string;\n enum?: (string | number | null)[];\n format?: 'date-time' | 'date' | 'time';\n properties?: Record<string, UniversalJsonSchema>;\n required?: string[];\n additionalProperties?: false;\n items?: UniversalJsonSchema;\n}\n\nexport interface ConversionSuccess {\n success: true;\n schema: UniversalJsonSchema;\n}\n\nexport interface ConversionFailure {\n success: false;\n error: string;\n}\n\nexport type ConversionResult = ConversionSuccess | ConversionFailure;\n\nfunction checkUnsupportedFeatures(\n jtdSchema: JTDSchemaJson,\n path = ''\n): string | null {\n if (!jtdSchema || typeof jtdSchema !== 'object') {\n return null;\n }\n\n if ('discriminator' in jtdSchema || 'mapping' in jtdSchema) {\n return `Discriminator unions are not supported${\n path ? ` (at ${path})` : ''\n }. Use a simpler object structure instead.`;\n }\n\n if ('ref' in jtdSchema) {\n return `Schema references (ref) are not supported${\n path ? ` (at ${path})` : ''\n }. Inline the schema definition instead.`;\n }\n\n if ('definitions' in jtdSchema) {\n return `Schema definitions are not supported${\n path ? ` (at ${path})` : ''\n }. Inline the schema definition instead.`;\n }\n\n if ('values' in jtdSchema) {\n return `Dictionary/map schemas (values form) are not supported${\n path ? ` (at ${path})` : ''\n }. OpenAI requires additionalProperties: false on all objects. Use explicit properties instead.`;\n }\n\n if ('elements' in jtdSchema && jtdSchema.elements) {\n const elemError = checkUnsupportedFeatures(\n jtdSchema.elements as JTDSchemaJson,\n `${path}/elements`\n );\n if (elemError) return elemError;\n }\n\n if ('properties' in jtdSchema && jtdSchema.properties) {\n for (const [key, value] of Object.entries(jtdSchema.properties)) {\n const propError = checkUnsupportedFeatures(\n value as JTDSchemaJson,\n `${path}/properties/${key}`\n );\n if (propError) return propError;\n }\n }\n\n if ('optionalProperties' in jtdSchema && jtdSchema.optionalProperties) {\n for (const [key, value] of Object.entries(jtdSchema.optionalProperties)) {\n const propError = checkUnsupportedFeatures(\n value as JTDSchemaJson,\n `${path}/optionalProperties/${key}`\n );\n if (propError) return propError;\n }\n }\n\n return null;\n}\n\nfunction convertSchemaToUniversal(\n jtdSchema: JTDSchemaJson\n): UniversalJsonSchema {\n if (!jtdSchema || typeof jtdSchema !== 'object') {\n return {};\n }\n\n const isNullable = 'nullable' in jtdSchema && jtdSchema.nullable === true;\n const result: UniversalJsonSchema = {};\n\n const metadata = jtdSchema.metadata as Record<string, unknown> | undefined;\n if (metadata) {\n if (typeof metadata['title'] === 'string' && metadata['title'].trim()) {\n result.title = metadata['title'].trim();\n }\n if (\n typeof metadata['description'] === 'string' &&\n metadata['description'].trim()\n ) {\n result.description = metadata['description'].trim();\n }\n }\n\n // Type form\n if ('type' in jtdSchema && jtdSchema.type) {\n const typeMap: Record<string, string> = {\n boolean: 'boolean',\n string: 'string',\n timestamp: 'string',\n float32: 'number',\n float64: 'number',\n int8: 'integer',\n uint8: 'integer',\n int16: 'integer',\n uint16: 'integer',\n int32: 'integer',\n uint32: 'integer'\n };\n\n const jtdType = jtdSchema.type as string;\n const baseType = typeMap[jtdType] || 'string';\n\n result.type = isNullable ? [baseType, 'null'] : baseType;\n\n if (jtdType === 'timestamp') {\n result.format = 'date-time';\n }\n\n return result;\n }\n\n // Enum form\n if ('enum' in jtdSchema && jtdSchema.enum) {\n const enumValues = jtdSchema.enum as string[];\n result.type = isNullable ? ['string', 'null'] : 'string';\n result.enum = isNullable ? [...enumValues, null] : enumValues;\n return result;\n }\n\n // Elements form\n if ('elements' in jtdSchema && jtdSchema.elements) {\n result.type = isNullable ? ['array', 'null'] : 'array';\n result.items = convertSchemaToUniversal(\n jtdSchema.elements as JTDSchemaJson\n );\n return result;\n }\n\n // Properties form\n if ('properties' in jtdSchema || 'optionalProperties' in jtdSchema) {\n result.type = isNullable ? ['object', 'null'] : 'object';\n result.properties = {};\n result.required = [];\n result.additionalProperties = false;\n\n if ('properties' in jtdSchema && jtdSchema.properties) {\n for (const [key, value] of Object.entries(jtdSchema.properties)) {\n result.properties[key] = convertSchemaToUniversal(\n value as JTDSchemaJson\n );\n result.required.push(key);\n }\n }\n\n if ('optionalProperties' in jtdSchema && jtdSchema.optionalProperties) {\n for (const [key, value] of Object.entries(jtdSchema.optionalProperties)) {\n result.properties[key] = convertSchemaToUniversal(\n value as JTDSchemaJson\n );\n }\n }\n\n return result;\n }\n\n // Empty form\n return result;\n}\n\n/** Convert JTD schema to Universal JSON Schema compatible with Claude, Gemini, and OpenAI. */\nexport function jtdToUniversalJsonSchema(\n jtdSchema: JTDSchemaJson\n): ConversionResult {\n const unsupportedError = checkUnsupportedFeatures(jtdSchema);\n if (unsupportedError) {\n return { success: false, error: unsupportedError };\n }\n\n try {\n const schema = convertSchemaToUniversal(jtdSchema);\n return { success: true, schema };\n } catch (err) {\n return {\n success: false,\n error: err instanceof Error ? err.message : 'Unknown conversion error'\n };\n }\n}\n\ninterface UniversalCompatible {\n compatible: true;\n}\n\ninterface UniversalNotCompatible {\n compatible: false;\n error: string;\n}\n\ntype UniversalCompatibilityResult =\n | UniversalCompatible\n | UniversalNotCompatible;\n\nfunction isUniversalCompatible(\n jtdSchema: JTDSchemaJson\n): UniversalCompatibilityResult {\n const error = checkUnsupportedFeatures(jtdSchema);\n if (error) {\n return { compatible: false, error };\n }\n\n return { compatible: true };\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// JTD SCHEMA VALIDATION (using the `jtd` npm package)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\nexport const MAX_VALIDATION_DEPTH = 32;\nexport const MAX_VALIDATION_ERRORS = 100;\n\n/** Validate that the input is a valid JTD schema. */\nexport function validateJTDSchema(\n schema: unknown\n): { valid: true; schema: JTDSchemaJson } | { valid: false; error: string } {\n if (!isSchema(schema)) {\n return {\n valid: false,\n error: 'Invalid JTD schema: Schema does not match JTD structure'\n };\n }\n\n if (!isValidSchema(schema)) {\n return {\n valid: false,\n error:\n 'Invalid JTD schema: Schema has semantic errors (e.g., circular references, conflicting forms)'\n };\n }\n\n return { valid: true, schema: schema as unknown as JTDSchemaJson };\n}\n\n/**\n * Validate that the input is a valid JTD schema compatible with universal JSON schema\n * (Anthropic Claude, Google Gemini, and OpenAI structured outputs).\n */\nexport function validateUniversalJTD(\n schema: unknown\n): { valid: true; schema: JTDSchemaJson } | { valid: false; error: string } {\n const jtdResult = validateJTDSchema(schema);\n if (!jtdResult.valid) return jtdResult;\n\n const s = jtdResult.schema;\n if (\n !('type' in s) &&\n !('enum' in s) &&\n !('elements' in s) &&\n !('properties' in s) &&\n !('optionalProperties' in s)\n ) {\n return {\n valid: false,\n error:\n 'Schema must define structure (properties, type, enum, or elements). Empty schemas are not supported.'\n };\n }\n\n const compatibilityResult = isUniversalCompatible(jtdResult.schema);\n if (!compatibilityResult.compatible) {\n return { valid: false, error: compatibilityResult.error };\n }\n\n return { valid: true, schema: jtdResult.schema };\n}\n\n/** Parse and validate a JSON string. */\nexport function validateJSON(jsonString: string): {\n valid: boolean;\n data?: unknown;\n error?: string;\n} {\n try {\n const data = JSON.parse(jsonString);\n return { valid: true, data };\n } catch (error) {\n return {\n valid: false,\n error: `Invalid JSON: ${error instanceof Error ? error.message : 'Parse error'}`\n };\n }\n}\n\n/** Parse a JSON string and validate it as a JTD schema. */\nexport function validateJTDSchemaString(\n schemaString: string\n): { valid: true; schema: JTDSchemaJson } | { valid: false; error: string } {\n const jsonResult = validateJSON(schemaString);\n if (!jsonResult.valid) return { valid: false, error: jsonResult.error! };\n\n return validateJTDSchema(jsonResult.data);\n}\n\n/** Parse a JSON string and validate it as a universal JTD schema (compatible with Claude, Gemini, OpenAI). */\nexport function validateUniversalJTDSchemaString(\n schemaString: string\n): { valid: true; schema: JTDSchemaJson } | { valid: false; error: string } {\n const jsonResult = validateJSON(schemaString);\n if (!jsonResult.valid) return { valid: false, error: jsonResult.error! };\n\n return validateUniversalJTD(jsonResult.data);\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// MONACO EDITOR CONFIG FOR JTD SCHEMA EDITING\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/**\n * Monaco editor JSON schema configuration for JTD schemas compatible with\n * Anthropic Claude, Google Gemini, and OpenAI structured outputs.\n * This is a restricted subset of JTD that excludes discriminator unions, refs, and values (dictionaries).\n */\nexport const UNIVERSAL_JTD_SCHEMA_CONFIG = {\n uri: 'https://mochabug.com/schemas/universal-jtd-schema.json',\n fileMatch: ['inmemory://jtd-schema/*.json'],\n schema: {\n $schema: 'http://json-schema.org/draft-07/schema#',\n title: 'Universal JTD Schema',\n description:\n 'JSON Type Definition schema compatible with Anthropic Claude, Google Gemini, and OpenAI structured outputs. Note: discriminator unions, refs, and dictionary/map schemas (values) are NOT supported.',\n type: 'object',\n properties: {\n type: {\n description: 'Type form - defines a primitive type',\n enum: [\n 'boolean',\n 'string',\n 'timestamp',\n 'float32',\n 'float64',\n 'int8',\n 'uint8',\n 'int16',\n 'uint16',\n 'int32',\n 'uint32'\n ]\n },\n enum: {\n description:\n 'Enum form - defines a set of string values for classification',\n type: 'array',\n items: { type: 'string' },\n minItems: 1\n },\n elements: {\n description: 'Elements form - defines an array with typed elements',\n $ref: '#'\n },\n properties: {\n description:\n 'Properties form - defines an object with required properties',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n optionalProperties: {\n description:\n 'Optional properties - defines optional object properties (can be omitted)',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n nullable: {\n description: 'Allow null values in addition to the defined type',\n type: 'boolean'\n },\n metadata: {\n description:\n 'Custom metadata - use \"title\" and \"description\" to guide the AI model',\n type: 'object',\n properties: {\n title: {\n type: 'string',\n description: 'Short title/label for this field'\n },\n description: {\n type: 'string',\n description:\n 'Detailed description of what this field should contain'\n }\n },\n additionalProperties: false\n }\n }\n // Note: We explicitly do NOT include discriminator, mapping, ref, definitions, values,\n // or additionalProperties as these are not universally supported across AI providers\n }\n};\n\n/** Monaco editor JSON schema configuration for JTD schema IntelliSense and validation. */\nexport const JTD_SCHEMA_CONFIG = {\n uri: 'https://jsontypedef.com/schemas/jtd-schema.json',\n fileMatch: ['inmemory://jtd-schema/*.json'],\n schema: {\n $schema: 'http://json-schema.org/draft-07/schema#',\n type: 'object',\n properties: {\n type: {\n description: 'Type form - defines a primitive type',\n enum: [\n 'boolean',\n 'string',\n 'timestamp',\n 'float32',\n 'float64',\n 'int8',\n 'uint8',\n 'int16',\n 'uint16',\n 'int32',\n 'uint32'\n ]\n },\n enum: {\n description: 'Enum form - defines a set of string values',\n type: 'array',\n items: { type: 'string' }\n },\n elements: {\n description: 'Elements form - defines an array with typed elements',\n $ref: '#'\n },\n properties: {\n description:\n 'Properties form - defines an object with required properties',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n optionalProperties: {\n description: 'Optional properties - defines optional object properties',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n values: {\n description: 'Values form - defines a map/dictionary with typed values',\n $ref: '#'\n },\n discriminator: {\n description: 'Discriminator form - defines a tagged union',\n type: 'string'\n },\n mapping: {\n description: 'Mapping for discriminator form',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n ref: {\n description: 'Ref form - references a definition',\n type: 'string'\n },\n definitions: {\n description: 'Top-level definitions for reusable schemas',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n nullable: {\n description: 'Allow null values',\n type: 'boolean'\n },\n metadata: {\n description: 'Custom metadata for documentation',\n type: 'object'\n },\n additionalProperties: {\n description: 'Allow additional properties (properties form only)',\n type: 'boolean'\n }\n }\n }\n};\n"],
|
|
5
|
-
"mappings": "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AE,MAAO,GAAO,MAAOA,EAAW,KAAO,CAGzE,CAWO,IAAMzE,EAA8B,CACzC,IAAK,yDACL,UAAW,CAAC,8BAA8B,EAC1C,OAAQ,CACN,QAAS,0CACT,MAAO,uBACP,YACE,uMACF,KAAM,SACN,WAAY,CACV,KAAM,CACJ,YAAa,uCACb,KAAM,CACJ,UACA,SACA,YACA,UACA,UACA,OACA,QACA,QACA,SACA,QACA,QACF,CACF,EACA,KAAM,CACJ,YACE,gEACF,KAAM,QACN,MAAO,CAAE,KAAM,QAAS,EACxB,SAAU,CACZ,EACA,SAAU,CACR,YAAa,uDACb,KAAM,GACR,EACA,WAAY,CACV,YACE,+DACF,KAAM,SACN,qBAAsB,CAAE,KAAM,GAAI,CACpC,EACA,mBAAoB,CAClB,YACE,4EACF,KAAM,SACN,qBAAsB,CAAE,KAAM,GAAI,CACpC,EACA,SAAU,CACR,YAAa,oDACb,KAAM,SACR,EACA,SAAU,CACR,YACE,wEACF,KAAM,SACN,WAAY,CACV,MAAO,CACL,KAAM,SACN,YAAa,kCACf,EACA,YAAa,CACX,KAAM,SACN,YACE,wDACJ,CACF,EACA,qBAAsB,EACxB,CACF,CAGF,CACF,EAGaH,EAAoB,CAC/B,IAAK,kDACL,UAAW,CAAC,8BAA8B,EAC1C,OAAQ,CACN,QAAS,0CACT,KAAM,SACN,WAAY,CACV,KAAM,CACJ,YAAa,uCACb,KAAM,CACJ,UACA,SACA,YACA,UACA,UACA,OACA,QACA,QACA,SACA,QACA,QACF,CACF,EACA,KAAM,CACJ,YAAa,6CACb,KAAM,QACN,MAAO,CAAE,KAAM,QAAS,CAC1B,EACA,SAAU,CACR,YAAa,uDACb,KAAM,GACR,EACA,WAAY,CACV,YACE,+DACF,KAAM,SACN,qBAAsB,CAAE,KAAM,GAAI,CACpC,EACA,mBAAoB,CAClB,YAAa,2DACb,KAAM,SACN,qBAAsB,CAAE,KAAM,GAAI,CACpC,EACA,OAAQ,CACN,YAAa,2DACb,KAAM,GACR,EACA,cAAe,CACb,YAAa,8CACb,KAAM,QACR,EACA,QAAS,CACP,YAAa,iCACb,KAAM,SACN,qBAAsB,CAAE,KAAM,GAAI,CACpC,EACA,IAAK,CACH,YAAa,qCACb,KAAM,QACR,EACA,YAAa,CACX,YAAa,6CACb,KAAM,SACN,qBAAsB,CAAE,KAAM,GAAI,CACpC,EACA,SAAU,CACR,YAAa,oBACb,KAAM,SACR,EACA,SAAU,CACR,YAAa,oCACb,KAAM,QACR,EACA,qBAAsB,CACpB,YAAa,qDACb,KAAM,SACR,CACF,CACF,CACF",
|
|
6
|
-
"names": ["signals_exports", "__export", "JTD_SCHEMA_CONFIG", "MAX_VALIDATION_DEPTH", "MAX_VALIDATION_ERRORS", "
|
|
4
|
+
"sourcesContent": ["import type {\n JTDSchemaJson,\n SignalDescriptorJson,\n SignalFormatJson\n} from '../api';\nimport { isSchema, isValidSchema, validate as jtdValidate } from 'jtd';\nimport type { Schema, ValidationError } from 'jtd';\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// JTD FUZZER (generate sample values from JTD schemas)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/** Maximum recursion depth for fuzzJTD to prevent infinite loops on self-referencing schemas. */\nconst FUZZ_MAX_DEPTH = 10;\n\n/** Generate a fuzzed (sample) value from a JTD schema. */\nexport function fuzzJTD(\n schema: JTDSchemaJson,\n definitions?: Record<string, JTDSchemaJson>,\n _depth: number = 0\n): unknown {\n if (_depth > FUZZ_MAX_DEPTH) return null;\n\n if (schema.ref) {\n const def = definitions?.[schema.ref];\n if (def) return fuzzJTD(def, definitions, _depth + 1);\n return null;\n }\n\n if (schema.type) {\n switch (schema.type) {\n case 'string':\n return 'Lorem ipsum';\n case 'timestamp':\n return '2024-01-15T10:30:00Z';\n case 'float32':\n case 'float64':\n return 42.5;\n case 'int8':\n case 'uint8':\n case 'int16':\n case 'uint16':\n case 'int32':\n case 'uint32':\n return BigInt(42);\n case 'boolean':\n return true;\n default:\n return null;\n }\n }\n\n if (schema.enum) {\n return schema.enum[0] ?? null;\n }\n\n if (schema.elements) {\n return [\n fuzzJTD(schema.elements, definitions, _depth + 1),\n fuzzJTD(schema.elements, definitions, _depth + 1)\n ];\n }\n\n if (schema.values) {\n return { key1: fuzzJTD(schema.values, definitions, _depth + 1) };\n }\n\n if (schema.properties || schema.optionalProperties) {\n const obj: Record<string, unknown> = {};\n if (schema.properties) {\n for (const [k, v] of Object.entries(schema.properties)) {\n obj[k] = fuzzJTD(v, definitions, _depth + 1);\n }\n }\n if (schema.optionalProperties) {\n for (const [k, v] of Object.entries(schema.optionalProperties)) {\n obj[k] = fuzzJTD(v, definitions, _depth + 1);\n }\n }\n return obj;\n }\n\n if (schema.discriminator && schema.mapping) {\n const firstKey = Object.keys(schema.mapping)[0];\n if (firstKey) {\n const variant = schema.mapping[firstKey]!;\n const obj = fuzzJTD(variant, definitions, _depth + 1) as Record<\n string,\n unknown\n >;\n obj[schema.discriminator] = firstKey;\n return obj;\n }\n return null;\n }\n\n // Empty schema\n return null;\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// JTD VALUE VALIDATION (delegates to the `jtd` npm package)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\nconst INTEGER_TYPES = new Set([\n 'int8',\n 'uint8',\n 'int16',\n 'uint16',\n 'int32',\n 'uint32'\n]);\n\nfunction formatInstancePath(instancePath: string[]): string {\n if (instancePath.length === 0) return '/';\n return instancePath\n .map((p) => (/^\\d+$/.test(p) ? `[${p}]` : `.${p}`))\n .join('');\n}\n\nfunction resolveSchemaParent(\n schema: Record<string, unknown>,\n schemaPath: string[]\n): Record<string, unknown> {\n let current: any = schema;\n for (let i = 0; i < schemaPath.length - 1; i++) {\n if (current && typeof current === 'object' && schemaPath[i]! in current) {\n current = current[schemaPath[i]!];\n } else {\n break;\n }\n }\n return current as Record<string, unknown>;\n}\n\nfunction resolveInstanceValue(value: unknown, instancePath: string[]): unknown {\n let current = value;\n for (const key of instancePath) {\n if (current && typeof current === 'object') {\n current = (current as Record<string, unknown>)[key];\n } else {\n return undefined;\n }\n }\n return current;\n}\n\nfunction formatValidationError(\n error: ValidationError,\n schema: Record<string, unknown>,\n value: unknown\n): string {\n const { instancePath, schemaPath } = error;\n const path = formatInstancePath(instancePath);\n const lastKey = schemaPath[schemaPath.length - 1];\n\n if (lastKey === 'type') {\n const parent = resolveSchemaParent(schema, schemaPath);\n const jtdType = parent?.type as string;\n if (jtdType === 'boolean') return `${path}: expected boolean`;\n if (jtdType === 'string') return `${path}: expected string`;\n if (jtdType === 'timestamp') return `${path}: expected timestamp string`;\n if (INTEGER_TYPES.has(jtdType)) return `${path}: expected integer`;\n return `${path}: expected number`;\n }\n\n if (lastKey === 'enum') {\n const parent = resolveSchemaParent(schema, schemaPath);\n const enumValues = parent?.enum as string[];\n return `${path}: expected one of [${enumValues.join(', ')}]`;\n }\n\n if (\n schemaPath.length >= 2 &&\n schemaPath[schemaPath.length - 2] === 'properties' &&\n lastKey\n ) {\n const prefix = path === '/' ? '' : path;\n return `${prefix}.${lastKey}: missing required property`;\n }\n\n if (lastKey === 'elements') return `${path}: expected array`;\n\n if (\n lastKey === 'properties' ||\n lastKey === 'optionalProperties' ||\n lastKey === 'values'\n ) {\n return `${path}: expected object`;\n }\n\n if (lastKey === 'discriminator')\n return `${path}: expected string discriminator`;\n\n if (lastKey === 'mapping') {\n const discValue = resolveInstanceValue(value, instancePath);\n return `${path}: unknown variant \"${discValue}\"`;\n }\n\n if (schemaPath.length === 0) return `${path}: unexpected property`;\n\n return `${path}: validation error at /${schemaPath.join('/')}`;\n}\n\n/**\n * Validate a value against a JTD schema, returning an array of error messages.\n * Delegates to the `jtd` npm package for spec-compliant validation.\n */\nexport function validateJsonAgainstJTD(\n schema: JTDSchemaJson,\n value: unknown,\n definitions?: Record<string, JTDSchemaJson>\n): string[] {\n const defs =\n definitions ??\n (schema.definitions as Record<string, JTDSchemaJson> | undefined);\n\n const schemaForValidation = defs\n ? ({ ...schema, definitions: defs } as Schema)\n : (schema as Schema);\n\n // The jtd lib throws on invalid schemas (e.g., unresolved refs).\n if (!isValidSchema(schemaForValidation)) {\n if (schema.ref) {\n return [`/: unknown ref \"${schema.ref}\"`];\n }\n return [`/: invalid schema`];\n }\n\n const errors = jtdValidate(schemaForValidation, value, {\n maxDepth: MAX_VALIDATION_DEPTH,\n maxErrors: MAX_VALIDATION_ERRORS\n });\n\n return errors.map((err) =>\n formatValidationError(\n err,\n schemaForValidation as Record<string, unknown>,\n value\n )\n );\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// SIGNAL-LEVEL VALIDATION (JSON values against JTD formats)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/** Validate a JSON value against a single SignalFormatJson. */\nexport function validateJsonAgainstSignal(\n format: SignalFormatJson,\n jsonValue: unknown\n): string[];\n/** Validate a JSON value against a SignalDescriptorJson (valid if value matches ANY JTD format). */\nexport function validateJsonAgainstSignal(\n descriptor: SignalDescriptorJson,\n jsonValue: unknown\n): string[];\nexport function validateJsonAgainstSignal(\n formatOrDescriptor: SignalFormatJson | SignalDescriptorJson,\n jsonValue: unknown\n): string[] {\n // Descriptor path \u2014 has `formats` array\n if (\n 'formats' in formatOrDescriptor &&\n Array.isArray(formatOrDescriptor.formats)\n ) {\n const jtdFormats = (\n formatOrDescriptor.formats as SignalFormatJson[]\n ).filter((f) => f.jtdSchema);\n if (jtdFormats.length === 0) {\n return ['/: no JTD formats in signal descriptor'];\n }\n // Valid if value matches ANY JTD format\n for (const format of jtdFormats) {\n const errors = validateJsonAgainstJTD(format.jtdSchema!, jsonValue);\n if (errors.length === 0) return [];\n }\n // None matched \u2014 return errors from last format attempt\n return validateJsonAgainstJTD(\n jtdFormats[jtdFormats.length - 1]!.jtdSchema!,\n jsonValue\n );\n }\n\n // Single format path\n const format = formatOrDescriptor as SignalFormatJson;\n if (!format.jtdSchema) {\n return ['/: signal format has no jtdSchema'];\n }\n return validateJsonAgainstJTD(format.jtdSchema, jsonValue);\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// JTD \u2192 JSON SCHEMA CONVERTER\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/**\n * Convert JTD (JSON Type Definition) schema to JSON Schema for validation.\n *\n * Supports all 8 JTD schema forms per RFC 8927:\n * - Empty form: {}\n * - Ref form: { ref: \"...\" }\n * - Type form: { type: \"...\" }\n * - Enum form: { enum: [...] }\n * - Elements form: { elements: {...} }\n * - Properties form: { properties: {...}, optionalProperties: {...} }\n * - Values form: { values: {...} }\n * - Discriminator form: { discriminator: \"...\", mapping: {...} }\n */\nexport function jtdToJsonSchema(\n jtdSchema: JTDSchemaJson,\n definitions?: Record<string, JTDSchemaJson>,\n isRoot = true\n): any {\n if (!jtdSchema || typeof jtdSchema !== 'object') {\n return {};\n }\n\n const isNullable = jtdSchema['nullable'];\n const defs =\n definitions ||\n (jtdSchema['definitions'] as Record<string, JTDSchemaJson> | undefined);\n\n const result: any = {};\n\n if (isRoot) {\n result.$schema = 'http://json-schema.org/draft-07/schema#';\n }\n\n // Ref form\n if (jtdSchema['ref']) {\n const refName = jtdSchema['ref'] as string;\n if (defs && defs[refName]) {\n const resolvedSchema = jtdToJsonSchema(\n defs[refName] as JTDSchemaJson,\n defs,\n false\n );\n\n if (isNullable) {\n if (resolvedSchema.type) {\n resolvedSchema.type = Array.isArray(resolvedSchema.type)\n ? [...resolvedSchema.type, 'null']\n : [resolvedSchema.type, 'null'];\n } else {\n return {\n ...resolvedSchema,\n anyOf: [resolvedSchema, { type: 'null' }],\n ...(isRoot\n ? { $schema: 'http://json-schema.org/draft-07/schema#' }\n : {})\n };\n }\n }\n\n return isRoot\n ? {\n ...resolvedSchema,\n $schema: 'http://json-schema.org/draft-07/schema#'\n }\n : resolvedSchema;\n }\n return isRoot ? result : {};\n }\n\n // Type form\n if (jtdSchema['type']) {\n const typeMap: Record<string, string> = {\n boolean: 'boolean',\n string: 'string',\n timestamp: 'string',\n float32: 'number',\n float64: 'number',\n int8: 'integer',\n uint8: 'integer',\n int16: 'integer',\n uint16: 'integer',\n int32: 'integer',\n uint32: 'integer'\n };\n const jtdType = jtdSchema['type'] as string;\n const baseType = typeMap[jtdType] || 'string';\n\n result.type = isNullable ? [baseType, 'null'] : baseType;\n\n if (baseType === 'string' && jtdType === 'timestamp') {\n result.format = 'date-time';\n }\n return result;\n }\n\n // Enum form\n if (jtdSchema['enum']) {\n result.type = isNullable ? ['string', 'null'] : 'string';\n result.enum = isNullable\n ? [...(jtdSchema['enum'] as string[]), null]\n : jtdSchema['enum'];\n return result;\n }\n\n // Elements form\n if (jtdSchema['elements']) {\n result.type = isNullable ? ['array', 'null'] : 'array';\n result.items = jtdToJsonSchema(\n jtdSchema['elements'] as JTDSchemaJson,\n defs,\n false\n );\n return result;\n }\n\n // Properties form\n if (jtdSchema['properties'] || jtdSchema['optionalProperties']) {\n result.type = isNullable ? ['object', 'null'] : 'object';\n result.properties = {};\n result.required = [];\n\n if (jtdSchema['properties']) {\n for (const [key, value] of Object.entries(jtdSchema['properties'])) {\n result.properties[key] = jtdToJsonSchema(\n value as JTDSchemaJson,\n defs,\n false\n );\n result.required.push(key);\n }\n }\n\n if (jtdSchema['optionalProperties']) {\n for (const [key, value] of Object.entries(\n jtdSchema['optionalProperties']\n )) {\n result.properties[key] = jtdToJsonSchema(\n value as JTDSchemaJson,\n defs,\n false\n );\n }\n }\n\n // JTD is strict by default\n if (jtdSchema['additionalProperties'] !== true) {\n result.additionalProperties = false;\n }\n\n return result;\n }\n\n // Values form\n if (jtdSchema['values']) {\n result.type = isNullable ? ['object', 'null'] : 'object';\n result.additionalProperties = jtdToJsonSchema(\n jtdSchema['values'] as JTDSchemaJson,\n defs,\n false\n );\n return result;\n }\n\n // Discriminator form\n if (jtdSchema['discriminator'] && jtdSchema['mapping']) {\n const variants = [];\n const discriminatorKey = jtdSchema['discriminator'] as string;\n\n for (const [tag, schema] of Object.entries(jtdSchema['mapping'])) {\n const variantSchema = jtdToJsonSchema(\n schema as JTDSchemaJson,\n defs,\n false\n );\n\n if (!variantSchema.type) {\n variantSchema.type = 'object';\n } else if (\n variantSchema.type !== 'object' &&\n !Array.isArray(variantSchema.type)\n ) {\n variantSchema.type = 'object';\n }\n\n variantSchema.properties = variantSchema.properties || {};\n variantSchema.properties[discriminatorKey] = { const: tag };\n\n variantSchema.required = variantSchema.required || [];\n if (!variantSchema.required.includes(discriminatorKey)) {\n variantSchema.required.unshift(discriminatorKey);\n }\n\n // JTD discriminator variants are strict by default\n if (variantSchema.additionalProperties === undefined) {\n variantSchema.additionalProperties = false;\n }\n\n variants.push(variantSchema);\n }\n\n if (isNullable) {\n variants.push({ type: 'null' });\n }\n\n result.oneOf = variants;\n return result;\n }\n\n // Empty form\n return result;\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// JTD SCHEMA VALIDATION (using the `jtd` npm package)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\nexport const MAX_VALIDATION_DEPTH = 32;\nexport const MAX_VALIDATION_ERRORS = 100;\n\n/** Validate that the input is a valid JTD schema. */\nexport function validateJTDSchema(\n schema: unknown\n): { valid: true; schema: JTDSchemaJson } | { valid: false; error: string } {\n if (!isSchema(schema)) {\n return {\n valid: false,\n error: 'Invalid JTD schema: Schema does not match JTD structure'\n };\n }\n\n if (!isValidSchema(schema)) {\n return {\n valid: false,\n error:\n 'Invalid JTD schema: Schema has semantic errors (e.g., circular references, conflicting forms)'\n };\n }\n\n return { valid: true, schema: schema as unknown as JTDSchemaJson };\n}\n\n/** Parse and validate a JSON string. */\nexport function validateJSON(jsonString: string): {\n valid: boolean;\n data?: unknown;\n error?: string;\n} {\n try {\n const data = JSON.parse(jsonString);\n return { valid: true, data };\n } catch (error) {\n return {\n valid: false,\n error: `Invalid JSON: ${error instanceof Error ? error.message : 'Parse error'}`\n };\n }\n}\n\n/** Parse a JSON string and validate it as a JTD schema. */\nexport function validateJTDSchemaString(\n schemaString: string\n): { valid: true; schema: JTDSchemaJson } | { valid: false; error: string } {\n const jsonResult = validateJSON(schemaString);\n if (!jsonResult.valid) return { valid: false, error: jsonResult.error! };\n\n return validateJTDSchema(jsonResult.data);\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// MONACO EDITOR CONFIG FOR JTD SCHEMA EDITING\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/** Monaco editor JSON schema configuration for JTD schema IntelliSense and validation. */\nexport const JTD_SCHEMA_CONFIG = {\n uri: 'https://jsontypedef.com/schemas/jtd-schema.json',\n fileMatch: ['inmemory://jtd-schema/*.json'],\n schema: {\n $schema: 'http://json-schema.org/draft-07/schema#',\n type: 'object',\n properties: {\n type: {\n description: 'Type form - defines a primitive type',\n enum: [\n 'boolean',\n 'string',\n 'timestamp',\n 'float32',\n 'float64',\n 'int8',\n 'uint8',\n 'int16',\n 'uint16',\n 'int32',\n 'uint32'\n ]\n },\n enum: {\n description: 'Enum form - defines a set of string values',\n type: 'array',\n items: { type: 'string' }\n },\n elements: {\n description: 'Elements form - defines an array with typed elements',\n $ref: '#'\n },\n properties: {\n description:\n 'Properties form - defines an object with required properties',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n optionalProperties: {\n description: 'Optional properties - defines optional object properties',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n values: {\n description: 'Values form - defines a map/dictionary with typed values',\n $ref: '#'\n },\n discriminator: {\n description: 'Discriminator form - defines a tagged union',\n type: 'string'\n },\n mapping: {\n description: 'Mapping for discriminator form',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n ref: {\n description: 'Ref form - references a definition',\n type: 'string'\n },\n definitions: {\n description: 'Top-level definitions for reusable schemas',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n nullable: {\n description: 'Allow null values',\n type: 'boolean'\n },\n metadata: {\n description: 'Custom metadata for documentation',\n type: 'object'\n },\n additionalProperties: {\n description: 'Allow additional properties (properties form only)',\n type: 'boolean'\n }\n }\n }\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["signals_exports", "__export", "JTD_SCHEMA_CONFIG", "MAX_VALIDATION_DEPTH", "MAX_VALIDATION_ERRORS", "fuzzJTD", "jtdToJsonSchema", "validateJSON", "validateJTDSchema", "validateJTDSchemaString", "validateJsonAgainstJTD", "validateJsonAgainstSignal", "__toCommonJS", "import_jtd", "FUZZ_MAX_DEPTH", "schema", "definitions", "_depth", "def", "obj", "k", "v", "firstKey", "variant", "INTEGER_TYPES", "formatInstancePath", "instancePath", "p", "resolveSchemaParent", "schemaPath", "current", "i", "resolveInstanceValue", "value", "key", "formatValidationError", "error", "path", "lastKey", "jtdType", "enumValues", "discValue", "defs", "schemaForValidation", "jtdValidate", "err", "formatOrDescriptor", "jsonValue", "jtdFormats", "f", "format", "jtdSchema", "isRoot", "isNullable", "result", "refName", "resolvedSchema", "typeMap", "baseType", "variants", "discriminatorKey", "tag", "variantSchema", "jsonString", "schemaString", "jsonResult"]
|
|
7
7
|
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{isSchema as H,isValidSchema as j,validate as R}from"jtd";var O=new Set(["int8","uint8","int16","uint16","int32","uint32"]);function P(e){return e.length===0?"/":e.map(r=>/^\d+$/.test(r)?`[${r}]`:`.${r}`).join("")}function v(e,r){let i=e;for(let o=0;o<r.length-1&&(i&&typeof i=="object"&&r[o]in i);o++)i=i[r[o]];return i}function x(e,r){let i=e;for(let o of r)if(i&&typeof i=="object")i=i[o];else return;return i}function E(e,r,i){let{instancePath:o,schemaPath:t}=e,n=P(o),s=t[t.length-1];if(s==="type"){let c=v(r,t)?.type;return c==="boolean"?`${n}: expected boolean`:c==="string"?`${n}: expected string`:c==="timestamp"?`${n}: expected timestamp string`:O.has(c)?`${n}: expected integer`:`${n}: expected number`}if(s==="enum"){let c=v(r,t)?.enum;return`${n}: expected one of [${c.join(", ")}]`}if(t.length>=2&&t[t.length-2]==="properties"&&s)return`${n==="/"?"":n}.${s}: missing required property`;if(s==="elements")return`${n}: expected array`;if(s==="properties"||s==="optionalProperties"||s==="values")return`${n}: expected object`;if(s==="discriminator")return`${n}: expected string discriminator`;if(s==="mapping"){let a=x(i,o);return`${n}: unknown variant "${a}"`}return t.length===0?`${n}: unexpected property`:`${n}: validation error at /${t.join("/")}`}function D(e,r,i){let o=i??e.definitions,t=o?{...e,definitions:o}:e;return j(t)?R(t,r,{maxDepth:N,maxErrors:C}).map(s=>E(s,t,r)):e.ref?[`/: unknown ref "${e.ref}"`]:["/: invalid schema"]}var N=32,C=100;var b=32,w={int8:{minimum:-128,maximum:127},uint8:{minimum:0,maximum:255},int16:{minimum:-32768,maximum:32767},uint16:{minimum:0,maximum:65535},int32:{minimum:-2147483648,maximum:2147483647},uint32:{minimum:0,maximum:4294967295}},$={minimum:-34028235e31,maximum:34028235e31};function h(e){return!e||typeof e!="object"?!0:e.type||e.enum||e.elements||e.values||e.discriminator||e.ref||e.properties&&Object.keys(e.properties).length>0||e.optionalProperties&&Object.keys(e.optionalProperties).length>0?!1:(e.properties!==void 0||e.optionalProperties!==void 0)&&e.additionalProperties===!0?!0:!(e.properties!==void 0||e.optionalProperties!==void 0)}function I(e,r){let i=e,o=0;for(;i.ref&&o<b;){let t=r?.[i.ref];if(!t)return!1;i=t,o++}return o>=b?!1:h(i)}function S(e){let r=[];if(!e||typeof e!="object")return r;if(e.ref&&r.push(e.ref),e.properties)for(let i of Object.values(e.properties))r.push(...S(i));if(e.optionalProperties)for(let i of Object.values(e.optionalProperties))r.push(...S(i));if(e.elements&&r.push(...S(e.elements)),e.values&&r.push(...S(e.values)),e.mapping)for(let i of Object.values(e.mapping))r.push(...S(i));return r}function M(e){let t=new Map;for(let s of Object.keys(e))t.set(s,0);function n(s){t.set(s,1);let a=e[s];if(a){for(let c of S(a))if(t.has(c)){if(t.get(c)===1)return c;if(t.get(c)===0){let u=n(c);if(u)return u}}}return t.set(s,2),null}for(let s of Object.keys(e))if(t.get(s)===0){let a=n(s);if(a)return a}return null}function k(e,r){e.description=e.description?`${e.description} ${r}`:r}var F=new Set(["title","label","name","description"]);function f(e,r){let i=r.metadata;if(!i)return;let o=[],t=typeof i.title=="string"&&i.title.trim()||typeof i.label=="string"&&i.label.trim()||typeof i.name=="string"&&i.name.trim(),n=typeof i.description=="string"?i.description.trim():"";t&&n?o.push(`${t}. ${n}`):t?o.push(t):n&&o.push(n);let s=[];for(let[a,c]of Object.entries(i))F.has(a)||(typeof c=="string"&&c.trim()?s.push(`[${a}: ${c.trim()}]`):(typeof c=="number"||typeof c=="boolean")&&s.push(`[${a}: ${c}]`));if(s.length>0&&o.push(s.join(" ")),o.length>0){let a=o.join(" ");e.description=e.description?`${e.description} ${a}`:a}}function J(e,r,i){if(i>b)throw new Error(`Schema nesting exceeded ${b} levels`);if(!e||typeof e!="object")return{type:"string",description:"Must be a valid JSON value."};if(h(e)){let n={type:e.nullable===!0?["string","null"]:"string",description:"Must be a valid JSON value."};return f(n,e),n}let o=e.nullable===!0;if(e.ref){let t=e.ref;if(!r?.[t])throw new Error(`Unresolved ref "${t}"`);if(o){let n={anyOf:[{$ref:`#/$defs/${t}`},{type:"null"}]};return f(n,e),n}return{$ref:`#/$defs/${t}`}}if(e.type){let t=e.type,n={},s=w[t];if(s)return n.type=o?["integer","null"]:"integer",f(n,e),k(n,`Value range: [${s.minimum}, ${s.maximum}].`),n;switch(t){case"boolean":n.type=o?["boolean","null"]:"boolean";break;case"string":n.type=o?["string","null"]:"string";break;case"timestamp":n.type=o?["string","null"]:"string",n.format="date-time";break;case"float32":return n.type=o?["number","null"]:"number",f(n,e),k(n,`Value range: [${$.minimum}, ${$.maximum}].`),n;case"float64":n.type=o?["number","null"]:"number";break;default:throw new Error(`Unknown JTD type "${t}"`)}return f(n,e),n}if(e.enum){let t={type:o?["string","null"]:"string",enum:o?[...e.enum,null]:[...e.enum]};return f(t,e),t}if(e.elements){let t={type:o?["array","null"]:"array",items:J(e.elements,r,i+1)};return f(t,e),t}if(e.properties||e.optionalProperties){let t={type:o?["object","null"]:"object",properties:{},additionalProperties:!1},n=[];if(e.properties)for(let[s,a]of Object.entries(e.properties))t.properties[s]=J(a,r,i+1),n.push(s);if(e.optionalProperties)for(let[s,a]of Object.entries(e.optionalProperties))t.properties[s]=J(a,r,i+1);return n.length>0&&(t.required=n),f(t,e),t}if(e.values){let t=J(e.values,r,i+1),n={type:o?["array","null"]:"array",items:{type:"object",properties:{key:{type:"string"},value:t},required:["key","value"],additionalProperties:!1}};return f(n,e),n}if(e.discriminator&&e.mapping){let t=e.discriminator,n=e.mapping,s=[];for(let[c,u]of Object.entries(n)){let p;h(u)?p={type:"object",properties:{[t]:{const:c},_data:{type:"string",description:"Must be a valid JSON value representing the variant data."}},required:[t,"_data"],additionalProperties:!1}:(p=J(u,r,i+1),p.properties[t]={const:c},(p.required??=[]).unshift(t),p.additionalProperties=!1),f(p,u),s.push(p)}let a={anyOf:s};return o&&a.anyOf.push({type:"null"}),f(a,e),a}return{type:"string",description:"Must be a valid JSON value."}}var q=new Set(Object.keys(w));function g(e,r,i,o){if(o>b||e==null)return e;if(r.ref){let t=i?.[r.ref];return t?g(e,t,i,o+1):e}if(h(r)){if(typeof e=="string")try{return JSON.parse(e)}catch{return e}return e}if(r.type&&q.has(r.type))return typeof e=="number"&&!Number.isInteger(e)?Math.round(e):e;if(r.elements&&Array.isArray(e))return e.map(t=>g(t,r.elements,i,o+1));if((r.properties||r.optionalProperties)&&typeof e=="object"&&e!==null){let t={...e};if(r.properties)for(let[n,s]of Object.entries(r.properties))n in t&&(t[n]=g(t[n],s,i,o+1));if(r.optionalProperties)for(let[n,s]of Object.entries(r.optionalProperties))n in t&&(t[n]=g(t[n],s,i,o+1));return t}if(r.values&&Array.isArray(e)){let t={};for(let n of e)if(typeof n=="object"&&n!==null){let s=n,a=s.key;t[a]=g(s.value,r.values,i,o+1)}return t}if(r.discriminator&&r.mapping&&typeof e=="object"&&e!==null){let t=e,n=r.discriminator,s=t[n],a=r.mapping[s];if(!a)return e;if(h(a)){let u=t._data;if(typeof u=="string")try{let p=JSON.parse(u);if(typeof p=="object"&&p!==null)return{[n]:s,...p}}catch{}return{[n]:s}}let c={[n]:s};if(a.properties)for(let[u,p]of Object.entries(a.properties))u in t&&(c[u]=g(t[u],p,i,o+1));if(a.optionalProperties)for(let[u,p]of Object.entries(a.optionalProperties))u in t&&(c[u]=g(t[u],p,i,o+1));return c}return e}function V(e){let r=e.definitions;if(r&&Object.keys(r).length>0){let n=M(r);if(n)throw new Error(`Anthropic structured output does not support recursive schemas. Definition "${n}" contains a circular reference.`)}let i=!I(e,r),o;if(i){if(o=J(e,r,0),r&&Object.keys(r).length>0){let n={};for(let[s,a]of Object.entries(r))n[s]=J(a,r,0);o.$defs=n}}else o={},f(o,e);return{schema:o,strict:i,convert:n=>{let s=g(n,e,r,0),a=D(e,s,r);return a.length>0?{success:!1,errors:a}:{success:!0,data:s}}}}function _(e){return{type:"string",description:`Base64-encoded binary content (MIME type: ${e}).`}}function A(e){if(e.jtdSchema)return V(e.jtdSchema);if(e.mimeType)return{schema:_(e.mimeType),strict:!0,convert:o=>typeof o!="string"?{success:!1,errors:[`/: expected base64 string for MIME type ${e.mimeType}, got ${typeof o}`]}:{success:!0,data:o}};throw new Error("Signal format has neither jtdSchema nor mimeType")}function G(e){let r=e.formats;if(!r||r.length===0)throw new Error("Signal descriptor has no formats");let i=e.name??"unnamed",o=e.optional===!0;if(r.length===1){let l=A(r[0]);if(e.label||e.description){let m=[];e.label&&m.push(e.label),e.description&&m.push(e.description);let d=m.join(". ");l.schema.description=l.schema.description?`${d} ${l.schema.description}`:d}return l}let t=[],n={};for(let l=0;l<r.length;l++){let m=r[l],d=`format_${l}`,y=A(m);if(m.jtdSchema){let T=y.schema.description;y.schema.description=T?`Structured JSON data. ${T}`:"Structured JSON data."}n[d]=y.schema,t.push({key:d,converter:y})}let s=t.map(l=>l.key),a=e.description??"",c=o?"Provide at most ONE of the following format properties. All are optional.":`You MUST provide exactly ONE of the following format properties: ${s.join(", ")}.`;return{schema:{type:"object",description:a?`${a} ${c}`:c,properties:n,additionalProperties:!1},strict:!0,convert:l=>{if(typeof l!="object"||l===null)return{success:!1,errors:[`/: expected object with format properties, got ${typeof l}`]};let m=l,d=t.find(({key:y})=>m[y]!==void 0&&m[y]!==null);return d?d.converter.convert(m[d.key]):o?{success:!0,data:null}:{success:!1,errors:[`Signal '${i}' is required but no format was provided. Set exactly one of: ${s.join(", ")}.`]}}}}export{G as convertSignalToAnthropicSchema,V as convertToAnthropicSchema};
|
|
2
|
+
//# sourceMappingURL=anthropic.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/signals/index.ts", "../../src/anthropic/index.ts"],
|
|
4
|
+
"sourcesContent": ["import type {\n JTDSchemaJson,\n SignalDescriptorJson,\n SignalFormatJson\n} from '../api';\nimport { isSchema, isValidSchema, validate as jtdValidate } from 'jtd';\nimport type { Schema, ValidationError } from 'jtd';\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// JTD FUZZER (generate sample values from JTD schemas)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/** Maximum recursion depth for fuzzJTD to prevent infinite loops on self-referencing schemas. */\nconst FUZZ_MAX_DEPTH = 10;\n\n/** Generate a fuzzed (sample) value from a JTD schema. */\nexport function fuzzJTD(\n schema: JTDSchemaJson,\n definitions?: Record<string, JTDSchemaJson>,\n _depth: number = 0\n): unknown {\n if (_depth > FUZZ_MAX_DEPTH) return null;\n\n if (schema.ref) {\n const def = definitions?.[schema.ref];\n if (def) return fuzzJTD(def, definitions, _depth + 1);\n return null;\n }\n\n if (schema.type) {\n switch (schema.type) {\n case 'string':\n return 'Lorem ipsum';\n case 'timestamp':\n return '2024-01-15T10:30:00Z';\n case 'float32':\n case 'float64':\n return 42.5;\n case 'int8':\n case 'uint8':\n case 'int16':\n case 'uint16':\n case 'int32':\n case 'uint32':\n return BigInt(42);\n case 'boolean':\n return true;\n default:\n return null;\n }\n }\n\n if (schema.enum) {\n return schema.enum[0] ?? null;\n }\n\n if (schema.elements) {\n return [\n fuzzJTD(schema.elements, definitions, _depth + 1),\n fuzzJTD(schema.elements, definitions, _depth + 1)\n ];\n }\n\n if (schema.values) {\n return { key1: fuzzJTD(schema.values, definitions, _depth + 1) };\n }\n\n if (schema.properties || schema.optionalProperties) {\n const obj: Record<string, unknown> = {};\n if (schema.properties) {\n for (const [k, v] of Object.entries(schema.properties)) {\n obj[k] = fuzzJTD(v, definitions, _depth + 1);\n }\n }\n if (schema.optionalProperties) {\n for (const [k, v] of Object.entries(schema.optionalProperties)) {\n obj[k] = fuzzJTD(v, definitions, _depth + 1);\n }\n }\n return obj;\n }\n\n if (schema.discriminator && schema.mapping) {\n const firstKey = Object.keys(schema.mapping)[0];\n if (firstKey) {\n const variant = schema.mapping[firstKey]!;\n const obj = fuzzJTD(variant, definitions, _depth + 1) as Record<\n string,\n unknown\n >;\n obj[schema.discriminator] = firstKey;\n return obj;\n }\n return null;\n }\n\n // Empty schema\n return null;\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// JTD VALUE VALIDATION (delegates to the `jtd` npm package)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\nconst INTEGER_TYPES = new Set([\n 'int8',\n 'uint8',\n 'int16',\n 'uint16',\n 'int32',\n 'uint32'\n]);\n\nfunction formatInstancePath(instancePath: string[]): string {\n if (instancePath.length === 0) return '/';\n return instancePath\n .map((p) => (/^\\d+$/.test(p) ? `[${p}]` : `.${p}`))\n .join('');\n}\n\nfunction resolveSchemaParent(\n schema: Record<string, unknown>,\n schemaPath: string[]\n): Record<string, unknown> {\n let current: any = schema;\n for (let i = 0; i < schemaPath.length - 1; i++) {\n if (current && typeof current === 'object' && schemaPath[i]! in current) {\n current = current[schemaPath[i]!];\n } else {\n break;\n }\n }\n return current as Record<string, unknown>;\n}\n\nfunction resolveInstanceValue(value: unknown, instancePath: string[]): unknown {\n let current = value;\n for (const key of instancePath) {\n if (current && typeof current === 'object') {\n current = (current as Record<string, unknown>)[key];\n } else {\n return undefined;\n }\n }\n return current;\n}\n\nfunction formatValidationError(\n error: ValidationError,\n schema: Record<string, unknown>,\n value: unknown\n): string {\n const { instancePath, schemaPath } = error;\n const path = formatInstancePath(instancePath);\n const lastKey = schemaPath[schemaPath.length - 1];\n\n if (lastKey === 'type') {\n const parent = resolveSchemaParent(schema, schemaPath);\n const jtdType = parent?.type as string;\n if (jtdType === 'boolean') return `${path}: expected boolean`;\n if (jtdType === 'string') return `${path}: expected string`;\n if (jtdType === 'timestamp') return `${path}: expected timestamp string`;\n if (INTEGER_TYPES.has(jtdType)) return `${path}: expected integer`;\n return `${path}: expected number`;\n }\n\n if (lastKey === 'enum') {\n const parent = resolveSchemaParent(schema, schemaPath);\n const enumValues = parent?.enum as string[];\n return `${path}: expected one of [${enumValues.join(', ')}]`;\n }\n\n if (\n schemaPath.length >= 2 &&\n schemaPath[schemaPath.length - 2] === 'properties' &&\n lastKey\n ) {\n const prefix = path === '/' ? '' : path;\n return `${prefix}.${lastKey}: missing required property`;\n }\n\n if (lastKey === 'elements') return `${path}: expected array`;\n\n if (\n lastKey === 'properties' ||\n lastKey === 'optionalProperties' ||\n lastKey === 'values'\n ) {\n return `${path}: expected object`;\n }\n\n if (lastKey === 'discriminator')\n return `${path}: expected string discriminator`;\n\n if (lastKey === 'mapping') {\n const discValue = resolveInstanceValue(value, instancePath);\n return `${path}: unknown variant \"${discValue}\"`;\n }\n\n if (schemaPath.length === 0) return `${path}: unexpected property`;\n\n return `${path}: validation error at /${schemaPath.join('/')}`;\n}\n\n/**\n * Validate a value against a JTD schema, returning an array of error messages.\n * Delegates to the `jtd` npm package for spec-compliant validation.\n */\nexport function validateJsonAgainstJTD(\n schema: JTDSchemaJson,\n value: unknown,\n definitions?: Record<string, JTDSchemaJson>\n): string[] {\n const defs =\n definitions ??\n (schema.definitions as Record<string, JTDSchemaJson> | undefined);\n\n const schemaForValidation = defs\n ? ({ ...schema, definitions: defs } as Schema)\n : (schema as Schema);\n\n // The jtd lib throws on invalid schemas (e.g., unresolved refs).\n if (!isValidSchema(schemaForValidation)) {\n if (schema.ref) {\n return [`/: unknown ref \"${schema.ref}\"`];\n }\n return [`/: invalid schema`];\n }\n\n const errors = jtdValidate(schemaForValidation, value, {\n maxDepth: MAX_VALIDATION_DEPTH,\n maxErrors: MAX_VALIDATION_ERRORS\n });\n\n return errors.map((err) =>\n formatValidationError(\n err,\n schemaForValidation as Record<string, unknown>,\n value\n )\n );\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// SIGNAL-LEVEL VALIDATION (JSON values against JTD formats)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/** Validate a JSON value against a single SignalFormatJson. */\nexport function validateJsonAgainstSignal(\n format: SignalFormatJson,\n jsonValue: unknown\n): string[];\n/** Validate a JSON value against a SignalDescriptorJson (valid if value matches ANY JTD format). */\nexport function validateJsonAgainstSignal(\n descriptor: SignalDescriptorJson,\n jsonValue: unknown\n): string[];\nexport function validateJsonAgainstSignal(\n formatOrDescriptor: SignalFormatJson | SignalDescriptorJson,\n jsonValue: unknown\n): string[] {\n // Descriptor path \u2014 has `formats` array\n if (\n 'formats' in formatOrDescriptor &&\n Array.isArray(formatOrDescriptor.formats)\n ) {\n const jtdFormats = (\n formatOrDescriptor.formats as SignalFormatJson[]\n ).filter((f) => f.jtdSchema);\n if (jtdFormats.length === 0) {\n return ['/: no JTD formats in signal descriptor'];\n }\n // Valid if value matches ANY JTD format\n for (const format of jtdFormats) {\n const errors = validateJsonAgainstJTD(format.jtdSchema!, jsonValue);\n if (errors.length === 0) return [];\n }\n // None matched \u2014 return errors from last format attempt\n return validateJsonAgainstJTD(\n jtdFormats[jtdFormats.length - 1]!.jtdSchema!,\n jsonValue\n );\n }\n\n // Single format path\n const format = formatOrDescriptor as SignalFormatJson;\n if (!format.jtdSchema) {\n return ['/: signal format has no jtdSchema'];\n }\n return validateJsonAgainstJTD(format.jtdSchema, jsonValue);\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// JTD \u2192 JSON SCHEMA CONVERTER\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/**\n * Convert JTD (JSON Type Definition) schema to JSON Schema for validation.\n *\n * Supports all 8 JTD schema forms per RFC 8927:\n * - Empty form: {}\n * - Ref form: { ref: \"...\" }\n * - Type form: { type: \"...\" }\n * - Enum form: { enum: [...] }\n * - Elements form: { elements: {...} }\n * - Properties form: { properties: {...}, optionalProperties: {...} }\n * - Values form: { values: {...} }\n * - Discriminator form: { discriminator: \"...\", mapping: {...} }\n */\nexport function jtdToJsonSchema(\n jtdSchema: JTDSchemaJson,\n definitions?: Record<string, JTDSchemaJson>,\n isRoot = true\n): any {\n if (!jtdSchema || typeof jtdSchema !== 'object') {\n return {};\n }\n\n const isNullable = jtdSchema['nullable'];\n const defs =\n definitions ||\n (jtdSchema['definitions'] as Record<string, JTDSchemaJson> | undefined);\n\n const result: any = {};\n\n if (isRoot) {\n result.$schema = 'http://json-schema.org/draft-07/schema#';\n }\n\n // Ref form\n if (jtdSchema['ref']) {\n const refName = jtdSchema['ref'] as string;\n if (defs && defs[refName]) {\n const resolvedSchema = jtdToJsonSchema(\n defs[refName] as JTDSchemaJson,\n defs,\n false\n );\n\n if (isNullable) {\n if (resolvedSchema.type) {\n resolvedSchema.type = Array.isArray(resolvedSchema.type)\n ? [...resolvedSchema.type, 'null']\n : [resolvedSchema.type, 'null'];\n } else {\n return {\n ...resolvedSchema,\n anyOf: [resolvedSchema, { type: 'null' }],\n ...(isRoot\n ? { $schema: 'http://json-schema.org/draft-07/schema#' }\n : {})\n };\n }\n }\n\n return isRoot\n ? {\n ...resolvedSchema,\n $schema: 'http://json-schema.org/draft-07/schema#'\n }\n : resolvedSchema;\n }\n return isRoot ? result : {};\n }\n\n // Type form\n if (jtdSchema['type']) {\n const typeMap: Record<string, string> = {\n boolean: 'boolean',\n string: 'string',\n timestamp: 'string',\n float32: 'number',\n float64: 'number',\n int8: 'integer',\n uint8: 'integer',\n int16: 'integer',\n uint16: 'integer',\n int32: 'integer',\n uint32: 'integer'\n };\n const jtdType = jtdSchema['type'] as string;\n const baseType = typeMap[jtdType] || 'string';\n\n result.type = isNullable ? [baseType, 'null'] : baseType;\n\n if (baseType === 'string' && jtdType === 'timestamp') {\n result.format = 'date-time';\n }\n return result;\n }\n\n // Enum form\n if (jtdSchema['enum']) {\n result.type = isNullable ? ['string', 'null'] : 'string';\n result.enum = isNullable\n ? [...(jtdSchema['enum'] as string[]), null]\n : jtdSchema['enum'];\n return result;\n }\n\n // Elements form\n if (jtdSchema['elements']) {\n result.type = isNullable ? ['array', 'null'] : 'array';\n result.items = jtdToJsonSchema(\n jtdSchema['elements'] as JTDSchemaJson,\n defs,\n false\n );\n return result;\n }\n\n // Properties form\n if (jtdSchema['properties'] || jtdSchema['optionalProperties']) {\n result.type = isNullable ? ['object', 'null'] : 'object';\n result.properties = {};\n result.required = [];\n\n if (jtdSchema['properties']) {\n for (const [key, value] of Object.entries(jtdSchema['properties'])) {\n result.properties[key] = jtdToJsonSchema(\n value as JTDSchemaJson,\n defs,\n false\n );\n result.required.push(key);\n }\n }\n\n if (jtdSchema['optionalProperties']) {\n for (const [key, value] of Object.entries(\n jtdSchema['optionalProperties']\n )) {\n result.properties[key] = jtdToJsonSchema(\n value as JTDSchemaJson,\n defs,\n false\n );\n }\n }\n\n // JTD is strict by default\n if (jtdSchema['additionalProperties'] !== true) {\n result.additionalProperties = false;\n }\n\n return result;\n }\n\n // Values form\n if (jtdSchema['values']) {\n result.type = isNullable ? ['object', 'null'] : 'object';\n result.additionalProperties = jtdToJsonSchema(\n jtdSchema['values'] as JTDSchemaJson,\n defs,\n false\n );\n return result;\n }\n\n // Discriminator form\n if (jtdSchema['discriminator'] && jtdSchema['mapping']) {\n const variants = [];\n const discriminatorKey = jtdSchema['discriminator'] as string;\n\n for (const [tag, schema] of Object.entries(jtdSchema['mapping'])) {\n const variantSchema = jtdToJsonSchema(\n schema as JTDSchemaJson,\n defs,\n false\n );\n\n if (!variantSchema.type) {\n variantSchema.type = 'object';\n } else if (\n variantSchema.type !== 'object' &&\n !Array.isArray(variantSchema.type)\n ) {\n variantSchema.type = 'object';\n }\n\n variantSchema.properties = variantSchema.properties || {};\n variantSchema.properties[discriminatorKey] = { const: tag };\n\n variantSchema.required = variantSchema.required || [];\n if (!variantSchema.required.includes(discriminatorKey)) {\n variantSchema.required.unshift(discriminatorKey);\n }\n\n // JTD discriminator variants are strict by default\n if (variantSchema.additionalProperties === undefined) {\n variantSchema.additionalProperties = false;\n }\n\n variants.push(variantSchema);\n }\n\n if (isNullable) {\n variants.push({ type: 'null' });\n }\n\n result.oneOf = variants;\n return result;\n }\n\n // Empty form\n return result;\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// JTD SCHEMA VALIDATION (using the `jtd` npm package)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\nexport const MAX_VALIDATION_DEPTH = 32;\nexport const MAX_VALIDATION_ERRORS = 100;\n\n/** Validate that the input is a valid JTD schema. */\nexport function validateJTDSchema(\n schema: unknown\n): { valid: true; schema: JTDSchemaJson } | { valid: false; error: string } {\n if (!isSchema(schema)) {\n return {\n valid: false,\n error: 'Invalid JTD schema: Schema does not match JTD structure'\n };\n }\n\n if (!isValidSchema(schema)) {\n return {\n valid: false,\n error:\n 'Invalid JTD schema: Schema has semantic errors (e.g., circular references, conflicting forms)'\n };\n }\n\n return { valid: true, schema: schema as unknown as JTDSchemaJson };\n}\n\n/** Parse and validate a JSON string. */\nexport function validateJSON(jsonString: string): {\n valid: boolean;\n data?: unknown;\n error?: string;\n} {\n try {\n const data = JSON.parse(jsonString);\n return { valid: true, data };\n } catch (error) {\n return {\n valid: false,\n error: `Invalid JSON: ${error instanceof Error ? error.message : 'Parse error'}`\n };\n }\n}\n\n/** Parse a JSON string and validate it as a JTD schema. */\nexport function validateJTDSchemaString(\n schemaString: string\n): { valid: true; schema: JTDSchemaJson } | { valid: false; error: string } {\n const jsonResult = validateJSON(schemaString);\n if (!jsonResult.valid) return { valid: false, error: jsonResult.error! };\n\n return validateJTDSchema(jsonResult.data);\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// MONACO EDITOR CONFIG FOR JTD SCHEMA EDITING\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/** Monaco editor JSON schema configuration for JTD schema IntelliSense and validation. */\nexport const JTD_SCHEMA_CONFIG = {\n uri: 'https://jsontypedef.com/schemas/jtd-schema.json',\n fileMatch: ['inmemory://jtd-schema/*.json'],\n schema: {\n $schema: 'http://json-schema.org/draft-07/schema#',\n type: 'object',\n properties: {\n type: {\n description: 'Type form - defines a primitive type',\n enum: [\n 'boolean',\n 'string',\n 'timestamp',\n 'float32',\n 'float64',\n 'int8',\n 'uint8',\n 'int16',\n 'uint16',\n 'int32',\n 'uint32'\n ]\n },\n enum: {\n description: 'Enum form - defines a set of string values',\n type: 'array',\n items: { type: 'string' }\n },\n elements: {\n description: 'Elements form - defines an array with typed elements',\n $ref: '#'\n },\n properties: {\n description:\n 'Properties form - defines an object with required properties',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n optionalProperties: {\n description: 'Optional properties - defines optional object properties',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n values: {\n description: 'Values form - defines a map/dictionary with typed values',\n $ref: '#'\n },\n discriminator: {\n description: 'Discriminator form - defines a tagged union',\n type: 'string'\n },\n mapping: {\n description: 'Mapping for discriminator form',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n ref: {\n description: 'Ref form - references a definition',\n type: 'string'\n },\n definitions: {\n description: 'Top-level definitions for reusable schemas',\n type: 'object',\n additionalProperties: { $ref: '#' }\n },\n nullable: {\n description: 'Allow null values',\n type: 'boolean'\n },\n metadata: {\n description: 'Custom metadata for documentation',\n type: 'object'\n },\n additionalProperties: {\n description: 'Allow additional properties (properties form only)',\n type: 'boolean'\n }\n }\n }\n};\n", "// Copyright 2024-2025 Mochabug, LLC. All rights reserved.\n// Licensed under the Apache License, Version 2.0.\n\nimport type {\n JTDSchemaJson,\n SignalDescriptorJson,\n SignalFormatJson\n} from '../api';\nimport { validateJsonAgainstJTD } from '../signals';\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// Types\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/** JSON Schema subset supported by Anthropic structured output. */\nexport interface AnthropicSchema {\n type?: string | string[];\n description?: string;\n properties?: Record<string, AnthropicSchema>;\n required?: string[];\n additionalProperties?: false;\n enum?: (string | number | boolean | null)[];\n const?: string | number | boolean | null;\n format?: string;\n items?: AnthropicSchema;\n anyOf?: AnthropicSchema[];\n $defs?: Record<string, AnthropicSchema>;\n $ref?: string;\n}\n\nexport interface ConvertSuccess {\n success: true;\n data: unknown;\n}\n\nexport interface ConvertFailure {\n success: false;\n errors: string[];\n}\n\nexport type ConvertResult = ConvertSuccess | ConvertFailure;\n\nexport interface AnthropicConversionResult {\n /** Anthropic structured output compatible JSON Schema. */\n schema: AnthropicSchema;\n /** Whether the schema supports strict mode. False for unstructured (empty) schemas. */\n strict: boolean;\n /** Convert Anthropic JSON output back to JTD-conforming JSON. */\n convert: (anthropicJson: unknown) => ConvertResult;\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// Constants\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\nconst MAX_REF_DEPTH = 32;\n\nconst INTEGER_BOUNDS: Record<string, { minimum: number; maximum: number }> = {\n int8: { minimum: -128, maximum: 127 },\n uint8: { minimum: 0, maximum: 255 },\n int16: { minimum: -32768, maximum: 32767 },\n uint16: { minimum: 0, maximum: 65535 },\n int32: { minimum: -2147483648, maximum: 2147483647 },\n uint32: { minimum: 0, maximum: 4294967295 }\n};\n\nconst FLOAT32_BOUNDS = {\n minimum: -3.4028235e38,\n maximum: 3.4028235e38\n};\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// Helpers\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/** Check if a JTD schema is unstructured (empty form or equivalent). */\nfunction isUnstructuredSchema(schema: JTDSchemaJson): boolean {\n if (!schema || typeof schema !== 'object') return true;\n\n if (\n schema.type ||\n schema.enum ||\n schema.elements ||\n schema.values ||\n schema.discriminator ||\n schema.ref\n ) {\n return false;\n }\n\n const hasRealProps =\n (schema.properties && Object.keys(schema.properties).length > 0) ||\n (schema.optionalProperties &&\n Object.keys(schema.optionalProperties).length > 0);\n\n if (hasRealProps) return false;\n\n if (\n (schema.properties !== undefined ||\n schema.optionalProperties !== undefined) &&\n schema.additionalProperties === true\n ) {\n return true;\n }\n\n if (\n schema.properties !== undefined ||\n schema.optionalProperties !== undefined\n ) {\n return false;\n }\n\n return true;\n}\n\n/** Resolve refs at root to determine if the root target is unstructured. */\nfunction isRootUnstructured(\n schema: JTDSchemaJson,\n defs: Record<string, JTDSchemaJson> | undefined\n): boolean {\n let resolved = schema;\n let depth = 0;\n while (resolved.ref && depth < MAX_REF_DEPTH) {\n const target = defs?.[resolved.ref as string];\n if (!target) return false;\n resolved = target;\n depth++;\n }\n if (depth >= MAX_REF_DEPTH) return false;\n return isUnstructuredSchema(resolved);\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// Circular ref detection (Anthropic does not support recursive schemas)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\nfunction collectRefsInSchema(schema: JTDSchemaJson): string[] {\n const refs: string[] = [];\n if (!schema || typeof schema !== 'object') return refs;\n if (schema.ref) refs.push(schema.ref as string);\n if (schema.properties) {\n for (const v of Object.values(schema.properties)) {\n refs.push(...collectRefsInSchema(v as JTDSchemaJson));\n }\n }\n if (schema.optionalProperties) {\n for (const v of Object.values(schema.optionalProperties)) {\n refs.push(...collectRefsInSchema(v as JTDSchemaJson));\n }\n }\n if (schema.elements)\n refs.push(...collectRefsInSchema(schema.elements as JTDSchemaJson));\n if (schema.values)\n refs.push(...collectRefsInSchema(schema.values as JTDSchemaJson));\n if (schema.mapping) {\n for (const v of Object.values(schema.mapping)) {\n refs.push(...collectRefsInSchema(v as JTDSchemaJson));\n }\n }\n return refs;\n}\n\n/**\n * Detect circular references in JTD definitions.\n * Returns the name of a definition involved in a cycle, or null if acyclic.\n */\nfunction detectCircularRefs(\n defs: Record<string, JTDSchemaJson>\n): string | null {\n const WHITE = 0,\n GRAY = 1,\n BLACK = 2;\n const color = new Map<string, number>();\n for (const name of Object.keys(defs)) color.set(name, WHITE);\n\n function dfs(name: string): string | null {\n color.set(name, GRAY);\n const schema = defs[name];\n if (schema) {\n for (const ref of collectRefsInSchema(schema)) {\n if (!color.has(ref)) continue;\n if (color.get(ref) === GRAY) return ref;\n if (color.get(ref) === WHITE) {\n const result = dfs(ref);\n if (result) return result;\n }\n }\n }\n color.set(name, BLACK);\n return null;\n }\n\n for (const name of Object.keys(defs)) {\n if (color.get(name) === WHITE) {\n const cycle = dfs(name);\n if (cycle) return cycle;\n }\n }\n return null;\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// Metadata helper\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\nfunction appendToDescription(result: AnthropicSchema, text: string): void {\n result.description = result.description\n ? `${result.description} ${text}`\n : text;\n}\n\nconst METADATA_KNOWN_KEYS = new Set(['title', 'label', 'name', 'description']);\n\nfunction applyMetadata(result: AnthropicSchema, schema: JTDSchemaJson): void {\n const meta = schema.metadata as Record<string, unknown> | undefined;\n if (!meta) return;\n\n const descParts: string[] = [];\n\n const titleCandidate =\n (typeof meta['title'] === 'string' && meta['title'].trim()) ||\n (typeof meta['label'] === 'string' && meta['label'].trim()) ||\n (typeof meta['name'] === 'string' && meta['name'].trim());\n\n const descText =\n typeof meta['description'] === 'string' ? meta['description'].trim() : '';\n\n if (titleCandidate && descText) {\n descParts.push(`${titleCandidate}. ${descText}`);\n } else if (titleCandidate) {\n descParts.push(titleCandidate);\n } else if (descText) {\n descParts.push(descText);\n }\n\n const extras: string[] = [];\n for (const [key, value] of Object.entries(meta)) {\n if (METADATA_KNOWN_KEYS.has(key)) continue;\n if (typeof value === 'string' && value.trim()) {\n extras.push(`[${key}: ${value.trim()}]`);\n } else if (typeof value === 'number' || typeof value === 'boolean') {\n extras.push(`[${key}: ${value}]`);\n }\n }\n if (extras.length > 0) {\n descParts.push(extras.join(' '));\n }\n\n if (descParts.length > 0) {\n const newDesc = descParts.join(' ');\n result.description = result.description\n ? `${result.description} ${newDesc}`\n : newDesc;\n }\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// Schema conversion (JTD \u2192 Anthropic JSON Schema)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\nfunction convertNode(\n schema: JTDSchemaJson,\n defs: Record<string, JTDSchemaJson> | undefined,\n depth: number\n): AnthropicSchema {\n if (depth > MAX_REF_DEPTH) {\n throw new Error(`Schema nesting exceeded ${MAX_REF_DEPTH} levels`);\n }\n\n if (!schema || typeof schema !== 'object') {\n return { type: 'string', description: 'Must be a valid JSON value.' };\n }\n\n // Unstructured \u2192 string\n if (isUnstructuredSchema(schema)) {\n const isNullable = schema.nullable === true;\n const result: AnthropicSchema = {\n type: isNullable ? ['string', 'null'] : 'string',\n description: 'Must be a valid JSON value.'\n };\n applyMetadata(result, schema);\n return result;\n }\n\n const isNullable = schema.nullable === true;\n\n // Ref form \u2192 $ref\n if (schema.ref) {\n const refName = schema.ref as string;\n if (!defs?.[refName]) {\n throw new Error(`Unresolved ref \"${refName}\"`);\n }\n if (isNullable) {\n const result: AnthropicSchema = {\n anyOf: [{ $ref: `#/$defs/${refName}` }, { type: 'null' }]\n };\n applyMetadata(result, schema);\n return result;\n }\n return { $ref: `#/$defs/${refName}` };\n }\n\n // Type form\n if (schema.type) {\n const jtdType = schema.type as string;\n const result: AnthropicSchema = {};\n\n // Anthropic doesn't support min/max \u2014 encode bounds in description\n const intBounds = INTEGER_BOUNDS[jtdType];\n if (intBounds) {\n result.type = isNullable ? ['integer', 'null'] : 'integer';\n applyMetadata(result, schema);\n appendToDescription(result, `Value range: [${intBounds.minimum}, ${intBounds.maximum}].`);\n return result;\n }\n\n switch (jtdType) {\n case 'boolean':\n result.type = isNullable ? ['boolean', 'null'] : 'boolean';\n break;\n case 'string':\n result.type = isNullable ? ['string', 'null'] : 'string';\n break;\n case 'timestamp':\n result.type = isNullable ? ['string', 'null'] : 'string';\n result.format = 'date-time';\n break;\n case 'float32':\n result.type = isNullable ? ['number', 'null'] : 'number';\n applyMetadata(result, schema);\n appendToDescription(result, `Value range: [${FLOAT32_BOUNDS.minimum}, ${FLOAT32_BOUNDS.maximum}].`);\n return result;\n case 'float64':\n result.type = isNullable ? ['number', 'null'] : 'number';\n break;\n default:\n throw new Error(`Unknown JTD type \"${jtdType}\"`);\n }\n\n applyMetadata(result, schema);\n return result;\n }\n\n // Enum form\n if (schema.enum) {\n const result: AnthropicSchema = {\n type: isNullable ? ['string', 'null'] : 'string',\n enum: isNullable\n ? [...(schema.enum as string[]), null]\n : [...(schema.enum as string[])]\n };\n applyMetadata(result, schema);\n return result;\n }\n\n // Elements form\n if (schema.elements) {\n const result: AnthropicSchema = {\n type: isNullable ? ['array', 'null'] : 'array',\n items: convertNode(schema.elements as JTDSchemaJson, defs, depth + 1)\n };\n applyMetadata(result, schema);\n return result;\n }\n\n // Properties form \u2014 optional properties stay optional (not in required)\n if (schema.properties || schema.optionalProperties) {\n const result: AnthropicSchema = {\n type: isNullable ? ['object', 'null'] : 'object',\n properties: {},\n additionalProperties: false\n };\n const required: string[] = [];\n\n if (schema.properties) {\n for (const [key, propSchema] of Object.entries(schema.properties)) {\n result.properties![key] = convertNode(\n propSchema as JTDSchemaJson,\n defs,\n depth + 1\n );\n required.push(key);\n }\n }\n\n if (schema.optionalProperties) {\n for (const [key, propSchema] of Object.entries(\n schema.optionalProperties\n )) {\n result.properties![key] = convertNode(\n propSchema as JTDSchemaJson,\n defs,\n depth + 1\n );\n // NOT added to required \u2014 genuinely optional\n }\n }\n\n if (required.length > 0) {\n result.required = required;\n }\n\n applyMetadata(result, schema);\n return result;\n }\n\n // Values form \u2192 array of {key, value} objects\n if (schema.values) {\n const valueSchema = convertNode(\n schema.values as JTDSchemaJson,\n defs,\n depth + 1\n );\n const result: AnthropicSchema = {\n type: isNullable ? ['array', 'null'] : 'array',\n items: {\n type: 'object',\n properties: {\n key: { type: 'string' },\n value: valueSchema\n },\n required: ['key', 'value'],\n additionalProperties: false\n }\n };\n applyMetadata(result, schema);\n return result;\n }\n\n // Discriminator form \u2192 anyOf with const for discriminator\n if (schema.discriminator && schema.mapping) {\n const discKey = schema.discriminator as string;\n const mapping = schema.mapping as Record<string, JTDSchemaJson>;\n const variants: AnthropicSchema[] = [];\n\n for (const [tag, variantSchema] of Object.entries(mapping)) {\n let variantOut: AnthropicSchema;\n\n if (isUnstructuredSchema(variantSchema)) {\n variantOut = {\n type: 'object',\n properties: {\n [discKey]: { const: tag },\n _data: {\n type: 'string',\n description:\n 'Must be a valid JSON value representing the variant data.'\n }\n },\n required: [discKey, '_data'],\n additionalProperties: false\n };\n } else {\n variantOut = convertNode(variantSchema, defs, depth + 1);\n // Per RFC 8927, mapping values are always properties form,\n // and the discriminator tag never appears in variant properties.\n variantOut.properties![discKey] = { const: tag };\n (variantOut.required ??= []).unshift(discKey);\n variantOut.additionalProperties = false;\n }\n\n applyMetadata(variantOut, variantSchema);\n variants.push(variantOut);\n }\n\n const result: AnthropicSchema = { anyOf: variants };\n if (isNullable) {\n result.anyOf!.push({ type: 'null' });\n }\n applyMetadata(result, schema);\n return result;\n }\n\n // Fallback\n return { type: 'string', description: 'Must be a valid JSON value.' };\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// Coercion (Anthropic output \u2192 JTD-conforming JSON)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\nconst INTEGER_TYPE_SET = new Set(Object.keys(INTEGER_BOUNDS));\n\nfunction coerceToJTD(\n value: unknown,\n schema: JTDSchemaJson,\n defs: Record<string, JTDSchemaJson> | undefined,\n depth: number\n): unknown {\n if (depth > MAX_REF_DEPTH) return value;\n if (value === null || value === undefined) return value;\n\n // Ref form\n if (schema.ref) {\n const resolved = defs?.[schema.ref as string];\n if (resolved) {\n return coerceToJTD(value, resolved, defs, depth + 1);\n }\n return value;\n }\n\n // Unstructured \u2014 parse JSON string\n if (isUnstructuredSchema(schema)) {\n if (typeof value === 'string') {\n try {\n return JSON.parse(value);\n } catch {\n return value;\n }\n }\n return value;\n }\n\n // Type form \u2014 integer coercion\n if (schema.type && INTEGER_TYPE_SET.has(schema.type as string)) {\n if (typeof value === 'number' && !Number.isInteger(value)) {\n return Math.round(value);\n }\n return value;\n }\n\n // Elements form\n if (schema.elements && Array.isArray(value)) {\n return value.map((item) =>\n coerceToJTD(item, schema.elements as JTDSchemaJson, defs, depth + 1)\n );\n }\n\n // Properties form \u2014 no null-stripping needed (optionals are genuinely optional)\n if (\n (schema.properties || schema.optionalProperties) &&\n typeof value === 'object' &&\n value !== null\n ) {\n const obj = { ...(value as Record<string, unknown>) };\n\n if (schema.properties) {\n for (const [k, propSchema] of Object.entries(schema.properties)) {\n if (k in obj) {\n obj[k] = coerceToJTD(\n obj[k],\n propSchema as JTDSchemaJson,\n defs,\n depth + 1\n );\n }\n }\n }\n\n if (schema.optionalProperties) {\n for (const [k, propSchema] of Object.entries(\n schema.optionalProperties\n )) {\n if (k in obj) {\n obj[k] = coerceToJTD(\n obj[k],\n propSchema as JTDSchemaJson,\n defs,\n depth + 1\n );\n }\n }\n }\n\n return obj;\n }\n\n // Values form \u2014 array of {key, value} \u2192 Record\n if (schema.values && Array.isArray(value)) {\n const result: Record<string, unknown> = {};\n for (const entry of value) {\n if (typeof entry === 'object' && entry !== null) {\n const rec = entry as Record<string, unknown>;\n const key = rec.key as string;\n result[key] = coerceToJTD(\n rec.value,\n schema.values as JTDSchemaJson,\n defs,\n depth + 1\n );\n }\n }\n return result;\n }\n\n // Discriminator form \u2014 flat object, coerce variant fields\n if (\n schema.discriminator &&\n schema.mapping &&\n typeof value === 'object' &&\n value !== null\n ) {\n const rec = value as Record<string, unknown>;\n const discKey = schema.discriminator as string;\n const tag = rec[discKey] as string;\n const variantSchema = (schema.mapping as Record<string, JTDSchemaJson>)[\n tag\n ];\n\n if (!variantSchema) return value;\n\n if (isUnstructuredSchema(variantSchema)) {\n const dataStr = rec._data;\n if (typeof dataStr === 'string') {\n try {\n const parsed = JSON.parse(dataStr);\n if (typeof parsed === 'object' && parsed !== null) {\n return { [discKey]: tag, ...parsed };\n }\n } catch {\n /* validation catches */\n }\n }\n return { [discKey]: tag };\n }\n\n const result: Record<string, unknown> = { [discKey]: tag };\n\n if (variantSchema.properties) {\n for (const [k, propSchema] of Object.entries(variantSchema.properties)) {\n if (k in rec) {\n result[k] = coerceToJTD(\n rec[k],\n propSchema as JTDSchemaJson,\n defs,\n depth + 1\n );\n }\n }\n }\n\n if (variantSchema.optionalProperties) {\n for (const [k, propSchema] of Object.entries(\n variantSchema.optionalProperties\n )) {\n if (k in rec) {\n result[k] = coerceToJTD(\n rec[k],\n propSchema as JTDSchemaJson,\n defs,\n depth + 1\n );\n }\n }\n }\n\n return result;\n }\n\n return value;\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// Public API\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\n/**\n * Convert a JTD schema to an Anthropic structured output compatible JSON Schema,\n * with a converter function that transforms and validates Anthropic output against\n * the original JTD schema.\n *\n * @throws {Error} if the JTD schema contains recursive definitions (not supported by Anthropic).\n * @throws {Error} if the JTD schema contains unresolved refs.\n */\nexport function convertToAnthropicSchema(\n jtdSchema: JTDSchemaJson\n): AnthropicConversionResult {\n const defs = jtdSchema.definitions as\n | Record<string, JTDSchemaJson>\n | undefined;\n\n // Anthropic does not support recursive schemas \u2014 detect and throw\n if (defs && Object.keys(defs).length > 0) {\n const cycleNode = detectCircularRefs(defs);\n if (cycleNode) {\n throw new Error(\n `Anthropic structured output does not support recursive schemas. Definition \"${cycleNode}\" contains a circular reference.`\n );\n }\n }\n\n const strict = !isRootUnstructured(jtdSchema, defs);\n\n let schema: AnthropicSchema;\n if (strict) {\n schema = convertNode(jtdSchema, defs, 0);\n\n if (defs && Object.keys(defs).length > 0) {\n const anthropicDefs: Record<string, AnthropicSchema> = {};\n for (const [name, defSchema] of Object.entries(defs)) {\n anthropicDefs[name] = convertNode(\n defSchema as JTDSchemaJson,\n defs,\n 0\n );\n }\n schema.$defs = anthropicDefs;\n }\n } else {\n schema = {};\n applyMetadata(schema, jtdSchema);\n }\n\n const convert = (anthropicJson: unknown): ConvertResult => {\n const coerced = coerceToJTD(anthropicJson, jtdSchema, defs, 0);\n const errors = validateJsonAgainstJTD(jtdSchema, coerced, defs);\n if (errors.length > 0) {\n return { success: false, errors };\n }\n return { success: true, data: coerced };\n };\n\n return { schema, strict, convert };\n}\n\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n// Signal-level conversion (SignalDescriptorJson \u2192 Anthropic schema)\n// \u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\n\nfunction convertMimeFormat(mimeType: string): AnthropicSchema {\n return {\n type: 'string',\n description: `Base64-encoded binary content (MIME type: ${mimeType}).`\n };\n}\n\nfunction convertSingleFormat(\n format: SignalFormatJson\n): AnthropicConversionResult {\n if (format.jtdSchema) {\n return convertToAnthropicSchema(format.jtdSchema);\n }\n if (format.mimeType) {\n const schema = convertMimeFormat(format.mimeType);\n const convert = (anthropicJson: unknown): ConvertResult => {\n if (typeof anthropicJson !== 'string') {\n return {\n success: false,\n errors: [\n `/: expected base64 string for MIME type ${format.mimeType}, got ${typeof anthropicJson}`\n ]\n };\n }\n return { success: true, data: anthropicJson };\n };\n return { schema, strict: true, convert };\n }\n throw new Error('Signal format has neither jtdSchema nor mimeType');\n}\n\n/**\n * Convert a SignalDescriptorJson to an Anthropic structured output compatible JSON Schema.\n *\n * Handles single and multi-format signals:\n * - Single format: schema is the converted format directly.\n * - Multiple formats: wrapper object with genuinely optional `format_0`, `format_1`, etc.\n *\n * @throws {Error} if the descriptor has no formats.\n */\nexport function convertSignalToAnthropicSchema(\n descriptor: SignalDescriptorJson\n): AnthropicConversionResult {\n const formats = descriptor.formats as SignalFormatJson[] | undefined;\n if (!formats || formats.length === 0) {\n throw new Error('Signal descriptor has no formats');\n }\n\n const signalName = descriptor.name ?? 'unnamed';\n const isOptional = descriptor.optional === true;\n\n // Single format \u2014 no wrapper\n if (formats.length === 1) {\n const result = convertSingleFormat(formats[0]!);\n if (descriptor.label || descriptor.description) {\n const parts: string[] = [];\n if (descriptor.label) parts.push(descriptor.label);\n if (descriptor.description) parts.push(descriptor.description);\n const newDesc = parts.join('. ');\n result.schema.description = result.schema.description\n ? `${newDesc} ${result.schema.description}`\n : newDesc;\n }\n return result;\n }\n\n // Multiple formats \u2014 optional format_N properties (Anthropic supports native optionals)\n const formatConverters: Array<{\n key: string;\n converter: AnthropicConversionResult;\n }> = [];\n\n const wrapperProps: Record<string, AnthropicSchema> = {};\n\n for (let i = 0; i < formats.length; i++) {\n const fmt = formats[i]!;\n const key = `format_${i}`;\n const conv = convertSingleFormat(fmt);\n\n if (fmt.jtdSchema) {\n const existing = conv.schema.description;\n conv.schema.description = existing\n ? `Structured JSON data. ${existing}`\n : 'Structured JSON data.';\n }\n\n wrapperProps[key] = conv.schema;\n formatConverters.push({ key, converter: conv });\n }\n\n const keys = formatConverters.map((f) => f.key);\n const baseDesc = descriptor.description ?? '';\n const guidance = isOptional\n ? 'Provide at most ONE of the following format properties. All are optional.'\n : `You MUST provide exactly ONE of the following format properties: ${keys.join(', ')}.`;\n\n const schema: AnthropicSchema = {\n type: 'object',\n description: baseDesc ? `${baseDesc} ${guidance}` : guidance,\n properties: wrapperProps,\n additionalProperties: false\n // No required \u2014 all format props are genuinely optional\n };\n\n const convert = (anthropicJson: unknown): ConvertResult => {\n if (typeof anthropicJson !== 'object' || anthropicJson === null) {\n return {\n success: false,\n errors: [\n `/: expected object with format properties, got ${typeof anthropicJson}`\n ]\n };\n }\n\n const rec = anthropicJson as Record<string, unknown>;\n\n const selected = formatConverters.find(\n ({ key }) => rec[key] !== undefined && rec[key] !== null\n );\n\n if (!selected) {\n if (isOptional) {\n return { success: true, data: null };\n }\n return {\n success: false,\n errors: [\n `Signal '${signalName}' is required but no format was provided. Set exactly one of: ${keys.join(', ')}.`\n ]\n };\n }\n\n return selected.converter.convert(rec[selected.key]);\n };\n\n return { schema, strict: true, convert };\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["isSchema", "isValidSchema", "jtdValidate", "INTEGER_TYPES", "formatInstancePath", "instancePath", "p", "resolveSchemaParent", "schema", "schemaPath", "current", "i", "resolveInstanceValue", "value", "key", "formatValidationError", "error", "path", "lastKey", "jtdType", "enumValues", "discValue", "validateJsonAgainstJTD", "definitions", "defs", "schemaForValidation", "isValidSchema", "jtdValidate", "MAX_VALIDATION_DEPTH", "MAX_VALIDATION_ERRORS", "err", "MAX_VALIDATION_DEPTH", "MAX_VALIDATION_ERRORS", "MAX_REF_DEPTH", "INTEGER_BOUNDS", "FLOAT32_BOUNDS", "isUnstructuredSchema", "schema", "isRootUnstructured", "defs", "resolved", "depth", "target", "collectRefsInSchema", "refs", "v", "detectCircularRefs", "color", "name", "dfs", "ref", "result", "cycle", "appendToDescription", "text", "METADATA_KNOWN_KEYS", "applyMetadata", "meta", "descParts", "titleCandidate", "descText", "extras", "key", "value", "newDesc", "convertNode", "isNullable", "refName", "jtdType", "intBounds", "required", "propSchema", "valueSchema", "discKey", "mapping", "variants", "tag", "variantSchema", "variantOut", "INTEGER_TYPE_SET", "coerceToJTD", "item", "obj", "k", "entry", "rec", "dataStr", "parsed", "convertToAnthropicSchema", "jtdSchema", "cycleNode", "strict", "anthropicDefs", "defSchema", "anthropicJson", "coerced", "errors", "validateJsonAgainstJTD", "convertMimeFormat", "mimeType", "convertSingleFormat", "format", "convertSignalToAnthropicSchema", "descriptor", "formats", "signalName", "isOptional", "parts", "formatConverters", "wrapperProps", "i", "fmt", "conv", "existing", "keys", "f", "baseDesc", "guidance", "selected"]
|
|
7
|
+
}
|