zodvex 0.3.1 → 0.3.2

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/index.d.ts CHANGED
@@ -445,6 +445,20 @@ interface ToJSONSchemaOptions {
445
445
  */
446
446
  declare function toJSONSchema<T extends z.ZodTypeAny>(schema: T, options?: ToJSONSchemaOptions): Record<string, any>;
447
447
 
448
+ /**
449
+ * Helper type for Convex system fields added to documents
450
+ */
451
+ type SystemFields<TableName extends string> = {
452
+ _id: ReturnType<typeof zid<TableName>>;
453
+ _creationTime: z.ZodNumber;
454
+ };
455
+ /**
456
+ * Maps over union options, extending each ZodObject variant with system fields.
457
+ * Non-object variants are preserved as-is.
458
+ */
459
+ type MapSystemFields<TableName extends string, Options extends readonly z.ZodTypeAny[]> = {
460
+ [K in keyof Options]: Options[K] extends z.ZodObject<infer Shape extends z.ZodRawShape> ? z.ZodObject<Shape & SystemFields<TableName>> : Options[K];
461
+ };
448
462
  /**
449
463
  * Adds Convex system fields (_id, _creationTime) to a Zod schema.
450
464
  *
@@ -455,7 +469,10 @@ declare function toJSONSchema<T extends z.ZodTypeAny>(schema: T, options?: ToJSO
455
469
  * @param schema - The Zod schema (object or union)
456
470
  * @returns Schema with system fields added
457
471
  */
458
- declare function addSystemFields<T extends string, S extends z.ZodTypeAny>(tableName: T, schema: S): z.ZodTypeAny;
472
+ declare function addSystemFields<TableName extends string, Shape extends z.ZodRawShape>(tableName: TableName, schema: z.ZodObject<Shape>): z.ZodObject<Shape & SystemFields<TableName>>;
473
+ declare function addSystemFields<TableName extends string, Options extends readonly z.ZodTypeAny[]>(tableName: TableName, schema: z.ZodUnion<Options>): z.ZodUnion<MapSystemFields<TableName, Options>>;
474
+ declare function addSystemFields<TableName extends string, Options extends readonly z.ZodObject<z.ZodRawShape>[], Discriminator extends string>(tableName: TableName, schema: z.ZodDiscriminatedUnion<Options, Discriminator>): z.ZodDiscriminatedUnion<MapSystemFields<TableName, Options>, Discriminator>;
475
+ declare function addSystemFields<TableName extends string, S extends z.ZodTypeAny>(tableName: TableName, schema: S): S;
459
476
  declare function zodDoc<TableName extends string, Shape extends z.ZodRawShape, Schema extends z.ZodObject<Shape>>(tableName: TableName, schema: Schema): z.ZodObject<Shape & {
460
477
  _id: ReturnType<typeof zid<TableName>>;
461
478
  _creationTime: z.ZodNumber;
@@ -522,7 +539,8 @@ declare function zodDocOrNull<TableName extends string, Shape extends z.ZodRawSh
522
539
  * )
523
540
  * ```
524
541
  */
525
- declare function zodTable<TableName extends string, Shape extends Record<string, z.ZodTypeAny>>(name: TableName, shape: Shape): ReturnType<typeof Table<any, TableName>> & {
542
+ type AddSystemFieldsResult<TableName extends string, Schema extends z.ZodTypeAny> = Schema extends z.ZodObject<infer Shape extends z.ZodRawShape> ? z.ZodObject<Shape & SystemFields<TableName>> : Schema extends z.ZodUnion<infer Options extends readonly z.ZodTypeAny[]> ? z.ZodUnion<MapSystemFields<TableName, Options>> : Schema extends z.ZodDiscriminatedUnion<infer Options extends readonly z.ZodObject<z.ZodRawShape>[], infer Disc extends string> ? z.ZodDiscriminatedUnion<MapSystemFields<TableName, Options>, Disc> : Schema;
543
+ declare function zodTable<TableName extends string, Shape extends Record<string, z.ZodTypeAny>>(name: TableName, shape: Shape): ReturnType<typeof Table<ConvexValidatorFromZodFieldsAuto<Shape>, TableName>> & {
526
544
  shape: Shape;
527
545
  zDoc: z.ZodObject<Shape & {
528
546
  _id: ReturnType<typeof zid<TableName>>;
@@ -538,8 +556,8 @@ declare function zodTable<TableName extends string, Schema extends z.ZodTypeAny>
538
556
  tableName: TableName;
539
557
  validator: ReturnType<typeof zodToConvex<Schema>>;
540
558
  schema: Schema;
541
- docArray: z.ZodArray<ReturnType<typeof addSystemFields<TableName, Schema>>>;
542
- withSystemFields: () => ReturnType<typeof addSystemFields<TableName, Schema>>;
559
+ docArray: z.ZodArray<AddSystemFieldsResult<TableName, Schema>>;
560
+ withSystemFields: () => AddSystemFieldsResult<TableName, Schema>;
543
561
  };
544
562
 
545
563
  declare function pick<T extends Record<string, any>, K extends keyof T>(obj: T, keys: K[]): Pick<T, K>;
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/ids.ts","../src/registry.ts","../src/mapping/handlers/enum.ts","../src/mapping/handlers/nullable.ts","../src/mapping/handlers/record.ts","../src/mapping/handlers/union.ts","../src/mapping/utils.ts","../src/mapping/core.ts","../src/codec.ts","../src/utils.ts","../src/custom.ts","../src/wrappers.ts","../src/builders.ts","../src/tables.ts"],"names":["z","v","zodToConvexInternal","metadata","asZodType"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * IDs + registry for Convex + Zod v4\n */\n\nimport type { GenericId } from 'convex/values'\nimport { z } from 'zod'\n\n// Simple registry for metadata\nconst metadata = new WeakMap<z.ZodTypeAny, any>()\n\nexport const registryHelpers = {\n getMetadata: (type: z.ZodTypeAny) => metadata.get(type),\n setMetadata: (type: z.ZodTypeAny, meta: any) => metadata.set(type, meta)\n}\n\n/**\n * Create a Zod validator for a Convex Id\n *\n * Compatible with AI SDK and other tools that don't support transforms.\n * Uses type-level branding instead of runtime transforms for GenericId<T> compatibility.\n *\n * @param tableName - The Convex table name for this ID\n * @returns A Zod string validator typed as GenericId<TableName>\n */\nexport function zid<TableName extends string>(\n tableName: TableName\n): z.ZodType<GenericId<TableName>> & { _tableName: TableName } {\n // Create base string validator with refinement (no transform or brand)\n const baseSchema = z\n .string()\n .refine(val => typeof val === 'string' && val.length > 0, {\n message: `Invalid ID for table \"${tableName}\"`\n })\n // Add a human-readable marker for client-side introspection utilities\n // used in apps/native (e.g., to detect relationship fields in dynamic forms).\n .describe(`convexId:${tableName}`)\n\n // Store metadata for registry lookup so mapping can convert to v.id(tableName)\n registryHelpers.setMetadata(baseSchema, {\n isConvexId: true,\n tableName\n })\n\n // Add the tableName property for type-level detection\n const branded = baseSchema as any\n branded._tableName = tableName\n\n // Type assertion provides GenericId<TableName> typing without runtime transform\n // This maintains type safety while being compatible with AI SDK and similar tools\n return branded as z.ZodType<GenericId<TableName>> & { _tableName: TableName }\n}\n\nexport type Zid<TableName extends string> = ReturnType<typeof zid<TableName>>\n","import { v } from 'convex/values'\nimport { z } from 'zod'\n\n// Registry for base type codecs\ntype BaseCodec = {\n check: (schema: any) => boolean\n toValidator: (schema: any) => any\n fromConvex: (value: any, schema: any) => any\n toConvex: (value: any, schema: any) => any\n}\n\nconst baseCodecs: BaseCodec[] = []\n\nexport function registerBaseCodec(codec: BaseCodec): void {\n baseCodecs.unshift(codec) // Add to front for priority\n}\n\nexport function findBaseCodec(schema: any): BaseCodec | undefined {\n return baseCodecs.find(codec => codec.check(schema))\n}\n\n// Built-in codec for Date\nregisterBaseCodec({\n check: schema => schema instanceof z.ZodDate,\n toValidator: () => v.float64(),\n fromConvex: value => {\n if (typeof value === 'number') {\n return new Date(value)\n }\n return value\n },\n toConvex: value => {\n if (value instanceof Date) {\n return value.getTime()\n }\n return value\n }\n})\n\n// Helper to convert Zod's internal types to ZodTypeAny\nfunction asZodType<T>(schema: T): z.ZodTypeAny {\n return schema as unknown as z.ZodTypeAny\n}\n\n// Helper to check if a schema is a Date type through the registry\nexport function isDateSchema(schema: any): boolean {\n if (schema instanceof z.ZodDate) return true\n\n // Check through optional/nullable (these have public unwrap())\n if (schema instanceof z.ZodOptional || schema instanceof z.ZodNullable) {\n return isDateSchema(asZodType(schema.unwrap()))\n }\n\n // Cannot check transforms/pipes without _def access\n // This is a limitation of using only public APIs\n\n return false\n}\n\n// ============================================================================\n// JSON Schema Override Support\n// ============================================================================\n// Zod's toJSONSchema doesn't support transforms, brands, and other \"unrepresentable\"\n// types by default. This module provides overrides for zodvex-managed types\n// so they can be used with AI SDKs and other JSON Schema-based tools.\n\n/**\n * Checks if a schema is a zid (Convex ID) schema by looking at its description.\n * zid schemas are marked with \"convexId:{tableName}\" in their description.\n */\nexport function isZidSchema(schema: z.ZodTypeAny): boolean {\n const description = schema.description\n return typeof description === 'string' && description.startsWith('convexId:')\n}\n\n/**\n * Extracts the table name from a zid schema's description.\n * Returns undefined if not a zid schema.\n */\nexport function getZidTableName(schema: z.ZodTypeAny): string | undefined {\n const description = schema.description\n if (typeof description === 'string' && description.startsWith('convexId:')) {\n return description.slice('convexId:'.length)\n }\n return undefined\n}\n\n/**\n * Context object passed to the JSON Schema override function.\n * Uses 'any' types for compatibility with Zod's internal types.\n */\nexport interface JSONSchemaOverrideContext {\n zodSchema: any // Zod's internal $ZodTypes\n jsonSchema: any // Zod's JSONSchema.BaseSchema\n}\n\n/**\n * Override function for z.toJSONSchema that handles zodvex-managed types.\n *\n * Handles:\n * - zid schemas: Converts to { type: \"string\" } with convexId format\n * - z.date(): Converts to { type: \"string\", format: \"date-time\" }\n *\n * @example\n * ```ts\n * import { z } from 'zod'\n * import { zid, zodvexJSONSchemaOverride } from 'zodvex'\n *\n * const schema = z.object({\n * userId: zid('users'),\n * name: z.string()\n * })\n *\n * const jsonSchema = z.toJSONSchema(schema, {\n * unrepresentable: 'any',\n * override: zodvexJSONSchemaOverride\n * })\n * // => { type: \"object\", properties: { userId: { type: \"string\" }, name: { type: \"string\" } } }\n * ```\n */\nexport function zodvexJSONSchemaOverride(ctx: JSONSchemaOverrideContext): void {\n const { zodSchema, jsonSchema } = ctx\n\n // Handle zid schemas (transforms with convexId description)\n if (isZidSchema(zodSchema)) {\n const tableName = getZidTableName(zodSchema)\n // Set our properties - don't clear existing ones set by user overrides\n // When unrepresentable: 'any', Zod already gives us {} so no clearing needed\n jsonSchema.type = 'string'\n if (tableName) {\n jsonSchema.format = `convex-id:${tableName}`\n }\n // Preserve the description from .describe() - this is what the LLM sees\n if (zodSchema.description) {\n jsonSchema.description = zodSchema.description\n }\n return\n }\n\n // Handle z.date() - convert to ISO 8601 string format\n // Zod v4 passes real schema instances here (ZodDate has `type === 'date'`).\n if (zodSchema instanceof z.ZodDate || (zodSchema as any).type === 'date') {\n jsonSchema.type = 'string'\n jsonSchema.format = 'date-time'\n return\n }\n}\n\n/**\n * Composes multiple JSON Schema override functions into one.\n * Overrides run in order - first override runs first.\n *\n * @example\n * ```ts\n * import { composeOverrides, zodvexJSONSchemaOverride } from 'zodvex'\n *\n * const myOverride = (ctx) => {\n * if (ctx.zodSchema.description?.startsWith('myType:')) {\n * ctx.jsonSchema.type = 'string'\n * ctx.jsonSchema.format = 'my-format'\n * }\n * }\n *\n * // User's override runs first, then zodvex's\n * z.toJSONSchema(schema, {\n * unrepresentable: 'any',\n * override: composeOverrides(myOverride, zodvexJSONSchemaOverride)\n * })\n * ```\n */\nexport function composeOverrides(\n ...overrides: Array<((ctx: JSONSchemaOverrideContext) => void) | undefined>\n): (ctx: JSONSchemaOverrideContext) => void {\n return (ctx: JSONSchemaOverrideContext) => {\n for (const override of overrides) {\n override?.(ctx)\n }\n }\n}\n\n/**\n * Options for toJSONSchema, matching Zod's interface.\n */\nexport interface ToJSONSchemaOptions {\n target?: 'draft-4' | 'draft-7' | 'draft-2020-12' | 'openapi-3.0'\n unrepresentable?: 'throw' | 'any'\n cycles?: 'ref' | 'throw'\n reused?: 'ref' | 'inline'\n io?: 'input' | 'output'\n override?: (ctx: JSONSchemaOverrideContext) => void\n}\n\n/**\n * Converts a Zod schema to JSON Schema with zodvex-aware overrides.\n *\n * This is a convenience wrapper around z.toJSONSchema that automatically\n * handles zodvex-managed types like zid and dates.\n *\n * @example\n * ```ts\n * import { zid, toJSONSchema } from 'zodvex'\n *\n * const schema = z.object({\n * userId: zid('users'),\n * createdAt: z.date(),\n * name: z.string()\n * })\n *\n * const jsonSchema = toJSONSchema(schema)\n * // Works with AI SDK's generateObject, etc.\n * ```\n */\nexport function toJSONSchema<T extends z.ZodTypeAny>(\n schema: T,\n options?: ToJSONSchemaOptions\n): Record<string, any> {\n const userOverride = options?.override\n\n return z.toJSONSchema(schema, {\n ...options,\n // Default to 'any' so transforms don't throw\n unrepresentable: options?.unrepresentable ?? 'any',\n // Chain our override with user's override\n override: ctx => {\n zodvexJSONSchemaOverride(ctx)\n userOverride?.(ctx)\n }\n })\n}\n","import type { GenericValidator, Validator } from 'convex/values'\nimport { v } from 'convex/values'\nimport { z } from 'zod'\n\n// Helper: Convert Zod enum types to Convex validators\nexport function convertEnumType(actualValidator: z.ZodEnum<any>): GenericValidator {\n const options = (actualValidator as any).options\n if (options && Array.isArray(options) && options.length > 0) {\n // Filter out undefined/null and convert to Convex validators\n const validLiterals = options\n .filter((opt: any) => opt !== undefined && opt !== null)\n .map((opt: any) => v.literal(opt))\n\n if (validLiterals.length === 1) {\n const [first] = validLiterals\n return first as Validator<any, 'required', any>\n } else if (validLiterals.length >= 2) {\n const [first, second, ...rest] = validLiterals\n return v.union(\n first as Validator<any, 'required', any>,\n second as Validator<any, 'required', any>,\n ...rest\n )\n } else {\n return v.any()\n }\n } else {\n return v.any()\n }\n}\n","import type { GenericValidator } from 'convex/values'\nimport { v } from 'convex/values'\nimport { z } from 'zod'\n\n// Helper: Convert Zod nullable types to Convex validators\nexport function convertNullableType(\n actualValidator: z.ZodNullable<any>,\n visited: Set<z.ZodTypeAny>,\n zodToConvexInternal: (schema: z.ZodTypeAny, visited: Set<z.ZodTypeAny>) => any\n): { validator: GenericValidator; isOptional: boolean } {\n const innerSchema = actualValidator.unwrap()\n if (innerSchema && innerSchema instanceof z.ZodType) {\n // Check if the inner schema is optional\n if (innerSchema instanceof z.ZodOptional) {\n // For nullable(optional(T)), we want optional(union(T, null))\n const innerInnerSchema = innerSchema.unwrap()\n const innerInnerValidator = zodToConvexInternal(innerInnerSchema as z.ZodType, visited)\n return {\n validator: v.union(innerInnerValidator, v.null()),\n isOptional: true // Mark as optional so it gets wrapped later\n }\n } else {\n const innerValidator = zodToConvexInternal(innerSchema, visited)\n return {\n validator: v.union(innerValidator, v.null()),\n isOptional: false\n }\n }\n } else {\n return {\n validator: v.any(),\n isOptional: false\n }\n }\n}\n","import type { GenericValidator } from 'convex/values'\nimport { v } from 'convex/values'\nimport { z } from 'zod'\n\n// Helper: Convert Zod record types to Convex validators\nexport function convertRecordType(\n actualValidator: z.ZodRecord<any, any>,\n visited: Set<z.ZodTypeAny>,\n zodToConvexInternal: (schema: z.ZodTypeAny, visited: Set<z.ZodTypeAny>) => any\n): GenericValidator {\n // In Zod v4, when z.record(z.string()) is used with one argument,\n // the argument becomes the value type and key defaults to string.\n // The valueType is stored in _def.valueType (or undefined if single arg)\n let valueType = (actualValidator as any)._def?.valueType\n\n // If valueType is undefined, it means single argument form was used\n // where the argument is actually the value type (stored in keyType)\n if (!valueType) {\n // Workaround: Zod v4 stores the value type in _def.keyType for single-argument z.record().\n // This accesses a private property as there is no public API for this in Zod v4.\n valueType = (actualValidator as any)._def?.keyType\n }\n\n if (valueType && valueType instanceof z.ZodType) {\n // First check if the Zod value type is optional before conversion\n const isZodOptional =\n valueType instanceof z.ZodOptional ||\n valueType instanceof z.ZodDefault ||\n (valueType instanceof z.ZodDefault && valueType.def.innerType instanceof z.ZodOptional)\n\n if (isZodOptional) {\n // For optional record values, we need to handle this specially\n let innerType: z.ZodTypeAny\n let recordDefaultValue: any = undefined\n let recordHasDefault = false\n\n if (valueType instanceof z.ZodDefault) {\n // Handle ZodDefault wrapper\n recordHasDefault = true\n recordDefaultValue = valueType.def.defaultValue\n const innerFromDefault = valueType.def.innerType\n if (innerFromDefault instanceof z.ZodOptional) {\n innerType = innerFromDefault.unwrap() as z.ZodTypeAny\n } else {\n innerType = innerFromDefault as z.ZodTypeAny\n }\n } else if (valueType instanceof z.ZodOptional) {\n // Direct ZodOptional\n innerType = valueType.unwrap() as z.ZodTypeAny\n } else {\n // Shouldn't happen based on isZodOptional check\n innerType = valueType as z.ZodTypeAny\n }\n\n // Convert the inner type to Convex and wrap in union with null\n const innerConvex = zodToConvexInternal(innerType, visited)\n const unionValidator = v.union(innerConvex, v.null())\n\n // Add default metadata if present\n if (recordHasDefault) {\n ;(unionValidator as any)._zodDefault = recordDefaultValue\n }\n\n return v.record(v.string(), unionValidator)\n } else {\n // Non-optional values can be converted normally\n return v.record(v.string(), zodToConvexInternal(valueType, visited))\n }\n } else {\n return v.record(v.string(), v.any())\n }\n}\n","import type { GenericValidator, Validator } from 'convex/values'\nimport { v } from 'convex/values'\nimport { z } from 'zod'\n\n// Helper: Convert Zod discriminated union types to Convex validators\nexport function convertDiscriminatedUnionType(\n actualValidator: z.ZodDiscriminatedUnion<any, any>,\n visited: Set<z.ZodTypeAny>,\n zodToConvexInternal: (schema: z.ZodTypeAny, visited: Set<z.ZodTypeAny>) => any\n): GenericValidator {\n const options =\n (actualValidator as any).def?.options || (actualValidator as any).def?.optionsMap?.values()\n if (options) {\n const opts = Array.isArray(options) ? options : Array.from(options)\n if (opts.length >= 2) {\n // IMPORTANT: Create a new visited set for each union member to prevent false circular\n // reference detection. The same schema can legitimately appear in multiple union branches.\n const convexOptions = opts.map((opt: any) => {\n const branchVisited = new Set(visited)\n return zodToConvexInternal(opt, branchVisited)\n }) as Validator<any, 'required', any>[]\n const [first, second, ...rest] = convexOptions\n return v.union(\n first as Validator<any, 'required', any>,\n second as Validator<any, 'required', any>,\n ...rest\n )\n } else {\n return v.any()\n }\n } else {\n return v.any()\n }\n}\n\n// Helper: Convert Zod union types to Convex validators\nexport function convertUnionType(\n actualValidator: z.ZodUnion<any>,\n visited: Set<z.ZodTypeAny>,\n zodToConvexInternal: (schema: z.ZodTypeAny, visited: Set<z.ZodTypeAny>) => any\n): GenericValidator {\n const options = (actualValidator as any).options\n if (options && Array.isArray(options) && options.length > 0) {\n if (options.length === 1) {\n return zodToConvexInternal(options[0], visited)\n } else {\n // Convert each option recursively\n // IMPORTANT: Create a new visited set for each union member to prevent false circular\n // reference detection. The same schema can legitimately appear in multiple union branches.\n // However, we do want to preserve the parent visited set to catch actual circular refs\n // that involve the union itself.\n const convexOptions = options.map((opt: any) => {\n // Create a new Set that includes the parent's visited schemas but won't pollute it\n const branchVisited = new Set(visited)\n return zodToConvexInternal(opt, branchVisited)\n }) as Validator<any, 'required', any>[]\n if (convexOptions.length >= 2) {\n const [first, second, ...rest] = convexOptions\n return v.union(\n first as Validator<any, 'required', any>,\n second as Validator<any, 'required', any>,\n ...rest\n )\n } else {\n return v.any()\n }\n }\n } else {\n return v.any()\n }\n}\n","import { v } from 'convex/values'\nimport { z } from 'zod'\nimport { registryHelpers, type Zid } from '../ids'\n\n// Helper to check if a schema is a Zid\nexport function isZid<T extends string>(schema: z.ZodType): schema is Zid<T> {\n // Check our metadata registry for ConvexId marker\n const metadata = registryHelpers.getMetadata(schema)\n return (\n metadata?.isConvexId === true && metadata?.tableName && typeof metadata.tableName === 'string'\n )\n}\n\n// union helpers\nexport function makeUnion(members: any[]): any {\n const nonNull = members.filter(Boolean)\n if (nonNull.length === 0) return v.any()\n if (nonNull.length === 1) return nonNull[0]\n return v.union(nonNull[0], nonNull[1], ...nonNull.slice(2))\n}\n\nexport function getObjectShape(obj: any): Record<string, any> {\n // Use public API .shape property for ZodObject\n if (obj instanceof z.ZodObject) {\n return obj.shape\n }\n // Fallback for edge cases\n if (obj && typeof obj === 'object' && typeof obj.shape === 'object') {\n return obj.shape as Record<string, any>\n }\n return {}\n}\n","import type { GenericValidator, PropertyValidators } from 'convex/values'\nimport { v } from 'convex/values'\nimport { z } from 'zod'\nimport { registryHelpers } from '../ids'\nimport { findBaseCodec } from '../registry'\nimport {\n convertDiscriminatedUnionType,\n convertEnumType,\n convertNullableType,\n convertRecordType,\n convertUnionType\n} from './handlers'\nimport type {\n ConvexValidatorFromZod,\n ConvexValidatorFromZodFieldsAuto,\n ZodValidator\n} from './types'\nimport { getObjectShape, isZid } from './utils'\n\n// Internal conversion function using ZodType with def.type detection\nfunction zodToConvexInternal<Z extends z.ZodTypeAny>(\n zodValidator: Z,\n visited: Set<z.ZodTypeAny> = new Set()\n): ConvexValidatorFromZod<Z, 'required'> {\n // Guard against undefined/null validators (can happen with { field: undefined } in args)\n if (!zodValidator) {\n return v.any() as ConvexValidatorFromZod<Z, 'required'>\n }\n\n // Detect circular references to prevent infinite recursion\n if (visited.has(zodValidator)) {\n return v.any() as ConvexValidatorFromZod<Z, 'required'>\n }\n visited.add(zodValidator)\n\n // Check for default and optional wrappers\n let actualValidator = zodValidator\n let isOptional = false\n let defaultValue: any = undefined\n let hasDefault = false\n\n // Handle ZodDefault (which wraps ZodOptional when using .optional().default())\n // Note: We access _def properties directly because Zod v4 doesn't expose public APIs\n // for unwrapping defaults. The removeDefault() method exists but returns a new schema\n // without preserving references, which breaks our visited Set tracking.\n if (zodValidator instanceof z.ZodDefault) {\n hasDefault = true\n defaultValue = (zodValidator as any).def?.defaultValue\n actualValidator = (zodValidator as any).def?.innerType as Z\n }\n\n // Check for optional (may be wrapped inside ZodDefault)\n if (actualValidator instanceof z.ZodOptional) {\n isOptional = true\n actualValidator = actualValidator.unwrap() as Z\n\n // If the unwrapped type is ZodDefault, handle it here\n if (actualValidator instanceof z.ZodDefault) {\n hasDefault = true\n defaultValue = (actualValidator as any).def?.defaultValue\n actualValidator = (actualValidator as any).def?.innerType as Z\n }\n }\n\n let convexValidator: GenericValidator\n\n // Check for Zid first (special case)\n if (isZid(actualValidator)) {\n const metadata = registryHelpers.getMetadata(actualValidator)\n const tableName = metadata?.tableName || 'unknown'\n convexValidator = v.id(tableName)\n } else {\n // Use def.type for robust, performant type detection instead of instanceof checks.\n // Rationale:\n // 1. Performance: Single switch statement vs. cascading instanceof checks\n // 2. Completeness: def.type covers ALL Zod variants including formats (email, url, uuid, etc.)\n // 3. Future-proof: Zod's internal structure is stable; instanceof checks can miss custom types\n // 4. Precision: def.type distinguishes between semantically different types (date vs number)\n // This private API access is intentional and necessary for comprehensive type coverage.\n //\n // Compatibility: This code relies on the internal `.def.type` property of ZodType.\n // This structure has been stable across Zod v3.x and v4.x. If upgrading Zod major versions,\n // verify that `.def.type` is still present and unchanged.\n const defType = (actualValidator as any).def?.type\n\n switch (defType) {\n case 'string':\n // This catches ZodString and ALL string format types (email, url, uuid, etc.)\n convexValidator = v.string()\n break\n case 'number':\n convexValidator = v.float64()\n break\n case 'bigint':\n convexValidator = v.int64()\n break\n case 'boolean':\n convexValidator = v.boolean()\n break\n case 'date':\n convexValidator = v.float64() // Dates are stored as timestamps in Convex\n break\n case 'null':\n convexValidator = v.null()\n break\n case 'nan':\n convexValidator = v.float64()\n break\n case 'array': {\n // Use classic API: ZodArray has .element property\n if (actualValidator instanceof z.ZodArray) {\n const element = (actualValidator as any).element\n if (element && element instanceof z.ZodType) {\n convexValidator = v.array(zodToConvexInternal(element, visited))\n } else {\n convexValidator = v.array(v.any())\n }\n } else {\n convexValidator = v.array(v.any())\n }\n break\n }\n case 'object': {\n // Use classic API: ZodObject has .shape property\n if (actualValidator instanceof z.ZodObject) {\n const shape = actualValidator.shape\n const convexShape: PropertyValidators = {}\n for (const [key, value] of Object.entries(shape)) {\n if (value && value instanceof z.ZodType) {\n convexShape[key] = zodToConvexInternal(value, visited)\n }\n }\n convexValidator = v.object(convexShape)\n } else {\n convexValidator = v.object({})\n }\n break\n }\n case 'union': {\n if (actualValidator instanceof z.ZodUnion) {\n convexValidator = convertUnionType(actualValidator, visited, zodToConvexInternal)\n } else {\n convexValidator = v.any()\n }\n break\n }\n case 'discriminatedUnion': {\n convexValidator = convertDiscriminatedUnionType(\n actualValidator as any,\n visited,\n zodToConvexInternal\n )\n break\n }\n case 'literal': {\n // Use classic API: ZodLiteral has .value property\n if (actualValidator instanceof z.ZodLiteral) {\n const literalValue = (actualValidator as any).value\n if (literalValue !== undefined && literalValue !== null) {\n convexValidator = v.literal(literalValue)\n } else {\n convexValidator = v.any()\n }\n } else {\n convexValidator = v.any()\n }\n break\n }\n case 'enum': {\n if (actualValidator instanceof z.ZodEnum) {\n convexValidator = convertEnumType(actualValidator)\n } else {\n convexValidator = v.any()\n }\n break\n }\n case 'record': {\n if (actualValidator instanceof z.ZodRecord) {\n convexValidator = convertRecordType(actualValidator, visited, zodToConvexInternal)\n } else {\n convexValidator = v.record(v.string(), v.any())\n }\n break\n }\n case 'transform':\n case 'pipe': {\n // Check for registered codec first\n const codec = findBaseCodec(actualValidator)\n if (codec) {\n convexValidator = codec.toValidator(actualValidator)\n } else {\n // Check for brand metadata\n const metadata = registryHelpers.getMetadata(actualValidator)\n if (metadata?.brand && metadata?.originalSchema) {\n // For branded types created by our zBrand function, use the original schema\n convexValidator = zodToConvexInternal(metadata.originalSchema, visited)\n } else {\n // For non-registered transforms, return v.any()\n convexValidator = v.any()\n }\n }\n break\n }\n case 'nullable': {\n if (actualValidator instanceof z.ZodNullable) {\n const result = convertNullableType(actualValidator, visited, zodToConvexInternal)\n convexValidator = result.validator\n if (result.isOptional) {\n isOptional = true\n }\n } else {\n convexValidator = v.any()\n }\n break\n }\n case 'tuple': {\n // Handle tuple types as objects with numeric keys\n if (actualValidator instanceof z.ZodTuple) {\n const items = (actualValidator as any).def?.items as z.ZodTypeAny[] | undefined\n if (items && items.length > 0) {\n const convexShape: PropertyValidators = {}\n items.forEach((item, index) => {\n convexShape[`_${index}`] = zodToConvexInternal(item, visited)\n })\n convexValidator = v.object(convexShape)\n } else {\n convexValidator = v.object({})\n }\n } else {\n convexValidator = v.object({})\n }\n break\n }\n case 'lazy': {\n // Handle lazy schemas by resolving them\n // Circular references are protected by the visited set check at function start\n if (actualValidator instanceof z.ZodLazy) {\n try {\n const getter = (actualValidator as any).def?.getter\n if (getter) {\n const resolvedSchema = getter()\n if (resolvedSchema && resolvedSchema instanceof z.ZodType) {\n convexValidator = zodToConvexInternal(resolvedSchema, visited)\n } else {\n convexValidator = v.any()\n }\n } else {\n convexValidator = v.any()\n }\n } catch {\n // If resolution fails, fall back to 'any'\n convexValidator = v.any()\n }\n } else {\n convexValidator = v.any()\n }\n break\n }\n case 'any':\n // Handle z.any() directly\n convexValidator = v.any()\n break\n case 'unknown':\n // Handle z.unknown() as any\n convexValidator = v.any()\n break\n case 'undefined':\n case 'void':\n case 'never':\n // These types don't have good Convex equivalents\n convexValidator = v.any()\n break\n case 'intersection':\n // Can't properly handle intersections\n convexValidator = v.any()\n break\n default:\n // For any unrecognized def.type, return v.any()\n // No instanceof fallbacks - keep it simple and performant\n if (process.env.NODE_ENV !== 'production') {\n console.warn(\n `[zodvex] Unrecognized Zod type \"${defType}\" encountered. Falling back to v.any().`,\n 'Schema:',\n actualValidator\n )\n }\n convexValidator = v.any()\n break\n }\n }\n\n // For optional or default fields, always use v.optional()\n const finalValidator = isOptional || hasDefault ? v.optional(convexValidator) : convexValidator\n\n // Add metadata if there's a default value\n if (hasDefault && typeof finalValidator === 'object' && finalValidator !== null) {\n ;(finalValidator as any)._zodDefault = defaultValue\n }\n\n return finalValidator as ConvexValidatorFromZod<Z, 'required'>\n}\n\nexport function zodToConvex<Z extends z.ZodTypeAny | ZodValidator>(\n zod: Z\n): Z extends z.ZodTypeAny\n ? ConvexValidatorFromZod<Z, 'required'>\n : Z extends ZodValidator\n ? ConvexValidatorFromZodFieldsAuto<Z>\n : never {\n if (typeof zod === 'object' && zod !== null && !(zod instanceof z.ZodType)) {\n return zodToConvexFields(zod as ZodValidator) as any\n }\n\n return zodToConvexInternal(zod as z.ZodTypeAny) as any\n}\n\nexport function zodToConvexFields<Z extends z.ZodRawShape>(\n zod: Z\n): ConvexValidatorFromZodFieldsAuto<Z> {\n // If it's a ZodObject, extract the shape\n const fields = zod instanceof z.ZodObject ? zod.shape : zod\n\n // Build the result object directly to preserve types\n const result: any = {}\n for (const [key, value] of Object.entries(fields)) {\n result[key] = zodToConvexInternal(value as z.ZodTypeAny)\n }\n\n return result as ConvexValidatorFromZodFieldsAuto<Z>\n}\n","import { z } from 'zod'\nimport { zodToConvex } from './mapping'\nimport { findBaseCodec, isDateSchema } from './registry'\n\n// Helper to convert Zod's internal types to ZodTypeAny\nfunction asZodType<T>(schema: T): z.ZodTypeAny {\n return schema as unknown as z.ZodTypeAny\n}\n\nexport type ConvexCodec<T> = {\n validator: any\n encode: (value: T) => any\n decode: (value: any) => T\n pick: <K extends keyof T>(keys: K[]) => ConvexCodec<Pick<T, K>>\n}\n\nexport function convexCodec<T>(schema: z.ZodType<T>): ConvexCodec<T> {\n const validator = zodToConvex(schema)\n\n return {\n validator,\n encode: (value: T) => toConvexJS(schema, value),\n decode: (value: any) => fromConvexJS(value, schema),\n pick: <K extends keyof T>(keys: K[] | Record<K, true>) => {\n if (!(schema instanceof z.ZodObject)) {\n throw new Error('pick() can only be called on object schemas')\n }\n // Handle both array and object formats\n const pickObj = Array.isArray(keys)\n ? keys.reduce((acc, k) => ({ ...acc, [k]: true }), {} as any)\n : keys\n const pickedSchema = schema.pick(pickObj as any)\n return convexCodec(pickedSchema) as ConvexCodec<Pick<T, K>>\n }\n }\n}\n\n// Convert JS values to Convex-safe JSON (handle Dates, remove undefined)\nexport function toConvexJS(schema?: any, value?: any): any {\n // If no schema provided, do basic conversion\n if (!schema || arguments.length === 1) {\n value = schema\n return basicToConvex(value)\n }\n\n // Use schema-aware conversion\n return schemaToConvex(value, schema)\n}\n\nfunction basicToConvex(value: any): any {\n if (value === undefined) return undefined\n if (value === null) return null\n if (value instanceof Date) return value.getTime()\n\n if (Array.isArray(value)) {\n return value.map(basicToConvex)\n }\n\n if (value && typeof value === 'object') {\n const result: any = {}\n for (const [k, v] of Object.entries(value)) {\n if (v !== undefined) {\n result[k] = basicToConvex(v)\n }\n }\n return result\n }\n\n return value\n}\n\nfunction schemaToConvex(value: any, schema: any): any {\n if (value === undefined || value === null) return value\n\n // Check base codec registry first\n const codec = findBaseCodec(schema)\n if (codec) {\n return codec.toConvex(value, schema)\n }\n\n // Handle wrapper types\n if (\n schema instanceof z.ZodOptional ||\n schema instanceof z.ZodNullable ||\n schema instanceof z.ZodDefault\n ) {\n // Use unwrap() method which is available on these types\n const inner = schema.unwrap()\n return schemaToConvex(value, asZodType(inner))\n }\n\n // Handle Date specifically\n if (schema instanceof z.ZodDate && value instanceof Date) {\n return value.getTime()\n }\n\n // Handle arrays\n if (schema instanceof z.ZodArray) {\n if (!Array.isArray(value)) return value\n return value.map(item => schemaToConvex(item, schema.element))\n }\n\n // Handle objects\n if (schema instanceof z.ZodObject) {\n if (!value || typeof value !== 'object') return value\n const shape = schema.shape\n const result: any = {}\n for (const [k, v] of Object.entries(value)) {\n if (v !== undefined) {\n result[k] = shape[k] ? schemaToConvex(v, shape[k]) : basicToConvex(v)\n }\n }\n return result\n }\n\n // Handle unions\n if (schema instanceof z.ZodUnion) {\n // Try each option to see which one matches\n for (const option of schema.options) {\n try {\n ;(option as any).parse(value) // Validate against this option\n return schemaToConvex(value, option)\n } catch {\n // Try next option\n }\n }\n }\n\n // Handle records\n if (schema instanceof z.ZodRecord) {\n if (!value || typeof value !== 'object') return value\n const result: any = {}\n for (const [k, v] of Object.entries(value)) {\n if (v !== undefined) {\n result[k] = schemaToConvex(v, schema.valueType)\n }\n }\n return result\n }\n\n // Default passthrough\n return basicToConvex(value)\n}\n\n// Convert Convex JSON back to JS values (handle timestamps -> Dates)\nexport function fromConvexJS(value: any, schema: any): any {\n if (value === undefined || value === null) return value\n\n // Check base codec registry first\n const codec = findBaseCodec(schema)\n if (codec) {\n return codec.fromConvex(value, schema)\n }\n\n // Handle wrapper types\n if (\n schema instanceof z.ZodOptional ||\n schema instanceof z.ZodNullable ||\n schema instanceof z.ZodDefault\n ) {\n // Use unwrap() method which is available on these types\n const inner = schema.unwrap()\n return fromConvexJS(value, asZodType(inner))\n }\n\n // Handle Date specifically\n if (schema instanceof z.ZodDate && typeof value === 'number') {\n return new Date(value)\n }\n\n // Check if schema is a Date through effects/transforms\n if (isDateSchema(schema) && typeof value === 'number') {\n return new Date(value)\n }\n\n // Handle arrays\n if (schema instanceof z.ZodArray) {\n if (!Array.isArray(value)) return value\n return value.map(item => fromConvexJS(item, schema.element))\n }\n\n // Handle objects\n if (schema instanceof z.ZodObject) {\n if (!value || typeof value !== 'object') return value\n const shape = schema.shape\n const result: any = {}\n for (const [k, v] of Object.entries(value)) {\n result[k] = shape[k] ? fromConvexJS(v, shape[k]) : v\n }\n return result\n }\n\n // Handle unions\n if (schema instanceof z.ZodUnion) {\n // Try to decode with each option\n for (const option of schema.options) {\n try {\n const decoded = fromConvexJS(value, option)\n ;(option as any).parse(decoded) // Validate the decoded value\n return decoded\n } catch {\n // Try next option\n }\n }\n }\n\n // Handle records\n if (schema instanceof z.ZodRecord) {\n if (!value || typeof value !== 'object') return value\n const result: any = {}\n for (const [k, v] of Object.entries(value)) {\n result[k] = fromConvexJS(v, schema.valueType)\n }\n return result\n }\n\n // Handle effects and transforms\n // Note: ZodPipe doesn't exist in Zod v4, only ZodTransform\n if (schema instanceof z.ZodTransform) {\n // Cannot access inner schema without _def, return value as-is\n return value\n }\n\n return value\n}\n","import { ConvexError } from 'convex/values'\nimport { z } from 'zod'\nimport { getObjectShape } from './mapping'\n\nexport function pick<T extends Record<string, any>, K extends keyof T>(\n obj: T,\n keys: K[]\n): Pick<T, K> {\n const result = {} as Pick<T, K>\n for (const key of keys) {\n if (key in obj) result[key] = obj[key]\n }\n return result\n}\n\n// Typed identity helper for returns schemas\nexport function returnsAs<R extends z.ZodTypeAny>() {\n return <T extends z.input<R>>(v: T) => v\n}\n\n// Format ZodError issues into a compact, consistent structure\nexport function formatZodIssues(\n error: z.ZodError,\n context?: 'args' | 'returns' | 'input' | 'output' | 'codec'\n) {\n return {\n error: 'ZodValidationError',\n context,\n issues: error.issues.map(issue => ({\n path: Array.isArray(issue.path) ? issue.path.join('.') : String(issue.path ?? ''),\n code: issue.code,\n message: issue.message\n })),\n // Keep a flattened snapshot for easier debugging without cyclic refs\n flatten: JSON.parse(JSON.stringify(error.flatten?.() ?? {}))\n }\n}\n\n// Handle Zod validation errors consistently across all wrappers\n// Throws a ConvexError with formatted issues if the error is a ZodError, otherwise re-throws\nexport function handleZodValidationError(\n e: unknown,\n context: 'args' | 'returns' | 'input' | 'output' | 'codec'\n): never {\n if (e instanceof z.ZodError) {\n throw new ConvexError(formatZodIssues(e, context))\n }\n throw e\n}\n\n// Helper: standard Convex paginate() result schema\nexport function zPaginated<T extends z.ZodTypeAny>(item: T) {\n return z.object({\n page: z.array(item),\n isDone: z.boolean(),\n continueCursor: z.string().nullable().optional()\n })\n}\n\n/**\n * Maps Date fields to number fields for docSchema generation.\n * Handles Date, Date.optional(), Date.nullable(), and Date.default() cases.\n * Returns the original field for non-Date types.\n */\nexport function mapDateFieldToNumber(field: z.ZodTypeAny): z.ZodTypeAny {\n // Direct Date field\n if (field instanceof z.ZodDate) {\n return z.number()\n }\n\n // Optional Date field\n if (field instanceof z.ZodOptional && field.unwrap() instanceof z.ZodDate) {\n return z.number().optional()\n }\n\n // Nullable Date field\n if (field instanceof z.ZodNullable && field.unwrap() instanceof z.ZodDate) {\n return z.number().nullable()\n }\n\n // Date with default value\n if (field instanceof z.ZodDefault) {\n const inner = field.removeDefault()\n if (inner instanceof z.ZodDate) {\n return z.number().optional()\n }\n }\n\n // Non-Date field - return as-is\n return field\n}\n\n// Schema picking utilities (moved from pick.ts for consolidation)\ntype Mask = readonly string[] | Record<string, boolean | 1 | true>\n\nfunction toKeys(mask: Mask): string[] {\n if (Array.isArray(mask)) return mask.map(String)\n return Object.keys(mask).filter(k => !!(mask as any)[k])\n}\n\n/**\n * Returns a plain shape object containing only the selected fields.\n * Accepts either a ZodObject or a raw shape object.\n */\nexport function pickShape(\n schemaOrShape: z.ZodObject<any> | Record<string, any>,\n mask: Mask\n): Record<string, any> {\n const keys = toKeys(mask)\n const shape =\n schemaOrShape instanceof z.ZodObject ? getObjectShape(schemaOrShape) : schemaOrShape || {}\n\n const out: Record<string, any> = {}\n for (const k of keys) {\n if (k in shape) out[k] = (shape as any)[k]\n }\n return out\n}\n\n// Builds a fresh Zod object from the selected fields (avoids Zod's .pick())\nexport function safePick(schema: z.ZodObject<any>, mask: Mask): z.ZodObject<any> {\n return z.object(pickShape(schema, mask))\n}\n\n/**\n * Convenience: omit a set of keys by building the complement.\n * Avoids using Zod's .omit() which can cause type depth issues.\n */\nexport function safeOmit(schema: z.ZodObject<any>, mask: Mask): z.ZodObject<any> {\n const shape = getObjectShape(schema)\n const omit = new Set(toKeys(mask))\n const keep = Object.keys(shape).filter(k => !omit.has(k))\n const picked = pickShape(schema, keep)\n return z.object(picked)\n}\n","import {\n type ActionBuilder,\n type ArgsArrayToObject,\n type DefaultFunctionArgs,\n type FunctionVisibility,\n type GenericActionCtx,\n type GenericDataModel,\n type GenericMutationCtx,\n type GenericQueryCtx,\n type MutationBuilder,\n type QueryBuilder\n} from 'convex/server'\nimport { ConvexError, type PropertyValidators } from 'convex/values'\nimport { type Customization, NoOp } from 'convex-helpers/server/customFunctions'\nimport { z } from 'zod'\nimport { fromConvexJS, toConvexJS } from './codec'\nimport { type ZodValidator, zodToConvex, zodToConvexFields } from './mapping'\nimport type { ExtractCtx, ExtractVisibility } from './types'\nimport { handleZodValidationError, pick } from './utils'\n\n// Type helpers for args transformation (from zodV3 example)\ntype OneArgArray<ArgsObject extends DefaultFunctionArgs = DefaultFunctionArgs> = [ArgsObject]\n\n// Simple type conversion from a Convex validator to a Zod validator return type\ntype NullToUndefinedOrNull<T> = T extends null ? T | undefined | void : T\ntype Returns<T> = Promise<NullToUndefinedOrNull<T>> | NullToUndefinedOrNull<T>\n\n// The return value before it's been validated: returned by the handler\ntype ReturnValueInput<ReturnsValidator extends z.ZodTypeAny | ZodValidator | void> = [\n ReturnsValidator\n] extends [z.ZodTypeAny]\n ? Returns<z.input<ReturnsValidator>>\n : [ReturnsValidator] extends [ZodValidator]\n ? Returns<z.input<z.ZodObject<ReturnsValidator>>>\n : any\n\n// The return value after it's been validated: returned to the client\ntype ReturnValueOutput<ReturnsValidator extends z.ZodTypeAny | ZodValidator | void> = [\n ReturnsValidator\n] extends [z.ZodTypeAny]\n ? Returns<z.output<ReturnsValidator>>\n : [ReturnsValidator] extends [ZodValidator]\n ? Returns<z.output<z.ZodObject<ReturnsValidator>>>\n : any\n\n// The args before they've been validated: passed from the client\ntype ArgsInput<ArgsValidator extends ZodValidator | z.ZodObject<any> | void> = [\n ArgsValidator\n] extends [z.ZodObject<any>]\n ? [z.input<ArgsValidator>]\n : [ArgsValidator] extends [ZodValidator]\n ? [z.input<z.ZodObject<ArgsValidator>>]\n : OneArgArray\n\n// The args after they've been validated: passed to the handler\ntype ArgsOutput<ArgsValidator extends ZodValidator | z.ZodObject<any> | void> = [\n ArgsValidator\n] extends [z.ZodObject<any>]\n ? [z.output<ArgsValidator>]\n : [ArgsValidator] extends [ZodValidator]\n ? [z.output<z.ZodObject<ArgsValidator>>]\n : OneArgArray\n\ntype Overwrite<T, U> = Omit<T, keyof U> & U\n\n// Hack to simplify how TypeScript renders object types\ntype Expand<ObjectType extends Record<any, any>> = ObjectType extends Record<any, any>\n ? {\n [Key in keyof ObjectType]: ObjectType[Key]\n }\n : never\n\ntype ArgsForHandlerType<\n OneOrZeroArgs extends [] | [Record<string, any>],\n CustomMadeArgs extends Record<string, any>\n> = CustomMadeArgs extends Record<string, never>\n ? OneOrZeroArgs\n : OneOrZeroArgs extends [infer A]\n ? [Expand<A & CustomMadeArgs>]\n : [CustomMadeArgs]\n\n// Helper type for function registration (from zodV3)\ntype Registration<\n FuncType extends 'query' | 'mutation' | 'action',\n Visibility extends FunctionVisibility,\n Args extends DefaultFunctionArgs,\n Output\n> = FuncType extends 'query'\n ? import('convex/server').RegisteredQuery<Visibility, Args, Output>\n : FuncType extends 'mutation'\n ? import('convex/server').RegisteredMutation<Visibility, Args, Output>\n : import('convex/server').RegisteredAction<Visibility, Args, Output>\n\n/**\n * A builder that customizes a Convex function, whether or not it validates\n * arguments. If the customization requires arguments, however, the resulting\n * builder will require argument validation too.\n *\n * This is our own Zod-aware CustomBuilder type that properly handles Zod validators.\n */\nexport type CustomBuilder<\n FuncType extends 'query' | 'mutation' | 'action',\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n InputCtx,\n Visibility extends FunctionVisibility,\n ExtraArgs extends Record<string, any>\n> = {\n <\n ArgsValidator extends ZodValidator | z.ZodObject<any> | void,\n ReturnsZodValidator extends z.ZodTypeAny | ZodValidator | void = void,\n ReturnValue extends ReturnValueInput<ReturnsZodValidator> = any\n >(\n func:\n | ({\n /**\n * Specify the arguments to the function as a Zod validator.\n */\n args?: ArgsValidator\n handler: (\n ctx: Overwrite<InputCtx, CustomCtx>,\n ...args: ArgsForHandlerType<ArgsOutput<ArgsValidator>, CustomMadeArgs>\n ) => ReturnValue\n /**\n * Validates the value returned by the function.\n * Note: you can't pass an object directly without wrapping it\n * in `z.object()`.\n */\n returns?: ReturnsZodValidator\n /**\n * If true, the function will not be validated by Convex,\n * in case you're seeing performance issues with validating twice.\n */\n skipConvexValidation?: boolean\n } & {\n [key in keyof ExtraArgs as key extends\n | 'args'\n | 'handler'\n | 'skipConvexValidation'\n | 'returns'\n ? never\n : key]: ExtraArgs[key]\n })\n | {\n (\n ctx: Overwrite<InputCtx, CustomCtx>,\n ...args: ArgsForHandlerType<ArgsOutput<ArgsValidator>, CustomMadeArgs>\n ): ReturnValue\n }\n ): Registration<\n FuncType,\n Visibility,\n ArgsArrayToObject<\n CustomArgsValidator extends Record<string, never>\n ? ArgsInput<ArgsValidator>\n : ArgsInput<ArgsValidator> extends [infer A]\n ? [Expand<A & import('convex/values').ObjectType<CustomArgsValidator>>]\n : [import('convex/values').ObjectType<CustomArgsValidator>]\n >,\n ReturnsZodValidator extends void ? ReturnValue : ReturnValueOutput<ReturnsZodValidator>\n >\n}\n\nexport function customFnBuilder<\n Ctx extends Record<string, any>,\n Builder extends (fn: any) => any,\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n builder: Builder,\n customization: Customization<Ctx, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n) {\n const customInput = customization.input ?? NoOp.input\n const inputArgs = customization.args ?? NoOp.args\n\n return function customBuilder(fn: any): any {\n const { args, handler = fn, returns: maybeObject, ...extra } = fn\n const skipConvexValidation = fn.skipConvexValidation ?? false\n\n const returns =\n maybeObject && !(maybeObject instanceof z.ZodType) ? z.object(maybeObject) : maybeObject\n // Only generate Convex return validator when not skipping Convex validation\n const returnValidator =\n returns && !skipConvexValidation ? { returns: zodToConvex(returns) } : undefined\n\n if (args) {\n let argsValidator = args\n let argsSchema: z.ZodObject<any>\n\n if (argsValidator instanceof z.ZodType) {\n if (argsValidator instanceof z.ZodObject) {\n argsSchema = argsValidator\n argsValidator = argsValidator.shape // Get the raw shape for zodToConvexFields\n } else {\n throw new Error(\n 'Unsupported non-object Zod schema for args; please provide an args schema using z.object({...}), e.g. z.object({ foo: z.string() })'\n )\n }\n } else {\n // It's a raw shape object with Zod validators as values\n argsSchema = z.object(argsValidator)\n }\n\n // Only generate Convex args validator when not skipping Convex validation\n const convexArgs = skipConvexValidation\n ? inputArgs\n : { ...zodToConvexFields(argsValidator), ...inputArgs }\n\n return builder({\n args: convexArgs,\n ...returnValidator,\n handler: async (ctx: Ctx, allArgs: any) => {\n const added: any = await customInput(\n ctx,\n pick(allArgs, Object.keys(inputArgs)) as any,\n extra\n )\n const argKeys = Object.keys(argsValidator)\n const rawArgs = pick(allArgs, argKeys)\n const decoded = fromConvexJS(rawArgs, argsSchema)\n // Always run Zod validation, regardless of skipConvexValidation\n const parsed = argsSchema.safeParse(decoded)\n if (!parsed.success) {\n handleZodValidationError(parsed.error, 'args')\n }\n const finalCtx = { ...ctx, ...(added?.ctx ?? {}) }\n const baseArgs = parsed.data as Record<string, unknown>\n const addedArgs = (added?.args as Record<string, unknown>) ?? {}\n const finalArgs = { ...baseArgs, ...addedArgs }\n const ret = await handler(finalCtx, finalArgs)\n // Always run Zod return validation when returns schema is provided\n if (returns) {\n let validated: any\n try {\n validated = (returns as z.ZodTypeAny).parse(ret)\n } catch (e) {\n handleZodValidationError(e, 'returns')\n }\n if (added?.onSuccess) {\n await added.onSuccess({\n ctx,\n args: parsed.data,\n result: validated\n })\n }\n return toConvexJS(returns as z.ZodTypeAny, validated)\n }\n if (added?.onSuccess) {\n await added.onSuccess({ ctx, args: parsed.data, result: ret })\n }\n return ret\n }\n })\n }\n return builder({\n args: inputArgs,\n ...returnValidator,\n handler: async (ctx: Ctx, allArgs: any) => {\n const added: any = await customInput(\n ctx,\n pick(allArgs, Object.keys(inputArgs)) as any,\n extra\n )\n const finalCtx = { ...ctx, ...(added?.ctx ?? {}) }\n const baseArgs = allArgs as Record<string, unknown>\n const addedArgs = (added?.args as Record<string, unknown>) ?? {}\n const finalArgs = { ...baseArgs, ...addedArgs }\n const ret = await handler(finalCtx, finalArgs)\n // Always run Zod return validation when returns schema is provided\n if (returns) {\n let validated: any\n try {\n validated = (returns as z.ZodTypeAny).parse(ret)\n } catch (e) {\n handleZodValidationError(e, 'returns')\n }\n if (added?.onSuccess) {\n await added.onSuccess({ ctx, args: allArgs, result: validated })\n }\n return toConvexJS(returns as z.ZodTypeAny, validated)\n }\n if (added?.onSuccess) {\n await added.onSuccess({ ctx, args: allArgs, result: ret })\n }\n return ret\n }\n })\n }\n}\n\n// Overload 1: With constraint - preferred to preserve DataModel types\nexport function zCustomQuery<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Visibility extends FunctionVisibility,\n DataModel extends GenericDataModel,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n query: QueryBuilder<DataModel, Visibility>,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'query',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n GenericQueryCtx<DataModel>,\n Visibility,\n ExtraArgs\n>\n\n// Overload 2: No constraint + decoupled ctx\nexport function zCustomQuery<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Visibility extends FunctionVisibility,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n query: QueryBuilder<any, Visibility>,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'query',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n any,\n Visibility,\n ExtraArgs\n>\n\n// Implementation\nexport function zCustomQuery<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Visibility extends FunctionVisibility,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n query: QueryBuilder<any, Visibility>,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n) {\n // Implementation deliberately uses 'any' ctx to preserve overload behavior\n // while avoiding a GenericDataModel constraint at the implementation level.\n return customFnBuilder<\n any,\n typeof query,\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n ExtraArgs\n >(query as any, customization as any) as any\n}\n\n// Overload 1: With constraint - preferred to preserve DataModel types\nexport function zCustomMutation<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Builder extends (fn: any) => any,\n Visibility extends FunctionVisibility = 'public',\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n mutation: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'mutation',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n ExtractCtx<Builder>,\n Visibility,\n ExtraArgs\n>\n\n// Implementation\nexport function zCustomMutation<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Builder extends (fn: any) => any,\n _Visibility extends FunctionVisibility = 'public',\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n mutation: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n) {\n return customFnBuilder<any, Builder, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>(\n mutation as any,\n customization as any\n ) as any\n}\n\n// Overload 1: With constraint - preferred to preserve DataModel types\nexport function zCustomAction<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Builder extends (fn: any) => any,\n Visibility extends FunctionVisibility = 'public',\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n action: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'action',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n ExtractCtx<Builder>,\n Visibility,\n ExtraArgs\n>\n\n// Implementation\nexport function zCustomAction<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Builder extends (fn: any) => any,\n _Visibility extends FunctionVisibility = 'public',\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n action: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n) {\n return customFnBuilder<any, Builder, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>(\n action as any,\n customization as any\n ) as any\n}\n","import type {\n FunctionVisibility,\n RegisteredAction,\n RegisteredMutation,\n RegisteredQuery\n} from 'convex/server'\nimport { ConvexError } from 'convex/values'\nimport { z } from 'zod'\nimport { fromConvexJS, toConvexJS } from './codec'\nimport { getObjectShape, zodToConvex, zodToConvexFields } from './mapping'\n// Typing helpers to keep handler args/returns precise without deep remapping\nimport type {\n ExtractCtx,\n ExtractVisibility,\n InferHandlerReturns,\n InferReturns,\n ZodToConvexArgs\n} from './types'\nimport { handleZodValidationError } from './utils'\n\n// Cache to avoid re-checking the same schema\nconst customCheckCache = new WeakMap<z.ZodTypeAny, boolean>()\n\n/**\n * Check if a schema contains z.custom types (runtime check).\n * Includes depth limit to prevent stack overflow on deeply nested schemas.\n */\nfunction containsCustom(schema: z.ZodTypeAny, maxDepth = 50, currentDepth = 0): boolean {\n // Check cache first\n const cached = customCheckCache.get(schema)\n if (cached !== undefined) {\n return cached\n }\n\n // Prevent stack overflow on deeply nested schemas\n if (currentDepth > maxDepth) {\n return false\n }\n\n let result = false\n\n // Zod v4 exports ZodCustom and instances expose `schema.type === \"custom\"`.\n if (schema instanceof z.ZodCustom) {\n result = true\n } else if (schema instanceof z.ZodUnion) {\n result = (schema.options as z.ZodTypeAny[]).some(opt =>\n containsCustom(opt, maxDepth, currentDepth + 1)\n )\n } else if (schema instanceof z.ZodOptional) {\n result = containsCustom(schema.unwrap() as z.ZodTypeAny, maxDepth, currentDepth + 1)\n } else if (schema instanceof z.ZodNullable) {\n result = containsCustom(schema.unwrap() as z.ZodTypeAny, maxDepth, currentDepth + 1)\n } else if (schema instanceof z.ZodDefault) {\n result = containsCustom(schema.removeDefault() as z.ZodTypeAny, maxDepth, currentDepth + 1)\n }\n\n customCheckCache.set(schema, result)\n return result\n}\n\nexport function zQuery<\n Builder extends (fn: any) => any,\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n>(\n query: Builder,\n input: A,\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>,\n options?: { returns?: R }\n): RegisteredQuery<Visibility, ZodToConvexArgs<A>, Promise<InferReturns<R>>> {\n let zodSchema: z.ZodTypeAny\n let args: Record<string, any>\n if (input instanceof z.ZodObject) {\n const zodObj = input as z.ZodObject<any>\n zodSchema = zodObj\n args = zodToConvexFields(getObjectShape(zodObj))\n } else if (input instanceof z.ZodType) {\n // Single schema → normalize to { value }\n zodSchema = z.object({ value: input as any })\n args = { value: zodToConvex(input as any) }\n } else {\n zodSchema = z.object(input as Record<string, any>)\n args = zodToConvexFields(input as Record<string, any>)\n }\n // Skip returns validator for schemas with custom types to avoid type depth issues\n const returns =\n options?.returns && !containsCustom(options.returns) ? zodToConvex(options.returns) : undefined\n\n return query({\n args,\n returns,\n handler: async (ctx: any, argsObject: unknown) => {\n const decoded = fromConvexJS(argsObject, zodSchema)\n let parsed: any\n try {\n parsed = zodSchema.parse(decoded) as any\n } catch (e) {\n handleZodValidationError(e, 'args')\n }\n const raw = await handler(ctx, parsed)\n if (options?.returns) {\n try {\n const validated = (options.returns as z.ZodTypeAny).parse(raw)\n return toConvexJS(options.returns as z.ZodTypeAny, validated)\n } catch (e) {\n handleZodValidationError(e, 'returns')\n }\n }\n // Fallback: ensure Convex-safe return values (e.g., Date → timestamp)\n return toConvexJS(raw) as any\n }\n }) as any\n}\n\nexport function zInternalQuery<\n Builder extends (fn: any) => any,\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n>(\n internalQuery: Builder,\n input: A,\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>,\n options?: { returns?: R }\n): RegisteredQuery<Visibility, ZodToConvexArgs<A>, Promise<InferReturns<R>>> {\n return zQuery(internalQuery, input, handler, options)\n}\n\nexport function zMutation<\n Builder extends (fn: any) => any,\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n>(\n mutation: Builder,\n input: A,\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>,\n options?: { returns?: R }\n): RegisteredMutation<Visibility, ZodToConvexArgs<A>, Promise<InferReturns<R>>> {\n let zodSchema: z.ZodTypeAny\n let args: Record<string, any>\n if (input instanceof z.ZodObject) {\n const zodObj = input as z.ZodObject<any>\n zodSchema = zodObj\n args = zodToConvexFields(getObjectShape(zodObj))\n } else if (input instanceof z.ZodType) {\n zodSchema = z.object({ value: input as any })\n args = { value: zodToConvex(input as any) }\n } else {\n zodSchema = z.object(input as Record<string, any>)\n args = zodToConvexFields(input as Record<string, any>)\n }\n // Skip returns validator for schemas with custom types to avoid type depth issues\n const returns =\n options?.returns && !containsCustom(options.returns) ? zodToConvex(options.returns) : undefined\n\n return mutation({\n args,\n returns,\n handler: async (ctx: any, argsObject: unknown) => {\n const decoded = fromConvexJS(argsObject, zodSchema)\n let parsed: any\n try {\n parsed = zodSchema.parse(decoded) as any\n } catch (e) {\n handleZodValidationError(e, 'args')\n }\n const raw = await handler(ctx, parsed)\n if (options?.returns) {\n try {\n const validated = (options.returns as z.ZodTypeAny).parse(raw)\n return toConvexJS(options.returns as z.ZodTypeAny, validated)\n } catch (e) {\n handleZodValidationError(e, 'returns')\n }\n }\n // Fallback: ensure Convex-safe return values (e.g., Date → timestamp)\n return toConvexJS(raw) as any\n }\n }) as any\n}\n\nexport function zInternalMutation<\n Builder extends (fn: any) => any,\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n>(\n internalMutation: Builder,\n input: A,\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>,\n options?: { returns?: R }\n): RegisteredMutation<Visibility, ZodToConvexArgs<A>, Promise<InferReturns<R>>> {\n return zMutation(internalMutation, input, handler, options)\n}\n\nexport function zAction<\n Builder extends (fn: any) => any,\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n>(\n action: Builder,\n input: A,\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>,\n options?: { returns?: R }\n): RegisteredAction<Visibility, ZodToConvexArgs<A>, Promise<InferReturns<R>>> {\n let zodSchema: z.ZodTypeAny\n let args: Record<string, any>\n if (input instanceof z.ZodObject) {\n const zodObj = input as z.ZodObject<any>\n zodSchema = zodObj\n args = zodToConvexFields(getObjectShape(zodObj))\n } else if (input instanceof z.ZodType) {\n zodSchema = z.object({ value: input as any })\n args = { value: zodToConvex(input as any) }\n } else {\n zodSchema = z.object(input as Record<string, any>)\n args = zodToConvexFields(input as Record<string, any>)\n }\n // Skip returns validator for schemas with custom types to avoid type depth issues\n const returns =\n options?.returns && !containsCustom(options.returns) ? zodToConvex(options.returns) : undefined\n\n return action({\n args,\n returns,\n handler: async (ctx: any, argsObject: unknown) => {\n const decoded = fromConvexJS(argsObject, zodSchema)\n let parsed: any\n try {\n parsed = zodSchema.parse(decoded) as any\n } catch (e) {\n handleZodValidationError(e, 'args')\n }\n const raw = await handler(ctx, parsed)\n if (options?.returns) {\n try {\n const validated = (options.returns as z.ZodTypeAny).parse(raw)\n return toConvexJS(options.returns as z.ZodTypeAny, validated)\n } catch (e) {\n handleZodValidationError(e, 'returns')\n }\n }\n // Fallback: ensure Convex-safe return values (e.g., Date → timestamp)\n return toConvexJS(raw) as any\n }\n }) as any\n}\n\nexport function zInternalAction<\n Builder extends (fn: any) => any,\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n>(\n internalAction: Builder,\n input: A,\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>,\n options?: { returns?: R }\n): RegisteredAction<Visibility, ZodToConvexArgs<A>, Promise<InferReturns<R>>> {\n return zAction(internalAction, input, handler, options) as any\n}\n","import type {\n FunctionVisibility,\n RegisteredAction,\n RegisteredMutation,\n RegisteredQuery\n} from 'convex/server'\nimport type { PropertyValidators } from 'convex/values'\nimport type { Customization } from 'convex-helpers/server/customFunctions'\nimport { z } from 'zod'\nimport { type CustomBuilder, customFnBuilder } from './custom'\nimport type {\n ExtractCtx,\n ExtractVisibility,\n InferHandlerReturns,\n InferReturns,\n ZodToConvexArgs\n} from './types'\nimport { zAction, zMutation, zQuery } from './wrappers'\n\n/**\n * Creates a reusable query builder from a Convex query builder.\n * Returns a builder function that accepts Convex-style config objects with args, handler, and returns.\n *\n * @example\n * ```ts\n * import { query } from './_generated/server'\n * import { zQueryBuilder } from 'zodvex'\n *\n * // Create a reusable builder\n * export const zq = zQueryBuilder(query)\n *\n * // Use it with Convex-style object syntax\n * export const getUser = zq({\n * args: { id: z.string() },\n * handler: async (ctx, { id }) => {\n * return ctx.db.get(id)\n * }\n * })\n * ```\n */\nexport function zQueryBuilder<Builder extends (fn: any) => any>(builder: Builder) {\n return <\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n >(config: {\n args?: A\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A extends undefined ? Record<string, never> : A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>\n returns?: R\n }): RegisteredQuery<\n Visibility,\n ZodToConvexArgs<A extends undefined ? Record<string, never> : A>,\n Promise<InferReturns<R>>\n > => {\n return zQuery(builder, config.args ?? ({} as any), config.handler, {\n returns: config.returns\n }) as any\n }\n}\n\n/**\n * Creates a reusable mutation builder from a Convex mutation builder.\n * Returns a builder function that accepts Convex-style config objects with args, handler, and returns.\n *\n * @example\n * ```ts\n * import { mutation } from './_generated/server'\n * import { zMutationBuilder } from 'zodvex'\n *\n * // Create a reusable builder\n * export const zm = zMutationBuilder(mutation)\n *\n * // Use it with Convex-style object syntax\n * export const updateUser = zm({\n * args: { id: z.string(), name: z.string() },\n * handler: async (ctx, { id, name }) => {\n * return ctx.db.patch(id, { name })\n * }\n * })\n * ```\n */\nexport function zMutationBuilder<Builder extends (fn: any) => any>(builder: Builder) {\n return <\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n >(config: {\n args?: A\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A extends undefined ? Record<string, never> : A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>\n returns?: R\n }): RegisteredMutation<\n Visibility,\n ZodToConvexArgs<A extends undefined ? Record<string, never> : A>,\n Promise<InferReturns<R>>\n > => {\n return zMutation(builder, config.args ?? ({} as any), config.handler, {\n returns: config.returns\n }) as any\n }\n}\n\n/**\n * Creates a reusable action builder from a Convex action builder.\n * Returns a builder function that accepts Convex-style config objects with args, handler, and returns.\n *\n * @example\n * ```ts\n * import { action } from './_generated/server'\n * import { zActionBuilder } from 'zodvex'\n *\n * // Create a reusable builder\n * export const za = zActionBuilder(action)\n *\n * // Use it with Convex-style object syntax\n * export const sendEmail = za({\n * args: { to: z.string().email(), subject: z.string() },\n * handler: async (ctx, { to, subject }) => {\n * // Send email\n * }\n * })\n * ```\n */\nexport function zActionBuilder<Builder extends (fn: any) => any>(builder: Builder) {\n return <\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n >(config: {\n args?: A\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A extends undefined ? Record<string, never> : A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>\n returns?: R\n }): RegisteredAction<\n Visibility,\n ZodToConvexArgs<A extends undefined ? Record<string, never> : A>,\n Promise<InferReturns<R>>\n > => {\n return zAction(builder, config.args ?? ({} as any), config.handler, {\n returns: config.returns\n }) as any\n }\n}\n\n/**\n * Creates a custom query builder with context injection from a Convex query builder.\n * Allows you to add custom context (like auth, permissions, etc.) to your queries.\n *\n * @example\n * ```ts\n * import { type QueryCtx, query } from './_generated/server'\n * import { zCustomQueryBuilder, customCtx } from 'zodvex'\n *\n * // Create a builder with auth context\n * export const authQuery = zCustomQueryBuilder(\n * query,\n * customCtx(async (ctx: QueryCtx) => {\n * const user = await getUserOrThrow(ctx)\n * return { user }\n * })\n * )\n *\n * // Use it with automatic user injection\n * export const getMyProfile = authQuery({\n * args: {},\n * handler: async (ctx) => {\n * // ctx.user is automatically available\n * return ctx.db.get(ctx.user._id)\n * }\n * })\n * ```\n */\nexport function zCustomQueryBuilder<\n Builder extends (fn: any) => any,\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n query: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'query',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n ExtractCtx<Builder>,\n Visibility,\n ExtraArgs\n> {\n return customFnBuilder<any, Builder, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>(\n query as any,\n customization as any\n ) as any\n}\n\n/**\n * Creates a custom mutation builder with context injection from a Convex mutation builder.\n * Allows you to add custom context (like auth, permissions, etc.) to your mutations.\n *\n * @example\n * ```ts\n * import { type MutationCtx, mutation } from './_generated/server'\n * import { zCustomMutationBuilder, customCtx } from 'zodvex'\n *\n * // Create a builder with auth context\n * export const authMutation = zCustomMutationBuilder(\n * mutation,\n * customCtx(async (ctx: MutationCtx) => {\n * const user = await getUserOrThrow(ctx)\n * return { user }\n * })\n * )\n *\n * // Use it with automatic user injection\n * export const updateProfile = authMutation({\n * args: { name: z.string() },\n * handler: async (ctx, { name }) => {\n * // ctx.user is automatically available\n * await ctx.db.patch(ctx.user._id, { name })\n * }\n * })\n * ```\n */\nexport function zCustomMutationBuilder<\n Builder extends (fn: any) => any,\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n mutation: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'mutation',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n ExtractCtx<Builder>,\n Visibility,\n ExtraArgs\n> {\n return customFnBuilder<any, Builder, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>(\n mutation as any,\n customization as any\n ) as any\n}\n\n/**\n * Creates a custom action builder with context injection from a Convex action builder.\n * Allows you to add custom context (like auth, permissions, etc.) to your actions.\n *\n * @example\n * ```ts\n * import { type ActionCtx, action } from './_generated/server'\n * import { zCustomActionBuilder, customCtx } from 'zodvex'\n *\n * // Create a builder with auth context\n * export const authAction = zCustomActionBuilder(\n * action,\n * customCtx(async (ctx: ActionCtx) => {\n * const identity = await ctx.auth.getUserIdentity()\n * if (!identity) throw new Error('Unauthorized')\n * return { userId: identity.subject }\n * })\n * )\n *\n * // Use it with automatic auth injection\n * export const sendEmail = authAction({\n * args: { to: z.string().email() },\n * handler: async (ctx, { to }) => {\n * // ctx.userId is automatically available\n * await sendEmailService(to, ctx.userId)\n * }\n * })\n * ```\n */\nexport function zCustomActionBuilder<\n Builder extends (fn: any) => any,\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n action: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'action',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n ExtractCtx<Builder>,\n Visibility,\n ExtraArgs\n> {\n return customFnBuilder<any, Builder, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>(\n action as any,\n customization as any\n ) as any\n}\n","import { defineTable } from 'convex/server'\nimport type { GenericId } from 'convex/values'\nimport { Table } from 'convex-helpers/server'\nimport { z } from 'zod'\nimport { zid } from './ids'\nimport { type ConvexValidatorFromZodFieldsAuto, zodToConvex, zodToConvexFields } from './mapping'\n\n/**\n * Adds Convex system fields (_id, _creationTime) to a Zod schema.\n *\n * For object schemas: extends with system fields\n * For union schemas: adds system fields to each variant\n *\n * @param tableName - The Convex table name\n * @param schema - The Zod schema (object or union)\n * @returns Schema with system fields added\n */\nexport function addSystemFields<T extends string, S extends z.ZodTypeAny>(\n tableName: T,\n schema: S\n): z.ZodTypeAny {\n // Handle union schemas - add system fields to each variant\n if (schema instanceof z.ZodUnion || schema instanceof z.ZodDiscriminatedUnion) {\n const options = (schema as z.ZodUnion<any>).options.map((variant: z.ZodTypeAny) => {\n if (variant instanceof z.ZodObject) {\n return variant.extend({\n _id: zid(tableName),\n _creationTime: z.number()\n })\n }\n // Non-object variants are returned as-is (shouldn't happen in practice)\n return variant\n })\n return z.union(options as any)\n }\n\n // Handle object schemas\n if (schema instanceof z.ZodObject) {\n return schema.extend({\n _id: zid(tableName),\n _creationTime: z.number()\n })\n }\n\n // Fallback: return schema as-is\n return schema\n}\n\n// Helper to create a Zod schema for a Convex document\nexport function zodDoc<\n TableName extends string,\n Shape extends z.ZodRawShape,\n Schema extends z.ZodObject<Shape>\n>(\n tableName: TableName,\n schema: Schema\n): z.ZodObject<\n Shape & {\n _id: ReturnType<typeof zid<TableName>>\n _creationTime: z.ZodNumber\n }\n> {\n // Use extend to preserve the original schema's type information\n return schema.extend({\n _id: zid(tableName),\n _creationTime: z.number()\n }) as any\n}\n\n// Helper to create nullable doc schema\nexport function zodDocOrNull<\n TableName extends string,\n Shape extends z.ZodRawShape,\n Schema extends z.ZodObject<Shape>\n>(tableName: TableName, schema: Schema) {\n return z.union([zodDoc(tableName, schema), z.null()])\n}\n\n/**\n * Helper to detect if input is an object shape (plain object with Zod validators)\n */\nfunction isObjectShape(input: any): input is Record<string, z.ZodTypeAny> {\n // Check if it's a plain object (not a Zod instance)\n if (!input || typeof input !== 'object') return false\n\n // If it's a Zod instance, it's not an object shape\n if (input instanceof z.ZodType) return false\n\n // Check if all values are Zod types\n for (const key in input) {\n if (!(input[key] instanceof z.ZodType)) {\n return false\n }\n }\n\n return true\n}\n\n/**\n * Defines a Convex table using either:\n * - A raw Zod shape (an object mapping field names to Zod types)\n * - A Zod union schema (for polymorphic tables)\n *\n * For object shapes, this function intentionally accepts a raw shape instead of a ZodObject instance.\n * Accepting raw shapes allows TypeScript to infer field types more accurately and efficiently,\n * leading to better type inference and performance throughout the codebase.\n *\n * For union schemas, this enables polymorphic tables with discriminated unions.\n *\n * Returns the Table definition along with Zod schemas for documents and arrays.\n *\n * @param name - The table name\n * @param schemaOrShape - Either a raw object shape or a Zod union schema\n * @returns A Table with attached helpers (shape, schema, zDoc, docArray, withSystemFields)\n *\n * @example Object shape\n * ```ts\n * const Users = zodTable('users', {\n * name: z.string(),\n * email: z.string().email(),\n * age: z.number().optional()\n * })\n *\n * // Use in schema\n * export default defineSchema({ users: Users.table })\n *\n * // Use for return types\n * export const getUsers = zQuery(query, {},\n * async (ctx) => ctx.db.query('users').collect(),\n * { returns: Users.docArray }\n * )\n * ```\n *\n * @example Union schema (polymorphic table)\n * ```ts\n * const shapeSchema = z.union([\n * z.object({ kind: z.literal('circle'), r: z.number() }),\n * z.object({ kind: z.literal('rectangle'), width: z.number() })\n * ])\n *\n * const Shapes = zodTable('shapes', shapeSchema)\n *\n * // Use in schema\n * export default defineSchema({ shapes: Shapes.table })\n *\n * // Use for return types with system fields\n * export const getShapes = zQuery(query, {},\n * async (ctx) => ctx.db.query('shapes').collect(),\n * { returns: Shapes.docArray }\n * )\n * ```\n */\nexport function zodTable<TableName extends string, Shape extends Record<string, z.ZodTypeAny>>(\n name: TableName,\n shape: Shape\n): ReturnType<typeof Table<any, TableName>> & {\n shape: Shape\n zDoc: z.ZodObject<\n Shape & {\n _id: ReturnType<typeof zid<TableName>>\n _creationTime: z.ZodNumber\n }\n >\n docArray: z.ZodArray<\n z.ZodObject<\n Shape & {\n _id: ReturnType<typeof zid<TableName>>\n _creationTime: z.ZodNumber\n }\n >\n >\n}\n\nexport function zodTable<TableName extends string, Schema extends z.ZodTypeAny>(\n name: TableName,\n schema: Schema\n): {\n table: ReturnType<typeof defineTable>\n tableName: TableName\n validator: ReturnType<typeof zodToConvex<Schema>>\n schema: Schema\n docArray: z.ZodArray<ReturnType<typeof addSystemFields<TableName, Schema>>>\n withSystemFields: () => ReturnType<typeof addSystemFields<TableName, Schema>>\n}\n\nexport function zodTable<\n TableName extends string,\n SchemaOrShape extends z.ZodTypeAny | Record<string, z.ZodTypeAny>\n>(name: TableName, schemaOrShape: SchemaOrShape): any {\n // Detect if it's an object shape or a schema\n if (isObjectShape(schemaOrShape)) {\n // Original object shape logic\n const shape = schemaOrShape as Record<string, z.ZodTypeAny>\n\n // Convert fields with proper types\n const convexFields = zodToConvexFields(shape) as ConvexValidatorFromZodFieldsAuto<typeof shape>\n\n // Create the Table from convex-helpers with explicit type\n const table = Table<ConvexValidatorFromZodFieldsAuto<typeof shape>, TableName>(\n name,\n convexFields\n )\n\n // Create zDoc schema with system fields\n const zDoc = zodDoc(name, z.object(shape))\n\n // Create docArray helper for return types\n const docArray = z.array(zDoc)\n\n // Attach everything for comprehensive usage\n return Object.assign(table, {\n shape,\n zDoc,\n docArray\n })\n } else {\n // Union or other schema type logic\n const schema = schemaOrShape as z.ZodTypeAny\n\n // Convert schema to Convex validator\n const convexValidator = zodToConvex(schema)\n\n // For unions, use defineTable directly (not Table helper which expects object fields)\n // Note: TypeScript types don't reflect it, but Convex supports union validators in tables\n const table = defineTable(convexValidator as any)\n\n // Create document schema with system fields\n const withFields = addSystemFields(name, schema)\n\n // Create docArray helper\n const docArray = z.array(withFields)\n\n // Attach helpers for union tables\n // Return structure similar to Table() but without fields-based helpers\n return {\n table,\n tableName: name,\n validator: convexValidator,\n schema,\n docArray,\n withSystemFields: () => addSystemFields(name, schema)\n }\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/ids.ts","../src/registry.ts","../src/mapping/handlers/enum.ts","../src/mapping/handlers/nullable.ts","../src/mapping/handlers/record.ts","../src/mapping/handlers/union.ts","../src/mapping/utils.ts","../src/mapping/core.ts","../src/codec.ts","../src/utils.ts","../src/custom.ts","../src/wrappers.ts","../src/builders.ts","../src/tables.ts"],"names":["z","v","zodToConvexInternal","metadata","asZodType"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * IDs + registry for Convex + Zod v4\n */\n\nimport type { GenericId } from 'convex/values'\nimport { z } from 'zod'\n\n// Simple registry for metadata\nconst metadata = new WeakMap<z.ZodTypeAny, any>()\n\nexport const registryHelpers = {\n getMetadata: (type: z.ZodTypeAny) => metadata.get(type),\n setMetadata: (type: z.ZodTypeAny, meta: any) => metadata.set(type, meta)\n}\n\n/**\n * Create a Zod validator for a Convex Id\n *\n * Compatible with AI SDK and other tools that don't support transforms.\n * Uses type-level branding instead of runtime transforms for GenericId<T> compatibility.\n *\n * @param tableName - The Convex table name for this ID\n * @returns A Zod string validator typed as GenericId<TableName>\n */\nexport function zid<TableName extends string>(\n tableName: TableName\n): z.ZodType<GenericId<TableName>> & { _tableName: TableName } {\n // Create base string validator with refinement (no transform or brand)\n const baseSchema = z\n .string()\n .refine(val => typeof val === 'string' && val.length > 0, {\n message: `Invalid ID for table \"${tableName}\"`\n })\n // Add a human-readable marker for client-side introspection utilities\n // used in apps/native (e.g., to detect relationship fields in dynamic forms).\n .describe(`convexId:${tableName}`)\n\n // Store metadata for registry lookup so mapping can convert to v.id(tableName)\n registryHelpers.setMetadata(baseSchema, {\n isConvexId: true,\n tableName\n })\n\n // Add the tableName property for type-level detection\n const branded = baseSchema as any\n branded._tableName = tableName\n\n // Type assertion provides GenericId<TableName> typing without runtime transform\n // This maintains type safety while being compatible with AI SDK and similar tools\n return branded as z.ZodType<GenericId<TableName>> & { _tableName: TableName }\n}\n\nexport type Zid<TableName extends string> = ReturnType<typeof zid<TableName>>\n","import { v } from 'convex/values'\nimport { z } from 'zod'\n\n// Registry for base type codecs\ntype BaseCodec = {\n check: (schema: any) => boolean\n toValidator: (schema: any) => any\n fromConvex: (value: any, schema: any) => any\n toConvex: (value: any, schema: any) => any\n}\n\nconst baseCodecs: BaseCodec[] = []\n\nexport function registerBaseCodec(codec: BaseCodec): void {\n baseCodecs.unshift(codec) // Add to front for priority\n}\n\nexport function findBaseCodec(schema: any): BaseCodec | undefined {\n return baseCodecs.find(codec => codec.check(schema))\n}\n\n// Built-in codec for Date\nregisterBaseCodec({\n check: schema => schema instanceof z.ZodDate,\n toValidator: () => v.float64(),\n fromConvex: value => {\n if (typeof value === 'number') {\n return new Date(value)\n }\n return value\n },\n toConvex: value => {\n if (value instanceof Date) {\n return value.getTime()\n }\n return value\n }\n})\n\n// Helper to convert Zod's internal types to ZodTypeAny\nfunction asZodType<T>(schema: T): z.ZodTypeAny {\n return schema as unknown as z.ZodTypeAny\n}\n\n// Helper to check if a schema is a Date type through the registry\nexport function isDateSchema(schema: any): boolean {\n if (schema instanceof z.ZodDate) return true\n\n // Check through optional/nullable (these have public unwrap())\n if (schema instanceof z.ZodOptional || schema instanceof z.ZodNullable) {\n return isDateSchema(asZodType(schema.unwrap()))\n }\n\n // Cannot check transforms/pipes without _def access\n // This is a limitation of using only public APIs\n\n return false\n}\n\n// ============================================================================\n// JSON Schema Override Support\n// ============================================================================\n// Zod's toJSONSchema doesn't support transforms, brands, and other \"unrepresentable\"\n// types by default. This module provides overrides for zodvex-managed types\n// so they can be used with AI SDKs and other JSON Schema-based tools.\n\n/**\n * Checks if a schema is a zid (Convex ID) schema by looking at its description.\n * zid schemas are marked with \"convexId:{tableName}\" in their description.\n */\nexport function isZidSchema(schema: z.ZodTypeAny): boolean {\n const description = schema.description\n return typeof description === 'string' && description.startsWith('convexId:')\n}\n\n/**\n * Extracts the table name from a zid schema's description.\n * Returns undefined if not a zid schema.\n */\nexport function getZidTableName(schema: z.ZodTypeAny): string | undefined {\n const description = schema.description\n if (typeof description === 'string' && description.startsWith('convexId:')) {\n return description.slice('convexId:'.length)\n }\n return undefined\n}\n\n/**\n * Context object passed to the JSON Schema override function.\n * Uses 'any' types for compatibility with Zod's internal types.\n */\nexport interface JSONSchemaOverrideContext {\n zodSchema: any // Zod's internal $ZodTypes\n jsonSchema: any // Zod's JSONSchema.BaseSchema\n}\n\n/**\n * Override function for z.toJSONSchema that handles zodvex-managed types.\n *\n * Handles:\n * - zid schemas: Converts to { type: \"string\" } with convexId format\n * - z.date(): Converts to { type: \"string\", format: \"date-time\" }\n *\n * @example\n * ```ts\n * import { z } from 'zod'\n * import { zid, zodvexJSONSchemaOverride } from 'zodvex'\n *\n * const schema = z.object({\n * userId: zid('users'),\n * name: z.string()\n * })\n *\n * const jsonSchema = z.toJSONSchema(schema, {\n * unrepresentable: 'any',\n * override: zodvexJSONSchemaOverride\n * })\n * // => { type: \"object\", properties: { userId: { type: \"string\" }, name: { type: \"string\" } } }\n * ```\n */\nexport function zodvexJSONSchemaOverride(ctx: JSONSchemaOverrideContext): void {\n const { zodSchema, jsonSchema } = ctx\n\n // Handle zid schemas (transforms with convexId description)\n if (isZidSchema(zodSchema)) {\n const tableName = getZidTableName(zodSchema)\n // Set our properties - don't clear existing ones set by user overrides\n // When unrepresentable: 'any', Zod already gives us {} so no clearing needed\n jsonSchema.type = 'string'\n if (tableName) {\n jsonSchema.format = `convex-id:${tableName}`\n }\n // Preserve the description from .describe() - this is what the LLM sees\n if (zodSchema.description) {\n jsonSchema.description = zodSchema.description\n }\n return\n }\n\n // Handle z.date() - convert to ISO 8601 string format\n // Zod v4 passes real schema instances here (ZodDate has `type === 'date'`).\n if (zodSchema instanceof z.ZodDate || (zodSchema as any).type === 'date') {\n jsonSchema.type = 'string'\n jsonSchema.format = 'date-time'\n return\n }\n}\n\n/**\n * Composes multiple JSON Schema override functions into one.\n * Overrides run in order - first override runs first.\n *\n * @example\n * ```ts\n * import { composeOverrides, zodvexJSONSchemaOverride } from 'zodvex'\n *\n * const myOverride = (ctx) => {\n * if (ctx.zodSchema.description?.startsWith('myType:')) {\n * ctx.jsonSchema.type = 'string'\n * ctx.jsonSchema.format = 'my-format'\n * }\n * }\n *\n * // User's override runs first, then zodvex's\n * z.toJSONSchema(schema, {\n * unrepresentable: 'any',\n * override: composeOverrides(myOverride, zodvexJSONSchemaOverride)\n * })\n * ```\n */\nexport function composeOverrides(\n ...overrides: Array<((ctx: JSONSchemaOverrideContext) => void) | undefined>\n): (ctx: JSONSchemaOverrideContext) => void {\n return (ctx: JSONSchemaOverrideContext) => {\n for (const override of overrides) {\n override?.(ctx)\n }\n }\n}\n\n/**\n * Options for toJSONSchema, matching Zod's interface.\n */\nexport interface ToJSONSchemaOptions {\n target?: 'draft-4' | 'draft-7' | 'draft-2020-12' | 'openapi-3.0'\n unrepresentable?: 'throw' | 'any'\n cycles?: 'ref' | 'throw'\n reused?: 'ref' | 'inline'\n io?: 'input' | 'output'\n override?: (ctx: JSONSchemaOverrideContext) => void\n}\n\n/**\n * Converts a Zod schema to JSON Schema with zodvex-aware overrides.\n *\n * This is a convenience wrapper around z.toJSONSchema that automatically\n * handles zodvex-managed types like zid and dates.\n *\n * @example\n * ```ts\n * import { zid, toJSONSchema } from 'zodvex'\n *\n * const schema = z.object({\n * userId: zid('users'),\n * createdAt: z.date(),\n * name: z.string()\n * })\n *\n * const jsonSchema = toJSONSchema(schema)\n * // Works with AI SDK's generateObject, etc.\n * ```\n */\nexport function toJSONSchema<T extends z.ZodTypeAny>(\n schema: T,\n options?: ToJSONSchemaOptions\n): Record<string, any> {\n const userOverride = options?.override\n\n return z.toJSONSchema(schema, {\n ...options,\n // Default to 'any' so transforms don't throw\n unrepresentable: options?.unrepresentable ?? 'any',\n // Chain our override with user's override\n override: ctx => {\n zodvexJSONSchemaOverride(ctx)\n userOverride?.(ctx)\n }\n })\n}\n","import type { GenericValidator, Validator } from 'convex/values'\nimport { v } from 'convex/values'\nimport { z } from 'zod'\n\n// Helper: Convert Zod enum types to Convex validators\nexport function convertEnumType(actualValidator: z.ZodEnum<any>): GenericValidator {\n const options = (actualValidator as any).options\n if (options && Array.isArray(options) && options.length > 0) {\n // Filter out undefined/null and convert to Convex validators\n const validLiterals = options\n .filter((opt: any) => opt !== undefined && opt !== null)\n .map((opt: any) => v.literal(opt))\n\n if (validLiterals.length === 1) {\n const [first] = validLiterals\n return first as Validator<any, 'required', any>\n } else if (validLiterals.length >= 2) {\n const [first, second, ...rest] = validLiterals\n return v.union(\n first as Validator<any, 'required', any>,\n second as Validator<any, 'required', any>,\n ...rest\n )\n } else {\n return v.any()\n }\n } else {\n return v.any()\n }\n}\n","import type { GenericValidator } from 'convex/values'\nimport { v } from 'convex/values'\nimport { z } from 'zod'\n\n// Helper: Convert Zod nullable types to Convex validators\nexport function convertNullableType(\n actualValidator: z.ZodNullable<any>,\n visited: Set<z.ZodTypeAny>,\n zodToConvexInternal: (schema: z.ZodTypeAny, visited: Set<z.ZodTypeAny>) => any\n): { validator: GenericValidator; isOptional: boolean } {\n const innerSchema = actualValidator.unwrap()\n if (innerSchema && innerSchema instanceof z.ZodType) {\n // Check if the inner schema is optional\n if (innerSchema instanceof z.ZodOptional) {\n // For nullable(optional(T)), we want optional(union(T, null))\n const innerInnerSchema = innerSchema.unwrap()\n const innerInnerValidator = zodToConvexInternal(innerInnerSchema as z.ZodType, visited)\n return {\n validator: v.union(innerInnerValidator, v.null()),\n isOptional: true // Mark as optional so it gets wrapped later\n }\n } else {\n const innerValidator = zodToConvexInternal(innerSchema, visited)\n return {\n validator: v.union(innerValidator, v.null()),\n isOptional: false\n }\n }\n } else {\n return {\n validator: v.any(),\n isOptional: false\n }\n }\n}\n","import type { GenericValidator } from 'convex/values'\nimport { v } from 'convex/values'\nimport { z } from 'zod'\n\n// Helper: Convert Zod record types to Convex validators\nexport function convertRecordType(\n actualValidator: z.ZodRecord<any, any>,\n visited: Set<z.ZodTypeAny>,\n zodToConvexInternal: (schema: z.ZodTypeAny, visited: Set<z.ZodTypeAny>) => any\n): GenericValidator {\n // In Zod v4, when z.record(z.string()) is used with one argument,\n // the argument becomes the value type and key defaults to string.\n // The valueType is stored in _def.valueType (or undefined if single arg)\n let valueType = (actualValidator as any)._def?.valueType\n\n // If valueType is undefined, it means single argument form was used\n // where the argument is actually the value type (stored in keyType)\n if (!valueType) {\n // Workaround: Zod v4 stores the value type in _def.keyType for single-argument z.record().\n // This accesses a private property as there is no public API for this in Zod v4.\n valueType = (actualValidator as any)._def?.keyType\n }\n\n if (valueType && valueType instanceof z.ZodType) {\n // First check if the Zod value type is optional before conversion\n const isZodOptional =\n valueType instanceof z.ZodOptional ||\n valueType instanceof z.ZodDefault ||\n (valueType instanceof z.ZodDefault && valueType.def.innerType instanceof z.ZodOptional)\n\n if (isZodOptional) {\n // For optional record values, we need to handle this specially\n let innerType: z.ZodTypeAny\n let recordDefaultValue: any = undefined\n let recordHasDefault = false\n\n if (valueType instanceof z.ZodDefault) {\n // Handle ZodDefault wrapper\n recordHasDefault = true\n recordDefaultValue = valueType.def.defaultValue\n const innerFromDefault = valueType.def.innerType\n if (innerFromDefault instanceof z.ZodOptional) {\n innerType = innerFromDefault.unwrap() as z.ZodTypeAny\n } else {\n innerType = innerFromDefault as z.ZodTypeAny\n }\n } else if (valueType instanceof z.ZodOptional) {\n // Direct ZodOptional\n innerType = valueType.unwrap() as z.ZodTypeAny\n } else {\n // Shouldn't happen based on isZodOptional check\n innerType = valueType as z.ZodTypeAny\n }\n\n // Convert the inner type to Convex and wrap in union with null\n const innerConvex = zodToConvexInternal(innerType, visited)\n const unionValidator = v.union(innerConvex, v.null())\n\n // Add default metadata if present\n if (recordHasDefault) {\n ;(unionValidator as any)._zodDefault = recordDefaultValue\n }\n\n return v.record(v.string(), unionValidator)\n } else {\n // Non-optional values can be converted normally\n return v.record(v.string(), zodToConvexInternal(valueType, visited))\n }\n } else {\n return v.record(v.string(), v.any())\n }\n}\n","import type { GenericValidator, Validator } from 'convex/values'\nimport { v } from 'convex/values'\nimport { z } from 'zod'\n\n// Helper: Convert Zod discriminated union types to Convex validators\nexport function convertDiscriminatedUnionType(\n actualValidator: z.ZodDiscriminatedUnion<any, any>,\n visited: Set<z.ZodTypeAny>,\n zodToConvexInternal: (schema: z.ZodTypeAny, visited: Set<z.ZodTypeAny>) => any\n): GenericValidator {\n const options =\n (actualValidator as any).def?.options || (actualValidator as any).def?.optionsMap?.values()\n if (options) {\n const opts = Array.isArray(options) ? options : Array.from(options)\n if (opts.length >= 2) {\n // IMPORTANT: Create a new visited set for each union member to prevent false circular\n // reference detection. The same schema can legitimately appear in multiple union branches.\n const convexOptions = opts.map((opt: any) => {\n const branchVisited = new Set(visited)\n return zodToConvexInternal(opt, branchVisited)\n }) as Validator<any, 'required', any>[]\n const [first, second, ...rest] = convexOptions\n return v.union(\n first as Validator<any, 'required', any>,\n second as Validator<any, 'required', any>,\n ...rest\n )\n } else {\n return v.any()\n }\n } else {\n return v.any()\n }\n}\n\n// Helper: Convert Zod union types to Convex validators\nexport function convertUnionType(\n actualValidator: z.ZodUnion<any>,\n visited: Set<z.ZodTypeAny>,\n zodToConvexInternal: (schema: z.ZodTypeAny, visited: Set<z.ZodTypeAny>) => any\n): GenericValidator {\n const options = (actualValidator as any).options\n if (options && Array.isArray(options) && options.length > 0) {\n if (options.length === 1) {\n return zodToConvexInternal(options[0], visited)\n } else {\n // Convert each option recursively\n // IMPORTANT: Create a new visited set for each union member to prevent false circular\n // reference detection. The same schema can legitimately appear in multiple union branches.\n // However, we do want to preserve the parent visited set to catch actual circular refs\n // that involve the union itself.\n const convexOptions = options.map((opt: any) => {\n // Create a new Set that includes the parent's visited schemas but won't pollute it\n const branchVisited = new Set(visited)\n return zodToConvexInternal(opt, branchVisited)\n }) as Validator<any, 'required', any>[]\n if (convexOptions.length >= 2) {\n const [first, second, ...rest] = convexOptions\n return v.union(\n first as Validator<any, 'required', any>,\n second as Validator<any, 'required', any>,\n ...rest\n )\n } else {\n return v.any()\n }\n }\n } else {\n return v.any()\n }\n}\n","import { v } from 'convex/values'\nimport { z } from 'zod'\nimport { registryHelpers, type Zid } from '../ids'\n\n// Helper to check if a schema is a Zid\nexport function isZid<T extends string>(schema: z.ZodType): schema is Zid<T> {\n // Check our metadata registry for ConvexId marker\n const metadata = registryHelpers.getMetadata(schema)\n return (\n metadata?.isConvexId === true && metadata?.tableName && typeof metadata.tableName === 'string'\n )\n}\n\n// union helpers\nexport function makeUnion(members: any[]): any {\n const nonNull = members.filter(Boolean)\n if (nonNull.length === 0) return v.any()\n if (nonNull.length === 1) return nonNull[0]\n return v.union(nonNull[0], nonNull[1], ...nonNull.slice(2))\n}\n\nexport function getObjectShape(obj: any): Record<string, any> {\n // Use public API .shape property for ZodObject\n if (obj instanceof z.ZodObject) {\n return obj.shape\n }\n // Fallback for edge cases\n if (obj && typeof obj === 'object' && typeof obj.shape === 'object') {\n return obj.shape as Record<string, any>\n }\n return {}\n}\n","import type { GenericValidator, PropertyValidators } from 'convex/values'\nimport { v } from 'convex/values'\nimport { z } from 'zod'\nimport { registryHelpers } from '../ids'\nimport { findBaseCodec } from '../registry'\nimport {\n convertDiscriminatedUnionType,\n convertEnumType,\n convertNullableType,\n convertRecordType,\n convertUnionType\n} from './handlers'\nimport type {\n ConvexValidatorFromZod,\n ConvexValidatorFromZodFieldsAuto,\n ZodValidator\n} from './types'\nimport { getObjectShape, isZid } from './utils'\n\n// Internal conversion function using ZodType with def.type detection\nfunction zodToConvexInternal<Z extends z.ZodTypeAny>(\n zodValidator: Z,\n visited: Set<z.ZodTypeAny> = new Set()\n): ConvexValidatorFromZod<Z, 'required'> {\n // Guard against undefined/null validators (can happen with { field: undefined } in args)\n if (!zodValidator) {\n return v.any() as ConvexValidatorFromZod<Z, 'required'>\n }\n\n // Detect circular references to prevent infinite recursion\n if (visited.has(zodValidator)) {\n return v.any() as ConvexValidatorFromZod<Z, 'required'>\n }\n visited.add(zodValidator)\n\n // Check for default and optional wrappers\n let actualValidator = zodValidator\n let isOptional = false\n let defaultValue: any = undefined\n let hasDefault = false\n\n // Handle ZodDefault (which wraps ZodOptional when using .optional().default())\n // Note: We access _def properties directly because Zod v4 doesn't expose public APIs\n // for unwrapping defaults. The removeDefault() method exists but returns a new schema\n // without preserving references, which breaks our visited Set tracking.\n if (zodValidator instanceof z.ZodDefault) {\n hasDefault = true\n defaultValue = (zodValidator as any).def?.defaultValue\n actualValidator = (zodValidator as any).def?.innerType as Z\n }\n\n // Check for optional (may be wrapped inside ZodDefault)\n if (actualValidator instanceof z.ZodOptional) {\n isOptional = true\n actualValidator = actualValidator.unwrap() as Z\n\n // If the unwrapped type is ZodDefault, handle it here\n if (actualValidator instanceof z.ZodDefault) {\n hasDefault = true\n defaultValue = (actualValidator as any).def?.defaultValue\n actualValidator = (actualValidator as any).def?.innerType as Z\n }\n }\n\n let convexValidator: GenericValidator\n\n // Check for Zid first (special case)\n if (isZid(actualValidator)) {\n const metadata = registryHelpers.getMetadata(actualValidator)\n const tableName = metadata?.tableName || 'unknown'\n convexValidator = v.id(tableName)\n } else {\n // Use def.type for robust, performant type detection instead of instanceof checks.\n // Rationale:\n // 1. Performance: Single switch statement vs. cascading instanceof checks\n // 2. Completeness: def.type covers ALL Zod variants including formats (email, url, uuid, etc.)\n // 3. Future-proof: Zod's internal structure is stable; instanceof checks can miss custom types\n // 4. Precision: def.type distinguishes between semantically different types (date vs number)\n // This private API access is intentional and necessary for comprehensive type coverage.\n //\n // Compatibility: This code relies on the internal `.def.type` property of ZodType.\n // This structure has been stable across Zod v3.x and v4.x. If upgrading Zod major versions,\n // verify that `.def.type` is still present and unchanged.\n const defType = (actualValidator as any).def?.type\n\n switch (defType) {\n case 'string':\n // This catches ZodString and ALL string format types (email, url, uuid, etc.)\n convexValidator = v.string()\n break\n case 'number':\n convexValidator = v.float64()\n break\n case 'bigint':\n convexValidator = v.int64()\n break\n case 'boolean':\n convexValidator = v.boolean()\n break\n case 'date':\n convexValidator = v.float64() // Dates are stored as timestamps in Convex\n break\n case 'null':\n convexValidator = v.null()\n break\n case 'nan':\n convexValidator = v.float64()\n break\n case 'array': {\n // Use classic API: ZodArray has .element property\n if (actualValidator instanceof z.ZodArray) {\n const element = (actualValidator as any).element\n if (element && element instanceof z.ZodType) {\n convexValidator = v.array(zodToConvexInternal(element, visited))\n } else {\n convexValidator = v.array(v.any())\n }\n } else {\n convexValidator = v.array(v.any())\n }\n break\n }\n case 'object': {\n // Use classic API: ZodObject has .shape property\n if (actualValidator instanceof z.ZodObject) {\n const shape = actualValidator.shape\n const convexShape: PropertyValidators = {}\n for (const [key, value] of Object.entries(shape)) {\n if (value && value instanceof z.ZodType) {\n convexShape[key] = zodToConvexInternal(value, visited)\n }\n }\n convexValidator = v.object(convexShape)\n } else {\n convexValidator = v.object({})\n }\n break\n }\n case 'union': {\n if (actualValidator instanceof z.ZodUnion) {\n convexValidator = convertUnionType(actualValidator, visited, zodToConvexInternal)\n } else {\n convexValidator = v.any()\n }\n break\n }\n case 'discriminatedUnion': {\n convexValidator = convertDiscriminatedUnionType(\n actualValidator as any,\n visited,\n zodToConvexInternal\n )\n break\n }\n case 'literal': {\n // Use classic API: ZodLiteral has .value property\n if (actualValidator instanceof z.ZodLiteral) {\n const literalValue = (actualValidator as any).value\n if (literalValue !== undefined && literalValue !== null) {\n convexValidator = v.literal(literalValue)\n } else {\n convexValidator = v.any()\n }\n } else {\n convexValidator = v.any()\n }\n break\n }\n case 'enum': {\n if (actualValidator instanceof z.ZodEnum) {\n convexValidator = convertEnumType(actualValidator)\n } else {\n convexValidator = v.any()\n }\n break\n }\n case 'record': {\n if (actualValidator instanceof z.ZodRecord) {\n convexValidator = convertRecordType(actualValidator, visited, zodToConvexInternal)\n } else {\n convexValidator = v.record(v.string(), v.any())\n }\n break\n }\n case 'transform':\n case 'pipe': {\n // Check for registered codec first\n const codec = findBaseCodec(actualValidator)\n if (codec) {\n convexValidator = codec.toValidator(actualValidator)\n } else {\n // Check for brand metadata\n const metadata = registryHelpers.getMetadata(actualValidator)\n if (metadata?.brand && metadata?.originalSchema) {\n // For branded types created by our zBrand function, use the original schema\n convexValidator = zodToConvexInternal(metadata.originalSchema, visited)\n } else {\n // For non-registered transforms, return v.any()\n convexValidator = v.any()\n }\n }\n break\n }\n case 'nullable': {\n if (actualValidator instanceof z.ZodNullable) {\n const result = convertNullableType(actualValidator, visited, zodToConvexInternal)\n convexValidator = result.validator\n if (result.isOptional) {\n isOptional = true\n }\n } else {\n convexValidator = v.any()\n }\n break\n }\n case 'tuple': {\n // Handle tuple types as objects with numeric keys\n if (actualValidator instanceof z.ZodTuple) {\n const items = (actualValidator as any).def?.items as z.ZodTypeAny[] | undefined\n if (items && items.length > 0) {\n const convexShape: PropertyValidators = {}\n items.forEach((item, index) => {\n convexShape[`_${index}`] = zodToConvexInternal(item, visited)\n })\n convexValidator = v.object(convexShape)\n } else {\n convexValidator = v.object({})\n }\n } else {\n convexValidator = v.object({})\n }\n break\n }\n case 'lazy': {\n // Handle lazy schemas by resolving them\n // Circular references are protected by the visited set check at function start\n if (actualValidator instanceof z.ZodLazy) {\n try {\n const getter = (actualValidator as any).def?.getter\n if (getter) {\n const resolvedSchema = getter()\n if (resolvedSchema && resolvedSchema instanceof z.ZodType) {\n convexValidator = zodToConvexInternal(resolvedSchema, visited)\n } else {\n convexValidator = v.any()\n }\n } else {\n convexValidator = v.any()\n }\n } catch {\n // If resolution fails, fall back to 'any'\n convexValidator = v.any()\n }\n } else {\n convexValidator = v.any()\n }\n break\n }\n case 'any':\n // Handle z.any() directly\n convexValidator = v.any()\n break\n case 'unknown':\n // Handle z.unknown() as any\n convexValidator = v.any()\n break\n case 'undefined':\n case 'void':\n case 'never':\n // These types don't have good Convex equivalents\n convexValidator = v.any()\n break\n case 'intersection':\n // Can't properly handle intersections\n convexValidator = v.any()\n break\n default:\n // For any unrecognized def.type, return v.any()\n // No instanceof fallbacks - keep it simple and performant\n if (process.env.NODE_ENV !== 'production') {\n console.warn(\n `[zodvex] Unrecognized Zod type \"${defType}\" encountered. Falling back to v.any().`,\n 'Schema:',\n actualValidator\n )\n }\n convexValidator = v.any()\n break\n }\n }\n\n // For optional or default fields, always use v.optional()\n const finalValidator = isOptional || hasDefault ? v.optional(convexValidator) : convexValidator\n\n // Add metadata if there's a default value\n if (hasDefault && typeof finalValidator === 'object' && finalValidator !== null) {\n ;(finalValidator as any)._zodDefault = defaultValue\n }\n\n return finalValidator as ConvexValidatorFromZod<Z, 'required'>\n}\n\nexport function zodToConvex<Z extends z.ZodTypeAny | ZodValidator>(\n zod: Z\n): Z extends z.ZodTypeAny\n ? ConvexValidatorFromZod<Z, 'required'>\n : Z extends ZodValidator\n ? ConvexValidatorFromZodFieldsAuto<Z>\n : never {\n if (typeof zod === 'object' && zod !== null && !(zod instanceof z.ZodType)) {\n return zodToConvexFields(zod as ZodValidator) as any\n }\n\n return zodToConvexInternal(zod as z.ZodTypeAny) as any\n}\n\nexport function zodToConvexFields<Z extends z.ZodRawShape>(\n zod: Z\n): ConvexValidatorFromZodFieldsAuto<Z> {\n // If it's a ZodObject, extract the shape\n const fields = zod instanceof z.ZodObject ? zod.shape : zod\n\n // Build the result object directly to preserve types\n const result: any = {}\n for (const [key, value] of Object.entries(fields)) {\n result[key] = zodToConvexInternal(value as z.ZodTypeAny)\n }\n\n return result as ConvexValidatorFromZodFieldsAuto<Z>\n}\n","import { z } from 'zod'\nimport { zodToConvex } from './mapping'\nimport { findBaseCodec, isDateSchema } from './registry'\n\n// Helper to convert Zod's internal types to ZodTypeAny\nfunction asZodType<T>(schema: T): z.ZodTypeAny {\n return schema as unknown as z.ZodTypeAny\n}\n\nexport type ConvexCodec<T> = {\n validator: any\n encode: (value: T) => any\n decode: (value: any) => T\n pick: <K extends keyof T>(keys: K[]) => ConvexCodec<Pick<T, K>>\n}\n\nexport function convexCodec<T>(schema: z.ZodType<T>): ConvexCodec<T> {\n const validator = zodToConvex(schema)\n\n return {\n validator,\n encode: (value: T) => toConvexJS(schema, value),\n decode: (value: any) => fromConvexJS(value, schema),\n pick: <K extends keyof T>(keys: K[] | Record<K, true>) => {\n if (!(schema instanceof z.ZodObject)) {\n throw new Error('pick() can only be called on object schemas')\n }\n // Handle both array and object formats\n const pickObj = Array.isArray(keys)\n ? keys.reduce((acc, k) => ({ ...acc, [k]: true }), {} as any)\n : keys\n const pickedSchema = schema.pick(pickObj as any)\n return convexCodec(pickedSchema) as ConvexCodec<Pick<T, K>>\n }\n }\n}\n\n// Convert JS values to Convex-safe JSON (handle Dates, remove undefined)\nexport function toConvexJS(schema?: any, value?: any): any {\n // If no schema provided, do basic conversion\n if (!schema || arguments.length === 1) {\n value = schema\n return basicToConvex(value)\n }\n\n // Use schema-aware conversion\n return schemaToConvex(value, schema)\n}\n\nfunction basicToConvex(value: any): any {\n if (value === undefined) return undefined\n if (value === null) return null\n if (value instanceof Date) return value.getTime()\n\n if (Array.isArray(value)) {\n return value.map(basicToConvex)\n }\n\n if (value && typeof value === 'object') {\n const result: any = {}\n for (const [k, v] of Object.entries(value)) {\n if (v !== undefined) {\n result[k] = basicToConvex(v)\n }\n }\n return result\n }\n\n return value\n}\n\nfunction schemaToConvex(value: any, schema: any): any {\n if (value === undefined || value === null) return value\n\n // Check base codec registry first\n const codec = findBaseCodec(schema)\n if (codec) {\n return codec.toConvex(value, schema)\n }\n\n // Handle wrapper types\n if (\n schema instanceof z.ZodOptional ||\n schema instanceof z.ZodNullable ||\n schema instanceof z.ZodDefault\n ) {\n // Use unwrap() method which is available on these types\n const inner = schema.unwrap()\n return schemaToConvex(value, asZodType(inner))\n }\n\n // Handle Date specifically\n if (schema instanceof z.ZodDate && value instanceof Date) {\n return value.getTime()\n }\n\n // Handle arrays\n if (schema instanceof z.ZodArray) {\n if (!Array.isArray(value)) return value\n return value.map(item => schemaToConvex(item, schema.element))\n }\n\n // Handle objects\n if (schema instanceof z.ZodObject) {\n if (!value || typeof value !== 'object') return value\n const shape = schema.shape\n const result: any = {}\n for (const [k, v] of Object.entries(value)) {\n if (v !== undefined) {\n result[k] = shape[k] ? schemaToConvex(v, shape[k]) : basicToConvex(v)\n }\n }\n return result\n }\n\n // Handle unions\n if (schema instanceof z.ZodUnion) {\n // Try each option to see which one matches\n for (const option of schema.options) {\n try {\n ;(option as any).parse(value) // Validate against this option\n return schemaToConvex(value, option)\n } catch {\n // Try next option\n }\n }\n }\n\n // Handle records\n if (schema instanceof z.ZodRecord) {\n if (!value || typeof value !== 'object') return value\n const result: any = {}\n for (const [k, v] of Object.entries(value)) {\n if (v !== undefined) {\n result[k] = schemaToConvex(v, schema.valueType)\n }\n }\n return result\n }\n\n // Default passthrough\n return basicToConvex(value)\n}\n\n// Convert Convex JSON back to JS values (handle timestamps -> Dates)\nexport function fromConvexJS(value: any, schema: any): any {\n if (value === undefined || value === null) return value\n\n // Check base codec registry first\n const codec = findBaseCodec(schema)\n if (codec) {\n return codec.fromConvex(value, schema)\n }\n\n // Handle wrapper types\n if (\n schema instanceof z.ZodOptional ||\n schema instanceof z.ZodNullable ||\n schema instanceof z.ZodDefault\n ) {\n // Use unwrap() method which is available on these types\n const inner = schema.unwrap()\n return fromConvexJS(value, asZodType(inner))\n }\n\n // Handle Date specifically\n if (schema instanceof z.ZodDate && typeof value === 'number') {\n return new Date(value)\n }\n\n // Check if schema is a Date through effects/transforms\n if (isDateSchema(schema) && typeof value === 'number') {\n return new Date(value)\n }\n\n // Handle arrays\n if (schema instanceof z.ZodArray) {\n if (!Array.isArray(value)) return value\n return value.map(item => fromConvexJS(item, schema.element))\n }\n\n // Handle objects\n if (schema instanceof z.ZodObject) {\n if (!value || typeof value !== 'object') return value\n const shape = schema.shape\n const result: any = {}\n for (const [k, v] of Object.entries(value)) {\n result[k] = shape[k] ? fromConvexJS(v, shape[k]) : v\n }\n return result\n }\n\n // Handle unions\n if (schema instanceof z.ZodUnion) {\n // Try to decode with each option\n for (const option of schema.options) {\n try {\n const decoded = fromConvexJS(value, option)\n ;(option as any).parse(decoded) // Validate the decoded value\n return decoded\n } catch {\n // Try next option\n }\n }\n }\n\n // Handle records\n if (schema instanceof z.ZodRecord) {\n if (!value || typeof value !== 'object') return value\n const result: any = {}\n for (const [k, v] of Object.entries(value)) {\n result[k] = fromConvexJS(v, schema.valueType)\n }\n return result\n }\n\n // Handle effects and transforms\n // Note: ZodPipe doesn't exist in Zod v4, only ZodTransform\n if (schema instanceof z.ZodTransform) {\n // Cannot access inner schema without _def, return value as-is\n return value\n }\n\n return value\n}\n","import { ConvexError } from 'convex/values'\nimport { z } from 'zod'\nimport { getObjectShape } from './mapping'\n\nexport function pick<T extends Record<string, any>, K extends keyof T>(\n obj: T,\n keys: K[]\n): Pick<T, K> {\n const result = {} as Pick<T, K>\n for (const key of keys) {\n if (key in obj) result[key] = obj[key]\n }\n return result\n}\n\n// Typed identity helper for returns schemas\nexport function returnsAs<R extends z.ZodTypeAny>() {\n return <T extends z.input<R>>(v: T) => v\n}\n\n// Format ZodError issues into a compact, consistent structure\nexport function formatZodIssues(\n error: z.ZodError,\n context?: 'args' | 'returns' | 'input' | 'output' | 'codec'\n) {\n return {\n error: 'ZodValidationError',\n context,\n issues: error.issues.map(issue => ({\n path: Array.isArray(issue.path) ? issue.path.join('.') : String(issue.path ?? ''),\n code: issue.code,\n message: issue.message\n })),\n // Keep a flattened snapshot for easier debugging without cyclic refs\n flatten: JSON.parse(JSON.stringify(error.flatten?.() ?? {}))\n }\n}\n\n// Handle Zod validation errors consistently across all wrappers\n// Throws a ConvexError with formatted issues if the error is a ZodError, otherwise re-throws\nexport function handleZodValidationError(\n e: unknown,\n context: 'args' | 'returns' | 'input' | 'output' | 'codec'\n): never {\n if (e instanceof z.ZodError) {\n throw new ConvexError(formatZodIssues(e, context))\n }\n throw e\n}\n\n// Helper: standard Convex paginate() result schema\nexport function zPaginated<T extends z.ZodTypeAny>(item: T) {\n return z.object({\n page: z.array(item),\n isDone: z.boolean(),\n continueCursor: z.string().nullable().optional()\n })\n}\n\n/**\n * Maps Date fields to number fields for docSchema generation.\n * Handles Date, Date.optional(), Date.nullable(), and Date.default() cases.\n * Returns the original field for non-Date types.\n */\nexport function mapDateFieldToNumber(field: z.ZodTypeAny): z.ZodTypeAny {\n // Direct Date field\n if (field instanceof z.ZodDate) {\n return z.number()\n }\n\n // Optional Date field\n if (field instanceof z.ZodOptional && field.unwrap() instanceof z.ZodDate) {\n return z.number().optional()\n }\n\n // Nullable Date field\n if (field instanceof z.ZodNullable && field.unwrap() instanceof z.ZodDate) {\n return z.number().nullable()\n }\n\n // Date with default value\n if (field instanceof z.ZodDefault) {\n const inner = field.removeDefault()\n if (inner instanceof z.ZodDate) {\n return z.number().optional()\n }\n }\n\n // Non-Date field - return as-is\n return field\n}\n\n// Schema picking utilities (moved from pick.ts for consolidation)\ntype Mask = readonly string[] | Record<string, boolean | 1 | true>\n\nfunction toKeys(mask: Mask): string[] {\n if (Array.isArray(mask)) return mask.map(String)\n return Object.keys(mask).filter(k => !!(mask as any)[k])\n}\n\n/**\n * Returns a plain shape object containing only the selected fields.\n * Accepts either a ZodObject or a raw shape object.\n */\nexport function pickShape(\n schemaOrShape: z.ZodObject<any> | Record<string, any>,\n mask: Mask\n): Record<string, any> {\n const keys = toKeys(mask)\n const shape =\n schemaOrShape instanceof z.ZodObject ? getObjectShape(schemaOrShape) : schemaOrShape || {}\n\n const out: Record<string, any> = {}\n for (const k of keys) {\n if (k in shape) out[k] = (shape as any)[k]\n }\n return out\n}\n\n// Builds a fresh Zod object from the selected fields (avoids Zod's .pick())\nexport function safePick(schema: z.ZodObject<any>, mask: Mask): z.ZodObject<any> {\n return z.object(pickShape(schema, mask))\n}\n\n/**\n * Convenience: omit a set of keys by building the complement.\n * Avoids using Zod's .omit() which can cause type depth issues.\n */\nexport function safeOmit(schema: z.ZodObject<any>, mask: Mask): z.ZodObject<any> {\n const shape = getObjectShape(schema)\n const omit = new Set(toKeys(mask))\n const keep = Object.keys(shape).filter(k => !omit.has(k))\n const picked = pickShape(schema, keep)\n return z.object(picked)\n}\n","import {\n type ActionBuilder,\n type ArgsArrayToObject,\n type DefaultFunctionArgs,\n type FunctionVisibility,\n type GenericActionCtx,\n type GenericDataModel,\n type GenericMutationCtx,\n type GenericQueryCtx,\n type MutationBuilder,\n type QueryBuilder\n} from 'convex/server'\nimport { ConvexError, type PropertyValidators } from 'convex/values'\nimport { type Customization, NoOp } from 'convex-helpers/server/customFunctions'\nimport { z } from 'zod'\nimport { fromConvexJS, toConvexJS } from './codec'\nimport { type ZodValidator, zodToConvex, zodToConvexFields } from './mapping'\nimport type { ExtractCtx, ExtractVisibility } from './types'\nimport { handleZodValidationError, pick } from './utils'\n\n// Type helpers for args transformation (from zodV3 example)\ntype OneArgArray<ArgsObject extends DefaultFunctionArgs = DefaultFunctionArgs> = [ArgsObject]\n\n// Simple type conversion from a Convex validator to a Zod validator return type\ntype NullToUndefinedOrNull<T> = T extends null ? T | undefined | void : T\ntype Returns<T> = Promise<NullToUndefinedOrNull<T>> | NullToUndefinedOrNull<T>\n\n// The return value before it's been validated: returned by the handler\ntype ReturnValueInput<ReturnsValidator extends z.ZodTypeAny | ZodValidator | void> = [\n ReturnsValidator\n] extends [z.ZodTypeAny]\n ? Returns<z.input<ReturnsValidator>>\n : [ReturnsValidator] extends [ZodValidator]\n ? Returns<z.input<z.ZodObject<ReturnsValidator>>>\n : any\n\n// The return value after it's been validated: returned to the client\ntype ReturnValueOutput<ReturnsValidator extends z.ZodTypeAny | ZodValidator | void> = [\n ReturnsValidator\n] extends [z.ZodTypeAny]\n ? Returns<z.output<ReturnsValidator>>\n : [ReturnsValidator] extends [ZodValidator]\n ? Returns<z.output<z.ZodObject<ReturnsValidator>>>\n : any\n\n// The args before they've been validated: passed from the client\ntype ArgsInput<ArgsValidator extends ZodValidator | z.ZodObject<any> | void> = [\n ArgsValidator\n] extends [z.ZodObject<any>]\n ? [z.input<ArgsValidator>]\n : [ArgsValidator] extends [ZodValidator]\n ? [z.input<z.ZodObject<ArgsValidator>>]\n : OneArgArray\n\n// The args after they've been validated: passed to the handler\ntype ArgsOutput<ArgsValidator extends ZodValidator | z.ZodObject<any> | void> = [\n ArgsValidator\n] extends [z.ZodObject<any>]\n ? [z.output<ArgsValidator>]\n : [ArgsValidator] extends [ZodValidator]\n ? [z.output<z.ZodObject<ArgsValidator>>]\n : OneArgArray\n\ntype Overwrite<T, U> = Omit<T, keyof U> & U\n\n// Hack to simplify how TypeScript renders object types\ntype Expand<ObjectType extends Record<any, any>> = ObjectType extends Record<any, any>\n ? {\n [Key in keyof ObjectType]: ObjectType[Key]\n }\n : never\n\ntype ArgsForHandlerType<\n OneOrZeroArgs extends [] | [Record<string, any>],\n CustomMadeArgs extends Record<string, any>\n> = CustomMadeArgs extends Record<string, never>\n ? OneOrZeroArgs\n : OneOrZeroArgs extends [infer A]\n ? [Expand<A & CustomMadeArgs>]\n : [CustomMadeArgs]\n\n// Helper type for function registration (from zodV3)\ntype Registration<\n FuncType extends 'query' | 'mutation' | 'action',\n Visibility extends FunctionVisibility,\n Args extends DefaultFunctionArgs,\n Output\n> = FuncType extends 'query'\n ? import('convex/server').RegisteredQuery<Visibility, Args, Output>\n : FuncType extends 'mutation'\n ? import('convex/server').RegisteredMutation<Visibility, Args, Output>\n : import('convex/server').RegisteredAction<Visibility, Args, Output>\n\n/**\n * A builder that customizes a Convex function, whether or not it validates\n * arguments. If the customization requires arguments, however, the resulting\n * builder will require argument validation too.\n *\n * This is our own Zod-aware CustomBuilder type that properly handles Zod validators.\n */\nexport type CustomBuilder<\n FuncType extends 'query' | 'mutation' | 'action',\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n InputCtx,\n Visibility extends FunctionVisibility,\n ExtraArgs extends Record<string, any>\n> = {\n <\n ArgsValidator extends ZodValidator | z.ZodObject<any> | void,\n ReturnsZodValidator extends z.ZodTypeAny | ZodValidator | void = void,\n ReturnValue extends ReturnValueInput<ReturnsZodValidator> = any\n >(\n func:\n | ({\n /**\n * Specify the arguments to the function as a Zod validator.\n */\n args?: ArgsValidator\n handler: (\n ctx: Overwrite<InputCtx, CustomCtx>,\n ...args: ArgsForHandlerType<ArgsOutput<ArgsValidator>, CustomMadeArgs>\n ) => ReturnValue\n /**\n * Validates the value returned by the function.\n * Note: you can't pass an object directly without wrapping it\n * in `z.object()`.\n */\n returns?: ReturnsZodValidator\n /**\n * If true, the function will not be validated by Convex,\n * in case you're seeing performance issues with validating twice.\n */\n skipConvexValidation?: boolean\n } & {\n [key in keyof ExtraArgs as key extends\n | 'args'\n | 'handler'\n | 'skipConvexValidation'\n | 'returns'\n ? never\n : key]: ExtraArgs[key]\n })\n | {\n (\n ctx: Overwrite<InputCtx, CustomCtx>,\n ...args: ArgsForHandlerType<ArgsOutput<ArgsValidator>, CustomMadeArgs>\n ): ReturnValue\n }\n ): Registration<\n FuncType,\n Visibility,\n ArgsArrayToObject<\n CustomArgsValidator extends Record<string, never>\n ? ArgsInput<ArgsValidator>\n : ArgsInput<ArgsValidator> extends [infer A]\n ? [Expand<A & import('convex/values').ObjectType<CustomArgsValidator>>]\n : [import('convex/values').ObjectType<CustomArgsValidator>]\n >,\n ReturnsZodValidator extends void ? ReturnValue : ReturnValueOutput<ReturnsZodValidator>\n >\n}\n\nexport function customFnBuilder<\n Ctx extends Record<string, any>,\n Builder extends (fn: any) => any,\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n builder: Builder,\n customization: Customization<Ctx, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n) {\n const customInput = customization.input ?? NoOp.input\n const inputArgs = customization.args ?? NoOp.args\n\n return function customBuilder(fn: any): any {\n const { args, handler = fn, returns: maybeObject, ...extra } = fn\n const skipConvexValidation = fn.skipConvexValidation ?? false\n\n const returns =\n maybeObject && !(maybeObject instanceof z.ZodType) ? z.object(maybeObject) : maybeObject\n // Only generate Convex return validator when not skipping Convex validation\n const returnValidator =\n returns && !skipConvexValidation ? { returns: zodToConvex(returns) } : undefined\n\n if (args) {\n let argsValidator = args\n let argsSchema: z.ZodObject<any>\n\n if (argsValidator instanceof z.ZodType) {\n if (argsValidator instanceof z.ZodObject) {\n argsSchema = argsValidator\n argsValidator = argsValidator.shape // Get the raw shape for zodToConvexFields\n } else {\n throw new Error(\n 'Unsupported non-object Zod schema for args; please provide an args schema using z.object({...}), e.g. z.object({ foo: z.string() })'\n )\n }\n } else {\n // It's a raw shape object with Zod validators as values\n argsSchema = z.object(argsValidator)\n }\n\n // Only generate Convex args validator when not skipping Convex validation\n const convexArgs = skipConvexValidation\n ? inputArgs\n : { ...zodToConvexFields(argsValidator), ...inputArgs }\n\n return builder({\n args: convexArgs,\n ...returnValidator,\n handler: async (ctx: Ctx, allArgs: any) => {\n const added: any = await customInput(\n ctx,\n pick(allArgs, Object.keys(inputArgs)) as any,\n extra\n )\n const argKeys = Object.keys(argsValidator)\n const rawArgs = pick(allArgs, argKeys)\n const decoded = fromConvexJS(rawArgs, argsSchema)\n // Always run Zod validation, regardless of skipConvexValidation\n const parsed = argsSchema.safeParse(decoded)\n if (!parsed.success) {\n handleZodValidationError(parsed.error, 'args')\n }\n const finalCtx = { ...ctx, ...(added?.ctx ?? {}) }\n const baseArgs = parsed.data as Record<string, unknown>\n const addedArgs = (added?.args as Record<string, unknown>) ?? {}\n const finalArgs = { ...baseArgs, ...addedArgs }\n const ret = await handler(finalCtx, finalArgs)\n // Always run Zod return validation when returns schema is provided\n if (returns) {\n let validated: any\n try {\n validated = (returns as z.ZodTypeAny).parse(ret)\n } catch (e) {\n handleZodValidationError(e, 'returns')\n }\n if (added?.onSuccess) {\n await added.onSuccess({\n ctx,\n args: parsed.data,\n result: validated\n })\n }\n return toConvexJS(returns as z.ZodTypeAny, validated)\n }\n if (added?.onSuccess) {\n await added.onSuccess({ ctx, args: parsed.data, result: ret })\n }\n return ret\n }\n })\n }\n return builder({\n args: inputArgs,\n ...returnValidator,\n handler: async (ctx: Ctx, allArgs: any) => {\n const added: any = await customInput(\n ctx,\n pick(allArgs, Object.keys(inputArgs)) as any,\n extra\n )\n const finalCtx = { ...ctx, ...(added?.ctx ?? {}) }\n const baseArgs = allArgs as Record<string, unknown>\n const addedArgs = (added?.args as Record<string, unknown>) ?? {}\n const finalArgs = { ...baseArgs, ...addedArgs }\n const ret = await handler(finalCtx, finalArgs)\n // Always run Zod return validation when returns schema is provided\n if (returns) {\n let validated: any\n try {\n validated = (returns as z.ZodTypeAny).parse(ret)\n } catch (e) {\n handleZodValidationError(e, 'returns')\n }\n if (added?.onSuccess) {\n await added.onSuccess({ ctx, args: allArgs, result: validated })\n }\n return toConvexJS(returns as z.ZodTypeAny, validated)\n }\n if (added?.onSuccess) {\n await added.onSuccess({ ctx, args: allArgs, result: ret })\n }\n return ret\n }\n })\n }\n}\n\n// Overload 1: With constraint - preferred to preserve DataModel types\nexport function zCustomQuery<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Visibility extends FunctionVisibility,\n DataModel extends GenericDataModel,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n query: QueryBuilder<DataModel, Visibility>,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'query',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n GenericQueryCtx<DataModel>,\n Visibility,\n ExtraArgs\n>\n\n// Overload 2: No constraint + decoupled ctx\nexport function zCustomQuery<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Visibility extends FunctionVisibility,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n query: QueryBuilder<any, Visibility>,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'query',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n any,\n Visibility,\n ExtraArgs\n>\n\n// Implementation\nexport function zCustomQuery<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Visibility extends FunctionVisibility,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n query: QueryBuilder<any, Visibility>,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n) {\n // Implementation deliberately uses 'any' ctx to preserve overload behavior\n // while avoiding a GenericDataModel constraint at the implementation level.\n return customFnBuilder<\n any,\n typeof query,\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n ExtraArgs\n >(query as any, customization as any) as any\n}\n\n// Overload 1: With constraint - preferred to preserve DataModel types\nexport function zCustomMutation<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Builder extends (fn: any) => any,\n Visibility extends FunctionVisibility = 'public',\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n mutation: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'mutation',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n ExtractCtx<Builder>,\n Visibility,\n ExtraArgs\n>\n\n// Implementation\nexport function zCustomMutation<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Builder extends (fn: any) => any,\n _Visibility extends FunctionVisibility = 'public',\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n mutation: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n) {\n return customFnBuilder<any, Builder, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>(\n mutation as any,\n customization as any\n ) as any\n}\n\n// Overload 1: With constraint - preferred to preserve DataModel types\nexport function zCustomAction<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Builder extends (fn: any) => any,\n Visibility extends FunctionVisibility = 'public',\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n action: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'action',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n ExtractCtx<Builder>,\n Visibility,\n ExtraArgs\n>\n\n// Implementation\nexport function zCustomAction<\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Builder extends (fn: any) => any,\n _Visibility extends FunctionVisibility = 'public',\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n action: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n) {\n return customFnBuilder<any, Builder, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>(\n action as any,\n customization as any\n ) as any\n}\n","import type {\n FunctionVisibility,\n RegisteredAction,\n RegisteredMutation,\n RegisteredQuery\n} from 'convex/server'\nimport { ConvexError } from 'convex/values'\nimport { z } from 'zod'\nimport { fromConvexJS, toConvexJS } from './codec'\nimport { getObjectShape, zodToConvex, zodToConvexFields } from './mapping'\n// Typing helpers to keep handler args/returns precise without deep remapping\nimport type {\n ExtractCtx,\n ExtractVisibility,\n InferHandlerReturns,\n InferReturns,\n ZodToConvexArgs\n} from './types'\nimport { handleZodValidationError } from './utils'\n\n// Cache to avoid re-checking the same schema\nconst customCheckCache = new WeakMap<z.ZodTypeAny, boolean>()\n\n/**\n * Check if a schema contains z.custom types (runtime check).\n * Includes depth limit to prevent stack overflow on deeply nested schemas.\n */\nfunction containsCustom(schema: z.ZodTypeAny, maxDepth = 50, currentDepth = 0): boolean {\n // Check cache first\n const cached = customCheckCache.get(schema)\n if (cached !== undefined) {\n return cached\n }\n\n // Prevent stack overflow on deeply nested schemas\n if (currentDepth > maxDepth) {\n return false\n }\n\n let result = false\n\n // Zod v4 exports ZodCustom and instances expose `schema.type === \"custom\"`.\n if (schema instanceof z.ZodCustom) {\n result = true\n } else if (schema instanceof z.ZodUnion) {\n result = (schema.options as z.ZodTypeAny[]).some(opt =>\n containsCustom(opt, maxDepth, currentDepth + 1)\n )\n } else if (schema instanceof z.ZodOptional) {\n result = containsCustom(schema.unwrap() as z.ZodTypeAny, maxDepth, currentDepth + 1)\n } else if (schema instanceof z.ZodNullable) {\n result = containsCustom(schema.unwrap() as z.ZodTypeAny, maxDepth, currentDepth + 1)\n } else if (schema instanceof z.ZodDefault) {\n result = containsCustom(schema.removeDefault() as z.ZodTypeAny, maxDepth, currentDepth + 1)\n }\n\n customCheckCache.set(schema, result)\n return result\n}\n\nexport function zQuery<\n Builder extends (fn: any) => any,\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n>(\n query: Builder,\n input: A,\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>,\n options?: { returns?: R }\n): RegisteredQuery<Visibility, ZodToConvexArgs<A>, Promise<InferReturns<R>>> {\n let zodSchema: z.ZodTypeAny\n let args: Record<string, any>\n if (input instanceof z.ZodObject) {\n const zodObj = input as z.ZodObject<any>\n zodSchema = zodObj\n args = zodToConvexFields(getObjectShape(zodObj))\n } else if (input instanceof z.ZodType) {\n // Single schema → normalize to { value }\n zodSchema = z.object({ value: input as any })\n args = { value: zodToConvex(input as any) }\n } else {\n zodSchema = z.object(input as Record<string, any>)\n args = zodToConvexFields(input as Record<string, any>)\n }\n // Skip returns validator for schemas with custom types to avoid type depth issues\n const returns =\n options?.returns && !containsCustom(options.returns) ? zodToConvex(options.returns) : undefined\n\n return query({\n args,\n returns,\n handler: async (ctx: any, argsObject: unknown) => {\n const decoded = fromConvexJS(argsObject, zodSchema)\n let parsed: any\n try {\n parsed = zodSchema.parse(decoded) as any\n } catch (e) {\n handleZodValidationError(e, 'args')\n }\n const raw = await handler(ctx, parsed)\n if (options?.returns) {\n try {\n const validated = (options.returns as z.ZodTypeAny).parse(raw)\n return toConvexJS(options.returns as z.ZodTypeAny, validated)\n } catch (e) {\n handleZodValidationError(e, 'returns')\n }\n }\n // Fallback: ensure Convex-safe return values (e.g., Date → timestamp)\n return toConvexJS(raw) as any\n }\n }) as any\n}\n\nexport function zInternalQuery<\n Builder extends (fn: any) => any,\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n>(\n internalQuery: Builder,\n input: A,\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>,\n options?: { returns?: R }\n): RegisteredQuery<Visibility, ZodToConvexArgs<A>, Promise<InferReturns<R>>> {\n return zQuery(internalQuery, input, handler, options)\n}\n\nexport function zMutation<\n Builder extends (fn: any) => any,\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n>(\n mutation: Builder,\n input: A,\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>,\n options?: { returns?: R }\n): RegisteredMutation<Visibility, ZodToConvexArgs<A>, Promise<InferReturns<R>>> {\n let zodSchema: z.ZodTypeAny\n let args: Record<string, any>\n if (input instanceof z.ZodObject) {\n const zodObj = input as z.ZodObject<any>\n zodSchema = zodObj\n args = zodToConvexFields(getObjectShape(zodObj))\n } else if (input instanceof z.ZodType) {\n zodSchema = z.object({ value: input as any })\n args = { value: zodToConvex(input as any) }\n } else {\n zodSchema = z.object(input as Record<string, any>)\n args = zodToConvexFields(input as Record<string, any>)\n }\n // Skip returns validator for schemas with custom types to avoid type depth issues\n const returns =\n options?.returns && !containsCustom(options.returns) ? zodToConvex(options.returns) : undefined\n\n return mutation({\n args,\n returns,\n handler: async (ctx: any, argsObject: unknown) => {\n const decoded = fromConvexJS(argsObject, zodSchema)\n let parsed: any\n try {\n parsed = zodSchema.parse(decoded) as any\n } catch (e) {\n handleZodValidationError(e, 'args')\n }\n const raw = await handler(ctx, parsed)\n if (options?.returns) {\n try {\n const validated = (options.returns as z.ZodTypeAny).parse(raw)\n return toConvexJS(options.returns as z.ZodTypeAny, validated)\n } catch (e) {\n handleZodValidationError(e, 'returns')\n }\n }\n // Fallback: ensure Convex-safe return values (e.g., Date → timestamp)\n return toConvexJS(raw) as any\n }\n }) as any\n}\n\nexport function zInternalMutation<\n Builder extends (fn: any) => any,\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n>(\n internalMutation: Builder,\n input: A,\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>,\n options?: { returns?: R }\n): RegisteredMutation<Visibility, ZodToConvexArgs<A>, Promise<InferReturns<R>>> {\n return zMutation(internalMutation, input, handler, options)\n}\n\nexport function zAction<\n Builder extends (fn: any) => any,\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n>(\n action: Builder,\n input: A,\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>,\n options?: { returns?: R }\n): RegisteredAction<Visibility, ZodToConvexArgs<A>, Promise<InferReturns<R>>> {\n let zodSchema: z.ZodTypeAny\n let args: Record<string, any>\n if (input instanceof z.ZodObject) {\n const zodObj = input as z.ZodObject<any>\n zodSchema = zodObj\n args = zodToConvexFields(getObjectShape(zodObj))\n } else if (input instanceof z.ZodType) {\n zodSchema = z.object({ value: input as any })\n args = { value: zodToConvex(input as any) }\n } else {\n zodSchema = z.object(input as Record<string, any>)\n args = zodToConvexFields(input as Record<string, any>)\n }\n // Skip returns validator for schemas with custom types to avoid type depth issues\n const returns =\n options?.returns && !containsCustom(options.returns) ? zodToConvex(options.returns) : undefined\n\n return action({\n args,\n returns,\n handler: async (ctx: any, argsObject: unknown) => {\n const decoded = fromConvexJS(argsObject, zodSchema)\n let parsed: any\n try {\n parsed = zodSchema.parse(decoded) as any\n } catch (e) {\n handleZodValidationError(e, 'args')\n }\n const raw = await handler(ctx, parsed)\n if (options?.returns) {\n try {\n const validated = (options.returns as z.ZodTypeAny).parse(raw)\n return toConvexJS(options.returns as z.ZodTypeAny, validated)\n } catch (e) {\n handleZodValidationError(e, 'returns')\n }\n }\n // Fallback: ensure Convex-safe return values (e.g., Date → timestamp)\n return toConvexJS(raw) as any\n }\n }) as any\n}\n\nexport function zInternalAction<\n Builder extends (fn: any) => any,\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n>(\n internalAction: Builder,\n input: A,\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>,\n options?: { returns?: R }\n): RegisteredAction<Visibility, ZodToConvexArgs<A>, Promise<InferReturns<R>>> {\n return zAction(internalAction, input, handler, options) as any\n}\n","import type {\n FunctionVisibility,\n RegisteredAction,\n RegisteredMutation,\n RegisteredQuery\n} from 'convex/server'\nimport type { PropertyValidators } from 'convex/values'\nimport type { Customization } from 'convex-helpers/server/customFunctions'\nimport { z } from 'zod'\nimport { type CustomBuilder, customFnBuilder } from './custom'\nimport type {\n ExtractCtx,\n ExtractVisibility,\n InferHandlerReturns,\n InferReturns,\n ZodToConvexArgs\n} from './types'\nimport { zAction, zMutation, zQuery } from './wrappers'\n\n/**\n * Creates a reusable query builder from a Convex query builder.\n * Returns a builder function that accepts Convex-style config objects with args, handler, and returns.\n *\n * @example\n * ```ts\n * import { query } from './_generated/server'\n * import { zQueryBuilder } from 'zodvex'\n *\n * // Create a reusable builder\n * export const zq = zQueryBuilder(query)\n *\n * // Use it with Convex-style object syntax\n * export const getUser = zq({\n * args: { id: z.string() },\n * handler: async (ctx, { id }) => {\n * return ctx.db.get(id)\n * }\n * })\n * ```\n */\nexport function zQueryBuilder<Builder extends (fn: any) => any>(builder: Builder) {\n return <\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n >(config: {\n args?: A\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A extends undefined ? Record<string, never> : A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>\n returns?: R\n }): RegisteredQuery<\n Visibility,\n ZodToConvexArgs<A extends undefined ? Record<string, never> : A>,\n Promise<InferReturns<R>>\n > => {\n return zQuery(builder, config.args ?? ({} as any), config.handler, {\n returns: config.returns\n }) as any\n }\n}\n\n/**\n * Creates a reusable mutation builder from a Convex mutation builder.\n * Returns a builder function that accepts Convex-style config objects with args, handler, and returns.\n *\n * @example\n * ```ts\n * import { mutation } from './_generated/server'\n * import { zMutationBuilder } from 'zodvex'\n *\n * // Create a reusable builder\n * export const zm = zMutationBuilder(mutation)\n *\n * // Use it with Convex-style object syntax\n * export const updateUser = zm({\n * args: { id: z.string(), name: z.string() },\n * handler: async (ctx, { id, name }) => {\n * return ctx.db.patch(id, { name })\n * }\n * })\n * ```\n */\nexport function zMutationBuilder<Builder extends (fn: any) => any>(builder: Builder) {\n return <\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n >(config: {\n args?: A\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A extends undefined ? Record<string, never> : A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>\n returns?: R\n }): RegisteredMutation<\n Visibility,\n ZodToConvexArgs<A extends undefined ? Record<string, never> : A>,\n Promise<InferReturns<R>>\n > => {\n return zMutation(builder, config.args ?? ({} as any), config.handler, {\n returns: config.returns\n }) as any\n }\n}\n\n/**\n * Creates a reusable action builder from a Convex action builder.\n * Returns a builder function that accepts Convex-style config objects with args, handler, and returns.\n *\n * @example\n * ```ts\n * import { action } from './_generated/server'\n * import { zActionBuilder } from 'zodvex'\n *\n * // Create a reusable builder\n * export const za = zActionBuilder(action)\n *\n * // Use it with Convex-style object syntax\n * export const sendEmail = za({\n * args: { to: z.string().email(), subject: z.string() },\n * handler: async (ctx, { to, subject }) => {\n * // Send email\n * }\n * })\n * ```\n */\nexport function zActionBuilder<Builder extends (fn: any) => any>(builder: Builder) {\n return <\n A extends z.ZodTypeAny | Record<string, z.ZodTypeAny>,\n R extends z.ZodTypeAny | undefined = undefined,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>\n >(config: {\n args?: A\n handler: (\n ctx: ExtractCtx<Builder>,\n args: ZodToConvexArgs<A extends undefined ? Record<string, never> : A>\n ) => InferHandlerReturns<R> | Promise<InferHandlerReturns<R>>\n returns?: R\n }): RegisteredAction<\n Visibility,\n ZodToConvexArgs<A extends undefined ? Record<string, never> : A>,\n Promise<InferReturns<R>>\n > => {\n return zAction(builder, config.args ?? ({} as any), config.handler, {\n returns: config.returns\n }) as any\n }\n}\n\n/**\n * Creates a custom query builder with context injection from a Convex query builder.\n * Allows you to add custom context (like auth, permissions, etc.) to your queries.\n *\n * @example\n * ```ts\n * import { type QueryCtx, query } from './_generated/server'\n * import { zCustomQueryBuilder, customCtx } from 'zodvex'\n *\n * // Create a builder with auth context\n * export const authQuery = zCustomQueryBuilder(\n * query,\n * customCtx(async (ctx: QueryCtx) => {\n * const user = await getUserOrThrow(ctx)\n * return { user }\n * })\n * )\n *\n * // Use it with automatic user injection\n * export const getMyProfile = authQuery({\n * args: {},\n * handler: async (ctx) => {\n * // ctx.user is automatically available\n * return ctx.db.get(ctx.user._id)\n * }\n * })\n * ```\n */\nexport function zCustomQueryBuilder<\n Builder extends (fn: any) => any,\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n query: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'query',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n ExtractCtx<Builder>,\n Visibility,\n ExtraArgs\n> {\n return customFnBuilder<any, Builder, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>(\n query as any,\n customization as any\n ) as any\n}\n\n/**\n * Creates a custom mutation builder with context injection from a Convex mutation builder.\n * Allows you to add custom context (like auth, permissions, etc.) to your mutations.\n *\n * @example\n * ```ts\n * import { type MutationCtx, mutation } from './_generated/server'\n * import { zCustomMutationBuilder, customCtx } from 'zodvex'\n *\n * // Create a builder with auth context\n * export const authMutation = zCustomMutationBuilder(\n * mutation,\n * customCtx(async (ctx: MutationCtx) => {\n * const user = await getUserOrThrow(ctx)\n * return { user }\n * })\n * )\n *\n * // Use it with automatic user injection\n * export const updateProfile = authMutation({\n * args: { name: z.string() },\n * handler: async (ctx, { name }) => {\n * // ctx.user is automatically available\n * await ctx.db.patch(ctx.user._id, { name })\n * }\n * })\n * ```\n */\nexport function zCustomMutationBuilder<\n Builder extends (fn: any) => any,\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n mutation: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'mutation',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n ExtractCtx<Builder>,\n Visibility,\n ExtraArgs\n> {\n return customFnBuilder<any, Builder, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>(\n mutation as any,\n customization as any\n ) as any\n}\n\n/**\n * Creates a custom action builder with context injection from a Convex action builder.\n * Allows you to add custom context (like auth, permissions, etc.) to your actions.\n *\n * @example\n * ```ts\n * import { type ActionCtx, action } from './_generated/server'\n * import { zCustomActionBuilder, customCtx } from 'zodvex'\n *\n * // Create a builder with auth context\n * export const authAction = zCustomActionBuilder(\n * action,\n * customCtx(async (ctx: ActionCtx) => {\n * const identity = await ctx.auth.getUserIdentity()\n * if (!identity) throw new Error('Unauthorized')\n * return { userId: identity.subject }\n * })\n * )\n *\n * // Use it with automatic auth injection\n * export const sendEmail = authAction({\n * args: { to: z.string().email() },\n * handler: async (ctx, { to }) => {\n * // ctx.userId is automatically available\n * await sendEmailService(to, ctx.userId)\n * }\n * })\n * ```\n */\nexport function zCustomActionBuilder<\n Builder extends (fn: any) => any,\n CustomArgsValidator extends PropertyValidators,\n CustomCtx extends Record<string, any>,\n CustomMadeArgs extends Record<string, any>,\n Visibility extends FunctionVisibility = ExtractVisibility<Builder>,\n ExtraArgs extends Record<string, any> = Record<string, any>\n>(\n action: Builder,\n customization: Customization<any, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>\n): CustomBuilder<\n 'action',\n CustomArgsValidator,\n CustomCtx,\n CustomMadeArgs,\n ExtractCtx<Builder>,\n Visibility,\n ExtraArgs\n> {\n return customFnBuilder<any, Builder, CustomArgsValidator, CustomCtx, CustomMadeArgs, ExtraArgs>(\n action as any,\n customization as any\n ) as any\n}\n","import { defineTable } from 'convex/server'\nimport type { GenericId } from 'convex/values'\nimport { Table } from 'convex-helpers/server'\nimport { z } from 'zod'\nimport { zid } from './ids'\nimport { type ConvexValidatorFromZodFieldsAuto, zodToConvex, zodToConvexFields } from './mapping'\n\n/**\n * Helper type for Convex system fields added to documents\n */\ntype SystemFields<TableName extends string> = {\n _id: ReturnType<typeof zid<TableName>>\n _creationTime: z.ZodNumber\n}\n\n/**\n * Maps over union options, extending each ZodObject variant with system fields.\n * Non-object variants are preserved as-is.\n */\ntype MapSystemFields<TableName extends string, Options extends readonly z.ZodTypeAny[]> = {\n [K in keyof Options]: Options[K] extends z.ZodObject<infer Shape extends z.ZodRawShape>\n ? z.ZodObject<Shape & SystemFields<TableName>>\n : Options[K]\n}\n\n/**\n * Adds Convex system fields (_id, _creationTime) to a Zod schema.\n *\n * For object schemas: extends with system fields\n * For union schemas: adds system fields to each variant\n *\n * @param tableName - The Convex table name\n * @param schema - The Zod schema (object or union)\n * @returns Schema with system fields added\n */\n// Overload 1: ZodObject - extends with system fields\nexport function addSystemFields<TableName extends string, Shape extends z.ZodRawShape>(\n tableName: TableName,\n schema: z.ZodObject<Shape>\n): z.ZodObject<Shape & SystemFields<TableName>>\n\n// Overload 2: ZodUnion - maps system fields to each variant\nexport function addSystemFields<TableName extends string, Options extends readonly z.ZodTypeAny[]>(\n tableName: TableName,\n schema: z.ZodUnion<Options>\n): z.ZodUnion<MapSystemFields<TableName, Options>>\n\n// Overload 3: ZodDiscriminatedUnion - maps system fields preserving discriminator\n// Note: Zod v4 signature is ZodDiscriminatedUnion<Options, Discriminator>\nexport function addSystemFields<\n TableName extends string,\n Options extends readonly z.ZodObject<z.ZodRawShape>[],\n Discriminator extends string\n>(\n tableName: TableName,\n schema: z.ZodDiscriminatedUnion<Options, Discriminator>\n): z.ZodDiscriminatedUnion<MapSystemFields<TableName, Options>, Discriminator>\n\n// Overload 4: Fallback for other ZodTypes - returns as-is\nexport function addSystemFields<TableName extends string, S extends z.ZodTypeAny>(\n tableName: TableName,\n schema: S\n): S\n\n// Implementation\nexport function addSystemFields<TableName extends string>(\n tableName: TableName,\n schema: z.ZodTypeAny\n): z.ZodTypeAny {\n // Handle union schemas - add system fields to each variant\n if (schema instanceof z.ZodUnion || schema instanceof z.ZodDiscriminatedUnion) {\n const options = (schema as z.ZodUnion<any>).options.map((variant: z.ZodTypeAny) => {\n if (variant instanceof z.ZodObject) {\n return variant.extend({\n _id: zid(tableName),\n _creationTime: z.number()\n })\n }\n // Non-object variants are returned as-is (shouldn't happen in practice)\n return variant\n })\n return z.union(options as any)\n }\n\n // Handle object schemas\n if (schema instanceof z.ZodObject) {\n return schema.extend({\n _id: zid(tableName),\n _creationTime: z.number()\n })\n }\n\n // Fallback: return schema as-is\n return schema\n}\n\n// Helper to create a Zod schema for a Convex document\nexport function zodDoc<\n TableName extends string,\n Shape extends z.ZodRawShape,\n Schema extends z.ZodObject<Shape>\n>(\n tableName: TableName,\n schema: Schema\n): z.ZodObject<\n Shape & {\n _id: ReturnType<typeof zid<TableName>>\n _creationTime: z.ZodNumber\n }\n> {\n // Use extend to preserve the original schema's type information\n return schema.extend({\n _id: zid(tableName),\n _creationTime: z.number()\n }) as any\n}\n\n// Helper to create nullable doc schema\nexport function zodDocOrNull<\n TableName extends string,\n Shape extends z.ZodRawShape,\n Schema extends z.ZodObject<Shape>\n>(tableName: TableName, schema: Schema) {\n return z.union([zodDoc(tableName, schema), z.null()])\n}\n\n/**\n * Helper to detect if input is an object shape (plain object with Zod validators)\n */\nfunction isObjectShape(input: any): input is Record<string, z.ZodTypeAny> {\n // Check if it's a plain object (not a Zod instance)\n if (!input || typeof input !== 'object') return false\n\n // If it's a Zod instance, it's not an object shape\n if (input instanceof z.ZodType) return false\n\n // Check if all values are Zod types\n for (const key in input) {\n if (!(input[key] instanceof z.ZodType)) {\n return false\n }\n }\n\n return true\n}\n\n/**\n * Defines a Convex table using either:\n * - A raw Zod shape (an object mapping field names to Zod types)\n * - A Zod union schema (for polymorphic tables)\n *\n * For object shapes, this function intentionally accepts a raw shape instead of a ZodObject instance.\n * Accepting raw shapes allows TypeScript to infer field types more accurately and efficiently,\n * leading to better type inference and performance throughout the codebase.\n *\n * For union schemas, this enables polymorphic tables with discriminated unions.\n *\n * Returns the Table definition along with Zod schemas for documents and arrays.\n *\n * @param name - The table name\n * @param schemaOrShape - Either a raw object shape or a Zod union schema\n * @returns A Table with attached helpers (shape, schema, zDoc, docArray, withSystemFields)\n *\n * @example Object shape\n * ```ts\n * const Users = zodTable('users', {\n * name: z.string(),\n * email: z.string().email(),\n * age: z.number().optional()\n * })\n *\n * // Use in schema\n * export default defineSchema({ users: Users.table })\n *\n * // Use for return types\n * export const getUsers = zQuery(query, {},\n * async (ctx) => ctx.db.query('users').collect(),\n * { returns: Users.docArray }\n * )\n * ```\n *\n * @example Union schema (polymorphic table)\n * ```ts\n * const shapeSchema = z.union([\n * z.object({ kind: z.literal('circle'), r: z.number() }),\n * z.object({ kind: z.literal('rectangle'), width: z.number() })\n * ])\n *\n * const Shapes = zodTable('shapes', shapeSchema)\n *\n * // Use in schema\n * export default defineSchema({ shapes: Shapes.table })\n *\n * // Use for return types with system fields\n * export const getShapes = zQuery(query, {},\n * async (ctx) => ctx.db.query('shapes').collect(),\n * { returns: Shapes.docArray }\n * )\n * ```\n */\n// Helper type to compute the result of addSystemFields for use in zodTable return type\ntype AddSystemFieldsResult<\n TableName extends string,\n Schema extends z.ZodTypeAny\n> = Schema extends z.ZodObject<infer Shape extends z.ZodRawShape>\n ? z.ZodObject<Shape & SystemFields<TableName>>\n : Schema extends z.ZodUnion<infer Options extends readonly z.ZodTypeAny[]>\n ? z.ZodUnion<MapSystemFields<TableName, Options>>\n : Schema extends z.ZodDiscriminatedUnion<\n infer Options extends readonly z.ZodObject<z.ZodRawShape>[],\n infer Disc extends string\n >\n ? z.ZodDiscriminatedUnion<MapSystemFields<TableName, Options>, Disc>\n : Schema\n\n// Overload 1: Object shape (most common case)\nexport function zodTable<TableName extends string, Shape extends Record<string, z.ZodTypeAny>>(\n name: TableName,\n shape: Shape\n): ReturnType<typeof Table<ConvexValidatorFromZodFieldsAuto<Shape>, TableName>> & {\n shape: Shape\n zDoc: z.ZodObject<\n Shape & {\n _id: ReturnType<typeof zid<TableName>>\n _creationTime: z.ZodNumber\n }\n >\n docArray: z.ZodArray<\n z.ZodObject<\n Shape & {\n _id: ReturnType<typeof zid<TableName>>\n _creationTime: z.ZodNumber\n }\n >\n >\n}\n\n// Overload 2: Union/schema types\nexport function zodTable<TableName extends string, Schema extends z.ZodTypeAny>(\n name: TableName,\n schema: Schema\n): {\n table: ReturnType<typeof defineTable>\n tableName: TableName\n validator: ReturnType<typeof zodToConvex<Schema>>\n schema: Schema\n docArray: z.ZodArray<AddSystemFieldsResult<TableName, Schema>>\n withSystemFields: () => AddSystemFieldsResult<TableName, Schema>\n}\n\nexport function zodTable<\n TableName extends string,\n SchemaOrShape extends z.ZodTypeAny | Record<string, z.ZodTypeAny>\n>(name: TableName, schemaOrShape: SchemaOrShape): any {\n // Detect if it's an object shape or a schema\n if (isObjectShape(schemaOrShape)) {\n // Original object shape logic\n const shape = schemaOrShape as Record<string, z.ZodTypeAny>\n\n // Convert fields with proper types\n const convexFields = zodToConvexFields(shape) as ConvexValidatorFromZodFieldsAuto<typeof shape>\n\n // Create the Table from convex-helpers with explicit type\n const table = Table<ConvexValidatorFromZodFieldsAuto<typeof shape>, TableName>(\n name,\n convexFields\n )\n\n // Create zDoc schema with system fields\n const zDoc = zodDoc(name, z.object(shape))\n\n // Create docArray helper for return types\n const docArray = z.array(zDoc)\n\n // Attach everything for comprehensive usage\n return Object.assign(table, {\n shape,\n zDoc,\n docArray\n })\n } else {\n // Union or other schema type logic\n const schema = schemaOrShape as z.ZodTypeAny\n\n // Convert schema to Convex validator\n const convexValidator = zodToConvex(schema)\n\n // For unions, use defineTable directly (not Table helper which expects object fields)\n // Note: TypeScript types don't reflect it, but Convex supports union validators in tables\n const table = defineTable(convexValidator as any)\n\n // Create document schema with system fields\n const withFields = addSystemFields(name, schema)\n\n // Create docArray helper\n const docArray = z.array(withFields)\n\n // Attach helpers for union tables\n // Return structure similar to Table() but without fields-based helpers\n return {\n table,\n tableName: name,\n validator: convexValidator,\n schema,\n docArray,\n withSystemFields: () => addSystemFields(name, schema)\n }\n }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "zodvex",
3
- "version": "0.3.1",
3
+ "version": "0.3.2",
4
4
  "description": "Zod <=> Convex integration, supporting Zod 4",
5
5
  "keywords": ["zod", "convex", "validators", "codec", "mapping", "schema", "validation"],
6
6
  "homepage": "https://github.com/panzacoder/zodvex#readme",
@@ -0,0 +1,476 @@
1
+ /**
2
+ * Compile-time type tests for zodTable inference (Type Regression Fix)
3
+ *
4
+ * These assertions cause TypeScript errors if zodTable returns `any` or
5
+ * fails to preserve proper type information.
6
+ * This file is type-checked but not included in the bundle.
7
+ */
8
+ import type { GenericId } from 'convex/values'
9
+ import { z } from 'zod'
10
+ import { zid } from '../ids'
11
+ import { zodTable } from '../tables'
12
+
13
+ // Test helper: causes TS error if assigned `any`
14
+ declare function expectNotAny<T>(value: 0 extends 1 & T ? never : T): void
15
+
16
+ // Test helper: causes TS error if types don't match
17
+ declare function expectType<T>(value: T): void
18
+
19
+ // --- Test 1: Basic table is not `any` ---
20
+
21
+ const BasicTable = zodTable('basic', { name: z.string() })
22
+ expectNotAny(BasicTable)
23
+ expectNotAny(BasicTable.table)
24
+ expectNotAny(BasicTable.shape)
25
+ expectNotAny(BasicTable.zDoc)
26
+ expectNotAny(BasicTable.docArray)
27
+
28
+ // --- Test 2: Shape preserves field types ---
29
+
30
+ type BasicShape = typeof BasicTable.shape
31
+ // Shape['name'] should be z.ZodString, not any
32
+ declare const nameField: BasicShape['name']
33
+ expectNotAny(nameField)
34
+
35
+ // Verify the type is actually ZodString
36
+ declare function expectZodString(v: z.ZodString): void
37
+ expectZodString(BasicTable.shape.name)
38
+
39
+ // --- Test 3: zDoc includes system fields ---
40
+
41
+ type BasicDocShape = typeof BasicTable.zDoc extends z.ZodObject<infer S> ? S : never
42
+ // Must have _id and _creationTime keys
43
+ declare const hasId: BasicDocShape['_id']
44
+ declare const hasCreationTime: BasicDocShape['_creationTime']
45
+ expectNotAny(hasId)
46
+ expectNotAny(hasCreationTime)
47
+
48
+ // --- Test 4: zDoc._output rejects invalid data ---
49
+
50
+ type BasicDoc = z.infer<typeof BasicTable.zDoc>
51
+ // @ts-expect-error - should fail if Doc is `any`
52
+ const _invalidDoc: BasicDoc = { completelyWrong: true }
53
+
54
+ // Valid doc should work
55
+ declare const validDoc: BasicDoc
56
+ expectNotAny(validDoc.name)
57
+ expectNotAny(validDoc._id)
58
+ expectNotAny(validDoc._creationTime)
59
+
60
+ // --- Test 5: Complex schema with optionals, arrays, nested objects ---
61
+
62
+ const ComplexTable = zodTable('complex', {
63
+ required: z.string(),
64
+ optional: z.string().optional(),
65
+ nullable: z.string().nullable(),
66
+ optionalNullable: z.string().optional().nullable(),
67
+ array: z.array(z.number()),
68
+ nested: z.object({
69
+ inner: z.string(),
70
+ deepNested: z.object({
71
+ value: z.boolean()
72
+ })
73
+ })
74
+ })
75
+
76
+ expectNotAny(ComplexTable)
77
+ expectNotAny(ComplexTable.shape)
78
+ expectNotAny(ComplexTable.zDoc)
79
+
80
+ type ComplexDoc = z.infer<typeof ComplexTable.zDoc>
81
+ declare const complexDoc: ComplexDoc
82
+
83
+ // Verify each field type is preserved
84
+ expectNotAny(complexDoc.required)
85
+ expectNotAny(complexDoc.optional)
86
+ expectNotAny(complexDoc.nullable)
87
+ expectNotAny(complexDoc.optionalNullable)
88
+ expectNotAny(complexDoc.array)
89
+ expectNotAny(complexDoc.nested)
90
+ expectNotAny(complexDoc.nested.inner)
91
+ expectNotAny(complexDoc.nested.deepNested)
92
+ expectNotAny(complexDoc.nested.deepNested.value)
93
+
94
+ // @ts-expect-error - should fail: required is string, not number
95
+ const _complexInvalid: ComplexDoc['required'] = 123
96
+
97
+ // --- Test 6: Table with zid references (common Convex pattern) ---
98
+
99
+ const _UsersTable = zodTable('users', {
100
+ name: z.string(),
101
+ email: z.string().email()
102
+ })
103
+
104
+ const PostsTable = zodTable('posts', {
105
+ title: z.string(),
106
+ content: z.string(),
107
+ authorId: zid('users'),
108
+ categoryId: zid('categories').optional()
109
+ })
110
+
111
+ expectNotAny(PostsTable)
112
+ expectNotAny(PostsTable.shape)
113
+ expectNotAny(PostsTable.zDoc)
114
+
115
+ type PostDoc = z.infer<typeof PostsTable.zDoc>
116
+ declare const postDoc: PostDoc
117
+
118
+ expectNotAny(postDoc.title)
119
+ expectNotAny(postDoc.authorId)
120
+ expectNotAny(postDoc.categoryId)
121
+
122
+ // @ts-expect-error - authorId should be GenericId<'users'>, not any
123
+ const _postInvalid: PostDoc = { title: 'test', content: 'test', authorId: 123 }
124
+
125
+ // --- Test 7: Spread operator preserves types (the actual symptom) ---
126
+
127
+ declare const docToSpread: z.infer<typeof BasicTable.zDoc>
128
+ const spread = { ...docToSpread, extra: 'field' }
129
+ expectNotAny(spread._id)
130
+ expectNotAny(spread.name)
131
+ expectNotAny(spread._creationTime)
132
+
133
+ // The spread should have proper types
134
+ // @ts-expect-error - _id should be GenericId<'basic'>, not accept random object
135
+ const _spreadInvalid: typeof spread._id = { notAnId: true }
136
+
137
+ // --- Test 8: docArray preserves document types ---
138
+
139
+ type BasicDocArray = z.infer<typeof BasicTable.docArray>
140
+ declare const docArray: BasicDocArray
141
+
142
+ expectNotAny(docArray)
143
+ expectNotAny(docArray[0])
144
+ expectNotAny(docArray[0].name)
145
+ expectNotAny(docArray[0]._id)
146
+
147
+ // @ts-expect-error - array element should have proper type
148
+ const _arrayInvalid: BasicDocArray = [{ notValid: true }]
149
+
150
+ // --- Test 9: Multiple tables don't interfere with each other ---
151
+
152
+ const TableA = zodTable('tableA', { fieldA: z.string() })
153
+ const TableB = zodTable('tableB', { fieldB: z.number() })
154
+
155
+ expectNotAny(TableA.shape.fieldA)
156
+ expectNotAny(TableB.shape.fieldB)
157
+
158
+ // Each table's zDoc should be properly typed
159
+ type DocA = z.infer<typeof TableA.zDoc>
160
+ type DocB = z.infer<typeof TableB.zDoc>
161
+
162
+ declare const docA: DocA
163
+ declare const docB: DocB
164
+
165
+ // @ts-expect-error - docA should not have fieldB
166
+ const _aHasB: typeof docA.fieldB = 'test'
167
+
168
+ // @ts-expect-error - docB should not have fieldA
169
+ const _bHasA: typeof docB.fieldA = 123
170
+
171
+ // --- Test 10: GenericId types are preserved correctly ---
172
+
173
+ type BasicDocId = z.infer<typeof BasicTable.zDoc>['_id']
174
+ // Should be GenericId<'basic'>
175
+ declare function expectGenericId<T extends string>(id: GenericId<T>): void
176
+ declare const basicId: BasicDocId
177
+ expectGenericId(basicId)
178
+
179
+ // --- Test 11: Union schema support still works ---
180
+
181
+ const UnionTable = zodTable(
182
+ 'shapes',
183
+ z.union([
184
+ z.object({ kind: z.literal('circle'), radius: z.number() }),
185
+ z.object({ kind: z.literal('rectangle'), width: z.number(), height: z.number() })
186
+ ])
187
+ )
188
+
189
+ expectNotAny(UnionTable)
190
+ expectNotAny(UnionTable.table)
191
+ expectNotAny(UnionTable.schema)
192
+ expectNotAny(UnionTable.docArray)
193
+
194
+ // --- Test 12: Table.doc validator returns properly typed document, not any ---
195
+ // This is the ACTUAL bug: ReturnType<typeof Table<any, TableName>> causes Table properties to be any
196
+
197
+ // The .doc property is a Convex validator - check its inferred type
198
+ type DocValidatorType = typeof BasicTable.doc
199
+ // If Table<any, ...> is used, DocValidatorType will have `any` in its type params
200
+ expectNotAny({} as DocValidatorType)
201
+
202
+ // --- Test 13: Table.withoutSystemFields should preserve field types ---
203
+
204
+ type WithoutSystemFields = typeof BasicTable.withoutSystemFields
205
+ expectNotAny({} as WithoutSystemFields)
206
+
207
+ // --- Test 14: Table.withSystemFields should not be any ---
208
+ // Check that withSystemFields preserves proper field structure
209
+
210
+ type WithSystemFields = typeof BasicTable.withSystemFields
211
+ expectNotAny({} as WithSystemFields)
212
+
213
+ // --- Test 15: doc validator should have properly typed fields, not index signature any ---
214
+ // The bug causes VObject<{ [x: string]: any; ... }> instead of VObject<{ name: ... }>
215
+
216
+ type DocValidator = typeof BasicTable.doc
217
+ // Check that the doc validator type doesn't have any in its structure
218
+ // This is a compile-time check - if any propagates, this file fails to compile
219
+ declare const docValidator: DocValidator
220
+ expectNotAny(docValidator)
221
+
222
+ // --- Test 16: Discriminated union schema support ---
223
+
224
+ const DiscriminatedUnionTable = zodTable(
225
+ 'events',
226
+ z.discriminatedUnion('type', [
227
+ z.object({ type: z.literal('click'), x: z.number(), y: z.number() }),
228
+ z.object({ type: z.literal('scroll'), offset: z.number() }),
229
+ z.object({ type: z.literal('keypress'), key: z.string() })
230
+ ])
231
+ )
232
+
233
+ expectNotAny(DiscriminatedUnionTable)
234
+ expectNotAny(DiscriminatedUnionTable.table)
235
+ expectNotAny(DiscriminatedUnionTable.schema)
236
+ expectNotAny(DiscriminatedUnionTable.docArray)
237
+
238
+ // --- Test 17: Enum fields preserve literal types ---
239
+
240
+ const EnumTable = zodTable('statuses', {
241
+ status: z.enum(['pending', 'active', 'completed', 'archived']),
242
+ priority: z.enum(['low', 'medium', 'high'])
243
+ })
244
+
245
+ expectNotAny(EnumTable)
246
+ expectNotAny(EnumTable.shape)
247
+ expectNotAny(EnumTable.shape.status)
248
+ expectNotAny(EnumTable.shape.priority)
249
+
250
+ type EnumDoc = z.infer<typeof EnumTable.zDoc>
251
+ declare const enumDoc: EnumDoc
252
+ expectNotAny(enumDoc.status)
253
+ expectNotAny(enumDoc.priority)
254
+
255
+ // @ts-expect-error - status should only accept enum values, not arbitrary strings
256
+ const _enumInvalid: EnumDoc['status'] = 'invalid_status'
257
+
258
+ // --- Test 18: Default values don't break inference ---
259
+
260
+ const DefaultsTable = zodTable('defaults', {
261
+ name: z.string().default('unnamed'),
262
+ count: z.number().default(0),
263
+ active: z.boolean().default(true)
264
+ })
265
+
266
+ expectNotAny(DefaultsTable)
267
+ expectNotAny(DefaultsTable.shape)
268
+ expectNotAny(DefaultsTable.zDoc)
269
+
270
+ type DefaultsDoc = z.infer<typeof DefaultsTable.zDoc>
271
+ declare const defaultsDoc: DefaultsDoc
272
+ expectNotAny(defaultsDoc.name)
273
+ expectNotAny(defaultsDoc.count)
274
+ expectNotAny(defaultsDoc.active)
275
+
276
+ // --- Test 19: Empty shape edge case ---
277
+
278
+ const EmptyTable = zodTable('empty', {})
279
+ expectNotAny(EmptyTable)
280
+ expectNotAny(EmptyTable.table)
281
+ expectNotAny(EmptyTable.zDoc)
282
+
283
+ // Empty table should still have system fields
284
+ type EmptyDoc = z.infer<typeof EmptyTable.zDoc>
285
+ declare const emptyDoc: EmptyDoc
286
+ expectNotAny(emptyDoc._id)
287
+ expectNotAny(emptyDoc._creationTime)
288
+
289
+ // =============================================================================
290
+ // UNION TABLE TYPE TESTS
291
+ // These tests check for type preservation in the union schema overload
292
+ // =============================================================================
293
+
294
+ // --- Test 20: Union table docArray should preserve variant types ---
295
+
296
+ const ShapesTable = zodTable(
297
+ 'shapes',
298
+ z.union([
299
+ z.object({ kind: z.literal('circle'), radius: z.number() }),
300
+ z.object({ kind: z.literal('rectangle'), width: z.number(), height: z.number() })
301
+ ])
302
+ )
303
+
304
+ // The docArray should infer proper document types with system fields
305
+ type ShapeDocArray = z.infer<typeof ShapesTable.docArray>
306
+ declare const shapeDocArray: ShapeDocArray
307
+
308
+ // TODO: This test currently passes but the inferred type is very loose (ZodTypeAny)
309
+ // Ideally, shapeDocArray[0] should have discriminated union fields
310
+ expectNotAny(shapeDocArray)
311
+
312
+ // --- Test 21: Union table withSystemFields() should preserve variant types ---
313
+ // BUG: addSystemFields returns z.ZodTypeAny, causing type loss
314
+
315
+ const shapeWithFields = ShapesTable.withSystemFields()
316
+
317
+ // BUG DETECTION: withSystemFields returns ZodTypeAny instead of preserving the union type
318
+ // z.infer<z.ZodTypeAny> = any, which breaks type safety
319
+ type ShapeDocFromWithFields = z.infer<typeof shapeWithFields>
320
+
321
+ // This should detect if the type is any
322
+ expectNotAny({} as ShapeDocFromWithFields)
323
+
324
+ // More specific test: the document should have the union variant fields + system fields
325
+ // If withSystemFields worked correctly, we should be able to access kind, radius, etc.
326
+ declare const shapeDoc: ShapeDocFromWithFields
327
+
328
+ // BUG: These should error with "Property does not exist" if type is any
329
+ // because any accepts all property accesses without error
330
+ // @ts-expect-error - if this is unused, shapeDoc is any (the bug)
331
+ const _testAnyAccess: typeof shapeDoc.thisPropertyShouldNotExist = 'test'
332
+
333
+ // Direct test: what is z.infer<z.ZodTypeAny>?
334
+ type DirectZodTypeAnyInfer = z.infer<z.ZodTypeAny>
335
+ // If this is any, the next line will fail
336
+ expectNotAny({} as DirectZodTypeAnyInfer)
337
+
338
+ // Test: check if addSystemFields return type loses union info
339
+ type AddSystemFieldsReturn = ReturnType<typeof ShapesTable.withSystemFields>
340
+ // @ts-expect-error - if unused, the return type accepts all assignments (is any or unknown)
341
+ const _addSystemFieldsTest: AddSystemFieldsReturn = 'this should not be assignable to a Zod schema'
342
+
343
+ // Debug types show:
344
+ // - DirectZodTypeAnyInfer = unknown (not any!)
345
+ // - ShapeDocFromWithFields = unknown
346
+ // - AddSystemFieldsReturn = ZodType<unknown, ...>
347
+ // In Zod v4, z.infer<z.ZodTypeAny> = unknown, which still loses type info
348
+
349
+ // Test helper to detect unknown type (different from any)
350
+ declare function expectNotUnknown<T>(value: unknown extends T ? never : T): void
351
+
352
+ // BUG DETECTION: These fail because types degrade to `unknown`
353
+ // When fixed, these should pass (types should be the actual union)
354
+ expectNotUnknown({} as ShapeDocFromWithFields)
355
+
356
+ // Test: Does the docArray lose type info?
357
+ type DocArrayElement = ShapeDocArray[number]
358
+ // BUG: DocArrayElement is `unknown`, should be the union type with system fields
359
+ expectNotUnknown({} as DocArrayElement)
360
+
361
+ // --- Test 22: Union table schema property preserves original schema type ---
362
+ // This should work - schema property is directly typed as Schema
363
+
364
+ type ShapesSchema = typeof ShapesTable.schema
365
+ expectNotAny({} as ShapesSchema)
366
+
367
+ // The schema should be the original union, not any
368
+ type ShapesSchemaOutput = z.infer<ShapesSchema>
369
+ declare const shapesOutput: ShapesSchemaOutput
370
+
371
+ // This SHOULD error because shapesOutput is a union type, not any
372
+ // @ts-expect-error - should fail if schema output is any
373
+ const _shapesOutputInvalid: ShapesSchemaOutput = { notAShape: true }
374
+
375
+ // --- Test 23: Discriminated union table type preservation ---
376
+
377
+ const EventsTable = zodTable(
378
+ 'events',
379
+ z.discriminatedUnion('type', [
380
+ z.object({ type: z.literal('click'), x: z.number(), y: z.number() }),
381
+ z.object({ type: z.literal('scroll'), offset: z.number() })
382
+ ])
383
+ )
384
+
385
+ // The schema should preserve discriminated union type
386
+ type EventsSchema = typeof EventsTable.schema
387
+ expectNotAny({} as EventsSchema)
388
+
389
+ type EventsOutput = z.infer<EventsSchema>
390
+ declare const eventsOutput: EventsOutput
391
+
392
+ // This SHOULD error because eventsOutput is a discriminated union, not any
393
+ // @ts-expect-error - should fail if output is any
394
+ const _eventsInvalid: EventsOutput = { notAnEvent: 123 }
395
+
396
+ // The discriminator should work
397
+ declare const clickEvent: EventsOutput & { type: 'click' }
398
+ expectNotAny(clickEvent.x)
399
+ expectNotAny(clickEvent.y)
400
+
401
+ // =============================================================================
402
+ // STRUCTURAL TESTS FOR UNION/DU TYPE INFERENCE
403
+ // These verify the actual structure is correct, not just "not any/unknown"
404
+ // =============================================================================
405
+
406
+ // --- Test 24: Union docArray elements have system fields ---
407
+
408
+ type ShapeDocElement = z.infer<typeof ShapesTable.docArray>[number]
409
+ declare const shapeElement: ShapeDocElement
410
+
411
+ // System fields should exist on union doc elements
412
+ expectNotAny(shapeElement._id)
413
+ expectNotAny(shapeElement._creationTime)
414
+
415
+ // --- Test 25: Union variant fields are accessible ---
416
+
417
+ // For a union, we should be able to access the common discriminator
418
+ // Note: 'kind' exists on both variants
419
+ expectNotAny(shapeElement.kind)
420
+
421
+ // --- Test 26: Discriminated union narrowing works ---
422
+
423
+ type EventDoc = z.infer<typeof EventsTable.docArray>[number]
424
+ declare const eventDoc: EventDoc
425
+
426
+ // Before narrowing, variant-specific fields should not be directly accessible
427
+ // (they exist on some variants but not all)
428
+
429
+ // After narrowing by discriminator, variant fields should be accessible
430
+ function _handleEvent(event: EventDoc) {
431
+ if (event.type === 'click') {
432
+ // After narrowing, x and y should be accessible
433
+ const x: number = event.x
434
+ const y: number = event.y
435
+ return { x, y }
436
+ } else if (event.type === 'scroll') {
437
+ // After narrowing, offset should be accessible
438
+ const offset: number = event.offset
439
+ return { offset }
440
+ }
441
+ return null
442
+ }
443
+
444
+ // --- Test 27: Union docs reject invalid variants ---
445
+
446
+ // @ts-expect-error - missing required 'kind' discriminator
447
+ const _invalidShapeDoc1: ShapeDocElement = { _id: '' as any, _creationTime: 0 }
448
+
449
+ // @ts-expect-error - 'kind' value doesn't match any variant
450
+ const _invalidShapeDoc2: ShapeDocElement = {
451
+ kind: 'triangle' as any, // not a valid variant
452
+ _id: '' as any,
453
+ _creationTime: 0
454
+ }
455
+
456
+ // --- Test 28: Discriminated union docs have proper system field types ---
457
+
458
+ // _id should be GenericId<'events'>, not just any string
459
+ type EventDocId = EventDoc['_id']
460
+ declare const eventId: EventDocId
461
+ expectNotAny(eventId)
462
+ declare function expectGenericIdEvents(id: GenericId<'events'>): void
463
+ expectGenericIdEvents(eventId)
464
+
465
+ // --- Test 29: withSystemFields() result has variant fields accessible ---
466
+
467
+ const eventsWithFields = EventsTable.withSystemFields()
468
+ type EventWithFields = z.infer<typeof eventsWithFields>
469
+ declare const eventWithFields: EventWithFields
470
+
471
+ // Should have system fields
472
+ expectNotAny(eventWithFields._id)
473
+ expectNotAny(eventWithFields._creationTime)
474
+
475
+ // Should have discriminator
476
+ expectNotAny(eventWithFields.type)
package/src/tables.ts CHANGED
@@ -5,6 +5,24 @@ import { z } from 'zod'
5
5
  import { zid } from './ids'
6
6
  import { type ConvexValidatorFromZodFieldsAuto, zodToConvex, zodToConvexFields } from './mapping'
7
7
 
8
+ /**
9
+ * Helper type for Convex system fields added to documents
10
+ */
11
+ type SystemFields<TableName extends string> = {
12
+ _id: ReturnType<typeof zid<TableName>>
13
+ _creationTime: z.ZodNumber
14
+ }
15
+
16
+ /**
17
+ * Maps over union options, extending each ZodObject variant with system fields.
18
+ * Non-object variants are preserved as-is.
19
+ */
20
+ type MapSystemFields<TableName extends string, Options extends readonly z.ZodTypeAny[]> = {
21
+ [K in keyof Options]: Options[K] extends z.ZodObject<infer Shape extends z.ZodRawShape>
22
+ ? z.ZodObject<Shape & SystemFields<TableName>>
23
+ : Options[K]
24
+ }
25
+
8
26
  /**
9
27
  * Adds Convex system fields (_id, _creationTime) to a Zod schema.
10
28
  *
@@ -15,9 +33,39 @@ import { type ConvexValidatorFromZodFieldsAuto, zodToConvex, zodToConvexFields }
15
33
  * @param schema - The Zod schema (object or union)
16
34
  * @returns Schema with system fields added
17
35
  */
18
- export function addSystemFields<T extends string, S extends z.ZodTypeAny>(
19
- tableName: T,
36
+ // Overload 1: ZodObject - extends with system fields
37
+ export function addSystemFields<TableName extends string, Shape extends z.ZodRawShape>(
38
+ tableName: TableName,
39
+ schema: z.ZodObject<Shape>
40
+ ): z.ZodObject<Shape & SystemFields<TableName>>
41
+
42
+ // Overload 2: ZodUnion - maps system fields to each variant
43
+ export function addSystemFields<TableName extends string, Options extends readonly z.ZodTypeAny[]>(
44
+ tableName: TableName,
45
+ schema: z.ZodUnion<Options>
46
+ ): z.ZodUnion<MapSystemFields<TableName, Options>>
47
+
48
+ // Overload 3: ZodDiscriminatedUnion - maps system fields preserving discriminator
49
+ // Note: Zod v4 signature is ZodDiscriminatedUnion<Options, Discriminator>
50
+ export function addSystemFields<
51
+ TableName extends string,
52
+ Options extends readonly z.ZodObject<z.ZodRawShape>[],
53
+ Discriminator extends string
54
+ >(
55
+ tableName: TableName,
56
+ schema: z.ZodDiscriminatedUnion<Options, Discriminator>
57
+ ): z.ZodDiscriminatedUnion<MapSystemFields<TableName, Options>, Discriminator>
58
+
59
+ // Overload 4: Fallback for other ZodTypes - returns as-is
60
+ export function addSystemFields<TableName extends string, S extends z.ZodTypeAny>(
61
+ tableName: TableName,
20
62
  schema: S
63
+ ): S
64
+
65
+ // Implementation
66
+ export function addSystemFields<TableName extends string>(
67
+ tableName: TableName,
68
+ schema: z.ZodTypeAny
21
69
  ): z.ZodTypeAny {
22
70
  // Handle union schemas - add system fields to each variant
23
71
  if (schema instanceof z.ZodUnion || schema instanceof z.ZodDiscriminatedUnion) {
@@ -150,10 +198,26 @@ function isObjectShape(input: any): input is Record<string, z.ZodTypeAny> {
150
198
  * )
151
199
  * ```
152
200
  */
201
+ // Helper type to compute the result of addSystemFields for use in zodTable return type
202
+ type AddSystemFieldsResult<
203
+ TableName extends string,
204
+ Schema extends z.ZodTypeAny
205
+ > = Schema extends z.ZodObject<infer Shape extends z.ZodRawShape>
206
+ ? z.ZodObject<Shape & SystemFields<TableName>>
207
+ : Schema extends z.ZodUnion<infer Options extends readonly z.ZodTypeAny[]>
208
+ ? z.ZodUnion<MapSystemFields<TableName, Options>>
209
+ : Schema extends z.ZodDiscriminatedUnion<
210
+ infer Options extends readonly z.ZodObject<z.ZodRawShape>[],
211
+ infer Disc extends string
212
+ >
213
+ ? z.ZodDiscriminatedUnion<MapSystemFields<TableName, Options>, Disc>
214
+ : Schema
215
+
216
+ // Overload 1: Object shape (most common case)
153
217
  export function zodTable<TableName extends string, Shape extends Record<string, z.ZodTypeAny>>(
154
218
  name: TableName,
155
219
  shape: Shape
156
- ): ReturnType<typeof Table<any, TableName>> & {
220
+ ): ReturnType<typeof Table<ConvexValidatorFromZodFieldsAuto<Shape>, TableName>> & {
157
221
  shape: Shape
158
222
  zDoc: z.ZodObject<
159
223
  Shape & {
@@ -171,6 +235,7 @@ export function zodTable<TableName extends string, Shape extends Record<string,
171
235
  >
172
236
  }
173
237
 
238
+ // Overload 2: Union/schema types
174
239
  export function zodTable<TableName extends string, Schema extends z.ZodTypeAny>(
175
240
  name: TableName,
176
241
  schema: Schema
@@ -179,8 +244,8 @@ export function zodTable<TableName extends string, Schema extends z.ZodTypeAny>(
179
244
  tableName: TableName
180
245
  validator: ReturnType<typeof zodToConvex<Schema>>
181
246
  schema: Schema
182
- docArray: z.ZodArray<ReturnType<typeof addSystemFields<TableName, Schema>>>
183
- withSystemFields: () => ReturnType<typeof addSystemFields<TableName, Schema>>
247
+ docArray: z.ZodArray<AddSystemFieldsResult<TableName, Schema>>
248
+ withSystemFields: () => AddSystemFieldsResult<TableName, Schema>
184
249
  }
185
250
 
186
251
  export function zodTable<