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
@@ -1,5 +1,5 @@
1
1
  import equal from "fast-deep-equal";
2
- import { alphabetical, diff, omit } from "radashi";
2
+ import { alphabetical, diff } from "radashi";
3
3
  import { Naite } from "../index.js";
4
4
  import { formatCode } from "../utils/formatter.js";
5
5
  import { differenceWith, intersectionBy } from "../utils/utils.js";
@@ -168,12 +168,16 @@ function getPgArrayType(column, elementType) {
168
168
  }
169
169
  const methodMap = {
170
170
  index: "INDEX",
171
- fulltext: "INDEX",
172
171
  unique: "UNIQUE INDEX"
173
172
  };
174
- const nullsNotDistinctClause = index.nullsNotDistinct === undefined ? "" : ` NULLS ${index.nullsNotDistinct ? "NOT DISTINCT" : "DISTINCT"}`;
173
+ const nullsNotDistinctClause = index.type === "unique" && index.nullsNotDistinct !== undefined ? ` NULLS ${index.nullsNotDistinct ? "NOT DISTINCT" : "DISTINCT"}` : "";
174
+ const usingClause = index.using === undefined ? "" : `USING ${index.using}`;
175
175
  return `await knex.raw(
176
- \`CREATE ${methodMap[index.type]} ${index.name} ON ${table} (${index.columns.map((col)=>{
176
+ \`CREATE ${methodMap[index.type]} ${index.name} ON ${table} ${usingClause}(${index.columns.map((col)=>{
177
+ // 정렬 옵션은 btree만 사용 가능
178
+ if (index.using !== "btree" && index.using !== undefined) {
179
+ return `${col.name}`;
180
+ }
177
181
  const sortOrderClause = col.sortOrder === undefined ? "" : ` ${col.sortOrder}`;
178
182
  const nullsFirstClause = col.nullsFirst === undefined ? "" : ` NULLS ${col.nullsFirst ? "FIRST" : "LAST"}`;
179
183
  return `${col.name}${sortOrderClause}${nullsFirstClause}`;
@@ -609,7 +613,8 @@ function getPgArrayType(column, elementType) {
609
613
  // sortOrder에 따라 nullsFirst의 default 값 설정
610
614
  nullsFirst: col.nullsFirst ?? col.sortOrder === "DESC"
611
615
  })),
612
- nullsNotDistinct: index.nullsNotDistinct ?? false
616
+ nullsNotDistinct: index.nullsNotDistinct ?? false,
617
+ using: index.using ?? "btree"
613
618
  };
614
619
  }
615
620
  /**
@@ -788,9 +793,7 @@ function getPgArrayType(column, elementType) {
788
793
  const alterCodes = [];
789
794
  // 1. columnsAndIndexes 처리
790
795
  const isEqualColumns = equal(entityColumns.map(normalizeColumnForComparison), dbColumns.map(normalizeColumnForComparison));
791
- const isEqualIndexes = equal(entityIndexes.map((index)=>omit(index, [
792
- "parser"
793
- ])).map(setMigrationIndexDefaults), dbIndexes);
796
+ const isEqualIndexes = equal(entityIndexes.map(setMigrationIndexDefaults), dbIndexes.map(setMigrationIndexDefaults));
794
797
  if (!isEqualColumns || !isEqualIndexes) {
795
798
  alterCodes.push(await generateAlterCode_ColumnAndIndexes(entitySet.table, entityColumns, entityIndexes, dbColumns, dbIndexes, dbSet.foreigns));
796
799
  }
@@ -804,4 +807,4 @@ function getPgArrayType(column, elementType) {
804
807
  return alterCodes.filter((alterCode)=>alterCode !== null).flat();
805
808
  }
806
809
 
807
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/migration/code-generation.ts"],"sourcesContent":["import equal from \"fast-deep-equal\";\nimport { alphabetical, diff, omit } from \"radashi\";\nimport { Naite } from \"..\";\nimport type {\n  GenMigrationCode,\n  MigrationColumn,\n  MigrationForeign,\n  MigrationIndex,\n  MigrationSet,\n} from \"../types/types\";\nimport { formatCode } from \"../utils/formatter\";\nimport { differenceWith, intersectionBy } from \"../utils/utils\";\n\n/**\n * 컬럼 정의 결과 타입\n * - builder: Knex table builder 메서드로 실행할 구문 (table.xxx())\n * - raw: knex.raw()로 실행할 구문\n */\ntype ColumnDefinitionResult = {\n  builder: string[];\n  raw: string[];\n};\n\n/**\n * 테이블 생성하는 케이스 - 컬럼/인덱스 생성\n */\nasync function generateCreateCode_ColumnAndIndexes(\n  table: string,\n  columns: MigrationColumn[],\n  indexes: MigrationIndex[],\n): Promise<GenMigrationCode> {\n  const columnDefs = genColumnDefinitions(table, columns);\n\n  // 컬럼, 인덱스 처리\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `await knex.schema.createTable(\"${table}\", (table) => {`,\n    ...columnDefs.builder,\n    \"});\",\n    // raw 구문 (Generated Column 등)\n    ...columnDefs.raw,\n    // index는 knex.raw로 처리하므로 createTable 밖에서 실행\n    ...indexes.map((index) => genIndexDefinition(index, table)),\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    ` return knex.schema.dropTable(\"${table}\");`,\n    \"}\",\n  ];\n  return {\n    table,\n    type: \"normal\",\n    title: `create__${table}`,\n    formatted: formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`),\n  };\n}\n\n/**\n * MigrationColumn[] 읽어서 컬럼 정의하는 구문 생성\n * @returns builder: table builder 메서드, raw: knex.raw() 구문\n */\nfunction genColumnDefinitions(table: string, columns: MigrationColumn[]): ColumnDefinitionResult {\n  const result: ColumnDefinitionResult = {\n    builder: [],\n    raw: [],\n  };\n\n  for (const column of columns) {\n    // Generated Column은 raw로 처리\n    if (column.generated) {\n      result.raw.push(genGeneratedColumnDefinition(table, column));\n      continue;\n    }\n\n    // 일반 컬럼은 builder로 처리\n    result.builder.push(genNormalColumnDefinition(column));\n  }\n\n  return result;\n}\n\n/**\n * Generated Column 정의 생성 (ALTER TABLE ADD COLUMN 사용)\n */\nfunction genGeneratedColumnDefinition(table: string, column: MigrationColumn): string {\n  if (!column.generated) {\n    throw new Error(\"Generated column definition required\");\n  }\n  const pgType = getPgTypeForColumn(column);\n  const storageType = column.generated.type === \"VIRTUAL\" ? \" VIRTUAL\" : \" STORED\";\n  const nullableClause = column.nullable ? \"\" : \" NOT NULL\";\n  return `await knex.raw(\\`ALTER TABLE \"${table}\" ADD COLUMN \"${column.name}\" ${pgType} GENERATED ALWAYS AS (${column.generated.expression})${storageType}${nullableClause}\\`);`;\n}\n\n/**\n * 일반 컬럼 정의 생성 (table.xxx() 체인)\n */\nfunction genNormalColumnDefinition(column: MigrationColumn): string {\n  const chains: string[] = [];\n\n  if (column.name === \"id\") {\n    return `table.increments().primary();`;\n  }\n\n  // 배열 타입 처리\n  if (column.type.endsWith(\"[]\")) {\n    const elementType = column.type.slice(0, -2); // \"integer[]\" -> \"integer\"\n    const pgType = getPgArrayType(column, elementType);\n    chains.push(`specificType('${column.name}', '${pgType}')`);\n  } else if (column.type === \"vector\") {\n    // Knex는 vector 타입을 직접 지원하지 않으므로 specificType 사용\n    chains.push(`specificType('${column.name}', 'vector(${column.dimensions})')`);\n  } else if (column.type === \"numberOrNumeric\") {\n    // number\n    if (column.numberType === \"real\") {\n      chains.push(`float('${column.name}')`);\n    } else if (column.numberType === \"double precision\") {\n      chains.push(`double('${column.name}')`);\n    } else if ((column.numberType ?? \"numeric\") === \"numeric\") {\n      chains.push(`decimal('${column.name}', ${column.precision}, ${column.scale})`);\n    }\n  } else if (column.type === \"string\") {\n    // string\n    if (column.length !== undefined) {\n      chains.push(`string('${column.name}', ${column.length})`);\n    } else {\n      chains.push(`text('${column.name}')`);\n    }\n  } else if (column.type === \"date\") {\n    // date\n    chains.push(`timestamp('${column.name}', { useTz: true })`);\n  } else if (column.type === \"json\") {\n    // json\n    chains.push(`jsonb('${column.name}')`);\n  } else {\n    // type, length\n    let extraType: string | undefined;\n    chains.push(\n      `${column.type}('${column.name}'${\n        column.length ? `, ${column.length}` : \"\"\n      }${extraType ? `, '${extraType}'` : \"\"})`,\n    );\n  }\n\n  // nullable\n  chains.push(column.nullable ? \"nullable()\" : \"notNullable()\");\n\n  // defaultTo\n  if (column.defaultTo !== undefined) {\n    if (typeof column.defaultTo === \"string\" && column.defaultTo.startsWith(`\"`)) {\n      chains.push(`defaultTo(${column.defaultTo})`);\n    } else {\n      chains.push(`defaultTo(knex.raw('${column.defaultTo}'))`);\n    }\n  }\n\n  return `table.${chains.join(\".\")};`;\n}\n\n/**\n * MigrationColumn의 타입을 PostgreSQL 타입 문자열로 변환\n */\nfunction getPgTypeForColumn(column: MigrationColumn): string {\n  if (column.type.endsWith(\"[]\")) {\n    const elementType = column.type.slice(0, -2);\n    return getPgArrayType(column, elementType);\n  }\n\n  switch (column.type) {\n    case \"string\":\n      return column.length !== undefined ? `varchar(${column.length})` : \"text\";\n    case \"bigInteger\":\n      return \"bigint\";\n    case \"numberOrNumeric\":\n      if (column.numberType === \"real\") return \"real\";\n      if (column.numberType === \"double precision\") return \"double precision\";\n      return `numeric(${column.precision}, ${column.scale})`;\n    case \"date\":\n      return \"timestamptz\";\n    case \"json\":\n      return \"jsonb\";\n    case \"vector\":\n      return `vector(${column.dimensions})`;\n    default:\n      return column.type;\n  }\n}\n\nfunction getPgArrayType(column: MigrationColumn, elementType: string): string {\n  if (elementType === \"numberOrNumeric\") {\n    if (column.numberType === \"real\") return \"real[]\";\n    if (column.numberType === \"double precision\") return \"double precision[]\";\n    return `numeric(${column.precision}, ${column.scale})[]`;\n  }\n  if (elementType === \"string\") {\n    return column.length ? `varchar(${column.length})[]` : \"text[]\";\n  }\n  if (elementType === \"date\") return \"timestamptz[]\";\n  if (elementType === \"integer\") return \"integer[]\";\n  if (elementType === \"bigInteger\") return \"bigint[]\";\n  if (elementType === \"boolean\") return \"boolean[]\";\n  if (elementType === \"uuid\") return \"uuid[]\";\n  if (elementType === \"enum\") return \"text[]\";\n  if (elementType === \"vector\") return `vector(${column.dimensions})[]`;\n\n  throw new Error(`Unknown array element type: ${elementType}`);\n}\n\n/**\n * 개별 인덱스 정의 생성\n */\nfunction genIndexDefinition(index: MigrationIndex, table: string): string {\n  if (index.type === \"hnsw\" || index.type === \"ivfflat\") {\n    return genVectorIndexDefinition(index, table);\n  }\n\n  const methodMap = {\n    index: \"INDEX\",\n    fulltext: \"INDEX\",\n    unique: \"UNIQUE INDEX\",\n  };\n\n  const nullsNotDistinctClause =\n    index.nullsNotDistinct === undefined\n      ? \"\"\n      : ` NULLS ${index.nullsNotDistinct ? \"NOT DISTINCT\" : \"DISTINCT\"}`;\n\n  return `await knex.raw(\n  \\`CREATE ${methodMap[index.type]} ${index.name} ON ${table} (${index.columns\n    .map((col) => {\n      const sortOrderClause = col.sortOrder === undefined ? \"\" : ` ${col.sortOrder}`;\n      const nullsFirstClause =\n        col.nullsFirst === undefined ? \"\" : ` NULLS ${col.nullsFirst ? \"FIRST\" : \"LAST\"}`;\n      return `${col.name}${sortOrderClause}${nullsFirstClause}`;\n    })\n    .join(\", \")})${nullsNotDistinctClause};\\`\n  );`;\n}\n\n/**\n * @description\n * - HNSW (Hierarchical Navigable Small World): 느린 빌드, 빠른 검색 속도, 높은 메모리 및 정확도\n * - IVFFlat (Inverted File with Flat Compression): 빠른 빌드, 중간 검색 속도, 낮은 메모리\n *\n * @example\n * // HNSW 인덱스 (권장 - 빠른 검색, 높은 정확도)\n * CREATE INDEX idx_embedding ON items USING hnsw (embedding vector_cosine_ops) WITH (m = 16, ef_construction = 64);\n *\n * // IVFFlat 인덱스 (대용량 데이터, 비용 중요 시)\n * CREATE INDEX idx_embedding ON items USING ivfflat (embedding vector_cosine_ops) WITH (lists = 100);\n */\nfunction genVectorIndexDefinition(index: MigrationIndex, table: string): string {\n  const column = index.columns[0];\n  const vectorOps = column.vectorOps ?? \"vector_cosine_ops\";\n\n  // HNSW (Hierarchical Navigable Small World) - 권장: 빠른 검색, 높은 정확도\n  if (index.type === \"hnsw\") {\n    const m = index.m ?? 16;\n    const efConstruction = index.efConstruction ?? 64;\n    return `await knex.raw(\\`CREATE INDEX ${index.name} ON ${table} USING hnsw (${column.name} ${vectorOps}) WITH (m = ${m}, ef_construction = ${efConstruction})\\`);`;\n  }\n\n  // IVFFlat (Inverted File with Flat Compression) - 대용량, 비용 중요 시\n  if (index.type === \"ivfflat\") {\n    const lists = index.lists ?? 100;\n    return `await knex.raw(\\`CREATE INDEX ${index.name} ON ${table} USING ivfflat (${column.name} ${vectorOps}) WITH (lists = ${lists})\\`);`;\n  }\n\n  throw new Error(`Unknown raw SQL index type: ${index.type}`);\n}\n\n/**\n * 테이블 생성하는 케이스 - FK 생성\n */\nasync function generateCreateCode_Foreign(\n  table: string,\n  foreigns: MigrationForeign[],\n): Promise<GenMigrationCode[]> {\n  if (foreigns.length === 0) {\n    return [];\n  }\n\n  const { up, down } = genForeignDefinitions(table, foreigns);\n  if (up.length === 0 && down.length === 0) {\n    console.log(\"fk 가 뭔가 다릅니다\");\n    return [];\n  }\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    \"// create fk\",\n    ...up,\n    \"});\",\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    \"// drop fk\",\n    ...down,\n    \"});\",\n    \"}\",\n  ];\n\n  const foreignKeysString = foreigns.map((foreign) => foreign.columns.join(\"_\")).join(\"_\");\n  return [\n    {\n      table,\n      type: \"foreign\",\n      title: `foreign__${table}__${foreignKeysString}`,\n      formatted: formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`),\n    },\n  ];\n}\n\n/**\n * MigrationForeign[] 읽어서 외부키 constraint 정의하는 구문 생성\n */\nfunction genForeignDefinitions(\n  table: string,\n  foreigns: MigrationForeign[],\n): { up: string[]; down: string[] } {\n  return foreigns.reduce(\n    (r, foreign) => {\n      const columnsStringQuote = foreign.columns\n        .map((col) => `'${col.replace(`${table}.`, \"\")}'`)\n        .join(\",\");\n      r.up.push(\n        `table.foreign('${foreign.columns.join(\",\")}')\n            .references('${foreign.to}')\n            .onUpdate('${foreign.onUpdate}')\n            .onDelete('${foreign.onDelete}')`,\n      );\n      r.down.push(`table.dropForeign([${columnsStringQuote}])`);\n      return r;\n    },\n    {\n      up: [] as string[],\n      down: [] as string[],\n    },\n  );\n}\n\n/**\n * 테이블 변경 케이스 - 컬럼/인덱스 변경\n */\nasync function generateAlterCode_ColumnAndIndexes(\n  table: string,\n  entityColumns: MigrationColumn[],\n  entityIndexes: MigrationIndex[],\n  dbColumns: MigrationColumn[],\n  dbIndexes: MigrationIndex[],\n  dbForeigns: MigrationForeign[],\n): Promise<GenMigrationCode[]> {\n  /*\n    세부 비교 후 다른점 찾아서 코드 생성\n\n    1. 컬럼갯수 다름: MD에 있으나, DB에 없다면 추가\n    2. 컬럼갯수 다름: MD에 없으나, DB에 있다면 삭제\n    3. 그외 컬럼(컬럼 갯수가 동일하거나, 다른 경우 동일한 컬럼끼리) => alter\n    4. 다른거 다 동일하고 index만 변경되는 경우\n\n    ** 컬럼명을 변경하는 경우는 따로 핸들링하지 않음\n    => drop/add 형태의 마이그레이션 코드가 생성되는데, 수동으로 rename 코드로 수정하여 처리\n  */\n\n  // 각 컬럼 이름 기준으로 add, drop, alter 여부 확인\n  const alterColumnsTo = getAlterColumnsTo(entityColumns, dbColumns);\n\n  // 추출된 컬럼들을 기준으로 각각 라인 생성\n  const alterColumnLinesTo = getAlterColumnLinesTo(\n    alterColumnsTo,\n    entityColumns,\n    table,\n    dbForeigns,\n  );\n\n  // 인덱스의 add, drop 여부 확인\n  const alterIndexesTo = getAlterIndexesTo(entityIndexes, dbIndexes);\n\n  // 인덱스가 삭제되는 경우, 컬럼과 같이 삭제된 케이스에는 drop에서 제외해야함!\n  const indexNeedsToDrop = alterIndexesTo.drop.filter(\n    (index) =>\n      index.columns.every(({ name }) =>\n        alterColumnsTo.drop.map((col) => col.name).includes(name),\n      ) === false,\n  );\n\n  // 빈 코드 생성 방지\n  const hasUpChanges =\n    alterColumnLinesTo.add.up.builder.length > 0 ||\n    alterColumnLinesTo.add.up.raw.length > 0 ||\n    alterColumnLinesTo.drop.up.builder.length > 0 ||\n    alterColumnLinesTo.alter.up.builder.length > 0 ||\n    alterIndexesTo.add.length > 0 ||\n    indexNeedsToDrop.length > 0;\n  if (!hasUpChanges) {\n    Naite.t(\"migrator:generateAlterCode_ColumnAndIndexes:emptyCodeGenerationError\", {\n      entityColumns,\n      dbColumns,\n      entityIndexes,\n      dbIndexes,\n    });\n    // throw new Error(\"컬럼/인덱스 변경 코드 생성 오류\");\n  }\n  Naite.t(\"migrator:generateAlterCode_ColumnAndIndexes:debug\", {\n    \"alterColumnsTo.add.length\": alterColumnsTo.add.length,\n    \"alterColumnsTo.drop.length\": alterColumnsTo.drop.length,\n    \"alterColumnsTo.alter.length\": alterColumnsTo.alter.length,\n    \"alterIndexesTo.add.length\": alterIndexesTo.add.length,\n    \"alterIndexesTo.drop.length\": alterIndexesTo.drop.length,\n    \"indexNeedsToDrop.length\": indexNeedsToDrop.length,\n  });\n  // Naite.t(\"migrator:generateAlterCode_ColumnAndIndexes:alterColumnsTo\", alterColumnsTo);\n\n  // TODO: 인덱스명 변경된 경우 처리\n\n  // table builder 메서드로 실행할 코드 (drop → add → alter 순서)\n  const upBuilderLines = [\n    ...(alterColumnLinesTo.drop.up.builder.length > 0 ? alterColumnLinesTo.drop.up.builder : []),\n    ...(alterColumnLinesTo.add.up.builder.length > 0 ? alterColumnLinesTo.add.up.builder : []),\n    ...(alterColumnLinesTo.alter.up.builder.length > 0 ? alterColumnLinesTo.alter.up.builder : []),\n    ...indexNeedsToDrop.map(genIndexDropDefinition),\n  ];\n\n  // knex.raw()로 실행할 코드\n  const upRawLines = [\n    ...(alterColumnLinesTo.add.up.raw.length > 0 ? alterColumnLinesTo.add.up.raw : []),\n    ...alterIndexesTo.add.map((index) => genIndexDefinition(index, table)),\n  ];\n\n  // down은 up의 역순 (add.down = drop rollback, drop.down = add rollback)\n  const downBuilderLines = [\n    ...(alterColumnLinesTo.add.down.builder.length > 0 ? alterColumnLinesTo.add.down.builder : []),\n    ...(alterColumnLinesTo.alter.down.builder.length > 0\n      ? alterColumnLinesTo.alter.down.builder\n      : []),\n    ...(alterColumnLinesTo.drop.down.builder.length > 0\n      ? alterColumnLinesTo.drop.down.builder\n      : []),\n    ...alterIndexesTo.add\n      .filter(\n        (index) =>\n          index.columns.every((indexCol) =>\n            alterColumnsTo.add.map((col) => col.name).includes(indexCol.name),\n          ) === false,\n      )\n      .map(genIndexDropDefinition),\n  ];\n\n  const downRawLines = [\n    ...(alterColumnLinesTo.drop.down.raw.length > 0 ? alterColumnLinesTo.drop.down.raw : []),\n    ...indexNeedsToDrop.map((index) => genIndexDefinition(index, table)),\n  ];\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    ...(upBuilderLines.length > 0\n      ? [`await knex.schema.alterTable(\"${table}\", (table) => {`, ...upBuilderLines, \"});\"]\n      : []),\n    ...upRawLines,\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    ...(downBuilderLines.length > 0\n      ? [`await knex.schema.alterTable(\"${table}\", (table) => {`, ...downBuilderLines, \"});\"]\n      : []),\n    ...downRawLines,\n    \"}\",\n  ];\n\n  const formatted = formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`);\n  const title = [\n    \"alter\",\n    table,\n    ...([\"add\", \"drop\", \"alter\"] as const)\n      .map((action) => {\n        const len = alterColumnsTo[action].length;\n        if (len > 0) {\n          return action + len;\n        }\n        return null;\n      })\n      .filter((part) => part !== null),\n  ].join(\"_\");\n\n  return [\n    {\n      table,\n      title,\n      formatted,\n      type: \"normal\",\n    },\n  ];\n}\n\n/**\n * 컬럼 비교를 위해 Generated Column의 expression을 제외한 객체를 생성\n */\nfunction normalizeColumnForComparison(col: MigrationColumn): MigrationColumn {\n  if (col.generated) {\n    return {\n      ...col,\n      generated: {\n        type: col.generated.type,\n        expression: \"\",\n      },\n    };\n  }\n  return col;\n}\n\n/**\n * 각 컬럼 이름 기준으로 add, drop, alter 여부 확인\n */\nfunction getAlterColumnsTo(entityColumns: MigrationColumn[], dbColumns: MigrationColumn[]) {\n  const columnsTo = {\n    add: [] as MigrationColumn[],\n    drop: [] as MigrationColumn[],\n    alter: [] as MigrationColumn[],\n  };\n\n  // 컬럼명 기준 비교\n  const extraColumns = {\n    db: diff(dbColumns, entityColumns, (col) => [col.name, col.generated?.type].join(\"///\")),\n    entity: diff(entityColumns, dbColumns, (col) => [col.name, col.generated?.type].join(\"///\")),\n  };\n  if (extraColumns.entity.length > 0) {\n    columnsTo.add = columnsTo.add.concat(extraColumns.entity);\n  }\n  if (extraColumns.db.length > 0) {\n    columnsTo.drop = columnsTo.drop.concat(extraColumns.db);\n  }\n\n  // 동일 컬럼명의 세부 필드 비교 (Generated Column expression 제외)\n  const sameDbColumns = intersectionBy(dbColumns, entityColumns, (col) => col.name);\n  const sameMdColumns = intersectionBy(entityColumns, dbColumns, (col) => col.name);\n  columnsTo.alter = differenceWith(\n    sameDbColumns,\n    sameMdColumns,\n    (a, b) => equal({ ...a, generated: undefined }, { ...b, generated: undefined }), // generated 컬럼은 alter로 처리하지 않음\n  );\n\n  return columnsTo;\n}\n\n/**\n * 추출된 컬럼들을 기준으로 각각 라인 생성\n */\nfunction getAlterColumnLinesTo(\n  columnsTo: ReturnType<typeof getAlterColumnsTo>,\n  entityColumns: MigrationColumn[],\n  table: string,\n  dbForeigns: MigrationForeign[],\n) {\n  const linesTo = {\n    add: {\n      up: { builder: [] as string[], raw: [] as string[] },\n      down: { builder: [] as string[], raw: [] as string[] },\n    },\n    drop: {\n      up: { builder: [] as string[], raw: [] as string[] },\n      down: { builder: [] as string[], raw: [] as string[] },\n    },\n    alter: {\n      up: { builder: [] as string[], raw: [] as string[] },\n      down: { builder: [] as string[], raw: [] as string[] },\n    },\n  };\n\n  // add columns\n  const addColumnDefs = genColumnDefinitions(table, columnsTo.add);\n  linesTo.add.up = {\n    builder: addColumnDefs.builder.length > 0 ? [\"// add\", ...addColumnDefs.builder] : [],\n    raw: addColumnDefs.raw.length > 0 ? [\"// add (generated)\", ...addColumnDefs.raw] : [],\n  };\n  linesTo.add.down = {\n    builder:\n      columnsTo.add.length > 0\n        ? [\n            \"// rollback - add\",\n            `table.dropColumns(${columnsTo.add.map((col) => `'${col.name}'`).join(\", \")})`,\n          ]\n        : [],\n    raw: [],\n  };\n\n  // drop할 컬럼에 걸린 FK 찾기\n  const dropColumnNames = columnsTo.drop.map((col) => col.name);\n  const fkToDropBeforeColumn = dbForeigns.filter((fk) =>\n    fk.columns.some((col) => dropColumnNames.includes(col)),\n  );\n\n  const dropFkLines = fkToDropBeforeColumn.map((fk) => {\n    const columnsStringQuote = fk.columns.map((col) => `'${col}'`).join(\",\");\n    return `table.dropForeign([${columnsStringQuote}])`;\n  });\n\n  const restoreFkLines = genForeignDefinitions(table, fkToDropBeforeColumn).up;\n\n  // drop의 rollback시에는 generated column도 복원해야 함\n  const dropColumnDefs = genColumnDefinitions(table, columnsTo.drop);\n  linesTo.drop = {\n    up: {\n      builder: [\n        ...(dropFkLines.length > 0\n          ? [\"// drop foreign keys on columns to be dropped\", ...dropFkLines]\n          : []),\n        ...(columnsTo.drop.length > 0\n          ? [\n              \"// drop columns\",\n              `table.dropColumns(${columnsTo.drop.map((col) => `'${col.name}'`).join(\", \")})`,\n            ]\n          : []),\n      ],\n      raw: [],\n    },\n    down: {\n      builder: [\n        ...(dropColumnDefs.builder.length > 0\n          ? [\"// rollback - drop columns\", ...dropColumnDefs.builder]\n          : []),\n        ...(restoreFkLines.length > 0 ? [\"// restore foreign keys\", ...restoreFkLines] : []),\n      ],\n      raw:\n        dropColumnDefs.raw.length > 0\n          ? [\"// rollback - drop columns (generated)\", ...dropColumnDefs.raw]\n          : [],\n    },\n  };\n\n  // alter columns (Generated Column은 ALTER 불가하므로 drop 후 재생성)\n  linesTo.alter = columnsTo.alter.reduce(\n    (r, dbColumn) => {\n      const entityColumn = entityColumns.find((col) => col.name === dbColumn.name);\n      if (entityColumn === undefined) {\n        return r;\n      }\n\n      // 컬럼 변경사항\n      const columnDiffUp = diff(\n        genColumnDefinitions(table, [entityColumn]).builder,\n        genColumnDefinitions(table, [dbColumn]).builder,\n      );\n      const columnDiffDown = diff(\n        genColumnDefinitions(table, [dbColumn]).builder,\n        genColumnDefinitions(table, [entityColumn]).builder,\n      );\n      if (columnDiffUp.length > 0) {\n        r.up.builder = [\n          ...r.up.builder,\n          \"// alter column\",\n          ...columnDiffUp.map((l) => `${l.replace(\";\", \"\")}.alter();`),\n        ];\n        r.down.builder = [\n          ...r.down.builder,\n          \"// rollback - alter column\",\n          ...columnDiffDown.map((l) => `${l.replace(\";\", \"\")}.alter();`),\n        ];\n      }\n\n      return r;\n    },\n    {\n      up: { builder: [] as string[], raw: [] as string[] },\n      down: { builder: [] as string[], raw: [] as string[] },\n    },\n  );\n\n  return linesTo;\n}\n\n/**\n * 인덱스의 add, drop 여부 확인\n */\nfunction getAlterIndexesTo(entityIndexes: MigrationIndex[], dbIndexes: MigrationIndex[]) {\n  // 인덱스 비교\n  const indexesTo = {\n    add: [] as MigrationIndex[],\n    drop: [] as MigrationIndex[],\n  };\n\n  // 인덱스 고유 식별자 생성 (name을 제외한 모든 필드를 문자열로 변환하여 조합)\n  const identity = <T extends Record<string, unknown>>(index: T): string => {\n    const keys = Object.keys(index)\n      .filter((key) => key !== \"name\")\n      .sort();\n\n    return keys\n      .map((key) => {\n        if (key === \"name\") {\n          return undefined;\n        }\n        if (key === \"columns\") {\n          return (index[key] as MigrationIndex[\"columns\"]).flatMap(identity);\n        }\n        return `${key}=${index[key as keyof MigrationIndex]}`;\n      })\n      .join(\"//\");\n  };\n\n  const extraIndexes = {\n    db: diff(dbIndexes, entityIndexes.map(setMigrationIndexDefaults), identity),\n    entity: diff(entityIndexes.map(setMigrationIndexDefaults), dbIndexes, identity),\n  };\n  if (extraIndexes.entity.length > 0) {\n    indexesTo.add = indexesTo.add.concat(extraIndexes.entity);\n  }\n  if (extraIndexes.db.length > 0) {\n    indexesTo.drop = indexesTo.drop.concat(extraIndexes.db);\n  }\n\n  return indexesTo;\n}\n\n/**\n * 인덱스 삭제 정의 생성\n */\nfunction genIndexDropDefinition(index: MigrationIndex) {\n  return `table.dropIndex([${index.columns\n    .map((column) => `'${column.name}'`)\n    .join(\",\")}], '${index.name}')`;\n}\n\n/**\n * DB 조회 결과와 비교하기 위한 인덱스 기본값 설정\n */\nfunction setMigrationIndexDefaults(index: MigrationIndex): MigrationIndex {\n  return {\n    ...index,\n    columns: index.columns.map((col) => ({\n      ...col,\n      sortOrder: col.sortOrder ?? \"ASC\",\n      // sortOrder에 따라 nullsFirst의 default 값 설정\n      nullsFirst: col.nullsFirst ?? col.sortOrder === \"DESC\",\n    })),\n    nullsNotDistinct: index.nullsNotDistinct ?? false,\n  };\n}\n\n/**\n * 테이블 변경 케이스 - Foreign Key 변경\n */\nasync function generateAlterCode_Foreigns(\n  table: string,\n  entityForeigns: MigrationForeign[],\n  dbForeigns: MigrationForeign[],\n  droppingColumns: MigrationColumn[] = [],\n): Promise<GenMigrationCode[]> {\n  // console.log({ entityForeigns, dbForeigns });\n\n  const getKey = (mf: MigrationForeign): string => {\n    return [mf.columns.join(\"-\"), mf.to].join(\"///\");\n  };\n\n  // 삭제될 컬럼명 목록\n  const droppingColumnNames = droppingColumns.map((col) => col.name);\n\n  const fkTo = entityForeigns.reduce(\n    (result, entityF) => {\n      const matchingDbF = dbForeigns.find((dbF) => getKey(entityF) === getKey(dbF));\n      if (!matchingDbF) {\n        result.add.push(entityF);\n        return result;\n      }\n\n      if (equal(entityF, matchingDbF) === false) {\n        result.alterSrc.push(matchingDbF);\n        result.alterDst.push(entityF);\n        return result;\n      }\n      return result;\n    },\n    {\n      add: [] as MigrationForeign[],\n      drop: [] as MigrationForeign[],\n      alterSrc: [] as MigrationForeign[],\n      alterDst: [] as MigrationForeign[],\n    },\n  );\n\n  // dbForeigns에는 있지만 entityForeigns에는 없는 경우 (삭제된 FK)\n  // 단, 삭제될 컬럼의 FK는 제외 (generateAlterCode_ColumnAndIndexes에서 처리)\n  dbForeigns.forEach((dbF) => {\n    const matchingEntityF = entityForeigns.find((entityF) => getKey(entityF) === getKey(dbF));\n    if (!matchingEntityF) {\n      // 이 FK의 컬럼이 삭제될 컬럼 목록에 있는지 확인\n      const isColumnDropping = dbF.columns.some((col) => droppingColumnNames.includes(col));\n      // 컬럼이 삭제되지 않는 경우에만 FK drop 목록에 추가\n      if (!isColumnDropping) {\n        fkTo.drop.push(dbF);\n      }\n    }\n  });\n\n  const linesTo = {\n    add: genForeignDefinitions(table, fkTo.add),\n    drop: genForeignDefinitions(table, fkTo.drop),\n    alterSrc: genForeignDefinitions(table, fkTo.alterSrc),\n    alterDst: genForeignDefinitions(table, fkTo.alterDst),\n  };\n\n  // drop fk columns인 경우(생성될 코드 없는 경우) 패스\n  const hasLines = Object.values(linesTo).some((l) => l.up.length > 0 || l.down.length > 0);\n  if (!hasLines) {\n    return [];\n  }\n\n  if (\n    linesTo.add.up.length === 0 &&\n    linesTo.drop.up.length === 0 &&\n    linesTo.alterSrc.up.length === 0 &&\n    linesTo.alterDst.up.length === 0\n  ) {\n    Naite.t(\"migrator:generateAlterCode_Foreigns:fkChangeCodeGenerationError\", {\n      table,\n      entityForeigns,\n      dbForeigns,\n    });\n    throw new Error(\"FK 변경 코드 생성 오류\");\n  }\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...linesTo.drop.down,\n    ...linesTo.add.up,\n    ...linesTo.alterSrc.down,\n    ...linesTo.alterDst.up,\n    \"})\",\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...linesTo.add.down,\n    ...linesTo.alterDst.down,\n    ...linesTo.alterSrc.up,\n    ...linesTo.drop.up,\n    \"})\",\n    \"}\",\n  ];\n\n  const formatted = formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`);\n  const title = [\n    \"alter\",\n    table,\n    \"foreigns\",\n    // TODO 바뀌는 부분\n  ].join(\"_\");\n\n  return [\n    {\n      table,\n      title,\n      formatted,\n      type: \"normal\",\n    },\n  ];\n}\n\n/**\n * 주어진 EntitySet을 기반으로 테이블 CREATE 마이그레이션 코드를 생성합니다.\n * @param entitySet\n * @returns CREATE 마이그레이션 코드\n */\nexport async function generateCreateCode(entitySet: MigrationSet): Promise<GenMigrationCode[]> {\n  return [\n    await generateCreateCode_ColumnAndIndexes(\n      entitySet.table,\n      entitySet.columns,\n      entitySet.indexes,\n    ),\n    ...(await generateCreateCode_Foreign(entitySet.table, entitySet.foreigns)),\n  ];\n}\n\n/**\n * 주어진 entitySet을 목표로, dbSet을 현 상황으로 하여 테이블 ALTER 마이그레이션 코드를 생성합니다.\n * @param entitySet 현 상황의 MigrationSet\n * @param dbSet 목표 상황의 MigrationSet\n * @returns ALTER 마이그레이션 코드\n */\nexport async function generateAlterCode(\n  entitySet: MigrationSet,\n  dbSet: MigrationSet,\n): Promise<GenMigrationCode[]> {\n  const replaceColumnDefaultTo = (col: MigrationColumn) => {\n    // float인 경우 기본값을 0으로 지정하는 경우 \"0.00\"으로 변환되는 케이스 대응\n    // if (col.type === \"float\" && col.defaultTo && String(col.defaultTo).includes('\"') === false) {\n    //   col.defaultTo = `\"${Number(col.defaultTo).toFixed(col.scale ?? 2)}\"`;\n    // }\n    // // string인 경우 기본값이 빈 스트링인 경우 대응\n    // if (col.type === \"string\" && col.defaultTo === \"\") {\n    //   col.defaultTo = '\"\"';\n    // }\n    // // boolean인 경우 기본값 정규화 (MySQL에서는 TINYINT(1)로 저장되므로 0 또는 1로 정규화)\n    // // TODO: db.ts에 typeCase 설정 확인하여 처리하도록 수정 필요\n    // if (col.type === \"boolean\" && col.defaultTo !== undefined) {\n    //   if (col.defaultTo === \"0\" || col.defaultTo.toLowerCase() === \"false\") {\n    //     col.defaultTo = \"0\";\n    //   } else if (col.defaultTo === \"1\" || col.defaultTo.toLowerCase() === \"true\") {\n    //     col.defaultTo = \"1\";\n    //   }\n    // }\n\n    // FIXME: 일단 MySQL 상황에서 발생했던 이슈의 workaround 이므로 Pg에서 재확인 후 대응 추가\n    return col;\n  };\n  const entityColumns = alphabetical(entitySet.columns, (a) => a.name).map(replaceColumnDefaultTo);\n  const dbColumns = alphabetical(dbSet.columns, (a) => a.name).map(replaceColumnDefaultTo);\n\n  /* 디버깅용 코드, 특정 컬럼에서 불일치 발생할 때 확인\n        const entityColumn = entitySet.columns.find(\n          (col) => col.name === \"price_krw\"\n        );\n        const dbColumn = dbSet.columns.find(\n          (col) => col.name === \"price_krw\"\n        );\n        console.debug({ entityColumn, dbColumn });\n         */\n\n  // ?\n  const entityIndexes = alphabetical(entitySet.indexes, (a) => [a.type, ...a.columns].join(\"-\"));\n  const dbIndexes = alphabetical(dbSet.indexes, (a) => [a.type, ...a.columns].join(\"-\"));\n\n  const replaceNoActionOnMySQL = (f: MigrationForeign) => {\n    // MySQL에서 RESTRICT와 NO ACTION은 동일함\n    const { onDelete, onUpdate } = f;\n    return {\n      ...f,\n      onUpdate: onUpdate === \"RESTRICT\" ? \"NO ACTION\" : onUpdate,\n      onDelete: onDelete === \"RESTRICT\" ? \"NO ACTION\" : onDelete,\n    };\n  };\n\n  const entityForeigns = alphabetical(entitySet.foreigns, (a) =>\n    [a.to, ...a.columns].join(\"-\"),\n  ).map((f) => replaceNoActionOnMySQL(f));\n  const dbForeigns = alphabetical(dbSet.foreigns, (a) => [a.to, ...a.columns].join(\"-\")).map((f) =>\n    replaceNoActionOnMySQL(f),\n  );\n\n  // 삭제될 컬럼 목록 계산\n  const droppingColumns = diff(dbColumns, entityColumns, (col) => col.name);\n\n  const alterCodes: (GenMigrationCode | GenMigrationCode[] | null)[] = [];\n\n  // 1. columnsAndIndexes 처리\n  const isEqualColumns = equal(\n    entityColumns.map(normalizeColumnForComparison),\n    dbColumns.map(normalizeColumnForComparison),\n  );\n  const isEqualIndexes = equal(\n    entityIndexes.map((index) => omit(index, [\"parser\"])).map(setMigrationIndexDefaults),\n    dbIndexes,\n  );\n  if (!isEqualColumns || !isEqualIndexes) {\n    alterCodes.push(\n      await generateAlterCode_ColumnAndIndexes(\n        entitySet.table,\n        entityColumns,\n        entityIndexes,\n        dbColumns,\n        dbIndexes,\n        dbSet.foreigns,\n      ),\n    );\n  }\n\n  // 2. foreigns 처리 (삭제될 컬럼 정보 전달)\n  if (equal(entityForeigns, dbForeigns) === false) {\n    alterCodes.push(\n      await generateAlterCode_Foreigns(\n        entitySet.table,\n        entityForeigns,\n        dbForeigns,\n        droppingColumns,\n      ),\n    );\n  }\n\n  if (alterCodes.every((alterCode) => alterCode === null)) {\n    return [];\n  }\n\n  return alterCodes.filter((alterCode) => alterCode !== null).flat();\n}\n"],"names":["equal","alphabetical","diff","omit","Naite","formatCode","differenceWith","intersectionBy","generateCreateCode_ColumnAndIndexes","table","columns","indexes","columnDefs","genColumnDefinitions","lines","builder","raw","map","index","genIndexDefinition","type","title","formatted","join","result","column","generated","push","genGeneratedColumnDefinition","genNormalColumnDefinition","Error","pgType","getPgTypeForColumn","storageType","nullableClause","nullable","name","expression","chains","endsWith","elementType","slice","getPgArrayType","dimensions","numberType","precision","scale","length","undefined","extraType","defaultTo","startsWith","genVectorIndexDefinition","methodMap","fulltext","unique","nullsNotDistinctClause","nullsNotDistinct","col","sortOrderClause","sortOrder","nullsFirstClause","nullsFirst","vectorOps","m","efConstruction","lists","generateCreateCode_Foreign","foreigns","up","down","genForeignDefinitions","console","log","foreignKeysString","foreign","reduce","r","columnsStringQuote","replace","to","onUpdate","onDelete","generateAlterCode_ColumnAndIndexes","entityColumns","entityIndexes","dbColumns","dbIndexes","dbForeigns","alterColumnsTo","getAlterColumnsTo","alterColumnLinesTo","getAlterColumnLinesTo","alterIndexesTo","getAlterIndexesTo","indexNeedsToDrop","drop","filter","every","includes","hasUpChanges","add","alter","t","upBuilderLines","genIndexDropDefinition","upRawLines","downBuilderLines","indexCol","downRawLines","action","len","part","normalizeColumnForComparison","columnsTo","extraColumns","db","entity","concat","sameDbColumns","sameMdColumns","a","b","linesTo","addColumnDefs","dropColumnNames","fkToDropBeforeColumn","fk","some","dropFkLines","restoreFkLines","dropColumnDefs","dbColumn","entityColumn","find","columnDiffUp","columnDiffDown","l","indexesTo","identity","keys","Object","key","sort","flatMap","extraIndexes","setMigrationIndexDefaults","generateAlterCode_Foreigns","entityForeigns","droppingColumns","getKey","mf","droppingColumnNames","fkTo","entityF","matchingDbF","dbF","alterSrc","alterDst","forEach","matchingEntityF","isColumnDropping","hasLines","values","generateCreateCode","entitySet","generateAlterCode","dbSet","replaceColumnDefaultTo","replaceNoActionOnMySQL","f","alterCodes","isEqualColumns","isEqualIndexes","alterCode","flat"],"mappings":"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"}
810
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/migration/code-generation.ts"],"sourcesContent":["import equal from \"fast-deep-equal\";\nimport { alphabetical, diff } from \"radashi\";\nimport { Naite } from \"..\";\nimport type {\n  GenMigrationCode,\n  MigrationColumn,\n  MigrationForeign,\n  MigrationIndex,\n  MigrationSet,\n} from \"../types/types\";\nimport { formatCode } from \"../utils/formatter\";\nimport { differenceWith, intersectionBy } from \"../utils/utils\";\n\n/**\n * 컬럼 정의 결과 타입\n * - builder: Knex table builder 메서드로 실행할 구문 (table.xxx())\n * - raw: knex.raw()로 실행할 구문\n */\ntype ColumnDefinitionResult = {\n  builder: string[];\n  raw: string[];\n};\n\n/**\n * 테이블 생성하는 케이스 - 컬럼/인덱스 생성\n */\nasync function generateCreateCode_ColumnAndIndexes(\n  table: string,\n  columns: MigrationColumn[],\n  indexes: MigrationIndex[],\n): Promise<GenMigrationCode> {\n  const columnDefs = genColumnDefinitions(table, columns);\n\n  // 컬럼, 인덱스 처리\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `await knex.schema.createTable(\"${table}\", (table) => {`,\n    ...columnDefs.builder,\n    \"});\",\n    // raw 구문 (Generated Column 등)\n    ...columnDefs.raw,\n    // index는 knex.raw로 처리하므로 createTable 밖에서 실행\n    ...indexes.map((index) => genIndexDefinition(index, table)),\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    ` return knex.schema.dropTable(\"${table}\");`,\n    \"}\",\n  ];\n  return {\n    table,\n    type: \"normal\",\n    title: `create__${table}`,\n    formatted: formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`),\n  };\n}\n\n/**\n * MigrationColumn[] 읽어서 컬럼 정의하는 구문 생성\n * @returns builder: table builder 메서드, raw: knex.raw() 구문\n */\nfunction genColumnDefinitions(table: string, columns: MigrationColumn[]): ColumnDefinitionResult {\n  const result: ColumnDefinitionResult = {\n    builder: [],\n    raw: [],\n  };\n\n  for (const column of columns) {\n    // Generated Column은 raw로 처리\n    if (column.generated) {\n      result.raw.push(genGeneratedColumnDefinition(table, column));\n      continue;\n    }\n\n    // 일반 컬럼은 builder로 처리\n    result.builder.push(genNormalColumnDefinition(column));\n  }\n\n  return result;\n}\n\n/**\n * Generated Column 정의 생성 (ALTER TABLE ADD COLUMN 사용)\n */\nfunction genGeneratedColumnDefinition(table: string, column: MigrationColumn): string {\n  if (!column.generated) {\n    throw new Error(\"Generated column definition required\");\n  }\n  const pgType = getPgTypeForColumn(column);\n  const storageType = column.generated.type === \"VIRTUAL\" ? \" VIRTUAL\" : \" STORED\";\n  const nullableClause = column.nullable ? \"\" : \" NOT NULL\";\n  return `await knex.raw(\\`ALTER TABLE \"${table}\" ADD COLUMN \"${column.name}\" ${pgType} GENERATED ALWAYS AS (${column.generated.expression})${storageType}${nullableClause}\\`);`;\n}\n\n/**\n * 일반 컬럼 정의 생성 (table.xxx() 체인)\n */\nfunction genNormalColumnDefinition(column: MigrationColumn): string {\n  const chains: string[] = [];\n\n  if (column.name === \"id\") {\n    return `table.increments().primary();`;\n  }\n\n  // 배열 타입 처리\n  if (column.type.endsWith(\"[]\")) {\n    const elementType = column.type.slice(0, -2); // \"integer[]\" -> \"integer\"\n    const pgType = getPgArrayType(column, elementType);\n    chains.push(`specificType('${column.name}', '${pgType}')`);\n  } else if (column.type === \"vector\") {\n    // Knex는 vector 타입을 직접 지원하지 않으므로 specificType 사용\n    chains.push(`specificType('${column.name}', 'vector(${column.dimensions})')`);\n  } else if (column.type === \"numberOrNumeric\") {\n    // number\n    if (column.numberType === \"real\") {\n      chains.push(`float('${column.name}')`);\n    } else if (column.numberType === \"double precision\") {\n      chains.push(`double('${column.name}')`);\n    } else if ((column.numberType ?? \"numeric\") === \"numeric\") {\n      chains.push(`decimal('${column.name}', ${column.precision}, ${column.scale})`);\n    }\n  } else if (column.type === \"string\") {\n    // string\n    if (column.length !== undefined) {\n      chains.push(`string('${column.name}', ${column.length})`);\n    } else {\n      chains.push(`text('${column.name}')`);\n    }\n  } else if (column.type === \"date\") {\n    // date\n    chains.push(`timestamp('${column.name}', { useTz: true })`);\n  } else if (column.type === \"json\") {\n    // json\n    chains.push(`jsonb('${column.name}')`);\n  } else {\n    // type, length\n    let extraType: string | undefined;\n    chains.push(\n      `${column.type}('${column.name}'${\n        column.length ? `, ${column.length}` : \"\"\n      }${extraType ? `, '${extraType}'` : \"\"})`,\n    );\n  }\n\n  // nullable\n  chains.push(column.nullable ? \"nullable()\" : \"notNullable()\");\n\n  // defaultTo\n  if (column.defaultTo !== undefined) {\n    if (typeof column.defaultTo === \"string\" && column.defaultTo.startsWith(`\"`)) {\n      chains.push(`defaultTo(${column.defaultTo})`);\n    } else {\n      chains.push(`defaultTo(knex.raw('${column.defaultTo}'))`);\n    }\n  }\n\n  return `table.${chains.join(\".\")};`;\n}\n\n/**\n * MigrationColumn의 타입을 PostgreSQL 타입 문자열로 변환\n */\nfunction getPgTypeForColumn(column: MigrationColumn): string {\n  if (column.type.endsWith(\"[]\")) {\n    const elementType = column.type.slice(0, -2);\n    return getPgArrayType(column, elementType);\n  }\n\n  switch (column.type) {\n    case \"string\":\n      return column.length !== undefined ? `varchar(${column.length})` : \"text\";\n    case \"bigInteger\":\n      return \"bigint\";\n    case \"numberOrNumeric\":\n      if (column.numberType === \"real\") return \"real\";\n      if (column.numberType === \"double precision\") return \"double precision\";\n      return `numeric(${column.precision}, ${column.scale})`;\n    case \"date\":\n      return \"timestamptz\";\n    case \"json\":\n      return \"jsonb\";\n    case \"vector\":\n      return `vector(${column.dimensions})`;\n    default:\n      return column.type;\n  }\n}\n\nfunction getPgArrayType(column: MigrationColumn, elementType: string): string {\n  if (elementType === \"numberOrNumeric\") {\n    if (column.numberType === \"real\") return \"real[]\";\n    if (column.numberType === \"double precision\") return \"double precision[]\";\n    return `numeric(${column.precision}, ${column.scale})[]`;\n  }\n  if (elementType === \"string\") {\n    return column.length ? `varchar(${column.length})[]` : \"text[]\";\n  }\n  if (elementType === \"date\") return \"timestamptz[]\";\n  if (elementType === \"integer\") return \"integer[]\";\n  if (elementType === \"bigInteger\") return \"bigint[]\";\n  if (elementType === \"boolean\") return \"boolean[]\";\n  if (elementType === \"uuid\") return \"uuid[]\";\n  if (elementType === \"enum\") return \"text[]\";\n  if (elementType === \"vector\") return `vector(${column.dimensions})[]`;\n\n  throw new Error(`Unknown array element type: ${elementType}`);\n}\n\n/**\n * 개별 인덱스 정의 생성\n */\nfunction genIndexDefinition(index: MigrationIndex, table: string): string {\n  if (index.type === \"hnsw\" || index.type === \"ivfflat\") {\n    return genVectorIndexDefinition(index, table);\n  }\n\n  const methodMap = {\n    index: \"INDEX\",\n    unique: \"UNIQUE INDEX\",\n  };\n\n  const nullsNotDistinctClause =\n    index.type === \"unique\" && index.nullsNotDistinct !== undefined\n      ? ` NULLS ${index.nullsNotDistinct ? \"NOT DISTINCT\" : \"DISTINCT\"}`\n      : \"\";\n\n  const usingClause = index.using === undefined ? \"\" : `USING ${index.using}`;\n\n  return `await knex.raw(\n  \\`CREATE ${methodMap[index.type]} ${index.name} ON ${table} ${usingClause}(${index.columns\n    .map((col) => {\n      // 정렬 옵션은 btree만 사용 가능\n      if (index.using !== \"btree\" && index.using !== undefined) {\n        return `${col.name}`;\n      }\n\n      const sortOrderClause = col.sortOrder === undefined ? \"\" : ` ${col.sortOrder}`;\n      const nullsFirstClause =\n        col.nullsFirst === undefined ? \"\" : ` NULLS ${col.nullsFirst ? \"FIRST\" : \"LAST\"}`;\n      return `${col.name}${sortOrderClause}${nullsFirstClause}`;\n    })\n    .join(\", \")})${nullsNotDistinctClause};\\`\n  );`;\n}\n\n/**\n * @description\n * - HNSW (Hierarchical Navigable Small World): 느린 빌드, 빠른 검색 속도, 높은 메모리 및 정확도\n * - IVFFlat (Inverted File with Flat Compression): 빠른 빌드, 중간 검색 속도, 낮은 메모리\n *\n * @example\n * // HNSW 인덱스 (권장 - 빠른 검색, 높은 정확도)\n * CREATE INDEX idx_embedding ON items USING hnsw (embedding vector_cosine_ops) WITH (m = 16, ef_construction = 64);\n *\n * // IVFFlat 인덱스 (대용량 데이터, 비용 중요 시)\n * CREATE INDEX idx_embedding ON items USING ivfflat (embedding vector_cosine_ops) WITH (lists = 100);\n */\nfunction genVectorIndexDefinition(index: MigrationIndex, table: string): string {\n  const column = index.columns[0];\n  const vectorOps = column.vectorOps ?? \"vector_cosine_ops\";\n\n  // HNSW (Hierarchical Navigable Small World) - 권장: 빠른 검색, 높은 정확도\n  if (index.type === \"hnsw\") {\n    const m = index.m ?? 16;\n    const efConstruction = index.efConstruction ?? 64;\n    return `await knex.raw(\\`CREATE INDEX ${index.name} ON ${table} USING hnsw (${column.name} ${vectorOps}) WITH (m = ${m}, ef_construction = ${efConstruction})\\`);`;\n  }\n\n  // IVFFlat (Inverted File with Flat Compression) - 대용량, 비용 중요 시\n  if (index.type === \"ivfflat\") {\n    const lists = index.lists ?? 100;\n    return `await knex.raw(\\`CREATE INDEX ${index.name} ON ${table} USING ivfflat (${column.name} ${vectorOps}) WITH (lists = ${lists})\\`);`;\n  }\n\n  throw new Error(`Unknown raw SQL index type: ${index.type}`);\n}\n\n/**\n * 테이블 생성하는 케이스 - FK 생성\n */\nasync function generateCreateCode_Foreign(\n  table: string,\n  foreigns: MigrationForeign[],\n): Promise<GenMigrationCode[]> {\n  if (foreigns.length === 0) {\n    return [];\n  }\n\n  const { up, down } = genForeignDefinitions(table, foreigns);\n  if (up.length === 0 && down.length === 0) {\n    console.log(\"fk 가 뭔가 다릅니다\");\n    return [];\n  }\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    \"// create fk\",\n    ...up,\n    \"});\",\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    \"// drop fk\",\n    ...down,\n    \"});\",\n    \"}\",\n  ];\n\n  const foreignKeysString = foreigns.map((foreign) => foreign.columns.join(\"_\")).join(\"_\");\n  return [\n    {\n      table,\n      type: \"foreign\",\n      title: `foreign__${table}__${foreignKeysString}`,\n      formatted: formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`),\n    },\n  ];\n}\n\n/**\n * MigrationForeign[] 읽어서 외부키 constraint 정의하는 구문 생성\n */\nfunction genForeignDefinitions(\n  table: string,\n  foreigns: MigrationForeign[],\n): { up: string[]; down: string[] } {\n  return foreigns.reduce(\n    (r, foreign) => {\n      const columnsStringQuote = foreign.columns\n        .map((col) => `'${col.replace(`${table}.`, \"\")}'`)\n        .join(\",\");\n      r.up.push(\n        `table.foreign('${foreign.columns.join(\",\")}')\n            .references('${foreign.to}')\n            .onUpdate('${foreign.onUpdate}')\n            .onDelete('${foreign.onDelete}')`,\n      );\n      r.down.push(`table.dropForeign([${columnsStringQuote}])`);\n      return r;\n    },\n    {\n      up: [] as string[],\n      down: [] as string[],\n    },\n  );\n}\n\n/**\n * 테이블 변경 케이스 - 컬럼/인덱스 변경\n */\nasync function generateAlterCode_ColumnAndIndexes(\n  table: string,\n  entityColumns: MigrationColumn[],\n  entityIndexes: MigrationIndex[],\n  dbColumns: MigrationColumn[],\n  dbIndexes: MigrationIndex[],\n  dbForeigns: MigrationForeign[],\n): Promise<GenMigrationCode[]> {\n  /*\n    세부 비교 후 다른점 찾아서 코드 생성\n\n    1. 컬럼갯수 다름: MD에 있으나, DB에 없다면 추가\n    2. 컬럼갯수 다름: MD에 없으나, DB에 있다면 삭제\n    3. 그외 컬럼(컬럼 갯수가 동일하거나, 다른 경우 동일한 컬럼끼리) => alter\n    4. 다른거 다 동일하고 index만 변경되는 경우\n\n    ** 컬럼명을 변경하는 경우는 따로 핸들링하지 않음\n    => drop/add 형태의 마이그레이션 코드가 생성되는데, 수동으로 rename 코드로 수정하여 처리\n  */\n\n  // 각 컬럼 이름 기준으로 add, drop, alter 여부 확인\n  const alterColumnsTo = getAlterColumnsTo(entityColumns, dbColumns);\n\n  // 추출된 컬럼들을 기준으로 각각 라인 생성\n  const alterColumnLinesTo = getAlterColumnLinesTo(\n    alterColumnsTo,\n    entityColumns,\n    table,\n    dbForeigns,\n  );\n\n  // 인덱스의 add, drop 여부 확인\n  const alterIndexesTo = getAlterIndexesTo(entityIndexes, dbIndexes);\n\n  // 인덱스가 삭제되는 경우, 컬럼과 같이 삭제된 케이스에는 drop에서 제외해야함!\n  const indexNeedsToDrop = alterIndexesTo.drop.filter(\n    (index) =>\n      index.columns.every(({ name }) =>\n        alterColumnsTo.drop.map((col) => col.name).includes(name),\n      ) === false,\n  );\n\n  // 빈 코드 생성 방지\n  const hasUpChanges =\n    alterColumnLinesTo.add.up.builder.length > 0 ||\n    alterColumnLinesTo.add.up.raw.length > 0 ||\n    alterColumnLinesTo.drop.up.builder.length > 0 ||\n    alterColumnLinesTo.alter.up.builder.length > 0 ||\n    alterIndexesTo.add.length > 0 ||\n    indexNeedsToDrop.length > 0;\n  if (!hasUpChanges) {\n    Naite.t(\"migrator:generateAlterCode_ColumnAndIndexes:emptyCodeGenerationError\", {\n      entityColumns,\n      dbColumns,\n      entityIndexes,\n      dbIndexes,\n    });\n    // throw new Error(\"컬럼/인덱스 변경 코드 생성 오류\");\n  }\n  Naite.t(\"migrator:generateAlterCode_ColumnAndIndexes:debug\", {\n    \"alterColumnsTo.add.length\": alterColumnsTo.add.length,\n    \"alterColumnsTo.drop.length\": alterColumnsTo.drop.length,\n    \"alterColumnsTo.alter.length\": alterColumnsTo.alter.length,\n    \"alterIndexesTo.add.length\": alterIndexesTo.add.length,\n    \"alterIndexesTo.drop.length\": alterIndexesTo.drop.length,\n    \"indexNeedsToDrop.length\": indexNeedsToDrop.length,\n  });\n  // Naite.t(\"migrator:generateAlterCode_ColumnAndIndexes:alterColumnsTo\", alterColumnsTo);\n\n  // TODO: 인덱스명 변경된 경우 처리\n\n  // table builder 메서드로 실행할 코드 (drop → add → alter 순서)\n  const upBuilderLines = [\n    ...(alterColumnLinesTo.drop.up.builder.length > 0 ? alterColumnLinesTo.drop.up.builder : []),\n    ...(alterColumnLinesTo.add.up.builder.length > 0 ? alterColumnLinesTo.add.up.builder : []),\n    ...(alterColumnLinesTo.alter.up.builder.length > 0 ? alterColumnLinesTo.alter.up.builder : []),\n    ...indexNeedsToDrop.map(genIndexDropDefinition),\n  ];\n\n  // knex.raw()로 실행할 코드\n  const upRawLines = [\n    ...(alterColumnLinesTo.add.up.raw.length > 0 ? alterColumnLinesTo.add.up.raw : []),\n    ...alterIndexesTo.add.map((index) => genIndexDefinition(index, table)),\n  ];\n\n  // down은 up의 역순 (add.down = drop rollback, drop.down = add rollback)\n  const downBuilderLines = [\n    ...(alterColumnLinesTo.add.down.builder.length > 0 ? alterColumnLinesTo.add.down.builder : []),\n    ...(alterColumnLinesTo.alter.down.builder.length > 0\n      ? alterColumnLinesTo.alter.down.builder\n      : []),\n    ...(alterColumnLinesTo.drop.down.builder.length > 0\n      ? alterColumnLinesTo.drop.down.builder\n      : []),\n    ...alterIndexesTo.add\n      .filter(\n        (index) =>\n          index.columns.every((indexCol) =>\n            alterColumnsTo.add.map((col) => col.name).includes(indexCol.name),\n          ) === false,\n      )\n      .map(genIndexDropDefinition),\n  ];\n\n  const downRawLines = [\n    ...(alterColumnLinesTo.drop.down.raw.length > 0 ? alterColumnLinesTo.drop.down.raw : []),\n    ...indexNeedsToDrop.map((index) => genIndexDefinition(index, table)),\n  ];\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    ...(upBuilderLines.length > 0\n      ? [`await knex.schema.alterTable(\"${table}\", (table) => {`, ...upBuilderLines, \"});\"]\n      : []),\n    ...upRawLines,\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    ...(downBuilderLines.length > 0\n      ? [`await knex.schema.alterTable(\"${table}\", (table) => {`, ...downBuilderLines, \"});\"]\n      : []),\n    ...downRawLines,\n    \"}\",\n  ];\n\n  const formatted = formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`);\n  const title = [\n    \"alter\",\n    table,\n    ...([\"add\", \"drop\", \"alter\"] as const)\n      .map((action) => {\n        const len = alterColumnsTo[action].length;\n        if (len > 0) {\n          return action + len;\n        }\n        return null;\n      })\n      .filter((part) => part !== null),\n  ].join(\"_\");\n\n  return [\n    {\n      table,\n      title,\n      formatted,\n      type: \"normal\",\n    },\n  ];\n}\n\n/**\n * 컬럼 비교를 위해 Generated Column의 expression을 제외한 객체를 생성\n */\nfunction normalizeColumnForComparison(col: MigrationColumn): MigrationColumn {\n  if (col.generated) {\n    return {\n      ...col,\n      generated: {\n        type: col.generated.type,\n        expression: \"\",\n      },\n    };\n  }\n  return col;\n}\n\n/**\n * 각 컬럼 이름 기준으로 add, drop, alter 여부 확인\n */\nfunction getAlterColumnsTo(entityColumns: MigrationColumn[], dbColumns: MigrationColumn[]) {\n  const columnsTo = {\n    add: [] as MigrationColumn[],\n    drop: [] as MigrationColumn[],\n    alter: [] as MigrationColumn[],\n  };\n\n  // 컬럼명 기준 비교\n  const extraColumns = {\n    db: diff(dbColumns, entityColumns, (col) => [col.name, col.generated?.type].join(\"///\")),\n    entity: diff(entityColumns, dbColumns, (col) => [col.name, col.generated?.type].join(\"///\")),\n  };\n  if (extraColumns.entity.length > 0) {\n    columnsTo.add = columnsTo.add.concat(extraColumns.entity);\n  }\n  if (extraColumns.db.length > 0) {\n    columnsTo.drop = columnsTo.drop.concat(extraColumns.db);\n  }\n\n  // 동일 컬럼명의 세부 필드 비교 (Generated Column expression 제외)\n  const sameDbColumns = intersectionBy(dbColumns, entityColumns, (col) => col.name);\n  const sameMdColumns = intersectionBy(entityColumns, dbColumns, (col) => col.name);\n  columnsTo.alter = differenceWith(\n    sameDbColumns,\n    sameMdColumns,\n    (a, b) => equal({ ...a, generated: undefined }, { ...b, generated: undefined }), // generated 컬럼은 alter로 처리하지 않음\n  );\n\n  return columnsTo;\n}\n\n/**\n * 추출된 컬럼들을 기준으로 각각 라인 생성\n */\nfunction getAlterColumnLinesTo(\n  columnsTo: ReturnType<typeof getAlterColumnsTo>,\n  entityColumns: MigrationColumn[],\n  table: string,\n  dbForeigns: MigrationForeign[],\n) {\n  const linesTo = {\n    add: {\n      up: { builder: [] as string[], raw: [] as string[] },\n      down: { builder: [] as string[], raw: [] as string[] },\n    },\n    drop: {\n      up: { builder: [] as string[], raw: [] as string[] },\n      down: { builder: [] as string[], raw: [] as string[] },\n    },\n    alter: {\n      up: { builder: [] as string[], raw: [] as string[] },\n      down: { builder: [] as string[], raw: [] as string[] },\n    },\n  };\n\n  // add columns\n  const addColumnDefs = genColumnDefinitions(table, columnsTo.add);\n  linesTo.add.up = {\n    builder: addColumnDefs.builder.length > 0 ? [\"// add\", ...addColumnDefs.builder] : [],\n    raw: addColumnDefs.raw.length > 0 ? [\"// add (generated)\", ...addColumnDefs.raw] : [],\n  };\n  linesTo.add.down = {\n    builder:\n      columnsTo.add.length > 0\n        ? [\n            \"// rollback - add\",\n            `table.dropColumns(${columnsTo.add.map((col) => `'${col.name}'`).join(\", \")})`,\n          ]\n        : [],\n    raw: [],\n  };\n\n  // drop할 컬럼에 걸린 FK 찾기\n  const dropColumnNames = columnsTo.drop.map((col) => col.name);\n  const fkToDropBeforeColumn = dbForeigns.filter((fk) =>\n    fk.columns.some((col) => dropColumnNames.includes(col)),\n  );\n\n  const dropFkLines = fkToDropBeforeColumn.map((fk) => {\n    const columnsStringQuote = fk.columns.map((col) => `'${col}'`).join(\",\");\n    return `table.dropForeign([${columnsStringQuote}])`;\n  });\n\n  const restoreFkLines = genForeignDefinitions(table, fkToDropBeforeColumn).up;\n\n  // drop의 rollback시에는 generated column도 복원해야 함\n  const dropColumnDefs = genColumnDefinitions(table, columnsTo.drop);\n  linesTo.drop = {\n    up: {\n      builder: [\n        ...(dropFkLines.length > 0\n          ? [\"// drop foreign keys on columns to be dropped\", ...dropFkLines]\n          : []),\n        ...(columnsTo.drop.length > 0\n          ? [\n              \"// drop columns\",\n              `table.dropColumns(${columnsTo.drop.map((col) => `'${col.name}'`).join(\", \")})`,\n            ]\n          : []),\n      ],\n      raw: [],\n    },\n    down: {\n      builder: [\n        ...(dropColumnDefs.builder.length > 0\n          ? [\"// rollback - drop columns\", ...dropColumnDefs.builder]\n          : []),\n        ...(restoreFkLines.length > 0 ? [\"// restore foreign keys\", ...restoreFkLines] : []),\n      ],\n      raw:\n        dropColumnDefs.raw.length > 0\n          ? [\"// rollback - drop columns (generated)\", ...dropColumnDefs.raw]\n          : [],\n    },\n  };\n\n  // alter columns (Generated Column은 ALTER 불가하므로 drop 후 재생성)\n  linesTo.alter = columnsTo.alter.reduce(\n    (r, dbColumn) => {\n      const entityColumn = entityColumns.find((col) => col.name === dbColumn.name);\n      if (entityColumn === undefined) {\n        return r;\n      }\n\n      // 컬럼 변경사항\n      const columnDiffUp = diff(\n        genColumnDefinitions(table, [entityColumn]).builder,\n        genColumnDefinitions(table, [dbColumn]).builder,\n      );\n      const columnDiffDown = diff(\n        genColumnDefinitions(table, [dbColumn]).builder,\n        genColumnDefinitions(table, [entityColumn]).builder,\n      );\n      if (columnDiffUp.length > 0) {\n        r.up.builder = [\n          ...r.up.builder,\n          \"// alter column\",\n          ...columnDiffUp.map((l) => `${l.replace(\";\", \"\")}.alter();`),\n        ];\n        r.down.builder = [\n          ...r.down.builder,\n          \"// rollback - alter column\",\n          ...columnDiffDown.map((l) => `${l.replace(\";\", \"\")}.alter();`),\n        ];\n      }\n\n      return r;\n    },\n    {\n      up: { builder: [] as string[], raw: [] as string[] },\n      down: { builder: [] as string[], raw: [] as string[] },\n    },\n  );\n\n  return linesTo;\n}\n\n/**\n * 인덱스의 add, drop 여부 확인\n */\nfunction getAlterIndexesTo(entityIndexes: MigrationIndex[], dbIndexes: MigrationIndex[]) {\n  // 인덱스 비교\n  const indexesTo = {\n    add: [] as MigrationIndex[],\n    drop: [] as MigrationIndex[],\n  };\n\n  // 인덱스 고유 식별자 생성 (name을 제외한 모든 필드를 문자열로 변환하여 조합)\n  const identity = <T extends Record<string, unknown>>(index: T): string => {\n    const keys = Object.keys(index)\n      .filter((key) => key !== \"name\")\n      .sort();\n\n    return keys\n      .map((key) => {\n        if (key === \"name\") {\n          return undefined;\n        }\n        if (key === \"columns\") {\n          return (index[key] as MigrationIndex[\"columns\"]).flatMap(identity);\n        }\n        return `${key}=${index[key as keyof MigrationIndex]}`;\n      })\n      .join(\"//\");\n  };\n\n  const extraIndexes = {\n    db: diff(dbIndexes, entityIndexes.map(setMigrationIndexDefaults), identity),\n    entity: diff(entityIndexes.map(setMigrationIndexDefaults), dbIndexes, identity),\n  };\n  if (extraIndexes.entity.length > 0) {\n    indexesTo.add = indexesTo.add.concat(extraIndexes.entity);\n  }\n  if (extraIndexes.db.length > 0) {\n    indexesTo.drop = indexesTo.drop.concat(extraIndexes.db);\n  }\n\n  return indexesTo;\n}\n\n/**\n * 인덱스 삭제 정의 생성\n */\nfunction genIndexDropDefinition(index: MigrationIndex) {\n  return `table.dropIndex([${index.columns\n    .map((column) => `'${column.name}'`)\n    .join(\",\")}], '${index.name}')`;\n}\n\n/**\n * DB 조회 결과와 비교하기 위한 인덱스 기본값 설정\n */\nfunction setMigrationIndexDefaults(index: MigrationIndex): MigrationIndex {\n  return {\n    ...index,\n    columns: index.columns.map((col) => ({\n      ...col,\n      sortOrder: col.sortOrder ?? \"ASC\",\n      // sortOrder에 따라 nullsFirst의 default 값 설정\n      nullsFirst: col.nullsFirst ?? col.sortOrder === \"DESC\",\n    })),\n    nullsNotDistinct: index.nullsNotDistinct ?? false,\n    using: index.using ?? \"btree\",\n  };\n}\n\n/**\n * 테이블 변경 케이스 - Foreign Key 변경\n */\nasync function generateAlterCode_Foreigns(\n  table: string,\n  entityForeigns: MigrationForeign[],\n  dbForeigns: MigrationForeign[],\n  droppingColumns: MigrationColumn[] = [],\n): Promise<GenMigrationCode[]> {\n  // console.log({ entityForeigns, dbForeigns });\n\n  const getKey = (mf: MigrationForeign): string => {\n    return [mf.columns.join(\"-\"), mf.to].join(\"///\");\n  };\n\n  // 삭제될 컬럼명 목록\n  const droppingColumnNames = droppingColumns.map((col) => col.name);\n\n  const fkTo = entityForeigns.reduce(\n    (result, entityF) => {\n      const matchingDbF = dbForeigns.find((dbF) => getKey(entityF) === getKey(dbF));\n      if (!matchingDbF) {\n        result.add.push(entityF);\n        return result;\n      }\n\n      if (equal(entityF, matchingDbF) === false) {\n        result.alterSrc.push(matchingDbF);\n        result.alterDst.push(entityF);\n        return result;\n      }\n      return result;\n    },\n    {\n      add: [] as MigrationForeign[],\n      drop: [] as MigrationForeign[],\n      alterSrc: [] as MigrationForeign[],\n      alterDst: [] as MigrationForeign[],\n    },\n  );\n\n  // dbForeigns에는 있지만 entityForeigns에는 없는 경우 (삭제된 FK)\n  // 단, 삭제될 컬럼의 FK는 제외 (generateAlterCode_ColumnAndIndexes에서 처리)\n  dbForeigns.forEach((dbF) => {\n    const matchingEntityF = entityForeigns.find((entityF) => getKey(entityF) === getKey(dbF));\n    if (!matchingEntityF) {\n      // 이 FK의 컬럼이 삭제될 컬럼 목록에 있는지 확인\n      const isColumnDropping = dbF.columns.some((col) => droppingColumnNames.includes(col));\n      // 컬럼이 삭제되지 않는 경우에만 FK drop 목록에 추가\n      if (!isColumnDropping) {\n        fkTo.drop.push(dbF);\n      }\n    }\n  });\n\n  const linesTo = {\n    add: genForeignDefinitions(table, fkTo.add),\n    drop: genForeignDefinitions(table, fkTo.drop),\n    alterSrc: genForeignDefinitions(table, fkTo.alterSrc),\n    alterDst: genForeignDefinitions(table, fkTo.alterDst),\n  };\n\n  // drop fk columns인 경우(생성될 코드 없는 경우) 패스\n  const hasLines = Object.values(linesTo).some((l) => l.up.length > 0 || l.down.length > 0);\n  if (!hasLines) {\n    return [];\n  }\n\n  if (\n    linesTo.add.up.length === 0 &&\n    linesTo.drop.up.length === 0 &&\n    linesTo.alterSrc.up.length === 0 &&\n    linesTo.alterDst.up.length === 0\n  ) {\n    Naite.t(\"migrator:generateAlterCode_Foreigns:fkChangeCodeGenerationError\", {\n      table,\n      entityForeigns,\n      dbForeigns,\n    });\n    throw new Error(\"FK 변경 코드 생성 오류\");\n  }\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...linesTo.drop.down,\n    ...linesTo.add.up,\n    ...linesTo.alterSrc.down,\n    ...linesTo.alterDst.up,\n    \"})\",\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...linesTo.add.down,\n    ...linesTo.alterDst.down,\n    ...linesTo.alterSrc.up,\n    ...linesTo.drop.up,\n    \"})\",\n    \"}\",\n  ];\n\n  const formatted = formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`);\n  const title = [\n    \"alter\",\n    table,\n    \"foreigns\",\n    // TODO 바뀌는 부분\n  ].join(\"_\");\n\n  return [\n    {\n      table,\n      title,\n      formatted,\n      type: \"normal\",\n    },\n  ];\n}\n\n/**\n * 주어진 EntitySet을 기반으로 테이블 CREATE 마이그레이션 코드를 생성합니다.\n * @param entitySet\n * @returns CREATE 마이그레이션 코드\n */\nexport async function generateCreateCode(entitySet: MigrationSet): Promise<GenMigrationCode[]> {\n  return [\n    await generateCreateCode_ColumnAndIndexes(\n      entitySet.table,\n      entitySet.columns,\n      entitySet.indexes,\n    ),\n    ...(await generateCreateCode_Foreign(entitySet.table, entitySet.foreigns)),\n  ];\n}\n\n/**\n * 주어진 entitySet을 목표로, dbSet을 현 상황으로 하여 테이블 ALTER 마이그레이션 코드를 생성합니다.\n * @param entitySet 현 상황의 MigrationSet\n * @param dbSet 목표 상황의 MigrationSet\n * @returns ALTER 마이그레이션 코드\n */\nexport async function generateAlterCode(\n  entitySet: MigrationSet,\n  dbSet: MigrationSet,\n): Promise<GenMigrationCode[]> {\n  const replaceColumnDefaultTo = (col: MigrationColumn) => {\n    // float인 경우 기본값을 0으로 지정하는 경우 \"0.00\"으로 변환되는 케이스 대응\n    // if (col.type === \"float\" && col.defaultTo && String(col.defaultTo).includes('\"') === false) {\n    //   col.defaultTo = `\"${Number(col.defaultTo).toFixed(col.scale ?? 2)}\"`;\n    // }\n    // // string인 경우 기본값이 빈 스트링인 경우 대응\n    // if (col.type === \"string\" && col.defaultTo === \"\") {\n    //   col.defaultTo = '\"\"';\n    // }\n    // // boolean인 경우 기본값 정규화 (MySQL에서는 TINYINT(1)로 저장되므로 0 또는 1로 정규화)\n    // // TODO: db.ts에 typeCase 설정 확인하여 처리하도록 수정 필요\n    // if (col.type === \"boolean\" && col.defaultTo !== undefined) {\n    //   if (col.defaultTo === \"0\" || col.defaultTo.toLowerCase() === \"false\") {\n    //     col.defaultTo = \"0\";\n    //   } else if (col.defaultTo === \"1\" || col.defaultTo.toLowerCase() === \"true\") {\n    //     col.defaultTo = \"1\";\n    //   }\n    // }\n\n    // FIXME: 일단 MySQL 상황에서 발생했던 이슈의 workaround 이므로 Pg에서 재확인 후 대응 추가\n    return col;\n  };\n  const entityColumns = alphabetical(entitySet.columns, (a) => a.name).map(replaceColumnDefaultTo);\n  const dbColumns = alphabetical(dbSet.columns, (a) => a.name).map(replaceColumnDefaultTo);\n\n  /* 디버깅용 코드, 특정 컬럼에서 불일치 발생할 때 확인\n        const entityColumn = entitySet.columns.find(\n          (col) => col.name === \"price_krw\"\n        );\n        const dbColumn = dbSet.columns.find(\n          (col) => col.name === \"price_krw\"\n        );\n        console.debug({ entityColumn, dbColumn });\n         */\n\n  // ?\n  const entityIndexes = alphabetical(entitySet.indexes, (a) => [a.type, ...a.columns].join(\"-\"));\n  const dbIndexes = alphabetical(dbSet.indexes, (a) => [a.type, ...a.columns].join(\"-\"));\n\n  const replaceNoActionOnMySQL = (f: MigrationForeign) => {\n    // MySQL에서 RESTRICT와 NO ACTION은 동일함\n    const { onDelete, onUpdate } = f;\n    return {\n      ...f,\n      onUpdate: onUpdate === \"RESTRICT\" ? \"NO ACTION\" : onUpdate,\n      onDelete: onDelete === \"RESTRICT\" ? \"NO ACTION\" : onDelete,\n    };\n  };\n\n  const entityForeigns = alphabetical(entitySet.foreigns, (a) =>\n    [a.to, ...a.columns].join(\"-\"),\n  ).map((f) => replaceNoActionOnMySQL(f));\n  const dbForeigns = alphabetical(dbSet.foreigns, (a) => [a.to, ...a.columns].join(\"-\")).map((f) =>\n    replaceNoActionOnMySQL(f),\n  );\n\n  // 삭제될 컬럼 목록 계산\n  const droppingColumns = diff(dbColumns, entityColumns, (col) => col.name);\n\n  const alterCodes: (GenMigrationCode | GenMigrationCode[] | null)[] = [];\n\n  // 1. columnsAndIndexes 처리\n  const isEqualColumns = equal(\n    entityColumns.map(normalizeColumnForComparison),\n    dbColumns.map(normalizeColumnForComparison),\n  );\n  const isEqualIndexes = equal(\n    entityIndexes.map(setMigrationIndexDefaults),\n    dbIndexes.map(setMigrationIndexDefaults),\n  );\n  if (!isEqualColumns || !isEqualIndexes) {\n    alterCodes.push(\n      await generateAlterCode_ColumnAndIndexes(\n        entitySet.table,\n        entityColumns,\n        entityIndexes,\n        dbColumns,\n        dbIndexes,\n        dbSet.foreigns,\n      ),\n    );\n  }\n\n  // 2. foreigns 처리 (삭제될 컬럼 정보 전달)\n  if (equal(entityForeigns, dbForeigns) === false) {\n    alterCodes.push(\n      await generateAlterCode_Foreigns(\n        entitySet.table,\n        entityForeigns,\n        dbForeigns,\n        droppingColumns,\n      ),\n    );\n  }\n\n  if (alterCodes.every((alterCode) => alterCode === null)) {\n    return [];\n  }\n\n  return alterCodes.filter((alterCode) => alterCode !== null).flat();\n}\n"],"names":["equal","alphabetical","diff","Naite","formatCode","differenceWith","intersectionBy","generateCreateCode_ColumnAndIndexes","table","columns","indexes","columnDefs","genColumnDefinitions","lines","builder","raw","map","index","genIndexDefinition","type","title","formatted","join","result","column","generated","push","genGeneratedColumnDefinition","genNormalColumnDefinition","Error","pgType","getPgTypeForColumn","storageType","nullableClause","nullable","name","expression","chains","endsWith","elementType","slice","getPgArrayType","dimensions","numberType","precision","scale","length","undefined","extraType","defaultTo","startsWith","genVectorIndexDefinition","methodMap","unique","nullsNotDistinctClause","nullsNotDistinct","usingClause","using","col","sortOrderClause","sortOrder","nullsFirstClause","nullsFirst","vectorOps","m","efConstruction","lists","generateCreateCode_Foreign","foreigns","up","down","genForeignDefinitions","console","log","foreignKeysString","foreign","reduce","r","columnsStringQuote","replace","to","onUpdate","onDelete","generateAlterCode_ColumnAndIndexes","entityColumns","entityIndexes","dbColumns","dbIndexes","dbForeigns","alterColumnsTo","getAlterColumnsTo","alterColumnLinesTo","getAlterColumnLinesTo","alterIndexesTo","getAlterIndexesTo","indexNeedsToDrop","drop","filter","every","includes","hasUpChanges","add","alter","t","upBuilderLines","genIndexDropDefinition","upRawLines","downBuilderLines","indexCol","downRawLines","action","len","part","normalizeColumnForComparison","columnsTo","extraColumns","db","entity","concat","sameDbColumns","sameMdColumns","a","b","linesTo","addColumnDefs","dropColumnNames","fkToDropBeforeColumn","fk","some","dropFkLines","restoreFkLines","dropColumnDefs","dbColumn","entityColumn","find","columnDiffUp","columnDiffDown","l","indexesTo","identity","keys","Object","key","sort","flatMap","extraIndexes","setMigrationIndexDefaults","generateAlterCode_Foreigns","entityForeigns","droppingColumns","getKey","mf","droppingColumnNames","fkTo","entityF","matchingDbF","dbF","alterSrc","alterDst","forEach","matchingEntityF","isColumnDropping","hasLines","values","generateCreateCode","entitySet","generateAlterCode","dbSet","replaceColumnDefaultTo","replaceNoActionOnMySQL","f","alterCodes","isEqualColumns","isEqualIndexes","alterCode","flat"],"mappings":"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"}
@@ -197,10 +197,12 @@ function resolveEntityPropTypeToMigrationColumnType(prop) {
197
197
  return "vector";
198
198
  case "vector[]":
199
199
  return "vector[]";
200
+ case "tsvector":
201
+ return "tsvector";
200
202
  default:
201
203
  exhaustive(prop);
202
204
  throw new Error(`Unknown entity prop type: ${prop.type}`);
203
205
  }
204
206
  }
205
207
 
206
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/migration/migration-set.ts"],"sourcesContent":["import inflection from \"inflection\";\nimport type { Entity } from \"../entity/entity\";\nimport { EntityManager } from \"../entity/entity-manager\";\nimport {\n  type EntityProp,\n  isBelongsToOneRelationProp,\n  isHasManyRelationProp,\n  isManyToManyRelationProp,\n  isNumberProp,\n  isNumericProp,\n  isOneToOneRelationProp,\n  isRelationProp,\n  isStringProp,\n  isVectorProp,\n  isVirtualProp,\n  type MigrationColumn,\n  type MigrationColumnType,\n  type MigrationForeign,\n  type MigrationIndex,\n  type MigrationJoinTable,\n  type MigrationSetAndJoinTable,\n} from \"../types/types\";\nimport { exhaustive } from \"../utils/utils\";\n\n/**\n * Entity를 읽어서 MigrationSetAndJoinTable을 만들어옵니다.\n * @param entity Entity 객체\n * @returns MigrationSetAndJoinTable 객체\n */\nexport function getMigrationSetFromEntity(entity: Entity): MigrationSetAndJoinTable {\n  const migrationSet: MigrationSetAndJoinTable = entity.props.reduce(\n    (r, prop) => {\n      // virtual 필드 제외\n      if (isVirtualProp(prop)) {\n        return r;\n      }\n      // HasMany 케이스는 아무 처리도 하지 않음\n      if (isHasManyRelationProp(prop)) {\n        return r;\n      }\n\n      // 일반 컬럼\n      if (!isRelationProp(prop)) {\n        const column = {\n          name: prop.name,\n          type: resolveEntityPropTypeToMigrationColumnType(prop),\n          nullable: prop.nullable === true,\n          ...(() => {\n            if (prop.dbDefault !== undefined) {\n              return {\n                defaultTo: prop.dbDefault,\n              };\n            }\n            return {};\n          })(),\n          // String 타입에 length 있는 경우 추가\n          ...(isStringProp(prop) &&\n            prop.length !== undefined && {\n              length: prop.length,\n            }),\n          // Number/Numeric 타입의 경우 precision, scale 추가\n          ...((isNumberProp(prop) || isNumericProp(prop)) && {\n            precision: prop.precision,\n            scale: prop.scale,\n            numberType: isNumberProp(prop) ? (prop.numberType ?? \"numeric\") : \"numeric\",\n          }),\n          // Vector 타입의 경우 dimensions 추가\n          ...(isVectorProp(prop) && {\n            dimensions: prop.dimensions,\n          }),\n          // Generated Column 정보 추가\n          ...(prop.generated && {\n            generated: prop.generated,\n          }),\n        };\n\n        r.columns.push(column);\n      }\n\n      if (isManyToManyRelationProp(prop)) {\n        // ManyToMany 케이스\n        const relMd = EntityManager.get(prop.with);\n        const table1 = entity.table;\n        const table2 = relMd.table;\n        const join = {\n          from: `${entity.table}.id`,\n          through: {\n            from: `${prop.joinTable}.${inflection.singularize(table1)}_id`,\n            to: `${prop.joinTable}.${inflection.singularize(table2)}_id`,\n            onUpdate: prop.onUpdate,\n            onDelete: prop.onDelete,\n          },\n          to: `${relMd.table}.id`,\n        };\n        const through = join.through;\n        const fields = [through.from, through.to];\n        r.joinTables.push({\n          table: through.from.split(\".\")[0],\n          indexes: [\n            // 조인 테이블에 걸린 인덱스 찾아와서 연결\n            ...entity.indexes\n              .filter((index) =>\n                index.columns.find((col) => col.name.includes(`${prop.joinTable}.`)),\n              )\n              .map((index) => ({\n                ...index,\n                columns: index.columns.map((col) => ({\n                  name: col.name.replace(`${prop.joinTable}.`, \"\"),\n                  nullsFirst: col.nullsFirst,\n                  sortOrder: col.sortOrder,\n                })),\n              })),\n          ],\n          columns: [\n            {\n              name: \"id\",\n              type: \"integer\",\n              nullable: false,\n            },\n            ...fields.map((field) => {\n              return {\n                name: field.split(\".\")[1],\n                type: \"integer\",\n                nullable: false,\n              } as MigrationColumn;\n            }),\n          ],\n          foreigns: fields.map((field) => {\n            // 현재 필드가 어떤 테이블에 속하는지 판단\n            const col = field.split(\".\")[1];\n            const to = (() => {\n              if (`${inflection.singularize(join.to.split(\".\")[0])}_id` === col) {\n                return join.to;\n              } else {\n                return join.from;\n              }\n            })();\n            return {\n              columns: [col],\n              to,\n              onUpdate: through.onUpdate,\n              onDelete: through.onDelete,\n            };\n          }),\n        });\n        return r;\n      } else if (\n        isBelongsToOneRelationProp(prop) ||\n        (isOneToOneRelationProp(prop) && prop.hasJoinColumn)\n      ) {\n        // -OneRelation 케이스\n        const idColumnName = `${prop.name}_id`;\n        r.columns.push({\n          name: idColumnName,\n          type: \"integer\",\n          nullable: prop.nullable ?? false,\n        });\n        if ((prop.useConstraint ?? true) === true) {\n          r.foreigns.push({\n            columns: [idColumnName],\n            to: `${inflection.underscore(inflection.pluralize(prop.with)).toLowerCase()}.id`,\n            onUpdate: prop.onUpdate ?? \"RESTRICT\",\n            onDelete: prop.onDelete ?? \"RESTRICT\",\n          });\n        }\n      }\n\n      return r;\n    },\n    {\n      table: entity.table,\n      columns: [] as MigrationColumn[],\n      indexes: [] as MigrationIndex[],\n      foreigns: [] as MigrationForeign[],\n      joinTables: [] as MigrationJoinTable[],\n    },\n  );\n\n  // indexes\n  migrationSet.indexes = entity.indexes.filter((index) =>\n    index.columns.find((col) => col.name.includes(\".\") === false),\n  );\n\n  return migrationSet;\n}\n\nfunction resolveEntityPropTypeToMigrationColumnType(prop: EntityProp): MigrationColumnType {\n  if (prop.type === \"relation\" || prop.type === \"virtual\") {\n    throw new Error(`Unresolved column type: ${prop.type}`);\n  }\n\n  switch (prop.type) {\n    case \"string\":\n      return \"string\";\n    case \"string[]\":\n      return \"string[]\";\n    case \"enum\":\n      return \"string\";\n    case \"enum[]\":\n      return \"string[]\";\n    case \"integer\":\n      return \"integer\";\n    case \"integer[]\":\n      return \"integer[]\";\n    case \"bigInteger\":\n      return \"bigInteger\";\n    case \"bigInteger[]\":\n      return \"bigInteger[]\";\n    case \"number\":\n      return \"numberOrNumeric\";\n    case \"number[]\":\n      return \"numberOrNumeric[]\";\n    case \"numeric\":\n      return \"numberOrNumeric\";\n    case \"numeric[]\":\n      return \"numberOrNumeric[]\";\n    case \"boolean\":\n      return \"boolean\";\n    case \"boolean[]\":\n      return \"boolean[]\";\n    case \"date\":\n      return \"date\";\n    case \"date[]\":\n      return \"date[]\";\n    case \"uuid\":\n      return \"uuid\";\n    case \"uuid[]\":\n      return \"uuid[]\";\n    case \"json\":\n      return \"json\";\n    case \"vector\":\n      return \"vector\";\n    case \"vector[]\":\n      return \"vector[]\";\n    default:\n      exhaustive(prop);\n      throw new Error(`Unknown entity prop type: ${(prop as { type: string }).type}`);\n  }\n}\n"],"names":["inflection","EntityManager","isBelongsToOneRelationProp","isHasManyRelationProp","isManyToManyRelationProp","isNumberProp","isNumericProp","isOneToOneRelationProp","isRelationProp","isStringProp","isVectorProp","isVirtualProp","exhaustive","getMigrationSetFromEntity","entity","migrationSet","props","reduce","r","prop","column","name","type","resolveEntityPropTypeToMigrationColumnType","nullable","dbDefault","undefined","defaultTo","length","precision","scale","numberType","dimensions","generated","columns","push","relMd","get","with","table1","table","table2","join","from","through","joinTable","singularize","to","onUpdate","onDelete","fields","joinTables","split","indexes","filter","index","find","col","includes","map","replace","nullsFirst","sortOrder","field","foreigns","hasJoinColumn","idColumnName","useConstraint","underscore","pluralize","toLowerCase","Error"],"mappings":"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"}
208
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/migration/migration-set.ts"],"sourcesContent":["import inflection from \"inflection\";\nimport type { Entity } from \"../entity/entity\";\nimport { EntityManager } from \"../entity/entity-manager\";\nimport {\n  type EntityProp,\n  isBelongsToOneRelationProp,\n  isHasManyRelationProp,\n  isManyToManyRelationProp,\n  isNumberProp,\n  isNumericProp,\n  isOneToOneRelationProp,\n  isRelationProp,\n  isStringProp,\n  isVectorProp,\n  isVirtualProp,\n  type MigrationColumn,\n  type MigrationColumnType,\n  type MigrationForeign,\n  type MigrationIndex,\n  type MigrationJoinTable,\n  type MigrationSetAndJoinTable,\n} from \"../types/types\";\nimport { exhaustive } from \"../utils/utils\";\n\n/**\n * Entity를 읽어서 MigrationSetAndJoinTable을 만들어옵니다.\n * @param entity Entity 객체\n * @returns MigrationSetAndJoinTable 객체\n */\nexport function getMigrationSetFromEntity(entity: Entity): MigrationSetAndJoinTable {\n  const migrationSet: MigrationSetAndJoinTable = entity.props.reduce(\n    (r, prop) => {\n      // virtual 필드 제외\n      if (isVirtualProp(prop)) {\n        return r;\n      }\n      // HasMany 케이스는 아무 처리도 하지 않음\n      if (isHasManyRelationProp(prop)) {\n        return r;\n      }\n\n      // 일반 컬럼\n      if (!isRelationProp(prop)) {\n        const column = {\n          name: prop.name,\n          type: resolveEntityPropTypeToMigrationColumnType(prop),\n          nullable: prop.nullable === true,\n          ...(() => {\n            if (prop.dbDefault !== undefined) {\n              return {\n                defaultTo: prop.dbDefault,\n              };\n            }\n            return {};\n          })(),\n          // String 타입에 length 있는 경우 추가\n          ...(isStringProp(prop) &&\n            prop.length !== undefined && {\n              length: prop.length,\n            }),\n          // Number/Numeric 타입의 경우 precision, scale 추가\n          ...((isNumberProp(prop) || isNumericProp(prop)) && {\n            precision: prop.precision,\n            scale: prop.scale,\n            numberType: isNumberProp(prop) ? (prop.numberType ?? \"numeric\") : \"numeric\",\n          }),\n          // Vector 타입의 경우 dimensions 추가\n          ...(isVectorProp(prop) && {\n            dimensions: prop.dimensions,\n          }),\n          // Generated Column 정보 추가\n          ...(prop.generated && {\n            generated: prop.generated,\n          }),\n        };\n\n        r.columns.push(column);\n      }\n\n      if (isManyToManyRelationProp(prop)) {\n        // ManyToMany 케이스\n        const relMd = EntityManager.get(prop.with);\n        const table1 = entity.table;\n        const table2 = relMd.table;\n        const join = {\n          from: `${entity.table}.id`,\n          through: {\n            from: `${prop.joinTable}.${inflection.singularize(table1)}_id`,\n            to: `${prop.joinTable}.${inflection.singularize(table2)}_id`,\n            onUpdate: prop.onUpdate,\n            onDelete: prop.onDelete,\n          },\n          to: `${relMd.table}.id`,\n        };\n        const through = join.through;\n        const fields = [through.from, through.to];\n        r.joinTables.push({\n          table: through.from.split(\".\")[0],\n          indexes: [\n            // 조인 테이블에 걸린 인덱스 찾아와서 연결\n            ...entity.indexes\n              .filter((index) =>\n                index.columns.find((col) => col.name.includes(`${prop.joinTable}.`)),\n              )\n              .map((index) => ({\n                ...index,\n                columns: index.columns.map((col) => ({\n                  name: col.name.replace(`${prop.joinTable}.`, \"\"),\n                  nullsFirst: col.nullsFirst,\n                  sortOrder: col.sortOrder,\n                })),\n              })),\n          ],\n          columns: [\n            {\n              name: \"id\",\n              type: \"integer\",\n              nullable: false,\n            },\n            ...fields.map((field) => {\n              return {\n                name: field.split(\".\")[1],\n                type: \"integer\",\n                nullable: false,\n              } as MigrationColumn;\n            }),\n          ],\n          foreigns: fields.map((field) => {\n            // 현재 필드가 어떤 테이블에 속하는지 판단\n            const col = field.split(\".\")[1];\n            const to = (() => {\n              if (`${inflection.singularize(join.to.split(\".\")[0])}_id` === col) {\n                return join.to;\n              } else {\n                return join.from;\n              }\n            })();\n            return {\n              columns: [col],\n              to,\n              onUpdate: through.onUpdate,\n              onDelete: through.onDelete,\n            };\n          }),\n        });\n        return r;\n      } else if (\n        isBelongsToOneRelationProp(prop) ||\n        (isOneToOneRelationProp(prop) && prop.hasJoinColumn)\n      ) {\n        // -OneRelation 케이스\n        const idColumnName = `${prop.name}_id`;\n        r.columns.push({\n          name: idColumnName,\n          type: \"integer\",\n          nullable: prop.nullable ?? false,\n        });\n        if ((prop.useConstraint ?? true) === true) {\n          r.foreigns.push({\n            columns: [idColumnName],\n            to: `${inflection.underscore(inflection.pluralize(prop.with)).toLowerCase()}.id`,\n            onUpdate: prop.onUpdate ?? \"RESTRICT\",\n            onDelete: prop.onDelete ?? \"RESTRICT\",\n          });\n        }\n      }\n\n      return r;\n    },\n    {\n      table: entity.table,\n      columns: [] as MigrationColumn[],\n      indexes: [] as MigrationIndex[],\n      foreigns: [] as MigrationForeign[],\n      joinTables: [] as MigrationJoinTable[],\n    },\n  );\n\n  // indexes\n  migrationSet.indexes = entity.indexes.filter((index) =>\n    index.columns.find((col) => col.name.includes(\".\") === false),\n  );\n\n  return migrationSet;\n}\n\nfunction resolveEntityPropTypeToMigrationColumnType(prop: EntityProp): MigrationColumnType {\n  if (prop.type === \"relation\" || prop.type === \"virtual\") {\n    throw new Error(`Unresolved column type: ${prop.type}`);\n  }\n\n  switch (prop.type) {\n    case \"string\":\n      return \"string\";\n    case \"string[]\":\n      return \"string[]\";\n    case \"enum\":\n      return \"string\";\n    case \"enum[]\":\n      return \"string[]\";\n    case \"integer\":\n      return \"integer\";\n    case \"integer[]\":\n      return \"integer[]\";\n    case \"bigInteger\":\n      return \"bigInteger\";\n    case \"bigInteger[]\":\n      return \"bigInteger[]\";\n    case \"number\":\n      return \"numberOrNumeric\";\n    case \"number[]\":\n      return \"numberOrNumeric[]\";\n    case \"numeric\":\n      return \"numberOrNumeric\";\n    case \"numeric[]\":\n      return \"numberOrNumeric[]\";\n    case \"boolean\":\n      return \"boolean\";\n    case \"boolean[]\":\n      return \"boolean[]\";\n    case \"date\":\n      return \"date\";\n    case \"date[]\":\n      return \"date[]\";\n    case \"uuid\":\n      return \"uuid\";\n    case \"uuid[]\":\n      return \"uuid[]\";\n    case \"json\":\n      return \"json\";\n    case \"vector\":\n      return \"vector\";\n    case \"vector[]\":\n      return \"vector[]\";\n    case \"tsvector\":\n      return \"tsvector\";\n    default:\n      exhaustive(prop);\n      throw new Error(`Unknown entity prop type: ${(prop as { type: string }).type}`);\n  }\n}\n"],"names":["inflection","EntityManager","isBelongsToOneRelationProp","isHasManyRelationProp","isManyToManyRelationProp","isNumberProp","isNumericProp","isOneToOneRelationProp","isRelationProp","isStringProp","isVectorProp","isVirtualProp","exhaustive","getMigrationSetFromEntity","entity","migrationSet","props","reduce","r","prop","column","name","type","resolveEntityPropTypeToMigrationColumnType","nullable","dbDefault","undefined","defaultTo","length","precision","scale","numberType","dimensions","generated","columns","push","relMd","get","with","table1","table","table2","join","from","through","joinTable","singularize","to","onUpdate","onDelete","fields","joinTables","split","indexes","filter","index","find","col","includes","map","replace","nullsFirst","sortOrder","field","foreigns","hasJoinColumn","idColumnName","useConstraint","underscore","pluralize","toLowerCase","Error"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"postgresql-schema-reader.d.ts","sourceRoot":"","sources":["../../src/migration/postgresql-schema-reader.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAEjC,OAAO,KAAK,EACV,eAAe,EAGf,YAAY,EAEb,MAAM,gBAAgB,CAAC;AAExB,MAAM,MAAM,QAAQ,GAAG;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,wBAAwB,EAAE,MAAM,GAAG,IAAI,CAAC;IACxC,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,YAAY,EAAE,MAAM,CAAC;IACrB,qBAAqB,EAAE,MAAM,GAAG,IAAI,CAAC;CACtC,CAAC;AAEF,KAAK,OAAO,GAAG;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;IACnB,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,OAAO,CAAC;IACrB,UAAU,EAAE,KAAK,GAAG,MAAM,CAAC;IAC3B,kBAAkB,EAAE,OAAO,CAAC;CAC7B,CAAC;AAEF,KAAK,SAAS,GAAG;IACf,eAAe,EAAE,MAAM,CAAC;IACxB,WAAW,EAAE,MAAM,CAAC;IACpB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,cAAM,2BAA2B;IAC/B;;;;;OAKG;IACG,qBAAqB,CAAC,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;IAwHzF;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAW3B;;OAEG;IACG,SAAS,CACb,SAAS,EAAE,IAAI,EACf,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE,OAAO,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC;IAsFhD;;;OAGG;YACW,mBAAmB;IAwBjC;;OAEG;IACH,gBAAgB,CACd,QAAQ,EAAE,QAAQ,GACjB,IAAI,CACL,eAAe,EACf,MAAM,GAAG,QAAQ,GAAG,WAAW,GAAG,OAAO,GAAG,YAAY,GAAG,YAAY,CACxE;CA+FF;AAED,eAAO,MAAM,sBAAsB,6BAAoC,CAAC"}
1
+ {"version":3,"file":"postgresql-schema-reader.d.ts","sourceRoot":"","sources":["../../src/migration/postgresql-schema-reader.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAEjC,OAAO,KAAK,EACV,eAAe,EAGf,YAAY,EAEb,MAAM,gBAAgB,CAAC;AAExB,MAAM,MAAM,QAAQ,GAAG;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,wBAAwB,EAAE,MAAM,GAAG,IAAI,CAAC;IACxC,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,YAAY,EAAE,MAAM,CAAC;IACrB,qBAAqB,EAAE,MAAM,GAAG,IAAI,CAAC;CACtC,CAAC;AAEF,KAAK,OAAO,GAAG;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;IACnB,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,OAAO,CAAC;IACrB,UAAU,EAAE,KAAK,GAAG,MAAM,CAAC;IAC3B,kBAAkB,EAAE,OAAO,CAAC;CAC7B,CAAC;AAEF,KAAK,SAAS,GAAG;IACf,eAAe,EAAE,MAAM,CAAC;IACxB,WAAW,EAAE,MAAM,CAAC;IACpB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,cAAM,2BAA2B;IAC/B;;;;;OAKG;IACG,qBAAqB,CAAC,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;IAyHzF;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAW3B;;OAEG;IACG,SAAS,CACb,SAAS,EAAE,IAAI,EACf,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE,OAAO,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC;IAsFhD;;;OAGG;YACW,mBAAmB;IAwBjC;;OAEG;IACH,gBAAgB,CACd,QAAQ,EAAE,QAAQ,GACjB,IAAI,CACL,eAAe,EACf,MAAM,GAAG,QAAQ,GAAG,WAAW,GAAG,OAAO,GAAG,YAAY,GAAG,YAAY,CACxE;CA+FF;AAED,eAAO,MAAM,sBAAsB,6BAAoC,CAAC"}