sonamu 0.7.8 → 0.7.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (34) hide show
  1. package/dist/database/base-model.d.ts +47 -2
  2. package/dist/database/base-model.d.ts.map +1 -1
  3. package/dist/database/base-model.js +87 -5
  4. package/dist/entity/entity-manager.d.ts +5 -5
  5. package/dist/entity/entity.d.ts +9 -0
  6. package/dist/entity/entity.d.ts.map +1 -1
  7. package/dist/entity/entity.js +16 -1
  8. package/dist/migration/code-generation.d.ts.map +1 -1
  9. package/dist/migration/code-generation.js +12 -9
  10. package/dist/migration/migration-set.js +3 -1
  11. package/dist/migration/postgresql-schema-reader.d.ts.map +1 -1
  12. package/dist/migration/postgresql-schema-reader.js +3 -2
  13. package/dist/template/implementations/generated.template.d.ts.map +1 -1
  14. package/dist/template/implementations/generated.template.js +3 -2
  15. package/dist/types/types.d.ts +30 -25
  16. package/dist/types/types.d.ts.map +1 -1
  17. package/dist/types/types.js +10 -7
  18. package/dist/vector/config.d.ts.map +1 -1
  19. package/dist/vector/config.js +2 -2
  20. package/dist/vector/embedding.d.ts +12 -8
  21. package/dist/vector/embedding.d.ts.map +1 -1
  22. package/dist/vector/embedding.js +59 -74
  23. package/dist/vector/vector-search.js +2 -2
  24. package/package.json +12 -5
  25. package/src/database/base-model.ts +132 -7
  26. package/src/entity/entity.ts +19 -0
  27. package/src/migration/code-generation.ts +15 -8
  28. package/src/migration/migration-set.ts +2 -0
  29. package/src/migration/postgresql-schema-reader.ts +1 -0
  30. package/src/template/implementations/generated.template.ts +3 -4
  31. package/src/types/types.ts +12 -6
  32. package/src/vector/config.ts +2 -4
  33. package/src/vector/embedding.ts +73 -104
  34. package/src/vector/vector-search.ts +1 -1
@@ -250,7 +250,8 @@ const BasePropFieldsWithoutAdditional = z.object({
250
250
  z.literal("date"),
251
251
  z.literal("date[]"),
252
252
  z.literal("uuid"),
253
- z.literal("uuid[]")
253
+ z.literal("uuid[]"),
254
+ z.literal("tsvector")
254
255
  ])
255
256
  }).strict();
256
257
  // precision/scale 필드
@@ -410,7 +411,8 @@ const NormalPropTypes = [
410
411
  "json",
411
412
  "virtual",
412
413
  "vector",
413
- "vector[]"
414
+ "vector[]",
415
+ "tsvector"
414
416
  ];
415
417
  // VIRTUAL Generated Column에서 사용 불가능한 타입들
416
418
  const VirtualGeneratedDisallowedTypes = [
@@ -510,15 +512,16 @@ const EntityIndexSchema = z.object({
510
512
  type: z.enum([
511
513
  "index",
512
514
  "unique",
513
- "fulltext",
514
515
  "hnsw",
515
516
  "ivfflat"
516
517
  ]),
517
518
  columns: z.array(EntityIndexColumnSchema),
518
519
  name: z.string().min(1).max(63),
519
- parser: z.enum([
520
- "built-in",
521
- "ngram"
520
+ using: z.enum([
521
+ "btree",
522
+ "hash",
523
+ "gin",
524
+ "gist"
522
525
  ]).optional(),
523
526
  nullsNotDistinct: z.boolean().optional(),
524
527
  m: z.number().optional(),
@@ -647,4 +650,4 @@ export const PathAndCode = z.object({
647
650
  });
648
651
  export var ApiParamType;
649
652
 
650
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/types/types.ts"],"sourcesContent":["import type { FastifyReply, FastifyRequest } from \"fastify\";\nimport { z } from \"zod\";\nimport type { ApiDecoratorOptions, AuthContext, Context } from \"../api\";\nimport type { GuardKey } from \"./../api/decorators\";\n\n/*\n  Utility Types\n*/\nexport function zArrayable<T extends z.ZodTypeAny>(shape: T): z.ZodUnion<[T, z.ZodArray<T>]> {\n  return z.union([shape, shape.array()]);\n}\n// biome-ignore lint/suspicious/noExplicitAny: any is used to make the type distributive\nexport type DistributiveOmit<T, K extends keyof any> = T extends any ? Omit<T, K> : never;\n\n/*\n  Model-Defintion\n*/\nexport type GeneratedColumnType = \"STORED\" | \"VIRTUAL\";\nexport type GeneratedColumn = {\n  type: GeneratedColumnType;\n  expression: string;\n};\nexport type CommonProp = {\n  name: string;\n  nullable?: boolean;\n  toFilter?: true;\n  desc?: string;\n  dbDefault?: string;\n  generated?: GeneratedColumn;\n};\nexport type IntegerProp = CommonProp & {\n  type: \"integer\";\n}; // PG: integer / TS: number / JSON: number\nexport type IntegerArrayProp = CommonProp & {\n  type: \"integer[]\";\n}; // PG: integer[] / TS: number[] / JSON: number[]\nexport type BigIntegerProp = CommonProp & {\n  type: \"bigInteger\";\n}; // PG: bigint / TS: bigint / JSON: bigint\nexport type BigIntegerArrayProp = CommonProp & {\n  type: \"bigInteger[]\";\n}; // PG: bigint[] / TS: bigint[] / JSON: bigint[]\nexport type StringProp = CommonProp & {\n  type: \"string\";\n  length?: number; // PG: varchar(n), text / TS: string / JSON: string\n}; // PG: text / TS: string / JSON: string\nexport type StringArrayProp = CommonProp & {\n  type: \"string[]\";\n  length?: number; // PG: varchar(n)[], text[] / TS: string[] / JSON: string[]\n}; // PG: varchar(n)[], text[] / TS: string[] / JSON: string[]\nexport type EnumProp = CommonProp & {\n  type: \"enum\";\n  id: string;\n  length?: number;\n}; // PG: text / TS: string / JSON: string\nexport type EnumArrayProp = CommonProp & {\n  type: \"enum[]\";\n  id: string;\n}; // PG: text[] / TS: string[] / JSON: string[]\nexport type NumberProp = CommonProp & {\n  type: \"number\";\n  precision?: number; // PG: numeric(p, s) / TS: number / JSON: number\n  scale?: number; // PG: numeric(p, s) / TS: number / JSON: number\n  numberType?: \"real\" | \"double precision\" | \"numeric\"; // 기본값: numeric\n}; // PG: numeric(p, s) / TS: number / JSON: number\nexport type NumberArrayProp = CommonProp & {\n  type: \"number[]\";\n  precision?: number;\n  scale?: number;\n  numberType?: \"real\" | \"double precision\" | \"numeric\"; // 기본값: numeric\n}; // PG: numeric(p, s)[] / TS: number[] / JSON: number[]\nexport type NumericProp = CommonProp & {\n  type: \"numeric\";\n  precision?: number;\n  scale?: number;\n}; // PG: numeric(p, s) / TS: string / JSON: string\nexport type NumericArrayProp = CommonProp & {\n  type: \"numeric[]\";\n  precision?: number;\n  scale?: number;\n}; // PG: numeric(p, s)[] / TS: string[] / JSON: string[]\nexport type BooleanProp = CommonProp & {\n  type: \"boolean\";\n}; // PG: boolean / TS: boolean / JSON: boolean\nexport type BooleanArrayProp = CommonProp & {\n  type: \"boolean[]\";\n}; // PG: boolean[] / TS: boolean[] / JSON: boolean[]\nexport type DateProp = CommonProp & {\n  type: \"date\";\n}; // PG: timestampz / TS: Date / JSON: string(ISOString)\nexport type DateArrayProp = CommonProp & {\n  type: \"date[]\";\n}; // PG: timestamptz[] / TS: Date[] / JSON: string[]\nexport type JsonProp = CommonProp & {\n  type: \"json\";\n  id: string;\n}; // PG: json / TS: any(id) / JSON: any\nexport type UuidProp = CommonProp & {\n  type: \"uuid\";\n}; // PG: uuid / TS: string / JSON: string\nexport type UuidArrayProp = CommonProp & {\n  type: \"uuid[]\";\n}; // PG: uuid[] / TS: string[] / JSON: string[]\nexport type VirtualProp = CommonProp & {\n  type: \"virtual\";\n  id: string;\n}; // PG: none / TS: any(id) / JSON: any\nexport type VectorProp = CommonProp & {\n  type: \"vector\";\n  dimensions: number;\n};\nexport type VectorArrayProp = CommonProp & {\n  type: \"vector[]\";\n  dimensions: number;\n};\nexport type RelationType = \"HasMany\" | \"BelongsToOne\" | \"ManyToMany\" | \"OneToOne\";\nexport type RelationOn = \"CASCADE\" | \"SET NULL\" | \"NO ACTION\" | \"SET DEFAULT\" | \"RESTRICT\";\ntype _RelationProp = {\n  type: \"relation\";\n  name: string;\n  with: string;\n  nullable?: boolean; // DEFAULT: false\n  toFilter?: true; // DEFAULT: false\n  desc?: string;\n};\nexport type OneToOneRelationProp = _RelationProp & {\n  relationType: \"OneToOne\";\n  customJoinClause?: string;\n} & (\n    | {\n        hasJoinColumn: true;\n        useConstraint?: boolean; // DEFAULT: true\n        onUpdate?: RelationOn; // DEFAULT: RESTRICT\n        onDelete?: RelationOn; // DEFAULT: RESTRICT\n      }\n    | {\n        hasJoinColumn: false;\n      }\n  );\nexport type BelongsToOneRelationProp = _RelationProp & {\n  relationType: \"BelongsToOne\";\n  customJoinClause?: string;\n  useConstraint?: boolean; // DEFAULT: true\n  onUpdate?: RelationOn; // DEFAULT: RESTRICT\n  onDelete?: RelationOn; // DEFAULT: RESTRICT\n};\nexport type HasManyRelationProp = _RelationProp & {\n  relationType: \"HasMany\";\n  joinColumn: string;\n  fromColumn?: string;\n};\nexport type ManyToManyRelationProp = _RelationProp & {\n  relationType: \"ManyToMany\";\n  joinTable: `${string}__${string}`;\n  onUpdate: RelationOn;\n  onDelete: RelationOn;\n};\nexport type RelationProp =\n  | OneToOneRelationProp\n  | BelongsToOneRelationProp\n  | HasManyRelationProp\n  | ManyToManyRelationProp;\n\nexport type EntityProp =\n  | IntegerProp\n  | IntegerArrayProp\n  | BigIntegerProp\n  | BigIntegerArrayProp\n  | StringProp\n  | StringArrayProp\n  | EnumProp\n  | EnumArrayProp\n  | NumberProp\n  | NumberArrayProp\n  | NumericProp\n  | NumericArrayProp\n  | NumericProp\n  | BooleanProp\n  | BooleanArrayProp\n  | DateProp\n  | DateArrayProp\n  | UuidProp\n  | UuidArrayProp\n  | JsonProp\n  | VirtualProp\n  | VectorProp\n  | VectorArrayProp\n  | RelationProp;\n\n/**\n * pgvector 거리 연산자 클래스\n *\n * @description\n * - `vector_cosine_ops`: 코사인 거리 (Cosine Distance) - 권장\n *   - SQL 연산자: `<=>`\n *   - 벡터의 방향만 비교 (크기 무시), 1 - cosine_similarity\n *   - 텍스트 임베딩, 시맨틱 검색에 가장 일반적으로 사용\n *   - 사용 예: OpenAI, Voyage 등 대부분의 임베딩 모델에 권장\n *\n * - `vector_ip_ops`: 내적 (Inner Product)\n *   - SQL 연산자: `<#>`\n *   - 두 벡터의 내적을 계산 (sum(a[i] * b[i]))\n *   - 정규화된 벡터에서 코사인 유사도와 동일한 결과\n *   - 값이 클수록 유사 (음수 연산자이므로 ORDER BY에서 주의)\n *   - 사용 예: 이미 정규화된 임베딩에서 가장 빠른 성능\n *\n * - `vector_l2_ops`: 유클리드 거리 (L2 Distance)\n *   - SQL 연산자: `<->`\n *   - 두 벡터 간의 직선 거리를 계산 (sqrt(sum((a[i] - b[i])^2)))\n *   - 벡터의 크기(magnitude)가 중요할 때 사용\n *   - 사용 예: 이미지 유사도, 절대적 거리 측정이 필요한 경우\n */\nexport type VectorOps = \"vector_cosine_ops\" | \"vector_ip_ops\" | \"vector_l2_ops\";\n\ntype EntityIndexColumn = {\n  name: string;\n  nullsFirst?: boolean;\n  sortOrder?: \"ASC\" | \"DESC\";\n  /** pgvector 인덱스에서 사용할 거리 연산자 (vector 컬럼에만 적용) */\n  vectorOps?: VectorOps;\n};\nexport type EntityIndex = {\n  type: \"index\" | \"unique\" | \"fulltext\" | \"hnsw\" | \"ivfflat\";\n  columns: EntityIndexColumn[];\n  name: string;\n  parser?: \"built-in\" | \"ngram\";\n  nullsNotDistinct?: boolean; // unique index only\n  /**\n   * HNSW (Hierarchical Navigable Small World) 인덱스: 각 노드의 최대 연결 수\n   *\n   * @description\n   * 그래프에서 각 노드가 가질 수 있는 최대 연결 수입니다.\n   * HNSW는 빠른 검색 속도와 높은 정확도를 제공하므로 권장됩니다.\n   * - 기본값: 16\n   * - 범위: 2 ~ 100\n   * - 높을수록: 정확도↑, 빌드 시간↑, 메모리↑\n   * - 권장: 빠른 빌드(8), 균형(16), 높은 정확도(32), 최고 정확도(64)\n   */\n  m?: number;\n  /**\n   * HNSW (Hierarchical Navigable Small World) 인덱스: 구성 시 탐색 범위\n   *\n   * @description\n   * 인덱스 구성 시 각 노드에서 탐색할 범위입니다.\n   * - 기본값: 64\n   * - 범위: 4 ~ 1000\n   * - 높을수록: 정확도↑, 빌드 시간↑\n   * - 권장: 빠른 빌드(32), 균형(64), 높은 정확도(128), 최고 정확도(256)\n   */\n  efConstruction?: number;\n  /**\n   * IVFFlat (Inverted File with Flat Compression) 인덱스: 클러스터링 리스트 수\n   *\n   * @description\n   * 벡터를 클러스터링할 버킷 수를 지정합니다.\n   * IVFFlat은 빠른 빌드와 낮은 메모리 사용이 필요할 때 사용합니다.\n   * - 권장값: sqrt(row_count) ~ row_count / 1000\n   * - 예시: 10,000행 → 100, 100,000행 → 300, 1,000,000행 → 1000\n   * - 많을수록 정확도↑, 검색 속도↓\n   */\n  lists?: number;\n};\nexport type EntityJson = {\n  id: string;\n  parentId?: string;\n  table: string;\n  title?: string;\n  props: EntityProp[];\n  indexes: EntityIndex[];\n  subsets: {\n    [subset: string]: string[];\n  };\n  enums: {\n    [enumId: string]: {\n      [key: string]: string;\n    };\n  };\n};\nexport type EntitySubsetRow = {\n  field: string;\n  has: {\n    [key: string]: boolean;\n  };\n  children: EntitySubsetRow[];\n  prefixes: string[];\n  relationEntity?: string;\n  isOpen?: boolean;\n};\nexport type FlattenSubsetRow = Omit<EntitySubsetRow, \"children\">;\n\n/*\n  PropNode\n*/\n\n/**\n * 엔티티의 필드 구조를 트리 형태로 표현하는 중간 노드입니다.\n *\n * **목적**: Entity의 subset 필드 표현식(예: \"id\", \"user.name\", \"tags[]\")을\n * 재귀적인 트리 구조로 파싱하여 Zod 스키마 생성의 중간 단계로 사용합니다.\n *\n * **변환 흐름**:\n * Entity subset → EntityPropNode (트리 구조) → Zod 스키마 → RenderingNode (UI용)\n *\n * **nodeType**:\n * - \"plain\": 단일 필드 (예: \"id\", \"name\")\n * - \"object\": 중첩 객체 (예: \"user.name\" → user 객체)\n * - \"array\": 배열 (예: \"tags[]\" → tags 배열)\n *\n * **사용 위치**: entity-converter.ts의 propNodeToZodType()\n */\nexport type EntityPropNode =\n  | {\n      nodeType: \"plain\";\n      prop: EntityProp;\n    }\n  | {\n      nodeType: \"object\" | \"array\";\n      prop?: EntityProp;\n      children: EntityPropNode[];\n    };\n\n/*\n  Prop Type Guards\n*/\nexport function isIntegerSingleProp(p: unknown): p is IntegerProp {\n  return (p as IntegerProp)?.type === \"integer\";\n}\nexport function isIntegerArrayProp(p: unknown): p is IntegerArrayProp {\n  return (p as IntegerArrayProp)?.type === \"integer[]\";\n}\nexport function isIntegerProp(p: unknown): p is IntegerProp | IntegerArrayProp {\n  return isIntegerSingleProp(p) || isIntegerArrayProp(p);\n}\nexport function isBigIntegerSingleProp(p: unknown): p is BigIntegerProp {\n  return (p as BigIntegerProp)?.type === \"bigInteger\";\n}\nexport function isBigIntegerArrayProp(p: unknown): p is BigIntegerArrayProp {\n  return (p as BigIntegerArrayProp)?.type === \"bigInteger[]\";\n}\nexport function isBigIntegerProp(p: unknown): p is BigIntegerProp | BigIntegerArrayProp {\n  return isBigIntegerSingleProp(p) || isBigIntegerArrayProp(p);\n}\nexport function isStringSingleProp(p: unknown): p is StringProp {\n  return (p as StringProp)?.type === \"string\";\n}\nexport function isStringArrayProp(p: unknown): p is StringArrayProp {\n  return (p as StringArrayProp)?.type === \"string[]\";\n}\nexport function isStringProp(p: unknown): p is StringProp | StringArrayProp {\n  return isStringSingleProp(p) || isStringArrayProp(p);\n}\nexport function isEnumSingleProp(p: unknown): p is EnumProp {\n  return (p as EnumProp)?.type === \"enum\";\n}\nexport function isEnumArrayProp(p: unknown): p is EnumArrayProp {\n  return (p as EnumArrayProp)?.type === \"enum[]\";\n}\nexport function isEnumProp(p: unknown): p is EnumProp | EnumArrayProp {\n  return isEnumSingleProp(p) || isEnumArrayProp(p);\n}\nexport function isNumberSingleProp(p: unknown): p is NumberProp {\n  return (p as NumberProp)?.type === \"number\";\n}\nexport function isNumberArrayProp(p: unknown): p is NumberArrayProp {\n  return (p as NumberArrayProp)?.type === \"number[]\";\n}\nexport function isNumberProp(p: unknown): p is NumberProp | NumberArrayProp {\n  return isNumberSingleProp(p) || isNumberArrayProp(p);\n}\nexport function isNumericSingleProp(p: unknown): p is NumericProp {\n  return (p as NumericProp)?.type === \"numeric\";\n}\nexport function isNumericArrayProp(p: unknown): p is NumericArrayProp {\n  return (p as NumericArrayProp)?.type === \"numeric[]\";\n}\nexport function isNumericProp(p: unknown): p is NumericProp | NumericArrayProp {\n  return isNumericSingleProp(p) || isNumericArrayProp(p);\n}\nexport function isBooleanSingleProp(p: unknown): p is BooleanProp {\n  return (p as BooleanProp)?.type === \"boolean\";\n}\nexport function isBooleanArrayProp(p: unknown): p is BooleanArrayProp {\n  return (p as BooleanArrayProp)?.type === \"boolean[]\";\n}\nexport function isBooleanProp(p: unknown): p is BooleanProp | BooleanArrayProp {\n  return isBooleanSingleProp(p) || isBooleanArrayProp(p);\n}\nexport function isDateSingleProp(p: unknown): p is DateProp {\n  return (p as DateProp)?.type === \"date\";\n}\nexport function isDateArrayProp(p: unknown): p is DateArrayProp {\n  return (p as DateArrayProp)?.type === \"date[]\";\n}\nexport function isDateProp(p: unknown): p is DateProp | DateArrayProp {\n  return isDateSingleProp(p) || isDateArrayProp(p);\n}\nexport function isUuidSingleProp(p: unknown): p is UuidProp {\n  return (p as UuidProp)?.type === \"uuid\";\n}\nexport function isUuidArrayProp(p: unknown): p is UuidArrayProp {\n  return (p as UuidArrayProp)?.type === \"uuid[]\";\n}\nexport function isUuidProp(p: unknown): p is UuidProp | UuidArrayProp {\n  return isUuidSingleProp(p) || isUuidArrayProp(p);\n}\nexport function isJsonProp(p: unknown): p is JsonProp {\n  return (p as JsonProp)?.type === \"json\";\n}\nexport function isVirtualProp(p: unknown): p is VirtualProp {\n  return (p as VirtualProp)?.type === \"virtual\";\n}\nexport function isVectorSingleProp(p: unknown): p is VectorProp {\n  return (p as VectorProp)?.type === \"vector\";\n}\nexport function isVectorArrayProp(p: unknown): p is VectorArrayProp {\n  return (p as VectorArrayProp)?.type === \"vector[]\";\n}\nexport function isVectorProp(p: unknown): p is VectorProp | VectorArrayProp {\n  return isVectorSingleProp(p) || isVectorArrayProp(p);\n}\nexport function isRelationProp(p: unknown): p is RelationProp {\n  return (p as RelationProp)?.type === \"relation\";\n}\nexport function isOneToOneRelationProp(p: unknown): p is OneToOneRelationProp {\n  return (p as OneToOneRelationProp)?.relationType === \"OneToOne\";\n}\nexport function isBelongsToOneRelationProp(p: unknown): p is BelongsToOneRelationProp {\n  return (p as BelongsToOneRelationProp)?.relationType === \"BelongsToOne\";\n}\nexport function isHasManyRelationProp(p: unknown): p is HasManyRelationProp {\n  return (p as HasManyRelationProp)?.relationType === \"HasMany\";\n}\nexport function isManyToManyRelationProp(p: unknown): p is ManyToManyRelationProp {\n  return (p as ManyToManyRelationProp)?.relationType === \"ManyToMany\";\n}\n\ntype JoinClause =\n  | {\n      from: string;\n      to: string;\n    }\n  | {\n      custom: string;\n    };\nexport function isCustomJoinClause(p: unknown): p is { custom: string } {\n  return !!(p as { custom: string })?.custom;\n}\n\ntype SubsetLoader = {\n  as: string;\n  table: string;\n  manyJoin: {\n    fromTable: string;\n    fromCol: string;\n    idField: string;\n    toTable: string;\n    toCol: string;\n    through?: {\n      table: string;\n      fromCol: string;\n      toCol: string;\n    };\n  };\n  oneJoins: ({\n    as: string;\n    join: \"inner\" | \"outer\";\n    table: string;\n  } & JoinClause)[];\n  select: string[];\n  loaders?: SubsetLoader[];\n};\n\nexport type SubsetQuery = {\n  select: string[];\n  virtual: string[];\n  joins: ({\n    as: string;\n    join: \"inner\" | \"outer\";\n    table: string;\n  } & JoinClause)[];\n  loaders: SubsetLoader[];\n};\n\n/* BaseModel */\nexport const SonamuQueryMode = z.enum([\"both\", \"list\", \"count\"]);\nexport type SonamuQueryMode = z.infer<typeof SonamuQueryMode>;\n\n/* Knex Migration */\nexport type KnexError = {\n  code: string;\n  errno: number;\n  sql: string;\n  sqlMessage: string;\n  sqlState: string;\n};\nexport function isKnexError(e: unknown): e is KnexError {\n  return !!(e as KnexError)?.code && !!(e as KnexError)?.sqlMessage && !!(e as KnexError)?.sqlState;\n}\n\nexport type KnexColumnType =\n  | \"string\"\n  | \"text\"\n  | \"smalltext\"\n  | \"mediumtext\"\n  | \"longtext\"\n  | \"integer\"\n  | \"bigInteger\"\n  | \"decimal\"\n  | \"timestamp\"\n  | \"boolean\"\n  | \"foreign\"\n  | \"uuid\"\n  | \"json\"\n  | \"float\"\n  | \"date\"\n  | \"time\"\n  | \"datetime\";\nexport type MigrationColumnType =\n  | \"string\"\n  | \"string[]\"\n  | \"integer\"\n  | \"integer[]\"\n  | \"bigInteger\"\n  | \"bigInteger[]\"\n  | \"numberOrNumeric\"\n  | \"numberOrNumeric[]\"\n  | \"boolean\"\n  | \"boolean[]\"\n  | \"date\"\n  | \"date[]\"\n  | \"uuid\"\n  | \"uuid[]\"\n  | \"json\"\n  | \"vector\"\n  | \"vector[]\"\n  | \"tsvector\";\nexport type MigrationColumn = {\n  name: string;\n  type: MigrationColumnType;\n  nullable: boolean;\n  numberType?: \"real\" | \"double precision\" | \"numeric\";\n  length?: number;\n  defaultTo?: string;\n  precision?: number;\n  scale?: number;\n  dimensions?: number;\n  generated?: GeneratedColumn;\n};\nexport type MigrationIndex = {\n  type: \"unique\" | \"index\" | \"fulltext\" | \"hnsw\" | \"ivfflat\";\n  columns: EntityIndexColumn[];\n  name: string;\n  parser?: \"built-in\" | \"ngram\";\n  nullsNotDistinct?: boolean;\n  /** HNSW (Hierarchical Navigable Small World): 각 노드의 최대 연결 수 */\n  m?: number;\n  /** HNSW (Hierarchical Navigable Small World): 구성 시 탐색 범위 */\n  efConstruction?: number;\n  /** IVFFlat (Inverted File with Flat Compression): 클러스터링 리스트 수 */\n  lists?: number;\n};\nexport type MigrationForeign = {\n  columns: string[];\n  to: string;\n  onUpdate: RelationOn;\n  onDelete: RelationOn;\n};\nexport type MigrationJoinTable = {\n  table: string;\n  indexes: MigrationIndex[];\n  columns: MigrationColumn[];\n  foreigns: MigrationForeign[];\n};\nexport type MigrationSet = {\n  table: string;\n  columns: MigrationColumn[];\n  indexes: MigrationIndex[];\n  foreigns: MigrationForeign[];\n};\nexport type MigrationSetAndJoinTable = MigrationSet & {\n  joinTables: MigrationJoinTable[];\n};\nexport type GenMigrationCode = {\n  title: string;\n  table: string;\n  type: \"normal\" | \"foreign\";\n  formatted: string | null;\n};\n\n/* Api */\nexport type ApiParam = {\n  name: string;\n  type: ApiParamType;\n  optional: boolean;\n  defaultDef?: string;\n};\nexport namespace ApiParamType {\n  export type Object = {\n    t: \"object\";\n    props: ApiParam[];\n  };\n  export type Union = {\n    t: \"union\";\n    types: ApiParamType[];\n  };\n  export type Intersection = {\n    t: \"intersection\";\n    types: ApiParamType[];\n  };\n  export type StringLiteral = {\n    t: \"string-literal\";\n    value: string;\n  };\n  export type NumericLiteral = {\n    t: \"numeric-literal\";\n    value: number;\n  };\n  export type Array = {\n    t: \"array\";\n    elementsType: ApiParamType;\n  };\n  export type Ref = {\n    t: \"ref\";\n    id: string;\n    args?: ApiParamType[];\n  };\n  export type IndexedAccess = {\n    t: \"indexed-access\";\n    object: ApiParamType;\n    index: ApiParamType;\n  };\n  export type TupleType = {\n    t: \"tuple-type\";\n    elements: ApiParamType[];\n  };\n  export type Pick = Ref & {\n    t: \"ref\";\n    id: \"Pick\";\n  };\n  export type Omit = Ref & {\n    t: \"ref\";\n    id: \"Omit\";\n  };\n  export type Partial = Ref & {\n    t: \"ref\";\n    id: \"Partial\";\n  };\n  export type Promise = Ref & {\n    t: \"ref\";\n    id: \"Promise\";\n  };\n  export type Context = Ref & {\n    t: \"ref\";\n    id: \"Context\";\n  };\n  export type TypeParam = {\n    t: \"type-param\";\n    id: string;\n    constraint?: ApiParamType;\n  };\n\n  export function isObject(v: unknown): v is ApiParamType.Object {\n    return (v as ApiParamType.Object)?.t === \"object\";\n  }\n  export function isUnion(v: unknown): v is ApiParamType.Union {\n    return (v as ApiParamType.Union)?.t === \"union\";\n  }\n  export function isIntersection(v: unknown): v is ApiParamType.Intersection {\n    return (v as ApiParamType.Intersection)?.t === \"intersection\";\n  }\n  export function isStringLiteral(v: unknown): v is ApiParamType.StringLiteral {\n    return (v as ApiParamType.StringLiteral)?.t === \"string-literal\";\n  }\n  export function isNumericLiteral(v: unknown): v is ApiParamType.NumericLiteral {\n    return (v as ApiParamType.NumericLiteral)?.t === \"numeric-literal\";\n  }\n  export function isArray(v: unknown): v is ApiParamType.Array {\n    return (v as ApiParamType.Array)?.t === \"array\";\n  }\n  export function isRef(v: unknown): v is ApiParamType.Ref {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"ref\";\n  }\n  export function isIndexedAccess(v: unknown): v is ApiParamType.IndexedAccess {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"indexed-access\";\n  }\n  export function isTupleType(v: unknown): v is ApiParamType.TupleType {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"tuple-type\";\n  }\n  export function isPick(v: unknown): v is ApiParamType.Pick {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Pick\"\n    );\n  }\n  export function isOmit(v: unknown): v is ApiParamType.Omit {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Omit\"\n    );\n  }\n  export function isPartial(v: unknown): v is ApiParamType.Partial {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Partial\"\n    );\n  }\n  export function isPromise(v: unknown): v is ApiParamType.Promise {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Promise\"\n    );\n  }\n  export function isContext(v: unknown): v is ApiParamType.Context {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Context\"\n    );\n  }\n  export function isRefKnex(v: unknown): v is ApiParamType.Ref {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Knex\"\n    );\n  }\n  export function isTypeParam(v: unknown): v is ApiParamType.TypeParam {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"type-param\";\n  }\n}\nexport type ApiParamType =\n  | \"string\"\n  | \"number\"\n  | \"boolean\"\n  | \"null\"\n  | \"undefined\"\n  | \"void\"\n  | \"any\"\n  | \"unknown\"\n  | \"true\"\n  | \"false\"\n  | ApiParamType.StringLiteral\n  | ApiParamType.NumericLiteral\n  | ApiParamType.Object\n  | ApiParamType.Union\n  | ApiParamType.Intersection\n  | ApiParamType.Array\n  | ApiParamType.Ref\n  | ApiParamType.IndexedAccess\n  | ApiParamType.TypeParam\n  | ApiParamType.TupleType;\n\n/* Template */\n/**\n * UI 컴포넌트 렌더링을 위한 메타데이터 노드입니다.\n *\n * **목적**: Zod 스키마로부터 프론트엔드 UI 컴포넌트를 자동 생성하기 위한\n * 렌더링 정보를 담은 트리 구조입니다. 각 필드가 어떤 UI 컴포넌트로\n * 표현되어야 하는지(텍스트, 이미지, 날짜, Enum 선택 등)를 명시합니다.\n *\n * **변환 흐름**:\n * Entity subset → EntityPropNode → Zod 스키마 → RenderingNode (UI용) → React 컴포넌트 코드 생성\n *\n * **주요 필드**:\n * - `renderType`: UI 컴포넌트 유형 (string-plain, number-fk_id, enums, array 등)\n * - `zodType`: 원본 Zod 스키마 (validation 용)\n * - `children`: 중첩된 객체 필드들 (object일 때)\n * - `element`: 배열 요소 타입 (array일 때)\n *\n * **사용 위치**:\n * - zod-converter.ts의 zodTypeToRenderingNode()에서 생성\n * - view_form.template.ts, view_list.template.ts 등에서 React 컴포넌트 코드 생성에 사용\n */\n// 셀프 참조 타입이므로 Zod 생략하고 직접 정의\nexport const RenderingNode = z.any();\nexport type RenderingNode = {\n  name: string;\n  label: string;\n  renderType:\n    | \"string-plain\"\n    | \"string-image\"\n    | \"string-datetime\"\n    | \"string-date\"\n    | \"datetime\"\n    | \"number-plain\"\n    | \"number-id\"\n    | \"number-fk_id\"\n    | \"boolean\"\n    | \"enums\"\n    | \"array\"\n    | \"array-images\"\n    | \"object\"\n    | \"object-pick\"\n    | \"record\"\n    | \"vector\";\n  zodType: z.ZodTypeAny;\n  element?: RenderingNode;\n  children?: RenderingNode[];\n  config?: {\n    picked: string;\n  };\n  optional?: boolean;\n  nullable?: boolean;\n};\n\nconst GeneratedColumnSchema = z.object({\n  type: z.enum([\"STORED\", \"VIRTUAL\"]),\n  expression: z.string(),\n});\n\nconst BasePropFields = {\n  name: z.string(),\n  desc: z.string().optional(),\n  nullable: z.boolean().optional(),\n  toFilter: z.boolean().default(false).optional(),\n  dbDefault: z.union([z.string(), z.number(), z.boolean()]).optional(),\n  generated: GeneratedColumnSchema.optional(),\n};\n\n// 부가 필드가 필요없는 prop\nconst BasePropFieldsWithoutAdditional = z\n  .object({\n    ...BasePropFields,\n    type: z.union([\n      z.literal(\"integer\"),\n      z.literal(\"integer[]\"),\n      z.literal(\"bigInteger\"),\n      z.literal(\"bigInteger[]\"),\n      z.literal(\"boolean\"),\n      z.literal(\"boolean[]\"),\n      z.literal(\"date\"),\n      z.literal(\"date[]\"),\n      z.literal(\"uuid\"),\n      z.literal(\"uuid[]\"),\n    ]),\n  })\n  .strict();\n\n// precision/scale 필드\nconst PrecisionScaleFields = {\n  precision: z.number().optional(),\n  scale: z.number().optional(),\n};\n\n// 각 타입별 스키마 정의\n\nconst StringPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"string\"),\n    length: z.number().optional(),\n  })\n  .strict();\nconst StringArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"string[]\"),\n    length: z.number().optional(),\n  })\n  .strict();\n\nconst EnumPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"enum\"),\n    id: z.string(),\n    length: z.number().optional(),\n  })\n  .strict();\nconst EnumArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"enum[]\"),\n    id: z.string(),\n  })\n  .strict();\n\nconst NumberPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"number\"),\n    ...PrecisionScaleFields,\n    numberType: z.enum([\"real\", \"double precision\", \"numeric\"]).optional(),\n  })\n  .strict();\nconst NumberArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"number[]\"),\n    ...PrecisionScaleFields,\n    numberType: z.enum([\"real\", \"double precision\", \"numeric\"]).optional(),\n  })\n  .strict();\n\nconst NumericPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"numeric\"),\n    ...PrecisionScaleFields,\n  })\n  .strict();\nconst NumericArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"numeric[]\"),\n    ...PrecisionScaleFields,\n  })\n  .strict();\n\nconst JsonPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"json\"),\n    id: z.string(),\n  })\n  .strict();\n\nconst VirtualPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"virtual\"),\n    id: z.string(),\n  })\n  .strict();\n\nconst VectorPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"vector\"),\n    dimensions: z.number(),\n  })\n  .strict();\nconst VectorArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"vector[]\"),\n    dimensions: z.number(),\n  })\n  .strict();\n\n// Relation 타입은 relationType에 따라 세분화\nconst BaseRelationFields = {\n  ...BasePropFields,\n  type: z.literal(\"relation\"),\n  with: z.string(),\n};\n\n// RelationOn 타입\nconst RelationOnSchema = z.enum([\"CASCADE\", \"SET NULL\", \"NO ACTION\", \"SET DEFAULT\", \"RESTRICT\"]);\n\nconst BelongsToOneRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"BelongsToOne\"),\n    customJoinClause: z.string().optional(),\n    useConstraint: z.boolean().optional(),\n    onUpdate: RelationOnSchema.optional(),\n    onDelete: RelationOnSchema.optional(),\n  })\n  .strict();\n\nconst HasManyRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"HasMany\"),\n    joinColumn: z.string(),\n    fromColumn: z.string().optional(),\n  })\n  .strict();\n\nconst ManyToManyRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"ManyToMany\"),\n    joinTable: z.string(),\n    onUpdate: RelationOnSchema,\n    onDelete: RelationOnSchema,\n  })\n  .strict();\n\nconst OneToOneRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"OneToOne\"),\n    customJoinClause: z.string().optional(),\n    hasJoinColumn: z.boolean().optional(),\n    useConstraint: z.boolean().optional(),\n    onUpdate: RelationOnSchema.optional(),\n    onDelete: RelationOnSchema.optional(),\n  })\n  .strict();\n\nconst RelationTypes = [\"BelongsToOne\", \"HasMany\", \"ManyToMany\", \"OneToOne\"] as const;\nexport const RelationPropSchema = z.discriminatedUnion(\n  \"relationType\",\n  [\n    BelongsToOneRelationPropSchema,\n    HasManyRelationPropSchema,\n    ManyToManyRelationPropSchema,\n    OneToOneRelationPropSchema,\n  ],\n  {\n    error: (iss) =>\n      `relationType은 ${RelationTypes.map((t) => `'${t}'`).join(\", \")} 중 하나여야 합니다. 입력값: \"${(iss.input as Record<string, unknown>)?.relationType}\"`,\n  },\n);\n\nconst NormalPropTypes = [\n  \"integer\",\n  \"integer[]\",\n  \"bigInteger\",\n  \"bigInteger[]\",\n  \"string\",\n  \"string[]\",\n  \"enum\",\n  \"enum[]\",\n  \"number\",\n  \"number[]\",\n  \"numeric\",\n  \"numeric[]\",\n  \"boolean\",\n  \"boolean[]\",\n  \"date\",\n  \"date[]\",\n  \"uuid\",\n  \"uuid[]\",\n  \"json\",\n  \"virtual\",\n  \"vector\",\n  \"vector[]\",\n] as const;\n\n// VIRTUAL Generated Column에서 사용 불가능한 타입들\nconst VirtualGeneratedDisallowedTypes = [\n  \"json\",\n  \"vector\",\n  \"vector[]\",\n  \"string[]\",\n  \"integer[]\",\n  \"bigInteger[]\",\n  \"boolean[]\",\n  \"date[]\",\n  \"uuid[]\",\n  \"number[]\",\n  \"numeric[]\",\n  \"enum[]\",\n] as const;\n\nexport const NormalPropSchema = z\n  .discriminatedUnion(\n    \"type\",\n    [\n      BasePropFieldsWithoutAdditional,\n      StringPropSchema,\n      StringArrayPropSchema,\n      EnumPropSchema,\n      EnumArrayPropSchema,\n      NumberPropSchema,\n      NumberArrayPropSchema,\n      NumericPropSchema,\n      NumericArrayPropSchema,\n      JsonPropSchema,\n      VirtualPropSchema,\n      VectorPropSchema,\n      VectorArrayPropSchema,\n    ],\n    {\n      error: (iss) =>\n        `type은 ${NormalPropTypes.map((t) => `'${t}'`).join(\", \")} 중 하나여야 합니다. 입력값: \"${(iss.input as Record<string, unknown>)?.type}\"`,\n    },\n  )\n  .superRefine((data, ctx) => {\n    if (!data.generated) {\n      return;\n    }\n\n    // dbDefault와 generated 동시 사용 불가\n    if (data.dbDefault !== undefined) {\n      ctx.addIssue({\n        code: \"custom\",\n        message: \"dbDefault와 generated는 함께 사용할 수 없습니다\",\n        path: [\"generated\"],\n      });\n    }\n\n    // virtual 타입은 generated 불가\n    if (data.type === \"virtual\") {\n      ctx.addIssue({\n        code: \"custom\",\n        message: \"virtual 타입은 generated column을 지원하지 않습니다\",\n        path: [\"generated\"],\n      });\n    }\n\n    // VIRTUAL Generated Column 타입 제한 검증\n    if (data.generated.type === \"VIRTUAL\") {\n      if ((VirtualGeneratedDisallowedTypes as readonly string[]).includes(data.type)) {\n        ctx.addIssue({\n          code: \"custom\",\n          message: `VIRTUAL generated column은 ${data.type} 타입을 지원하지 않습니다. STORED를 사용하세요.`,\n          path: [\"generated\", \"type\"],\n          fatal: true,\n        });\n      }\n    }\n  });\n\nconst AllPropTypes = [...NormalPropTypes, \"relation\"] as const;\nconst EntityPropSchema = z.discriminatedUnion(\"type\", [NormalPropSchema, RelationPropSchema], {\n  error: (iss) =>\n    `type은 ${AllPropTypes.map((t) => `'${t}'`).join(\", \")} 중 하나여야 합니다. 입력값: \"${(iss.input as Record<string, unknown>)?.type}\"`,\n});\n\nconst EntityIndexColumnSchema = z.object({\n  name: z.string(),\n  nullsFirst: z.boolean().optional(),\n  sortOrder: z.enum([\"ASC\", \"DESC\"]).optional(),\n  vectorOps: z.enum([\"vector_cosine_ops\", \"vector_ip_ops\", \"vector_l2_ops\"]).optional(),\n});\n\n// EntityIndex 스키마 정의\nconst EntityIndexSchema = z\n  .object({\n    type: z.enum([\"index\", \"unique\", \"fulltext\", \"hnsw\", \"ivfflat\"]),\n    columns: z.array(EntityIndexColumnSchema),\n    name: z.string().min(1).max(63),\n    parser: z.enum([\"built-in\", \"ngram\"]).optional(),\n    nullsNotDistinct: z.boolean().optional(),\n    m: z.number().optional(),\n    efConstruction: z.number().optional(),\n    lists: z.number().optional(),\n  })\n  .strict();\n\nexport const EntityJsonSchema = z\n  .object({\n    id: z.string().describe(\"PascalCase로 된 Entity ID\"),\n    title: z.string().describe(\"Entity 이름\"),\n    table: z.string().describe(\"snake_case로 된 테이블명\"),\n    parentId: z.string().optional().describe(\"부모 Entity ID\"),\n    props: z.array(EntityPropSchema),\n    indexes: z.array(EntityIndexSchema),\n    subsets: z.record(z.string(), z.array(z.string())),\n    enums: z.record(z.string(), z.record(z.string(), z.string())),\n  })\n  .strict();\n\nexport const TemplateOptions = z.object({\n  entity: EntityJsonSchema.omit({ id: true })\n    .extend({\n      entityId: z.string(),\n    })\n    .partial({\n      table: true,\n      props: true,\n      indexes: true,\n      subsets: true,\n      enums: true,\n    }),\n  init_types: z.object({\n    entityId: z.string(),\n  }),\n  generated: z.object({}),\n  generated_sso: z.object({}),\n  generated_http: z.object({\n    entityId: z.string(),\n  }),\n  model: z.object({\n    entityId: z.string(),\n    defaultSearchField: z.string().optional(),\n    defaultOrderBy: z.string().optional(),\n  }),\n  model_test: z.object({\n    entityId: z.string(),\n  }),\n  bridge: z.object({\n    entityId: z.string(),\n  }),\n  service: z.object({\n    namesRecord: z.object({\n      fs: z.string(),\n      fsPlural: z.string(),\n      camel: z.string(),\n      camelPlural: z.string(),\n      capital: z.string(),\n      capitalPlural: z.string(),\n      upper: z.string(),\n      constant: z.string(),\n    }),\n    modelTsPath: z.string(),\n  }),\n  view_list: z.object({\n    entityId: z.string(),\n    extra: z.unknown(),\n  }),\n  view_list_columns: z.object({\n    entityId: z.string(),\n    columns: z\n      .object({\n        name: z.string(),\n        label: z.string(),\n        tc: z.string(),\n      })\n      .array(),\n    columnImports: z.string(),\n  }),\n  view_search_input: z.object({\n    entityId: z.string(),\n  }),\n  view_form: z.object({\n    entityId: z.string(),\n  }),\n  view_id_all_select: z.object({\n    entityId: z.string(),\n  }),\n  view_id_async_select: z.object({\n    entityId: z.string(),\n    textField: z.string(),\n  }),\n  view_enums_select: z.object({\n    entityId: z.string(),\n    enumId: z.string(),\n  }),\n  view_enums_dropdown: z.object({\n    entityId: z.string(),\n    enumId: z.string(),\n  }),\n  view_enums_buttonset: z.object({\n    entityId: z.string(),\n    enumId: z.string(),\n  }),\n});\nexport type TemplateOptions = z.infer<typeof TemplateOptions>;\n\nexport const TemplateKey = z.enum([\n  \"entity\",\n  \"init_types\",\n  \"generated\",\n  \"generated_sso\",\n  \"generated_http\",\n  \"model\",\n  \"model_test\",\n  \"bridge\",\n  \"service\",\n  \"view_list\",\n  \"view_list_columns\",\n  \"view_search_input\",\n  \"view_form\",\n  \"view_id_all_select\",\n  \"view_id_async_select\",\n  \"view_enums_select\",\n  \"view_enums_dropdown\",\n  \"view_enums_buttonset\",\n]);\nexport type TemplateKey = z.infer<typeof TemplateKey>;\n\nexport const GenerateOptions = z.object({\n  overwrite: z.boolean().optional(),\n});\nexport type GenerateOptions = z.infer<typeof GenerateOptions>;\n\nexport const PathAndCode = z.object({\n  path: z.string(),\n  code: z.string(),\n});\nexport type PathAndCode = z.infer<typeof PathAndCode>;\n\nexport type FixtureSearchOptions = {\n  entityId: string;\n  field: string;\n  value: string;\n  searchType: \"equals\" | \"like\";\n};\n\ntype ColumnValue = string | number | boolean | Date | null;\nexport type FixtureRecord = {\n  fixtureId: string;\n  entityId: string;\n  id: number;\n  columns: {\n    [key: string]: {\n      prop: EntityProp;\n      value: ColumnValue | ColumnValue[];\n    };\n  };\n  fetchedRecords: string[];\n  belongsRecords: string[];\n  target?: FixtureRecord; // Import 대상 DB 레코드(id가 같은)\n  unique?: FixtureRecord; // Import 대상 DB 레코드(unique key가 같은)\n  override?: boolean;\n};\n\nexport type FixtureImportResult = {\n  entityId: string;\n  data: {\n    [key: string]: ColumnValue;\n  };\n};\n\nexport type RelationNode = {\n  fixtureId: string;\n  entityId: string;\n  related: Set<string>;\n};\n\n// biome-ignore lint/suspicious/noEmptyInterface: sonamu.generated.sso 에서 확장을 위해 준비된 빈 인터페이스\nexport interface DatabaseSchemaExtend {}\n// biome-ignore lint/suspicious/noEmptyInterface: sonamu.generated.sso 에서 확장을 위해 준비된 빈 인터페이스\nexport interface DatabaseForeignKeys {}\nexport type ManyToManyBaseSchema<FromIdKey extends string, ToIdKey extends string> = {\n  id: number;\n} & {\n  [K in `${FromIdKey}_id`]: number;\n} & {\n  [K in `${ToIdKey}_id`]: number;\n};\n\nexport type SonamuFastifyConfig = {\n  contextProvider: (\n    defaultContext: Pick<Context, \"request\" | \"reply\" | \"headers\" | \"createSSE\" | \"naiteStore\"> &\n      AuthContext,\n    request: FastifyRequest,\n    reply: FastifyReply,\n  ) => Context | Promise<Context>;\n  guardHandler: (\n    guard: GuardKey,\n    request: FastifyRequest,\n    api: {\n      typeParameters: ApiParamType.TypeParam[];\n      parameters: ApiParam[];\n      returnType: ApiParamType;\n      modelName: string;\n      methodName: string;\n      path: string;\n      options: ApiDecoratorOptions;\n    },\n  ) => void;\n};\n"],"names":["z","zArrayable","shape","union","array","isIntegerSingleProp","p","type","isIntegerArrayProp","isIntegerProp","isBigIntegerSingleProp","isBigIntegerArrayProp","isBigIntegerProp","isStringSingleProp","isStringArrayProp","isStringProp","isEnumSingleProp","isEnumArrayProp","isEnumProp","isNumberSingleProp","isNumberArrayProp","isNumberProp","isNumericSingleProp","isNumericArrayProp","isNumericProp","isBooleanSingleProp","isBooleanArrayProp","isBooleanProp","isDateSingleProp","isDateArrayProp","isDateProp","isUuidSingleProp","isUuidArrayProp","isUuidProp","isJsonProp","isVirtualProp","isVectorSingleProp","isVectorArrayProp","isVectorProp","isRelationProp","isOneToOneRelationProp","relationType","isBelongsToOneRelationProp","isHasManyRelationProp","isManyToManyRelationProp","isCustomJoinClause","custom","SonamuQueryMode","enum","isKnexError","e","code","sqlMessage","sqlState","ApiParamType","isObject","v","t","isUnion","isIntersection","isStringLiteral","isNumericLiteral","isArray","isRef","isIndexedAccess","isTupleType","isPick","id","isOmit","isPartial","isPromise","isContext","isRefKnex","isTypeParam","RenderingNode","any","GeneratedColumnSchema","object","expression","string","BasePropFields","name","desc","optional","nullable","boolean","toFilter","default","dbDefault","number","generated","BasePropFieldsWithoutAdditional","literal","strict","PrecisionScaleFields","precision","scale","StringPropSchema","length","StringArrayPropSchema","EnumPropSchema","EnumArrayPropSchema","NumberPropSchema","numberType","NumberArrayPropSchema","NumericPropSchema","NumericArrayPropSchema","JsonPropSchema","VirtualPropSchema","VectorPropSchema","dimensions","VectorArrayPropSchema","BaseRelationFields","with","RelationOnSchema","BelongsToOneRelationPropSchema","customJoinClause","useConstraint","onUpdate","onDelete","HasManyRelationPropSchema","joinColumn","fromColumn","ManyToManyRelationPropSchema","joinTable","OneToOneRelationPropSchema","hasJoinColumn","RelationTypes","RelationPropSchema","discriminatedUnion","error","iss","map","join","input","NormalPropTypes","VirtualGeneratedDisallowedTypes","NormalPropSchema","superRefine","data","ctx","undefined","addIssue","message","path","includes","fatal","AllPropTypes","EntityPropSchema","EntityIndexColumnSchema","nullsFirst","sortOrder","vectorOps","EntityIndexSchema","columns","min","max","parser","nullsNotDistinct","m","efConstruction","lists","EntityJsonSchema","describe","title","table","parentId","props","indexes","subsets","record","enums","TemplateOptions","entity","omit","extend","entityId","partial","init_types","generated_sso","generated_http","model","defaultSearchField","defaultOrderBy","model_test","bridge","service","namesRecord","fs","fsPlural","camel","camelPlural","capital","capitalPlural","upper","constant","modelTsPath","view_list","extra","unknown","view_list_columns","label","tc","columnImports","view_search_input","view_form","view_id_all_select","view_id_async_select","textField","view_enums_select","enumId","view_enums_dropdown","view_enums_buttonset","TemplateKey","GenerateOptions","overwrite","PathAndCode"],"mappings":"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"}
653
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/types/types.ts"],"sourcesContent":["import type { FastifyReply, FastifyRequest } from \"fastify\";\nimport { z } from \"zod\";\nimport type { ApiDecoratorOptions, AuthContext, Context } from \"../api\";\nimport type { GuardKey } from \"./../api/decorators\";\n\n/*\n  Utility Types\n*/\nexport function zArrayable<T extends z.ZodTypeAny>(shape: T): z.ZodUnion<[T, z.ZodArray<T>]> {\n  return z.union([shape, shape.array()]);\n}\n// biome-ignore lint/suspicious/noExplicitAny: any is used to make the type distributive\nexport type DistributiveOmit<T, K extends keyof any> = T extends any ? Omit<T, K> : never;\n\n/*\n  Model-Defintion\n*/\nexport type GeneratedColumnType = \"STORED\" | \"VIRTUAL\";\nexport type GeneratedColumn = {\n  type: GeneratedColumnType;\n  expression: string;\n};\nexport type CommonProp = {\n  name: string;\n  nullable?: boolean;\n  toFilter?: true;\n  desc?: string;\n  dbDefault?: string;\n  generated?: GeneratedColumn;\n};\nexport type IntegerProp = CommonProp & {\n  type: \"integer\";\n}; // PG: integer / TS: number / JSON: number\nexport type IntegerArrayProp = CommonProp & {\n  type: \"integer[]\";\n}; // PG: integer[] / TS: number[] / JSON: number[]\nexport type BigIntegerProp = CommonProp & {\n  type: \"bigInteger\";\n}; // PG: bigint / TS: bigint / JSON: bigint\nexport type BigIntegerArrayProp = CommonProp & {\n  type: \"bigInteger[]\";\n}; // PG: bigint[] / TS: bigint[] / JSON: bigint[]\nexport type StringProp = CommonProp & {\n  type: \"string\";\n  length?: number; // PG: varchar(n), text / TS: string / JSON: string\n}; // PG: text / TS: string / JSON: string\nexport type StringArrayProp = CommonProp & {\n  type: \"string[]\";\n  length?: number; // PG: varchar(n)[], text[] / TS: string[] / JSON: string[]\n}; // PG: varchar(n)[], text[] / TS: string[] / JSON: string[]\nexport type EnumProp = CommonProp & {\n  type: \"enum\";\n  id: string;\n  length?: number;\n}; // PG: text / TS: string / JSON: string\nexport type EnumArrayProp = CommonProp & {\n  type: \"enum[]\";\n  id: string;\n}; // PG: text[] / TS: string[] / JSON: string[]\nexport type NumberProp = CommonProp & {\n  type: \"number\";\n  precision?: number; // PG: numeric(p, s) / TS: number / JSON: number\n  scale?: number; // PG: numeric(p, s) / TS: number / JSON: number\n  numberType?: \"real\" | \"double precision\" | \"numeric\"; // 기본값: numeric\n}; // PG: numeric(p, s) / TS: number / JSON: number\nexport type NumberArrayProp = CommonProp & {\n  type: \"number[]\";\n  precision?: number;\n  scale?: number;\n  numberType?: \"real\" | \"double precision\" | \"numeric\"; // 기본값: numeric\n}; // PG: numeric(p, s)[] / TS: number[] / JSON: number[]\nexport type NumericProp = CommonProp & {\n  type: \"numeric\";\n  precision?: number;\n  scale?: number;\n}; // PG: numeric(p, s) / TS: string / JSON: string\nexport type NumericArrayProp = CommonProp & {\n  type: \"numeric[]\";\n  precision?: number;\n  scale?: number;\n}; // PG: numeric(p, s)[] / TS: string[] / JSON: string[]\nexport type BooleanProp = CommonProp & {\n  type: \"boolean\";\n}; // PG: boolean / TS: boolean / JSON: boolean\nexport type BooleanArrayProp = CommonProp & {\n  type: \"boolean[]\";\n}; // PG: boolean[] / TS: boolean[] / JSON: boolean[]\nexport type DateProp = CommonProp & {\n  type: \"date\";\n}; // PG: timestampz / TS: Date / JSON: string(ISOString)\nexport type DateArrayProp = CommonProp & {\n  type: \"date[]\";\n}; // PG: timestamptz[] / TS: Date[] / JSON: string[]\nexport type JsonProp = CommonProp & {\n  type: \"json\";\n  id: string;\n}; // PG: json / TS: any(id) / JSON: any\nexport type UuidProp = CommonProp & {\n  type: \"uuid\";\n}; // PG: uuid / TS: string / JSON: string\nexport type UuidArrayProp = CommonProp & {\n  type: \"uuid[]\";\n}; // PG: uuid[] / TS: string[] / JSON: string[]\nexport type VirtualProp = CommonProp & {\n  type: \"virtual\";\n  id: string;\n}; // PG: none / TS: any(id) / JSON: any\nexport type VectorProp = CommonProp & {\n  type: \"vector\";\n  dimensions: number;\n};\nexport type VectorArrayProp = CommonProp & {\n  type: \"vector[]\";\n  dimensions: number;\n};\nexport type TsVectorProp = CommonProp & {\n  type: \"tsvector\";\n};\nexport type RelationType = \"HasMany\" | \"BelongsToOne\" | \"ManyToMany\" | \"OneToOne\";\nexport type RelationOn = \"CASCADE\" | \"SET NULL\" | \"NO ACTION\" | \"SET DEFAULT\" | \"RESTRICT\";\ntype _RelationProp = {\n  type: \"relation\";\n  name: string;\n  with: string;\n  nullable?: boolean; // DEFAULT: false\n  toFilter?: true; // DEFAULT: false\n  desc?: string;\n};\nexport type OneToOneRelationProp = _RelationProp & {\n  relationType: \"OneToOne\";\n  customJoinClause?: string;\n} & (\n    | {\n        hasJoinColumn: true;\n        useConstraint?: boolean; // DEFAULT: true\n        onUpdate?: RelationOn; // DEFAULT: RESTRICT\n        onDelete?: RelationOn; // DEFAULT: RESTRICT\n      }\n    | {\n        hasJoinColumn: false;\n      }\n  );\nexport type BelongsToOneRelationProp = _RelationProp & {\n  relationType: \"BelongsToOne\";\n  customJoinClause?: string;\n  useConstraint?: boolean; // DEFAULT: true\n  onUpdate?: RelationOn; // DEFAULT: RESTRICT\n  onDelete?: RelationOn; // DEFAULT: RESTRICT\n};\nexport type HasManyRelationProp = _RelationProp & {\n  relationType: \"HasMany\";\n  joinColumn: string;\n  fromColumn?: string;\n};\nexport type ManyToManyRelationProp = _RelationProp & {\n  relationType: \"ManyToMany\";\n  joinTable: `${string}__${string}`;\n  onUpdate: RelationOn;\n  onDelete: RelationOn;\n};\nexport type RelationProp =\n  | OneToOneRelationProp\n  | BelongsToOneRelationProp\n  | HasManyRelationProp\n  | ManyToManyRelationProp;\n\nexport type EntityProp =\n  | IntegerProp\n  | IntegerArrayProp\n  | BigIntegerProp\n  | BigIntegerArrayProp\n  | StringProp\n  | StringArrayProp\n  | EnumProp\n  | EnumArrayProp\n  | NumberProp\n  | NumberArrayProp\n  | NumericProp\n  | NumericArrayProp\n  | NumericProp\n  | BooleanProp\n  | BooleanArrayProp\n  | DateProp\n  | DateArrayProp\n  | UuidProp\n  | UuidArrayProp\n  | JsonProp\n  | VirtualProp\n  | VectorProp\n  | VectorArrayProp\n  | TsVectorProp\n  | RelationProp;\n\n/**\n * pgvector 거리 연산자 클래스\n *\n * @description\n * - `vector_cosine_ops`: 코사인 거리 (Cosine Distance) - 권장\n *   - SQL 연산자: `<=>`\n *   - 벡터의 방향만 비교 (크기 무시), 1 - cosine_similarity\n *   - 텍스트 임베딩, 시맨틱 검색에 가장 일반적으로 사용\n *   - 사용 예: OpenAI, Voyage 등 대부분의 임베딩 모델에 권장\n *\n * - `vector_ip_ops`: 내적 (Inner Product)\n *   - SQL 연산자: `<#>`\n *   - 두 벡터의 내적을 계산 (sum(a[i] * b[i]))\n *   - 정규화된 벡터에서 코사인 유사도와 동일한 결과\n *   - 값이 클수록 유사 (음수 연산자이므로 ORDER BY에서 주의)\n *   - 사용 예: 이미 정규화된 임베딩에서 가장 빠른 성능\n *\n * - `vector_l2_ops`: 유클리드 거리 (L2 Distance)\n *   - SQL 연산자: `<->`\n *   - 두 벡터 간의 직선 거리를 계산 (sqrt(sum((a[i] - b[i])^2)))\n *   - 벡터의 크기(magnitude)가 중요할 때 사용\n *   - 사용 예: 이미지 유사도, 절대적 거리 측정이 필요한 경우\n */\nexport type VectorOps = \"vector_cosine_ops\" | \"vector_ip_ops\" | \"vector_l2_ops\";\n\ntype EntityIndexColumn = {\n  name: string;\n  nullsFirst?: boolean;\n  sortOrder?: \"ASC\" | \"DESC\";\n  /** pgvector 인덱스에서 사용할 거리 연산자 (vector 컬럼에만 적용) */\n  vectorOps?: VectorOps;\n};\nexport type EntityIndex = {\n  type: \"index\" | \"unique\" | \"hnsw\" | \"ivfflat\";\n  columns: EntityIndexColumn[];\n  name: string;\n  using?: \"btree\" | \"hash\" | \"gin\" | \"gist\";\n  nullsNotDistinct?: boolean; // unique index only\n  /**\n   * HNSW (Hierarchical Navigable Small World) 인덱스: 각 노드의 최대 연결 수\n   *\n   * @description\n   * 그래프에서 각 노드가 가질 수 있는 최대 연결 수입니다.\n   * HNSW는 빠른 검색 속도와 높은 정확도를 제공하므로 권장됩니다.\n   * - 기본값: 16\n   * - 범위: 2 ~ 100\n   * - 높을수록: 정확도↑, 빌드 시간↑, 메모리↑\n   * - 권장: 빠른 빌드(8), 균형(16), 높은 정확도(32), 최고 정확도(64)\n   */\n  m?: number;\n  /**\n   * HNSW (Hierarchical Navigable Small World) 인덱스: 구성 시 탐색 범위\n   *\n   * @description\n   * 인덱스 구성 시 각 노드에서 탐색할 범위입니다.\n   * - 기본값: 64\n   * - 범위: 4 ~ 1000\n   * - 높을수록: 정확도↑, 빌드 시간↑\n   * - 권장: 빠른 빌드(32), 균형(64), 높은 정확도(128), 최고 정확도(256)\n   */\n  efConstruction?: number;\n  /**\n   * IVFFlat (Inverted File with Flat Compression) 인덱스: 클러스터링 리스트 수\n   *\n   * @description\n   * 벡터를 클러스터링할 버킷 수를 지정합니다.\n   * IVFFlat은 빠른 빌드와 낮은 메모리 사용이 필요할 때 사용합니다.\n   * - 권장값: sqrt(row_count) ~ row_count / 1000\n   * - 예시: 10,000행 → 100, 100,000행 → 300, 1,000,000행 → 1000\n   * - 많을수록 정확도↑, 검색 속도↓\n   */\n  lists?: number;\n};\nexport type EntityJson = {\n  id: string;\n  parentId?: string;\n  table: string;\n  title?: string;\n  props: EntityProp[];\n  indexes: EntityIndex[];\n  subsets: {\n    [subset: string]: string[];\n  };\n  enums: {\n    [enumId: string]: {\n      [key: string]: string;\n    };\n  };\n};\nexport type EntitySubsetRow = {\n  field: string;\n  has: {\n    [key: string]: boolean;\n  };\n  children: EntitySubsetRow[];\n  prefixes: string[];\n  relationEntity?: string;\n  isOpen?: boolean;\n};\nexport type FlattenSubsetRow = Omit<EntitySubsetRow, \"children\">;\n\n/*\n  PropNode\n*/\n\n/**\n * 엔티티의 필드 구조를 트리 형태로 표현하는 중간 노드입니다.\n *\n * **목적**: Entity의 subset 필드 표현식(예: \"id\", \"user.name\", \"tags[]\")을\n * 재귀적인 트리 구조로 파싱하여 Zod 스키마 생성의 중간 단계로 사용합니다.\n *\n * **변환 흐름**:\n * Entity subset → EntityPropNode (트리 구조) → Zod 스키마 → RenderingNode (UI용)\n *\n * **nodeType**:\n * - \"plain\": 단일 필드 (예: \"id\", \"name\")\n * - \"object\": 중첩 객체 (예: \"user.name\" → user 객체)\n * - \"array\": 배열 (예: \"tags[]\" → tags 배열)\n *\n * **사용 위치**: entity-converter.ts의 propNodeToZodType()\n */\nexport type EntityPropNode =\n  | {\n      nodeType: \"plain\";\n      prop: EntityProp;\n    }\n  | {\n      nodeType: \"object\" | \"array\";\n      prop?: EntityProp;\n      children: EntityPropNode[];\n    };\n\n/*\n  Prop Type Guards\n*/\nexport function isIntegerSingleProp(p: unknown): p is IntegerProp {\n  return (p as IntegerProp)?.type === \"integer\";\n}\nexport function isIntegerArrayProp(p: unknown): p is IntegerArrayProp {\n  return (p as IntegerArrayProp)?.type === \"integer[]\";\n}\nexport function isIntegerProp(p: unknown): p is IntegerProp | IntegerArrayProp {\n  return isIntegerSingleProp(p) || isIntegerArrayProp(p);\n}\nexport function isBigIntegerSingleProp(p: unknown): p is BigIntegerProp {\n  return (p as BigIntegerProp)?.type === \"bigInteger\";\n}\nexport function isBigIntegerArrayProp(p: unknown): p is BigIntegerArrayProp {\n  return (p as BigIntegerArrayProp)?.type === \"bigInteger[]\";\n}\nexport function isBigIntegerProp(p: unknown): p is BigIntegerProp | BigIntegerArrayProp {\n  return isBigIntegerSingleProp(p) || isBigIntegerArrayProp(p);\n}\nexport function isStringSingleProp(p: unknown): p is StringProp {\n  return (p as StringProp)?.type === \"string\";\n}\nexport function isStringArrayProp(p: unknown): p is StringArrayProp {\n  return (p as StringArrayProp)?.type === \"string[]\";\n}\nexport function isStringProp(p: unknown): p is StringProp | StringArrayProp {\n  return isStringSingleProp(p) || isStringArrayProp(p);\n}\nexport function isEnumSingleProp(p: unknown): p is EnumProp {\n  return (p as EnumProp)?.type === \"enum\";\n}\nexport function isEnumArrayProp(p: unknown): p is EnumArrayProp {\n  return (p as EnumArrayProp)?.type === \"enum[]\";\n}\nexport function isEnumProp(p: unknown): p is EnumProp | EnumArrayProp {\n  return isEnumSingleProp(p) || isEnumArrayProp(p);\n}\nexport function isNumberSingleProp(p: unknown): p is NumberProp {\n  return (p as NumberProp)?.type === \"number\";\n}\nexport function isNumberArrayProp(p: unknown): p is NumberArrayProp {\n  return (p as NumberArrayProp)?.type === \"number[]\";\n}\nexport function isNumberProp(p: unknown): p is NumberProp | NumberArrayProp {\n  return isNumberSingleProp(p) || isNumberArrayProp(p);\n}\nexport function isNumericSingleProp(p: unknown): p is NumericProp {\n  return (p as NumericProp)?.type === \"numeric\";\n}\nexport function isNumericArrayProp(p: unknown): p is NumericArrayProp {\n  return (p as NumericArrayProp)?.type === \"numeric[]\";\n}\nexport function isNumericProp(p: unknown): p is NumericProp | NumericArrayProp {\n  return isNumericSingleProp(p) || isNumericArrayProp(p);\n}\nexport function isBooleanSingleProp(p: unknown): p is BooleanProp {\n  return (p as BooleanProp)?.type === \"boolean\";\n}\nexport function isBooleanArrayProp(p: unknown): p is BooleanArrayProp {\n  return (p as BooleanArrayProp)?.type === \"boolean[]\";\n}\nexport function isBooleanProp(p: unknown): p is BooleanProp | BooleanArrayProp {\n  return isBooleanSingleProp(p) || isBooleanArrayProp(p);\n}\nexport function isDateSingleProp(p: unknown): p is DateProp {\n  return (p as DateProp)?.type === \"date\";\n}\nexport function isDateArrayProp(p: unknown): p is DateArrayProp {\n  return (p as DateArrayProp)?.type === \"date[]\";\n}\nexport function isDateProp(p: unknown): p is DateProp | DateArrayProp {\n  return isDateSingleProp(p) || isDateArrayProp(p);\n}\nexport function isUuidSingleProp(p: unknown): p is UuidProp {\n  return (p as UuidProp)?.type === \"uuid\";\n}\nexport function isUuidArrayProp(p: unknown): p is UuidArrayProp {\n  return (p as UuidArrayProp)?.type === \"uuid[]\";\n}\nexport function isUuidProp(p: unknown): p is UuidProp | UuidArrayProp {\n  return isUuidSingleProp(p) || isUuidArrayProp(p);\n}\nexport function isJsonProp(p: unknown): p is JsonProp {\n  return (p as JsonProp)?.type === \"json\";\n}\nexport function isVirtualProp(p: unknown): p is VirtualProp {\n  return (p as VirtualProp)?.type === \"virtual\";\n}\nexport function isVectorSingleProp(p: unknown): p is VectorProp {\n  return (p as VectorProp)?.type === \"vector\";\n}\nexport function isVectorArrayProp(p: unknown): p is VectorArrayProp {\n  return (p as VectorArrayProp)?.type === \"vector[]\";\n}\nexport function isVectorProp(p: unknown): p is VectorProp | VectorArrayProp {\n  return isVectorSingleProp(p) || isVectorArrayProp(p);\n}\nexport function isRelationProp(p: unknown): p is RelationProp {\n  return (p as RelationProp)?.type === \"relation\";\n}\nexport function isOneToOneRelationProp(p: unknown): p is OneToOneRelationProp {\n  return (p as OneToOneRelationProp)?.relationType === \"OneToOne\";\n}\nexport function isBelongsToOneRelationProp(p: unknown): p is BelongsToOneRelationProp {\n  return (p as BelongsToOneRelationProp)?.relationType === \"BelongsToOne\";\n}\nexport function isHasManyRelationProp(p: unknown): p is HasManyRelationProp {\n  return (p as HasManyRelationProp)?.relationType === \"HasMany\";\n}\nexport function isManyToManyRelationProp(p: unknown): p is ManyToManyRelationProp {\n  return (p as ManyToManyRelationProp)?.relationType === \"ManyToMany\";\n}\n\ntype JoinClause =\n  | {\n      from: string;\n      to: string;\n    }\n  | {\n      custom: string;\n    };\nexport function isCustomJoinClause(p: unknown): p is { custom: string } {\n  return !!(p as { custom: string })?.custom;\n}\n\ntype SubsetLoader = {\n  as: string;\n  table: string;\n  manyJoin: {\n    fromTable: string;\n    fromCol: string;\n    idField: string;\n    toTable: string;\n    toCol: string;\n    through?: {\n      table: string;\n      fromCol: string;\n      toCol: string;\n    };\n  };\n  oneJoins: ({\n    as: string;\n    join: \"inner\" | \"outer\";\n    table: string;\n  } & JoinClause)[];\n  select: string[];\n  loaders?: SubsetLoader[];\n};\n\nexport type SubsetQuery = {\n  select: string[];\n  virtual: string[];\n  joins: ({\n    as: string;\n    join: \"inner\" | \"outer\";\n    table: string;\n  } & JoinClause)[];\n  loaders: SubsetLoader[];\n};\n\n/* BaseModel */\nexport const SonamuQueryMode = z.enum([\"both\", \"list\", \"count\"]);\nexport type SonamuQueryMode = z.infer<typeof SonamuQueryMode>;\n\n/* Knex Migration */\nexport type KnexError = {\n  code: string;\n  errno: number;\n  sql: string;\n  sqlMessage: string;\n  sqlState: string;\n};\nexport function isKnexError(e: unknown): e is KnexError {\n  return !!(e as KnexError)?.code && !!(e as KnexError)?.sqlMessage && !!(e as KnexError)?.sqlState;\n}\n\nexport type KnexColumnType =\n  | \"string\"\n  | \"text\"\n  | \"smalltext\"\n  | \"mediumtext\"\n  | \"longtext\"\n  | \"integer\"\n  | \"bigInteger\"\n  | \"decimal\"\n  | \"timestamp\"\n  | \"boolean\"\n  | \"foreign\"\n  | \"uuid\"\n  | \"json\"\n  | \"float\"\n  | \"date\"\n  | \"time\"\n  | \"datetime\";\nexport type MigrationColumnType =\n  | \"string\"\n  | \"string[]\"\n  | \"integer\"\n  | \"integer[]\"\n  | \"bigInteger\"\n  | \"bigInteger[]\"\n  | \"numberOrNumeric\"\n  | \"numberOrNumeric[]\"\n  | \"boolean\"\n  | \"boolean[]\"\n  | \"date\"\n  | \"date[]\"\n  | \"uuid\"\n  | \"uuid[]\"\n  | \"json\"\n  | \"vector\"\n  | \"vector[]\"\n  | \"tsvector\";\nexport type MigrationColumn = {\n  name: string;\n  type: MigrationColumnType;\n  nullable: boolean;\n  numberType?: \"real\" | \"double precision\" | \"numeric\";\n  length?: number;\n  defaultTo?: string;\n  precision?: number;\n  scale?: number;\n  dimensions?: number;\n  generated?: GeneratedColumn;\n};\nexport type MigrationIndex = {\n  type: \"unique\" | \"index\" | \"hnsw\" | \"ivfflat\";\n  columns: EntityIndexColumn[];\n  name: string;\n  using?: \"btree\" | \"hash\" | \"gin\" | \"gist\";\n  nullsNotDistinct?: boolean;\n  /** HNSW (Hierarchical Navigable Small World): 각 노드의 최대 연결 수 */\n  m?: number;\n  /** HNSW (Hierarchical Navigable Small World): 구성 시 탐색 범위 */\n  efConstruction?: number;\n  /** IVFFlat (Inverted File with Flat Compression): 클러스터링 리스트 수 */\n  lists?: number;\n};\nexport type MigrationForeign = {\n  columns: string[];\n  to: string;\n  onUpdate: RelationOn;\n  onDelete: RelationOn;\n};\nexport type MigrationJoinTable = {\n  table: string;\n  indexes: MigrationIndex[];\n  columns: MigrationColumn[];\n  foreigns: MigrationForeign[];\n};\nexport type MigrationSet = {\n  table: string;\n  columns: MigrationColumn[];\n  indexes: MigrationIndex[];\n  foreigns: MigrationForeign[];\n};\nexport type MigrationSetAndJoinTable = MigrationSet & {\n  joinTables: MigrationJoinTable[];\n};\nexport type GenMigrationCode = {\n  title: string;\n  table: string;\n  type: \"normal\" | \"foreign\";\n  formatted: string | null;\n};\n\n/* Api */\nexport type ApiParam = {\n  name: string;\n  type: ApiParamType;\n  optional: boolean;\n  defaultDef?: string;\n};\nexport namespace ApiParamType {\n  export type Object = {\n    t: \"object\";\n    props: ApiParam[];\n  };\n  export type Union = {\n    t: \"union\";\n    types: ApiParamType[];\n  };\n  export type Intersection = {\n    t: \"intersection\";\n    types: ApiParamType[];\n  };\n  export type StringLiteral = {\n    t: \"string-literal\";\n    value: string;\n  };\n  export type NumericLiteral = {\n    t: \"numeric-literal\";\n    value: number;\n  };\n  export type Array = {\n    t: \"array\";\n    elementsType: ApiParamType;\n  };\n  export type Ref = {\n    t: \"ref\";\n    id: string;\n    args?: ApiParamType[];\n  };\n  export type IndexedAccess = {\n    t: \"indexed-access\";\n    object: ApiParamType;\n    index: ApiParamType;\n  };\n  export type TupleType = {\n    t: \"tuple-type\";\n    elements: ApiParamType[];\n  };\n  export type Pick = Ref & {\n    t: \"ref\";\n    id: \"Pick\";\n  };\n  export type Omit = Ref & {\n    t: \"ref\";\n    id: \"Omit\";\n  };\n  export type Partial = Ref & {\n    t: \"ref\";\n    id: \"Partial\";\n  };\n  export type Promise = Ref & {\n    t: \"ref\";\n    id: \"Promise\";\n  };\n  export type Context = Ref & {\n    t: \"ref\";\n    id: \"Context\";\n  };\n  export type TypeParam = {\n    t: \"type-param\";\n    id: string;\n    constraint?: ApiParamType;\n  };\n\n  export function isObject(v: unknown): v is ApiParamType.Object {\n    return (v as ApiParamType.Object)?.t === \"object\";\n  }\n  export function isUnion(v: unknown): v is ApiParamType.Union {\n    return (v as ApiParamType.Union)?.t === \"union\";\n  }\n  export function isIntersection(v: unknown): v is ApiParamType.Intersection {\n    return (v as ApiParamType.Intersection)?.t === \"intersection\";\n  }\n  export function isStringLiteral(v: unknown): v is ApiParamType.StringLiteral {\n    return (v as ApiParamType.StringLiteral)?.t === \"string-literal\";\n  }\n  export function isNumericLiteral(v: unknown): v is ApiParamType.NumericLiteral {\n    return (v as ApiParamType.NumericLiteral)?.t === \"numeric-literal\";\n  }\n  export function isArray(v: unknown): v is ApiParamType.Array {\n    return (v as ApiParamType.Array)?.t === \"array\";\n  }\n  export function isRef(v: unknown): v is ApiParamType.Ref {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"ref\";\n  }\n  export function isIndexedAccess(v: unknown): v is ApiParamType.IndexedAccess {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"indexed-access\";\n  }\n  export function isTupleType(v: unknown): v is ApiParamType.TupleType {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"tuple-type\";\n  }\n  export function isPick(v: unknown): v is ApiParamType.Pick {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Pick\"\n    );\n  }\n  export function isOmit(v: unknown): v is ApiParamType.Omit {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Omit\"\n    );\n  }\n  export function isPartial(v: unknown): v is ApiParamType.Partial {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Partial\"\n    );\n  }\n  export function isPromise(v: unknown): v is ApiParamType.Promise {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Promise\"\n    );\n  }\n  export function isContext(v: unknown): v is ApiParamType.Context {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Context\"\n    );\n  }\n  export function isRefKnex(v: unknown): v is ApiParamType.Ref {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Knex\"\n    );\n  }\n  export function isTypeParam(v: unknown): v is ApiParamType.TypeParam {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"type-param\";\n  }\n}\nexport type ApiParamType =\n  | \"string\"\n  | \"number\"\n  | \"boolean\"\n  | \"null\"\n  | \"undefined\"\n  | \"void\"\n  | \"any\"\n  | \"unknown\"\n  | \"true\"\n  | \"false\"\n  | ApiParamType.StringLiteral\n  | ApiParamType.NumericLiteral\n  | ApiParamType.Object\n  | ApiParamType.Union\n  | ApiParamType.Intersection\n  | ApiParamType.Array\n  | ApiParamType.Ref\n  | ApiParamType.IndexedAccess\n  | ApiParamType.TypeParam\n  | ApiParamType.TupleType;\n\n/* Template */\n/**\n * UI 컴포넌트 렌더링을 위한 메타데이터 노드입니다.\n *\n * **목적**: Zod 스키마로부터 프론트엔드 UI 컴포넌트를 자동 생성하기 위한\n * 렌더링 정보를 담은 트리 구조입니다. 각 필드가 어떤 UI 컴포넌트로\n * 표현되어야 하는지(텍스트, 이미지, 날짜, Enum 선택 등)를 명시합니다.\n *\n * **변환 흐름**:\n * Entity subset → EntityPropNode → Zod 스키마 → RenderingNode (UI용) → React 컴포넌트 코드 생성\n *\n * **주요 필드**:\n * - `renderType`: UI 컴포넌트 유형 (string-plain, number-fk_id, enums, array 등)\n * - `zodType`: 원본 Zod 스키마 (validation 용)\n * - `children`: 중첩된 객체 필드들 (object일 때)\n * - `element`: 배열 요소 타입 (array일 때)\n *\n * **사용 위치**:\n * - zod-converter.ts의 zodTypeToRenderingNode()에서 생성\n * - view_form.template.ts, view_list.template.ts 등에서 React 컴포넌트 코드 생성에 사용\n */\n// 셀프 참조 타입이므로 Zod 생략하고 직접 정의\nexport const RenderingNode = z.any();\nexport type RenderingNode = {\n  name: string;\n  label: string;\n  renderType:\n    | \"string-plain\"\n    | \"string-image\"\n    | \"string-datetime\"\n    | \"string-date\"\n    | \"datetime\"\n    | \"number-plain\"\n    | \"number-id\"\n    | \"number-fk_id\"\n    | \"boolean\"\n    | \"enums\"\n    | \"array\"\n    | \"array-images\"\n    | \"object\"\n    | \"object-pick\"\n    | \"record\"\n    | \"vector\";\n  zodType: z.ZodTypeAny;\n  element?: RenderingNode;\n  children?: RenderingNode[];\n  config?: {\n    picked: string;\n  };\n  optional?: boolean;\n  nullable?: boolean;\n};\n\nconst GeneratedColumnSchema = z.object({\n  type: z.enum([\"STORED\", \"VIRTUAL\"]),\n  expression: z.string(),\n});\n\nconst BasePropFields = {\n  name: z.string(),\n  desc: z.string().optional(),\n  nullable: z.boolean().optional(),\n  toFilter: z.boolean().default(false).optional(),\n  dbDefault: z.union([z.string(), z.number(), z.boolean()]).optional(),\n  generated: GeneratedColumnSchema.optional(),\n};\n\n// 부가 필드가 필요없는 prop\nconst BasePropFieldsWithoutAdditional = z\n  .object({\n    ...BasePropFields,\n    type: z.union([\n      z.literal(\"integer\"),\n      z.literal(\"integer[]\"),\n      z.literal(\"bigInteger\"),\n      z.literal(\"bigInteger[]\"),\n      z.literal(\"boolean\"),\n      z.literal(\"boolean[]\"),\n      z.literal(\"date\"),\n      z.literal(\"date[]\"),\n      z.literal(\"uuid\"),\n      z.literal(\"uuid[]\"),\n      z.literal(\"tsvector\"),\n    ]),\n  })\n  .strict();\n\n// precision/scale 필드\nconst PrecisionScaleFields = {\n  precision: z.number().optional(),\n  scale: z.number().optional(),\n};\n\n// 각 타입별 스키마 정의\n\nconst StringPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"string\"),\n    length: z.number().optional(),\n  })\n  .strict();\nconst StringArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"string[]\"),\n    length: z.number().optional(),\n  })\n  .strict();\n\nconst EnumPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"enum\"),\n    id: z.string(),\n    length: z.number().optional(),\n  })\n  .strict();\nconst EnumArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"enum[]\"),\n    id: z.string(),\n  })\n  .strict();\n\nconst NumberPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"number\"),\n    ...PrecisionScaleFields,\n    numberType: z.enum([\"real\", \"double precision\", \"numeric\"]).optional(),\n  })\n  .strict();\nconst NumberArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"number[]\"),\n    ...PrecisionScaleFields,\n    numberType: z.enum([\"real\", \"double precision\", \"numeric\"]).optional(),\n  })\n  .strict();\n\nconst NumericPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"numeric\"),\n    ...PrecisionScaleFields,\n  })\n  .strict();\nconst NumericArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"numeric[]\"),\n    ...PrecisionScaleFields,\n  })\n  .strict();\n\nconst JsonPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"json\"),\n    id: z.string(),\n  })\n  .strict();\n\nconst VirtualPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"virtual\"),\n    id: z.string(),\n  })\n  .strict();\n\nconst VectorPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"vector\"),\n    dimensions: z.number(),\n  })\n  .strict();\nconst VectorArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"vector[]\"),\n    dimensions: z.number(),\n  })\n  .strict();\n\n// Relation 타입은 relationType에 따라 세분화\nconst BaseRelationFields = {\n  ...BasePropFields,\n  type: z.literal(\"relation\"),\n  with: z.string(),\n};\n\n// RelationOn 타입\nconst RelationOnSchema = z.enum([\"CASCADE\", \"SET NULL\", \"NO ACTION\", \"SET DEFAULT\", \"RESTRICT\"]);\n\nconst BelongsToOneRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"BelongsToOne\"),\n    customJoinClause: z.string().optional(),\n    useConstraint: z.boolean().optional(),\n    onUpdate: RelationOnSchema.optional(),\n    onDelete: RelationOnSchema.optional(),\n  })\n  .strict();\n\nconst HasManyRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"HasMany\"),\n    joinColumn: z.string(),\n    fromColumn: z.string().optional(),\n  })\n  .strict();\n\nconst ManyToManyRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"ManyToMany\"),\n    joinTable: z.string(),\n    onUpdate: RelationOnSchema,\n    onDelete: RelationOnSchema,\n  })\n  .strict();\n\nconst OneToOneRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"OneToOne\"),\n    customJoinClause: z.string().optional(),\n    hasJoinColumn: z.boolean().optional(),\n    useConstraint: z.boolean().optional(),\n    onUpdate: RelationOnSchema.optional(),\n    onDelete: RelationOnSchema.optional(),\n  })\n  .strict();\n\nconst RelationTypes = [\"BelongsToOne\", \"HasMany\", \"ManyToMany\", \"OneToOne\"] as const;\nexport const RelationPropSchema = z.discriminatedUnion(\n  \"relationType\",\n  [\n    BelongsToOneRelationPropSchema,\n    HasManyRelationPropSchema,\n    ManyToManyRelationPropSchema,\n    OneToOneRelationPropSchema,\n  ],\n  {\n    error: (iss) =>\n      `relationType은 ${RelationTypes.map((t) => `'${t}'`).join(\", \")} 중 하나여야 합니다. 입력값: \"${(iss.input as Record<string, unknown>)?.relationType}\"`,\n  },\n);\n\nconst NormalPropTypes = [\n  \"integer\",\n  \"integer[]\",\n  \"bigInteger\",\n  \"bigInteger[]\",\n  \"string\",\n  \"string[]\",\n  \"enum\",\n  \"enum[]\",\n  \"number\",\n  \"number[]\",\n  \"numeric\",\n  \"numeric[]\",\n  \"boolean\",\n  \"boolean[]\",\n  \"date\",\n  \"date[]\",\n  \"uuid\",\n  \"uuid[]\",\n  \"json\",\n  \"virtual\",\n  \"vector\",\n  \"vector[]\",\n  \"tsvector\",\n] as const;\n\n// VIRTUAL Generated Column에서 사용 불가능한 타입들\nconst VirtualGeneratedDisallowedTypes = [\n  \"json\",\n  \"vector\",\n  \"vector[]\",\n  \"string[]\",\n  \"integer[]\",\n  \"bigInteger[]\",\n  \"boolean[]\",\n  \"date[]\",\n  \"uuid[]\",\n  \"number[]\",\n  \"numeric[]\",\n  \"enum[]\",\n] as const;\n\nexport const NormalPropSchema = z\n  .discriminatedUnion(\n    \"type\",\n    [\n      BasePropFieldsWithoutAdditional,\n      StringPropSchema,\n      StringArrayPropSchema,\n      EnumPropSchema,\n      EnumArrayPropSchema,\n      NumberPropSchema,\n      NumberArrayPropSchema,\n      NumericPropSchema,\n      NumericArrayPropSchema,\n      JsonPropSchema,\n      VirtualPropSchema,\n      VectorPropSchema,\n      VectorArrayPropSchema,\n    ],\n    {\n      error: (iss) =>\n        `type은 ${NormalPropTypes.map((t) => `'${t}'`).join(\", \")} 중 하나여야 합니다. 입력값: \"${(iss.input as Record<string, unknown>)?.type}\"`,\n    },\n  )\n  .superRefine((data, ctx) => {\n    if (!data.generated) {\n      return;\n    }\n\n    // dbDefault와 generated 동시 사용 불가\n    if (data.dbDefault !== undefined) {\n      ctx.addIssue({\n        code: \"custom\",\n        message: \"dbDefault와 generated는 함께 사용할 수 없습니다\",\n        path: [\"generated\"],\n      });\n    }\n\n    // virtual 타입은 generated 불가\n    if (data.type === \"virtual\") {\n      ctx.addIssue({\n        code: \"custom\",\n        message: \"virtual 타입은 generated column을 지원하지 않습니다\",\n        path: [\"generated\"],\n      });\n    }\n\n    // VIRTUAL Generated Column 타입 제한 검증\n    if (data.generated.type === \"VIRTUAL\") {\n      if ((VirtualGeneratedDisallowedTypes as readonly string[]).includes(data.type)) {\n        ctx.addIssue({\n          code: \"custom\",\n          message: `VIRTUAL generated column은 ${data.type} 타입을 지원하지 않습니다. STORED를 사용하세요.`,\n          path: [\"generated\", \"type\"],\n          fatal: true,\n        });\n      }\n    }\n  });\n\nconst AllPropTypes = [...NormalPropTypes, \"relation\"] as const;\nconst EntityPropSchema = z.discriminatedUnion(\"type\", [NormalPropSchema, RelationPropSchema], {\n  error: (iss) =>\n    `type은 ${AllPropTypes.map((t) => `'${t}'`).join(\", \")} 중 하나여야 합니다. 입력값: \"${(iss.input as Record<string, unknown>)?.type}\"`,\n});\n\nconst EntityIndexColumnSchema = z.object({\n  name: z.string(),\n  nullsFirst: z.boolean().optional(),\n  sortOrder: z.enum([\"ASC\", \"DESC\"]).optional(),\n  vectorOps: z.enum([\"vector_cosine_ops\", \"vector_ip_ops\", \"vector_l2_ops\"]).optional(),\n});\n\n// EntityIndex 스키마 정의\nconst EntityIndexSchema = z\n  .object({\n    type: z.enum([\"index\", \"unique\", \"hnsw\", \"ivfflat\"]),\n    columns: z.array(EntityIndexColumnSchema),\n    name: z.string().min(1).max(63),\n    using: z.enum([\"btree\", \"hash\", \"gin\", \"gist\"]).optional(),\n    nullsNotDistinct: z.boolean().optional(),\n    m: z.number().optional(),\n    efConstruction: z.number().optional(),\n    lists: z.number().optional(),\n  })\n  .strict();\n\nexport const EntityJsonSchema = z\n  .object({\n    id: z.string().describe(\"PascalCase로 된 Entity ID\"),\n    title: z.string().describe(\"Entity 이름\"),\n    table: z.string().describe(\"snake_case로 된 테이블명\"),\n    parentId: z.string().optional().describe(\"부모 Entity ID\"),\n    props: z.array(EntityPropSchema),\n    indexes: z.array(EntityIndexSchema),\n    subsets: z.record(z.string(), z.array(z.string())),\n    enums: z.record(z.string(), z.record(z.string(), z.string())),\n  })\n  .strict();\n\nexport const TemplateOptions = z.object({\n  entity: EntityJsonSchema.omit({ id: true })\n    .extend({\n      entityId: z.string(),\n    })\n    .partial({\n      table: true,\n      props: true,\n      indexes: true,\n      subsets: true,\n      enums: true,\n    }),\n  init_types: z.object({\n    entityId: z.string(),\n  }),\n  generated: z.object({}),\n  generated_sso: z.object({}),\n  generated_http: z.object({\n    entityId: z.string(),\n  }),\n  model: z.object({\n    entityId: z.string(),\n    defaultSearchField: z.string().optional(),\n    defaultOrderBy: z.string().optional(),\n  }),\n  model_test: z.object({\n    entityId: z.string(),\n  }),\n  bridge: z.object({\n    entityId: z.string(),\n  }),\n  service: z.object({\n    namesRecord: z.object({\n      fs: z.string(),\n      fsPlural: z.string(),\n      camel: z.string(),\n      camelPlural: z.string(),\n      capital: z.string(),\n      capitalPlural: z.string(),\n      upper: z.string(),\n      constant: z.string(),\n    }),\n    modelTsPath: z.string(),\n  }),\n  view_list: z.object({\n    entityId: z.string(),\n    extra: z.unknown(),\n  }),\n  view_list_columns: z.object({\n    entityId: z.string(),\n    columns: z\n      .object({\n        name: z.string(),\n        label: z.string(),\n        tc: z.string(),\n      })\n      .array(),\n    columnImports: z.string(),\n  }),\n  view_search_input: z.object({\n    entityId: z.string(),\n  }),\n  view_form: z.object({\n    entityId: z.string(),\n  }),\n  view_id_all_select: z.object({\n    entityId: z.string(),\n  }),\n  view_id_async_select: z.object({\n    entityId: z.string(),\n    textField: z.string(),\n  }),\n  view_enums_select: z.object({\n    entityId: z.string(),\n    enumId: z.string(),\n  }),\n  view_enums_dropdown: z.object({\n    entityId: z.string(),\n    enumId: z.string(),\n  }),\n  view_enums_buttonset: z.object({\n    entityId: z.string(),\n    enumId: z.string(),\n  }),\n});\nexport type TemplateOptions = z.infer<typeof TemplateOptions>;\n\nexport const TemplateKey = z.enum([\n  \"entity\",\n  \"init_types\",\n  \"generated\",\n  \"generated_sso\",\n  \"generated_http\",\n  \"model\",\n  \"model_test\",\n  \"bridge\",\n  \"service\",\n  \"view_list\",\n  \"view_list_columns\",\n  \"view_search_input\",\n  \"view_form\",\n  \"view_id_all_select\",\n  \"view_id_async_select\",\n  \"view_enums_select\",\n  \"view_enums_dropdown\",\n  \"view_enums_buttonset\",\n]);\nexport type TemplateKey = z.infer<typeof TemplateKey>;\n\nexport const GenerateOptions = z.object({\n  overwrite: z.boolean().optional(),\n});\nexport type GenerateOptions = z.infer<typeof GenerateOptions>;\n\nexport const PathAndCode = z.object({\n  path: z.string(),\n  code: z.string(),\n});\nexport type PathAndCode = z.infer<typeof PathAndCode>;\n\nexport type FixtureSearchOptions = {\n  entityId: string;\n  field: string;\n  value: string;\n  searchType: \"equals\" | \"like\";\n};\n\ntype ColumnValue = string | number | boolean | Date | null;\nexport type FixtureRecord = {\n  fixtureId: string;\n  entityId: string;\n  id: number;\n  columns: {\n    [key: string]: {\n      prop: EntityProp;\n      value: ColumnValue | ColumnValue[];\n    };\n  };\n  fetchedRecords: string[];\n  belongsRecords: string[];\n  target?: FixtureRecord; // Import 대상 DB 레코드(id가 같은)\n  unique?: FixtureRecord; // Import 대상 DB 레코드(unique key가 같은)\n  override?: boolean;\n};\n\nexport type FixtureImportResult = {\n  entityId: string;\n  data: {\n    [key: string]: ColumnValue;\n  };\n};\n\nexport type RelationNode = {\n  fixtureId: string;\n  entityId: string;\n  related: Set<string>;\n};\n\n// biome-ignore lint/suspicious/noEmptyInterface: sonamu.generated.sso 에서 확장을 위해 준비된 빈 인터페이스\nexport interface DatabaseSchemaExtend {}\n// biome-ignore lint/suspicious/noEmptyInterface: sonamu.generated.sso 에서 확장을 위해 준비된 빈 인터페이스\nexport interface DatabaseForeignKeys {}\nexport type ManyToManyBaseSchema<FromIdKey extends string, ToIdKey extends string> = {\n  id: number;\n} & {\n  [K in `${FromIdKey}_id`]: number;\n} & {\n  [K in `${ToIdKey}_id`]: number;\n};\n\nexport type SonamuFastifyConfig = {\n  contextProvider: (\n    defaultContext: Pick<Context, \"request\" | \"reply\" | \"headers\" | \"createSSE\" | \"naiteStore\"> &\n      AuthContext,\n    request: FastifyRequest,\n    reply: FastifyReply,\n  ) => Context | Promise<Context>;\n  guardHandler: (\n    guard: GuardKey,\n    request: FastifyRequest,\n    api: {\n      typeParameters: ApiParamType.TypeParam[];\n      parameters: ApiParam[];\n      returnType: ApiParamType;\n      modelName: string;\n      methodName: string;\n      path: string;\n      options: ApiDecoratorOptions;\n    },\n  ) => void;\n};\n"],"names":["z","zArrayable","shape","union","array","isIntegerSingleProp","p","type","isIntegerArrayProp","isIntegerProp","isBigIntegerSingleProp","isBigIntegerArrayProp","isBigIntegerProp","isStringSingleProp","isStringArrayProp","isStringProp","isEnumSingleProp","isEnumArrayProp","isEnumProp","isNumberSingleProp","isNumberArrayProp","isNumberProp","isNumericSingleProp","isNumericArrayProp","isNumericProp","isBooleanSingleProp","isBooleanArrayProp","isBooleanProp","isDateSingleProp","isDateArrayProp","isDateProp","isUuidSingleProp","isUuidArrayProp","isUuidProp","isJsonProp","isVirtualProp","isVectorSingleProp","isVectorArrayProp","isVectorProp","isRelationProp","isOneToOneRelationProp","relationType","isBelongsToOneRelationProp","isHasManyRelationProp","isManyToManyRelationProp","isCustomJoinClause","custom","SonamuQueryMode","enum","isKnexError","e","code","sqlMessage","sqlState","ApiParamType","isObject","v","t","isUnion","isIntersection","isStringLiteral","isNumericLiteral","isArray","isRef","isIndexedAccess","isTupleType","isPick","id","isOmit","isPartial","isPromise","isContext","isRefKnex","isTypeParam","RenderingNode","any","GeneratedColumnSchema","object","expression","string","BasePropFields","name","desc","optional","nullable","boolean","toFilter","default","dbDefault","number","generated","BasePropFieldsWithoutAdditional","literal","strict","PrecisionScaleFields","precision","scale","StringPropSchema","length","StringArrayPropSchema","EnumPropSchema","EnumArrayPropSchema","NumberPropSchema","numberType","NumberArrayPropSchema","NumericPropSchema","NumericArrayPropSchema","JsonPropSchema","VirtualPropSchema","VectorPropSchema","dimensions","VectorArrayPropSchema","BaseRelationFields","with","RelationOnSchema","BelongsToOneRelationPropSchema","customJoinClause","useConstraint","onUpdate","onDelete","HasManyRelationPropSchema","joinColumn","fromColumn","ManyToManyRelationPropSchema","joinTable","OneToOneRelationPropSchema","hasJoinColumn","RelationTypes","RelationPropSchema","discriminatedUnion","error","iss","map","join","input","NormalPropTypes","VirtualGeneratedDisallowedTypes","NormalPropSchema","superRefine","data","ctx","undefined","addIssue","message","path","includes","fatal","AllPropTypes","EntityPropSchema","EntityIndexColumnSchema","nullsFirst","sortOrder","vectorOps","EntityIndexSchema","columns","min","max","using","nullsNotDistinct","m","efConstruction","lists","EntityJsonSchema","describe","title","table","parentId","props","indexes","subsets","record","enums","TemplateOptions","entity","omit","extend","entityId","partial","init_types","generated_sso","generated_http","model","defaultSearchField","defaultOrderBy","model_test","bridge","service","namesRecord","fs","fsPlural","camel","camelPlural","capital","capitalPlural","upper","constant","modelTsPath","view_list","extra","unknown","view_list_columns","label","tc","columnImports","view_search_input","view_form","view_id_all_select","view_id_async_select","textField","view_enums_select","enumId","view_enums_dropdown","view_enums_buttonset","TemplateKey","GenerateOptions","overwrite","PathAndCode"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/vector/config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAE5C;;;GAGG;AACH,eAAO,MAAM,qBAAqB,EAAE,YA6CnC,CAAC;AAEF;;;GAGG;AACH,wBAAgB,kBAAkB,CAChC,SAAS,GAAE,OAAO,CAAC,YAAY,CAAM,GACpC,YAAY,CAQd"}
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/vector/config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAE5C;;;GAGG;AACH,eAAO,MAAM,qBAAqB,EAAE,YA6CnC,CAAC;AAEF;;;GAGG;AACH,wBAAgB,kBAAkB,CAAC,SAAS,GAAE,OAAO,CAAC,YAAY,CAAM,GAAG,YAAY,CAQtF"}
@@ -10,7 +10,7 @@
10
10
  model: "voyage-3",
11
11
  dimensions: 1024,
12
12
  maxTokens: 32000,
13
- batchSize: 100
13
+ batchSize: 128
14
14
  },
15
15
  // OpenAI 설정
16
16
  // apiKey는 Sonamu.secrets에서 로드되므로 여기서는 빈 문자열
@@ -80,4 +80,4 @@
80
80
  };
81
81
  }
82
82
 
83
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy92ZWN0b3IvY29uZmlnLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVmVjdG9yQ29uZmlnIH0gZnJvbSBcIi4vdHlwZXNcIjtcblxuLyoqXG4gKiDrsqHthLAg6rKA7IOJIOq4sOuzuCDshKTsoJVcbiAqIOyCrOyaqeyekOuKlCDsnbQg7ISk7KCV7J2EIG92ZXJyaWRl7ZWY7JesIOy7pOyKpO2EsOuniOydtOymiO2VoCDsiJgg7J6I7J2MXG4gKi9cbmV4cG9ydCBjb25zdCBERUZBVUxUX1ZFQ1RPUl9DT05GSUc6IFZlY3RvckNvbmZpZyA9IHtcbiAgLy8gVm95YWdlIEFJIOyEpOyglVxuICAvLyBhcGlLZXnripQgU29uYW11LnNlY3JldHPsl5DshJwg66Gc65Oc65CY66+A66GcIOyXrOq4sOyEnOuKlCDruYgg66y47J6Q7Je0XG4gIHZveWFnZToge1xuICAgIGFwaUtleTogXCJcIixcbiAgICBiYXNlVXJsOiBcImh0dHBzOi8vYXBpLnZveWFnZWFpLmNvbS92MS9lbWJlZGRpbmdzXCIsXG4gICAgbW9kZWw6IFwidm95YWdlLTNcIixcbiAgICBkaW1lbnNpb25zOiAxMDI0LFxuICAgIG1heFRva2VuczogMzIwMDAsXG4gICAgYmF0Y2hTaXplOiAxMDAsXG4gIH0sXG5cbiAgLy8gT3BlbkFJIOyEpOyglVxuICAvLyBhcGlLZXnripQgU29uYW11LnNlY3JldHPsl5DshJwg66Gc65Oc65CY66+A66GcIOyXrOq4sOyEnOuKlCDruYgg66y47J6Q7Je0XG4gIG9wZW5haToge1xuICAgIGFwaUtleTogXCJcIixcbiAgICBiYXNlVXJsOiBcImh0dHBzOi8vYXBpLm9wZW5haS5jb20vdjEvZW1iZWRkaW5nc1wiLFxuICAgIG1vZGVsOiBcInRleHQtZW1iZWRkaW5nLTMtc21hbGxcIixcbiAgICBkaW1lbnNpb25zOiAxNTM2LFxuICAgIG1heFRva2VuczogODE5MSxcbiAgICBiYXRjaFNpemU6IDEwMCxcbiAgfSxcblxuICAvLyDssq3tgrkg7ISk7KCVICjtlYTsmpTsi5wg7IKs7JqpKVxuICBjaHVua2luZzoge1xuICAgIGNodW5rU2l6ZTogNTAwLFxuICAgIGNodW5rT3ZlcmxhcDogNTAsXG4gICAgbWluQ2h1bmtTaXplOiA1MCxcbiAgICBza2lwVGhyZXNob2xkOiAyMDAsXG4gICAgc2VwYXJhdG9yczogW1wiXFxuXFxuXCIsIFwiXFxuXCIsIFwi44CCXCIsIFwiLiBcIiwgXCIhIFwiLCBcIj8gXCIsIFwiLCBcIiwgXCIgXCJdLFxuICB9LFxuXG4gIC8vIOqygOyDiSDshKTsoJVcbiAgc2VhcmNoOiB7XG4gICAgZGVmYXVsdExpbWl0OiAxMCxcbiAgICBzaW1pbGFyaXR5VGhyZXNob2xkOiAwLjUsXG4gICAgdmVjdG9yV2VpZ2h0OiAwLjcsXG4gICAgZnRzV2VpZ2h0OiAwLjMsXG4gIH0sXG5cbiAgLy8gcGd2ZWN0b3Ig7ISk7KCVXG4gIHBndmVjdG9yOiB7XG4gICAgaXRlcmF0aXZlU2NhbjogdHJ1ZSxcbiAgICBlZlNlYXJjaDogMTAwLFxuICB9LFxufTtcblxuLyoqXG4gKiDshKTsoJUg7IOd7ISxIO2XrO2NvCDtlajsiJhcbiAqIOu2gOu2hCDshKTsoJXrp4wg7KCc6rO17ZWY66m0IOuCmOuouOyngOuKlCDquLDrs7jqsJIg7IKs7JqpXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVWZWN0b3JDb25maWcoXG4gIG92ZXJyaWRlczogUGFydGlhbDxWZWN0b3JDb25maWc+ID0ge31cbik6IFZlY3RvckNvbmZpZyB7XG4gIHJldHVybiB7XG4gICAgdm95YWdlOiB7IC4uLkRFRkFVTFRfVkVDVE9SX0NPTkZJRy52b3lhZ2UsIC4uLm92ZXJyaWRlcy52b3lhZ2UgfSxcbiAgICBvcGVuYWk6IHsgLi4uREVGQVVMVF9WRUNUT1JfQ09ORklHLm9wZW5haSwgLi4ub3ZlcnJpZGVzLm9wZW5haSB9LFxuICAgIGNodW5raW5nOiB7IC4uLkRFRkFVTFRfVkVDVE9SX0NPTkZJRy5jaHVua2luZywgLi4ub3ZlcnJpZGVzLmNodW5raW5nIH0sXG4gICAgc2VhcmNoOiB7IC4uLkRFRkFVTFRfVkVDVE9SX0NPTkZJRy5zZWFyY2gsIC4uLm92ZXJyaWRlcy5zZWFyY2ggfSxcbiAgICBwZ3ZlY3RvcjogeyAuLi5ERUZBVUxUX1ZFQ1RPUl9DT05GSUcucGd2ZWN0b3IsIC4uLm92ZXJyaWRlcy5wZ3ZlY3RvciB9LFxuICB9O1xufVxuIl0sIm5hbWVzIjpbIkRFRkFVTFRfVkVDVE9SX0NPTkZJRyIsInZveWFnZSIsImFwaUtleSIsImJhc2VVcmwiLCJtb2RlbCIsImRpbWVuc2lvbnMiLCJtYXhUb2tlbnMiLCJiYXRjaFNpemUiLCJvcGVuYWkiLCJjaHVua2luZyIsImNodW5rU2l6ZSIsImNodW5rT3ZlcmxhcCIsIm1pbkNodW5rU2l6ZSIsInNraXBUaHJlc2hvbGQiLCJzZXBhcmF0b3JzIiwic2VhcmNoIiwiZGVmYXVsdExpbWl0Iiwic2ltaWxhcml0eVRocmVzaG9sZCIsInZlY3RvcldlaWdodCIsImZ0c1dlaWdodCIsInBndmVjdG9yIiwiaXRlcmF0aXZlU2NhbiIsImVmU2VhcmNoIiwiY3JlYXRlVmVjdG9yQ29uZmlnIiwib3ZlcnJpZGVzIl0sIm1hcHBpbmdzIjoiQUFFQTs7O0NBR0MsR0FDRCxPQUFPLE1BQU1BLHdCQUFzQztJQUNqRCxlQUFlO0lBQ2YsNENBQTRDO0lBQzVDQyxRQUFRO1FBQ05DLFFBQVE7UUFDUkMsU0FBUztRQUNUQyxPQUFPO1FBQ1BDLFlBQVk7UUFDWkMsV0FBVztRQUNYQyxXQUFXO0lBQ2I7SUFFQSxZQUFZO0lBQ1osNENBQTRDO0lBQzVDQyxRQUFRO1FBQ05OLFFBQVE7UUFDUkMsU0FBUztRQUNUQyxPQUFPO1FBQ1BDLFlBQVk7UUFDWkMsV0FBVztRQUNYQyxXQUFXO0lBQ2I7SUFFQSxpQkFBaUI7SUFDakJFLFVBQVU7UUFDUkMsV0FBVztRQUNYQyxjQUFjO1FBQ2RDLGNBQWM7UUFDZEMsZUFBZTtRQUNmQyxZQUFZO1lBQUM7WUFBUTtZQUFNO1lBQUs7WUFBTTtZQUFNO1lBQU07WUFBTTtTQUFJO0lBQzlEO0lBRUEsUUFBUTtJQUNSQyxRQUFRO1FBQ05DLGNBQWM7UUFDZEMscUJBQXFCO1FBQ3JCQyxjQUFjO1FBQ2RDLFdBQVc7SUFDYjtJQUVBLGNBQWM7SUFDZEMsVUFBVTtRQUNSQyxlQUFlO1FBQ2ZDLFVBQVU7SUFDWjtBQUNGLEVBQUU7QUFFRjs7O0NBR0MsR0FDRCxPQUFPLFNBQVNDLG1CQUNkQyxZQUFtQyxDQUFDLENBQUM7SUFFckMsT0FBTztRQUNMdkIsUUFBUTtZQUFFLEdBQUdELHNCQUFzQkMsTUFBTTtZQUFFLEdBQUd1QixVQUFVdkIsTUFBTTtRQUFDO1FBQy9ETyxRQUFRO1lBQUUsR0FBR1Isc0JBQXNCUSxNQUFNO1lBQUUsR0FBR2dCLFVBQVVoQixNQUFNO1FBQUM7UUFDL0RDLFVBQVU7WUFBRSxHQUFHVCxzQkFBc0JTLFFBQVE7WUFBRSxHQUFHZSxVQUFVZixRQUFRO1FBQUM7UUFDckVNLFFBQVE7WUFBRSxHQUFHZixzQkFBc0JlLE1BQU07WUFBRSxHQUFHUyxVQUFVVCxNQUFNO1FBQUM7UUFDL0RLLFVBQVU7WUFBRSxHQUFHcEIsc0JBQXNCb0IsUUFBUTtZQUFFLEdBQUdJLFVBQVVKLFFBQVE7UUFBQztJQUN2RTtBQUNGIn0=
83
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy92ZWN0b3IvY29uZmlnLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVmVjdG9yQ29uZmlnIH0gZnJvbSBcIi4vdHlwZXNcIjtcblxuLyoqXG4gKiDrsqHthLAg6rKA7IOJIOq4sOuzuCDshKTsoJVcbiAqIOyCrOyaqeyekOuKlCDsnbQg7ISk7KCV7J2EIG92ZXJyaWRl7ZWY7JesIOy7pOyKpO2EsOuniOydtOymiO2VoCDsiJgg7J6I7J2MXG4gKi9cbmV4cG9ydCBjb25zdCBERUZBVUxUX1ZFQ1RPUl9DT05GSUc6IFZlY3RvckNvbmZpZyA9IHtcbiAgLy8gVm95YWdlIEFJIOyEpOyglVxuICAvLyBhcGlLZXnripQgU29uYW11LnNlY3JldHPsl5DshJwg66Gc65Oc65CY66+A66GcIOyXrOq4sOyEnOuKlCDruYgg66y47J6Q7Je0XG4gIHZveWFnZToge1xuICAgIGFwaUtleTogXCJcIixcbiAgICBiYXNlVXJsOiBcImh0dHBzOi8vYXBpLnZveWFnZWFpLmNvbS92MS9lbWJlZGRpbmdzXCIsXG4gICAgbW9kZWw6IFwidm95YWdlLTNcIixcbiAgICBkaW1lbnNpb25zOiAxMDI0LFxuICAgIG1heFRva2VuczogMzIwMDAsXG4gICAgYmF0Y2hTaXplOiAxMjgsXG4gIH0sXG5cbiAgLy8gT3BlbkFJIOyEpOyglVxuICAvLyBhcGlLZXnripQgU29uYW11LnNlY3JldHPsl5DshJwg66Gc65Oc65CY66+A66GcIOyXrOq4sOyEnOuKlCDruYgg66y47J6Q7Je0XG4gIG9wZW5haToge1xuICAgIGFwaUtleTogXCJcIixcbiAgICBiYXNlVXJsOiBcImh0dHBzOi8vYXBpLm9wZW5haS5jb20vdjEvZW1iZWRkaW5nc1wiLFxuICAgIG1vZGVsOiBcInRleHQtZW1iZWRkaW5nLTMtc21hbGxcIixcbiAgICBkaW1lbnNpb25zOiAxNTM2LFxuICAgIG1heFRva2VuczogODE5MSxcbiAgICBiYXRjaFNpemU6IDEwMCxcbiAgfSxcblxuICAvLyDssq3tgrkg7ISk7KCVICjtlYTsmpTsi5wg7IKs7JqpKVxuICBjaHVua2luZzoge1xuICAgIGNodW5rU2l6ZTogNTAwLFxuICAgIGNodW5rT3ZlcmxhcDogNTAsXG4gICAgbWluQ2h1bmtTaXplOiA1MCxcbiAgICBza2lwVGhyZXNob2xkOiAyMDAsXG4gICAgc2VwYXJhdG9yczogW1wiXFxuXFxuXCIsIFwiXFxuXCIsIFwi44CCXCIsIFwiLiBcIiwgXCIhIFwiLCBcIj8gXCIsIFwiLCBcIiwgXCIgXCJdLFxuICB9LFxuXG4gIC8vIOqygOyDiSDshKTsoJVcbiAgc2VhcmNoOiB7XG4gICAgZGVmYXVsdExpbWl0OiAxMCxcbiAgICBzaW1pbGFyaXR5VGhyZXNob2xkOiAwLjUsXG4gICAgdmVjdG9yV2VpZ2h0OiAwLjcsXG4gICAgZnRzV2VpZ2h0OiAwLjMsXG4gIH0sXG5cbiAgLy8gcGd2ZWN0b3Ig7ISk7KCVXG4gIHBndmVjdG9yOiB7XG4gICAgaXRlcmF0aXZlU2NhbjogdHJ1ZSxcbiAgICBlZlNlYXJjaDogMTAwLFxuICB9LFxufTtcblxuLyoqXG4gKiDshKTsoJUg7IOd7ISxIO2XrO2NvCDtlajsiJhcbiAqIOu2gOu2hCDshKTsoJXrp4wg7KCc6rO17ZWY66m0IOuCmOuouOyngOuKlCDquLDrs7jqsJIg7IKs7JqpXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVWZWN0b3JDb25maWcob3ZlcnJpZGVzOiBQYXJ0aWFsPFZlY3RvckNvbmZpZz4gPSB7fSk6IFZlY3RvckNvbmZpZyB7XG4gIHJldHVybiB7XG4gICAgdm95YWdlOiB7IC4uLkRFRkFVTFRfVkVDVE9SX0NPTkZJRy52b3lhZ2UsIC4uLm92ZXJyaWRlcy52b3lhZ2UgfSxcbiAgICBvcGVuYWk6IHsgLi4uREVGQVVMVF9WRUNUT1JfQ09ORklHLm9wZW5haSwgLi4ub3ZlcnJpZGVzLm9wZW5haSB9LFxuICAgIGNodW5raW5nOiB7IC4uLkRFRkFVTFRfVkVDVE9SX0NPTkZJRy5jaHVua2luZywgLi4ub3ZlcnJpZGVzLmNodW5raW5nIH0sXG4gICAgc2VhcmNoOiB7IC4uLkRFRkFVTFRfVkVDVE9SX0NPTkZJRy5zZWFyY2gsIC4uLm92ZXJyaWRlcy5zZWFyY2ggfSxcbiAgICBwZ3ZlY3RvcjogeyAuLi5ERUZBVUxUX1ZFQ1RPUl9DT05GSUcucGd2ZWN0b3IsIC4uLm92ZXJyaWRlcy5wZ3ZlY3RvciB9LFxuICB9O1xufVxuIl0sIm5hbWVzIjpbIkRFRkFVTFRfVkVDVE9SX0NPTkZJRyIsInZveWFnZSIsImFwaUtleSIsImJhc2VVcmwiLCJtb2RlbCIsImRpbWVuc2lvbnMiLCJtYXhUb2tlbnMiLCJiYXRjaFNpemUiLCJvcGVuYWkiLCJjaHVua2luZyIsImNodW5rU2l6ZSIsImNodW5rT3ZlcmxhcCIsIm1pbkNodW5rU2l6ZSIsInNraXBUaHJlc2hvbGQiLCJzZXBhcmF0b3JzIiwic2VhcmNoIiwiZGVmYXVsdExpbWl0Iiwic2ltaWxhcml0eVRocmVzaG9sZCIsInZlY3RvcldlaWdodCIsImZ0c1dlaWdodCIsInBndmVjdG9yIiwiaXRlcmF0aXZlU2NhbiIsImVmU2VhcmNoIiwiY3JlYXRlVmVjdG9yQ29uZmlnIiwib3ZlcnJpZGVzIl0sIm1hcHBpbmdzIjoiQUFFQTs7O0NBR0MsR0FDRCxPQUFPLE1BQU1BLHdCQUFzQztJQUNqRCxlQUFlO0lBQ2YsNENBQTRDO0lBQzVDQyxRQUFRO1FBQ05DLFFBQVE7UUFDUkMsU0FBUztRQUNUQyxPQUFPO1FBQ1BDLFlBQVk7UUFDWkMsV0FBVztRQUNYQyxXQUFXO0lBQ2I7SUFFQSxZQUFZO0lBQ1osNENBQTRDO0lBQzVDQyxRQUFRO1FBQ05OLFFBQVE7UUFDUkMsU0FBUztRQUNUQyxPQUFPO1FBQ1BDLFlBQVk7UUFDWkMsV0FBVztRQUNYQyxXQUFXO0lBQ2I7SUFFQSxpQkFBaUI7SUFDakJFLFVBQVU7UUFDUkMsV0FBVztRQUNYQyxjQUFjO1FBQ2RDLGNBQWM7UUFDZEMsZUFBZTtRQUNmQyxZQUFZO1lBQUM7WUFBUTtZQUFNO1lBQUs7WUFBTTtZQUFNO1lBQU07WUFBTTtTQUFJO0lBQzlEO0lBRUEsUUFBUTtJQUNSQyxRQUFRO1FBQ05DLGNBQWM7UUFDZEMscUJBQXFCO1FBQ3JCQyxjQUFjO1FBQ2RDLFdBQVc7SUFDYjtJQUVBLGNBQWM7SUFDZEMsVUFBVTtRQUNSQyxlQUFlO1FBQ2ZDLFVBQVU7SUFDWjtBQUNGLEVBQUU7QUFFRjs7O0NBR0MsR0FDRCxPQUFPLFNBQVNDLG1CQUFtQkMsWUFBbUMsQ0FBQyxDQUFDO0lBQ3RFLE9BQU87UUFDTHZCLFFBQVE7WUFBRSxHQUFHRCxzQkFBc0JDLE1BQU07WUFBRSxHQUFHdUIsVUFBVXZCLE1BQU07UUFBQztRQUMvRE8sUUFBUTtZQUFFLEdBQUdSLHNCQUFzQlEsTUFBTTtZQUFFLEdBQUdnQixVQUFVaEIsTUFBTTtRQUFDO1FBQy9EQyxVQUFVO1lBQUUsR0FBR1Qsc0JBQXNCUyxRQUFRO1lBQUUsR0FBR2UsVUFBVWYsUUFBUTtRQUFDO1FBQ3JFTSxRQUFRO1lBQUUsR0FBR2Ysc0JBQXNCZSxNQUFNO1lBQUUsR0FBR1MsVUFBVVQsTUFBTTtRQUFDO1FBQy9ESyxVQUFVO1lBQUUsR0FBR3BCLHNCQUFzQm9CLFFBQVE7WUFBRSxHQUFHSSxVQUFVSixRQUFRO1FBQUM7SUFDdkU7QUFDRiJ9
@@ -1,18 +1,27 @@
1
1
  import type { EmbeddingProvider, EmbeddingResult, ProgressCallback, VectorConfig, VectorInputType } from "./types";
2
2
  /**
3
3
  * 임베딩 클라이언트
4
- * Voyage AI와 OpenAI 임베딩을 통합 지원
4
+ * Voyage AI와 OpenAI 임베딩을 SDK 방식으로 통합 지원
5
5
  */
6
6
  export declare class Embedding {
7
7
  private config;
8
8
  constructor(config?: Partial<VectorConfig>);
9
+ /**
10
+ * Voyage AI 클라이언트 초기화
11
+ */
12
+ private getVoyageClient;
13
+ /**
14
+ * OpenAI provider 생성
15
+ */
16
+ private getOpenAIProvider;
9
17
  /**
10
18
  * 텍스트 임베딩 생성
11
- * @param texts - 임베딩할 텍스트 배열
19
+ * @param texts - 임베딩할 텍스트 배열 (batchSize이상 시 자동 분할)
12
20
  * @param provider - 'voyage' | 'openai'
13
21
  * @param inputType - 'document' | 'query' (Voyage AI만 해당)
22
+ * @param onProgress - 진행률 콜백
14
23
  */
15
- embed(texts: string[], provider: EmbeddingProvider, inputType?: VectorInputType): Promise<EmbeddingResult[]>;
24
+ embed(texts: string[], provider: EmbeddingProvider, inputType?: VectorInputType, onProgress?: ProgressCallback): Promise<EmbeddingResult[]>;
16
25
  /**
17
26
  * 단일 텍스트 임베딩 (편의 메서드)
18
27
  */
@@ -25,10 +34,6 @@ export declare class Embedding {
25
34
  * OpenAI 임베딩
26
35
  */
27
36
  private embedOpenAI;
28
- /**
29
- * 배치 임베딩 (대량 처리)
30
- */
31
- embedBatch(texts: string[], provider: EmbeddingProvider, inputType?: VectorInputType, onProgress?: ProgressCallback): Promise<EmbeddingResult[]>;
32
37
  /**
33
38
  * 벡터를 PostgreSQL vector 타입 문자열로 변환
34
39
  */
@@ -37,6 +42,5 @@ export declare class Embedding {
37
42
  * 임베딩 provider의 차원 수 반환
38
43
  */
39
44
  getDimensions(provider: EmbeddingProvider): number;
40
- private delay;
41
45
  }
42
46
  //# sourceMappingURL=embedding.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"embedding.d.ts","sourceRoot":"","sources":["../../src/vector/embedding.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,iBAAiB,EACjB,eAAe,EACf,gBAAgB,EAChB,YAAY,EACZ,eAAe,EAChB,MAAM,SAAS,CAAC;AAEjB;;;GAGG;AACH,qBAAa,SAAS;IACpB,OAAO,CAAC,MAAM,CAAe;gBAEjB,MAAM,GAAE,OAAO,CAAC,YAAY,CAAM;IAU9C;;;;;OAKG;IACG,KAAK,CACT,KAAK,EAAE,MAAM,EAAE,EACf,QAAQ,EAAE,iBAAiB,EAC3B,SAAS,GAAE,eAA4B,GACtC,OAAO,CAAC,eAAe,EAAE,CAAC;IAQ7B;;OAEG;IACG,QAAQ,CACZ,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,iBAAiB,EAC3B,SAAS,GAAE,eAA4B,GACtC,OAAO,CAAC,eAAe,CAAC;IAK3B;;OAEG;YACW,WAAW;IAyCzB;;OAEG;YACW,WAAW;IAqCzB;;OAEG;IACG,UAAU,CACd,KAAK,EAAE,MAAM,EAAE,EACf,QAAQ,EAAE,iBAAiB,EAC3B,SAAS,GAAE,eAA4B,EACvC,UAAU,CAAC,EAAE,gBAAgB,GAC5B,OAAO,CAAC,eAAe,EAAE,CAAC;IAwB7B;;OAEG;IACH,MAAM,CAAC,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,MAAM;IAIlD;;OAEG;IACH,aAAa,CAAC,QAAQ,EAAE,iBAAiB,GAAG,MAAM;IAMlD,OAAO,CAAC,KAAK;CAGd"}
1
+ {"version":3,"file":"embedding.d.ts","sourceRoot":"","sources":["../../src/vector/embedding.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACV,iBAAiB,EACjB,eAAe,EACf,gBAAgB,EAChB,YAAY,EACZ,eAAe,EAChB,MAAM,SAAS,CAAC;AAEjB;;;GAGG;AACH,qBAAa,SAAS;IACpB,OAAO,CAAC,MAAM,CAAe;gBAEjB,MAAM,GAAE,OAAO,CAAC,YAAY,CAAM;IAU9C;;OAEG;IACH,OAAO,CAAC,eAAe;IAQvB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAQzB;;;;;;OAMG;IACG,KAAK,CACT,KAAK,EAAE,MAAM,EAAE,EACf,QAAQ,EAAE,iBAAiB,EAC3B,SAAS,GAAE,eAA4B,EACvC,UAAU,CAAC,EAAE,gBAAgB,GAC5B,OAAO,CAAC,eAAe,EAAE,CAAC;IA0B7B;;OAEG;IACG,QAAQ,CACZ,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,iBAAiB,EAC3B,SAAS,GAAE,eAA4B,GACtC,OAAO,CAAC,eAAe,CAAC;IAK3B;;OAEG;YACW,WAAW;IAuBzB;;OAEG;YACW,WAAW;IAiBzB;;OAEG;IACH,MAAM,CAAC,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,MAAM;IAIlD;;OAEG;IACH,aAAa,CAAC,QAAQ,EAAE,iBAAiB,GAAG,MAAM;CAGnD"}