@strapi/database 5.29.0 → 5.30.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (89) hide show
  1. package/dist/connection.js.map +1 -1
  2. package/dist/connection.mjs.map +1 -1
  3. package/dist/dialects/dialect.js.map +1 -1
  4. package/dist/dialects/dialect.mjs.map +1 -1
  5. package/dist/dialects/index.js.map +1 -1
  6. package/dist/dialects/index.mjs.map +1 -1
  7. package/dist/dialects/mysql/database-inspector.js.map +1 -1
  8. package/dist/dialects/mysql/database-inspector.mjs.map +1 -1
  9. package/dist/dialects/mysql/index.js +1 -2
  10. package/dist/dialects/mysql/index.js.map +1 -1
  11. package/dist/dialects/mysql/index.mjs +1 -2
  12. package/dist/dialects/mysql/index.mjs.map +1 -1
  13. package/dist/dialects/mysql/schema-inspector.js.map +1 -1
  14. package/dist/dialects/mysql/schema-inspector.mjs.map +1 -1
  15. package/dist/dialects/postgresql/index.js.map +1 -1
  16. package/dist/dialects/postgresql/index.mjs.map +1 -1
  17. package/dist/dialects/postgresql/schema-inspector.js.map +1 -1
  18. package/dist/dialects/postgresql/schema-inspector.mjs.map +1 -1
  19. package/dist/dialects/sqlite/index.js.map +1 -1
  20. package/dist/dialects/sqlite/index.mjs.map +1 -1
  21. package/dist/dialects/sqlite/schema-inspector.js.map +1 -1
  22. package/dist/dialects/sqlite/schema-inspector.mjs.map +1 -1
  23. package/dist/entity-manager/index.js.map +1 -1
  24. package/dist/entity-manager/index.mjs.map +1 -1
  25. package/dist/entity-manager/morph-relations.js.map +1 -1
  26. package/dist/entity-manager/morph-relations.mjs.map +1 -1
  27. package/dist/errors/database.js.map +1 -1
  28. package/dist/errors/database.mjs.map +1 -1
  29. package/dist/errors/invalid-date.js.map +1 -1
  30. package/dist/errors/invalid-date.mjs.map +1 -1
  31. package/dist/errors/invalid-datetime.js.map +1 -1
  32. package/dist/errors/invalid-datetime.mjs.map +1 -1
  33. package/dist/errors/invalid-relation.js.map +1 -1
  34. package/dist/errors/invalid-relation.mjs.map +1 -1
  35. package/dist/errors/invalid-time.js.map +1 -1
  36. package/dist/errors/invalid-time.mjs.map +1 -1
  37. package/dist/errors/not-null.js.map +1 -1
  38. package/dist/errors/not-null.mjs.map +1 -1
  39. package/dist/fields/field.js.map +1 -1
  40. package/dist/fields/field.mjs.map +1 -1
  41. package/dist/fields/index.js.map +1 -1
  42. package/dist/fields/index.mjs.map +1 -1
  43. package/dist/fields/number.js.map +1 -1
  44. package/dist/fields/number.mjs.map +1 -1
  45. package/dist/fields/shared/parsers.js.map +1 -1
  46. package/dist/fields/shared/parsers.mjs.map +1 -1
  47. package/dist/index.js.map +1 -1
  48. package/dist/index.mjs.map +1 -1
  49. package/dist/metadata/metadata.js.map +1 -1
  50. package/dist/metadata/metadata.mjs.map +1 -1
  51. package/dist/metadata/relations.js.map +1 -1
  52. package/dist/metadata/relations.mjs.map +1 -1
  53. package/dist/migrations/internal-migrations/5.0.0-01-convert-identifiers-long-than-max-length.js.map +1 -1
  54. package/dist/migrations/internal-migrations/5.0.0-01-convert-identifiers-long-than-max-length.mjs.map +1 -1
  55. package/dist/migrations/internal-migrations/5.0.0-02-document-id.js.map +1 -1
  56. package/dist/migrations/internal-migrations/5.0.0-02-document-id.mjs.map +1 -1
  57. package/dist/migrations/internal-migrations/5.0.0-05-drop-slug-unique-index.js.map +1 -1
  58. package/dist/migrations/internal-migrations/5.0.0-05-drop-slug-unique-index.mjs.map +1 -1
  59. package/dist/migrations/logger.js.map +1 -1
  60. package/dist/migrations/logger.mjs.map +1 -1
  61. package/dist/query/helpers/join.js.map +1 -1
  62. package/dist/query/helpers/join.mjs.map +1 -1
  63. package/dist/query/helpers/order-by.js.map +1 -1
  64. package/dist/query/helpers/order-by.mjs.map +1 -1
  65. package/dist/query/helpers/populate/apply.js.map +1 -1
  66. package/dist/query/helpers/populate/apply.mjs.map +1 -1
  67. package/dist/query/helpers/search.js.map +1 -1
  68. package/dist/query/helpers/search.mjs.map +1 -1
  69. package/dist/query/helpers/streams/readable.js.map +1 -1
  70. package/dist/query/helpers/streams/readable.mjs.map +1 -1
  71. package/dist/query/helpers/where.js.map +1 -1
  72. package/dist/query/helpers/where.mjs.map +1 -1
  73. package/dist/query/query-builder.js.map +1 -1
  74. package/dist/query/query-builder.mjs.map +1 -1
  75. package/dist/repairs/operations/remove-orphan-morph-types.js.map +1 -1
  76. package/dist/repairs/operations/remove-orphan-morph-types.mjs.map +1 -1
  77. package/dist/schema/builder.js.map +1 -1
  78. package/dist/schema/builder.mjs.map +1 -1
  79. package/dist/schema/schema.js.map +1 -1
  80. package/dist/schema/schema.mjs.map +1 -1
  81. package/dist/utils/identifiers/hash.js.map +1 -1
  82. package/dist/utils/identifiers/hash.mjs.map +1 -1
  83. package/dist/utils/identifiers/index.js +2 -4
  84. package/dist/utils/identifiers/index.js.map +1 -1
  85. package/dist/utils/identifiers/index.mjs +2 -4
  86. package/dist/utils/identifiers/index.mjs.map +1 -1
  87. package/dist/utils/knex.js.map +1 -1
  88. package/dist/utils/knex.mjs.map +1 -1
  89. package/package.json +4 -4
@@ -1 +1 @@
1
- {"version":3,"file":"builder.js","sources":["../../src/schema/builder.ts"],"sourcesContent":["import { isNil, prop, omit, castArray } from 'lodash/fp';\nimport createDebug from 'debug';\n\nimport type { Knex } from 'knex';\nimport type { Database } from '..';\nimport type { Schema, Table, SchemaDiff, TableDiff, ForeignKey, Index, Column } from './types';\n\nconst debug = createDebug('strapi::database');\n\nexport default (db: Database) => {\n const helpers = createHelpers(db);\n\n return {\n /**\n * Returns a knex schema builder instance\n * @param {string} table - table name\n */\n getSchemaBuilder(trx: Knex.Transaction) {\n return db.getSchemaConnection(trx);\n },\n\n /**\n * Creates schema in DB\n */\n async createSchema(schema: Schema) {\n await db.connection.transaction(async (trx) => {\n await this.createTables(schema.tables, trx);\n });\n },\n\n /**\n * Creates a list of tables in a schema\n * @param {KnexInstance} trx\n * @param {Table[]} tables\n */\n async createTables(tables: Table[], trx: Knex.Transaction) {\n for (const table of tables) {\n debug(`Creating table: ${table.name}`);\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.createTable(schemaBuilder, table);\n }\n\n // create FKs once all the tables exist\n for (const table of tables) {\n debug(`Creating table foreign keys: ${table.name}`);\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.createTableForeignKeys(schemaBuilder, table);\n }\n },\n /**\n * Drops schema from DB\n */\n async dropSchema(schema: Schema, { dropDatabase = false } = {}) {\n if (dropDatabase) {\n // TODO: drop database & return as it will drop everything\n return;\n }\n\n await db.connection.transaction(async (trx) => {\n for (const table of schema.tables.reverse()) {\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.dropTable(schemaBuilder, table);\n }\n });\n },\n\n /**\n * Applies a schema diff update in the DB\n * @param {*} schemaDiff\n */\n // TODO: implement force option to disable removal in DB\n async updateSchema(schemaDiff: SchemaDiff['diff']) {\n const forceMigration = db.config.settings?.forceMigration;\n\n await db.dialect.startSchemaUpdate();\n\n // Pre-fetch metadata for all updated tables\n const existingMetadata: Record<string, { indexes: Index[]; foreignKeys: ForeignKey[] }> = {};\n const columnTypes: Record<string, Record<string, string | null>> = {};\n\n for (const table of schemaDiff.tables.updated) {\n existingMetadata[table.name] = {\n indexes: await db.dialect.schemaInspector.getIndexes(table.name),\n foreignKeys: await db.dialect.schemaInspector.getForeignKeys(table.name),\n };\n\n // Pre-fetch column types for PostgreSQL to avoid transaction timeouts\n if (db.config.connection.client === 'postgres') {\n columnTypes[table.name] = {};\n for (const updatedColumn of table.columns.updated) {\n columnTypes[table.name][updatedColumn.name] = await helpers.getCurrentColumnType(\n table.name,\n updatedColumn.name\n );\n }\n }\n }\n\n await db.connection.transaction(async (trx) => {\n await this.createTables(schemaDiff.tables.added, trx);\n\n if (forceMigration) {\n // drop all delete table foreign keys then delete the tables\n for (const table of schemaDiff.tables.removed) {\n debug(`Removing table foreign keys: ${table.name}`);\n\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.dropTableForeignKeys(schemaBuilder, table);\n }\n\n for (const table of schemaDiff.tables.removed) {\n debug(`Removing table: ${table.name}`);\n\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.dropTable(schemaBuilder, table);\n }\n }\n\n for (const table of schemaDiff.tables.updated) {\n debug(`Updating table: ${table.name}`);\n\n // Handle special type conversions before standard alterations\n await helpers.handleSpecialTypeConversions(trx, table, columnTypes[table.name] || {});\n\n // alter table\n const schemaBuilder = this.getSchemaBuilder(trx);\n\n const { indexes, foreignKeys } = existingMetadata[table.name];\n await helpers.alterTable(schemaBuilder, table, { indexes, foreignKeys });\n }\n });\n\n await db.dialect.endSchemaUpdate();\n },\n };\n};\n\nconst createHelpers = (db: Database) => {\n /**\n * Creates a foreign key on a table\n */\n const createForeignKey = (tableBuilder: Knex.TableBuilder, foreignKey: ForeignKey) => {\n const { name, columns, referencedColumns, referencedTable, onDelete, onUpdate } = foreignKey;\n\n const constraint = tableBuilder\n .foreign(columns, name)\n .references(referencedColumns)\n .inTable(db.getSchemaName() ? `${db.getSchemaName()}.${referencedTable}` : referencedTable);\n\n if (onDelete) {\n constraint.onDelete(onDelete);\n }\n\n if (onUpdate) {\n constraint.onUpdate(onUpdate);\n }\n };\n\n /**\n * Drops a foreign key from a table\n */\n const dropForeignKey = (\n tableBuilder: Knex.TableBuilder,\n foreignKey: ForeignKey,\n existingForeignKeys?: ForeignKey[]\n ) => {\n const { name, columns } = foreignKey;\n\n // Check if the index exists in existingIndexes, and return early if it doesn't\n if (\n existingForeignKeys &&\n !existingForeignKeys.some((existingIndex) => existingIndex?.name === name)\n ) {\n debug(`Foreign Key ${name} not found in existing foreign keys. Skipping drop.`);\n return;\n }\n\n tableBuilder.dropForeign(columns, name);\n };\n\n /**\n * Creates an index on a table\n */\n const createIndex = (tableBuilder: Knex.TableBuilder, index: Index) => {\n const { type, columns, name } = index;\n\n switch (type) {\n case 'primary': {\n return tableBuilder.primary(columns, { constraintName: name });\n }\n case 'unique': {\n return tableBuilder.unique(columns, { indexName: name });\n }\n default: {\n return tableBuilder.index(columns, name, type);\n }\n }\n };\n\n /**\n * Drops an index from table\n * @param {Knex.TableBuilder} tableBuilder\n * @param {Index} index\n */\n const dropIndex = (tableBuilder: Knex.TableBuilder, index: Index, existingIndexes?: Index[]) => {\n if (!db.config.settings?.forceMigration) {\n return;\n }\n\n const { type, columns, name } = index;\n\n // Check if the index exists in existingIndexes, and return early if it doesn't\n if (existingIndexes && !existingIndexes.some((existingIndex) => existingIndex?.name === name)) {\n debug(`Index ${index.name} not found in existingIndexes. Skipping drop.`);\n return;\n }\n\n switch (type) {\n case 'primary': {\n return tableBuilder.dropPrimary(name);\n }\n case 'unique': {\n return tableBuilder.dropUnique(columns, name);\n }\n default: {\n return tableBuilder.dropIndex(columns, name);\n }\n }\n };\n\n /**\n * Creates a column in a table\n */\n const createColumn = (tableBuilder: Knex.TableBuilder, column: Column) => {\n const { type, name, args = [], defaultTo, unsigned, notNullable } = column;\n\n const col = (tableBuilder[type as keyof Knex.TableBuilder] as any)(name, ...args);\n\n if (unsigned === true) {\n col.unsigned();\n }\n\n if (!isNil(defaultTo)) {\n const [value, opts] = castArray(defaultTo);\n\n if (prop('isRaw', opts)) {\n col.defaultTo(db.connection.raw(value), omit('isRaw', opts));\n } else {\n col.defaultTo(value, opts);\n }\n }\n\n if (notNullable === true) {\n col.notNullable();\n } else {\n col.nullable();\n }\n\n return col;\n };\n\n /**\n * Drops a column from a table\n */\n const dropColumn = (tableBuilder: Knex.TableBuilder, column: Column) => {\n if (!db.config.settings?.forceMigration) {\n return;\n }\n\n return tableBuilder.dropColumn(column.name);\n };\n\n /**\n * Creates a table in a database\n */\n const createTable = async (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n await schemaBuilder.createTable(table.name, (tableBuilder) => {\n // columns\n (table.columns || []).forEach((column) => createColumn(tableBuilder, column));\n\n // indexes\n (table.indexes || []).forEach((index) => createIndex(tableBuilder, index));\n\n // foreign keys\n\n if (!db.dialect.canAlterConstraints()) {\n (table.foreignKeys || []).forEach((foreignKey) =>\n createForeignKey(tableBuilder, foreignKey)\n );\n }\n });\n };\n\n /**\n * Alters a database table by applying a set of schema changes including updates to columns, indexes, and foreign keys.\n * This function ensures proper ordering of operations to avoid conflicts (e.g., foreign key errors) and handles\n * MySQL-specific quirks where dropping a foreign key can implicitly drop an associated index.\n *\n * @param {Knex.SchemaBuilder} schemaBuilder - Knex SchemaBuilder instance to perform schema operations.\n * @param {TableDiff['diff']} table - A diff object representing the schema changes to be applied to the table.\n * @param {{ indexes: Index[]; foreignKeys: ForeignKey[] }} existingMetadata - Metadata about existing indexes and\n * foreign keys in the table. Used to ensure safe operations and avoid unnecessary modifications.\n * - indexes: Array of existing index definitions.\n * - foreignKeys: Array of existing foreign key definitions.\n */\n const alterTable = async (\n schemaBuilder: Knex.SchemaBuilder,\n table: TableDiff['diff'],\n existingMetadata: { indexes: Index[]; foreignKeys: ForeignKey[] } = {\n indexes: [],\n foreignKeys: [],\n }\n ) => {\n let existingIndexes = [...existingMetadata.indexes];\n const existingForeignKeys = [...existingMetadata.foreignKeys];\n\n // Track dropped foreign keys\n const droppedForeignKeyNames: string[] = [];\n\n await schemaBuilder.alterTable(table.name, async (tableBuilder) => {\n // Drop foreign keys first to avoid foreign key errors in the following steps\n for (const removedForeignKey of table.foreignKeys.removed) {\n debug(`Dropping foreign key ${removedForeignKey.name} on ${table.name}`);\n dropForeignKey(tableBuilder, removedForeignKey, existingForeignKeys);\n\n droppedForeignKeyNames.push(removedForeignKey.name);\n }\n\n for (const updatedForeignKey of table.foreignKeys.updated) {\n debug(`Dropping updated foreign key ${updatedForeignKey.name} on ${table.name}`);\n dropForeignKey(tableBuilder, updatedForeignKey.object, existingForeignKeys);\n\n droppedForeignKeyNames.push(updatedForeignKey.object.name);\n }\n\n // In MySQL, dropping a foreign key can also implicitly drop an index with the same name\n // Remove dropped foreign keys from existingIndexes for MySQL\n if (db.config.connection.client === 'mysql') {\n existingIndexes = existingIndexes.filter(\n (index) => !droppedForeignKeyNames.includes(index.name)\n );\n }\n\n for (const removedIndex of table.indexes.removed) {\n debug(`Dropping index ${removedIndex.name} on ${table.name}`);\n dropIndex(tableBuilder, removedIndex, existingIndexes);\n }\n\n for (const updatedIndex of table.indexes.updated) {\n debug(`Dropping updated index ${updatedIndex.name} on ${table.name}`);\n dropIndex(tableBuilder, updatedIndex.object, existingIndexes);\n }\n\n // Drop columns after FKs have been removed to avoid FK errors\n for (const removedColumn of table.columns.removed) {\n debug(`Dropping column ${removedColumn.name} on ${table.name}`);\n dropColumn(tableBuilder, removedColumn);\n }\n\n // Update existing columns\n for (const updatedColumn of table.columns.updated) {\n debug(`Updating column ${updatedColumn.name} on ${table.name}`);\n\n const { object } = updatedColumn;\n\n if (object.type === 'increments') {\n createColumn(tableBuilder, { ...object, type: 'integer' }).alter();\n } else {\n createColumn(tableBuilder, object).alter();\n }\n }\n\n // Add any new columns\n for (const addedColumn of table.columns.added) {\n debug(`Creating column ${addedColumn.name} on ${table.name}`);\n\n if (addedColumn.type === 'increments' && !db.dialect.canAddIncrements()) {\n tableBuilder.integer(addedColumn.name).unsigned();\n tableBuilder.primary([addedColumn.name]);\n } else {\n createColumn(tableBuilder, addedColumn);\n }\n }\n\n // once the columns have all been updated, we can create indexes again\n for (const updatedForeignKey of table.foreignKeys.updated) {\n debug(`Recreating updated foreign key ${updatedForeignKey.name} on ${table.name}`);\n createForeignKey(tableBuilder, updatedForeignKey.object);\n }\n\n for (const updatedIndex of table.indexes.updated) {\n debug(`Recreating updated index ${updatedIndex.name} on ${table.name}`);\n createIndex(tableBuilder, updatedIndex.object);\n }\n\n for (const addedForeignKey of table.foreignKeys.added) {\n debug(`Creating foreign key ${addedForeignKey.name} on ${table.name}`);\n createForeignKey(tableBuilder, addedForeignKey);\n }\n\n for (const addedIndex of table.indexes.added) {\n debug(`Creating index ${addedIndex.name} on ${table.name}`);\n createIndex(tableBuilder, addedIndex);\n }\n });\n };\n\n /**\n * Drops a table from a database\n */\n const dropTable = (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n if (!db.config.settings.forceMigration) {\n return;\n }\n\n return schemaBuilder.dropTableIfExists(table.name);\n };\n\n /**\n * Creates a table foreign keys constraints\n */\n const createTableForeignKeys = async (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n // foreign keys\n await schemaBuilder.table(table.name, (tableBuilder) => {\n (table.foreignKeys || []).forEach((foreignKey) => createForeignKey(tableBuilder, foreignKey));\n });\n };\n\n /**\n * Drops a table foreign keys constraints\n */\n const dropTableForeignKeys = async (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n if (!db.config.settings.forceMigration) {\n return;\n }\n\n // foreign keys\n await schemaBuilder.table(table.name, (tableBuilder) => {\n (table.foreignKeys || []).forEach((foreignKey) => dropForeignKey(tableBuilder, foreignKey));\n });\n };\n\n /**\n * Get the current column type from the database\n */\n const getCurrentColumnType = async (\n tableName: string,\n columnName: string\n ): Promise<string | null> => {\n try {\n const schemaName = db.getSchemaName();\n const result = await db.connection.raw(\n `\n SELECT data_type \n FROM information_schema.columns \n WHERE table_name = ? \n AND column_name = ?\n ${schemaName ? 'AND table_schema = ?' : ''}\n LIMIT 1\n `,\n schemaName ? [tableName, columnName, schemaName] : [tableName, columnName]\n );\n\n return result.rows?.[0]?.data_type || null;\n } catch (error) {\n // Log error but don't fail the migration\n debug(\n `Failed to get column type for ${tableName}.${columnName}: ${error instanceof Error ? error.message : String(error)}`\n );\n return null;\n }\n };\n\n /**\n * Apply column properties after type conversion\n */\n const applyColumnProperties = async (\n trx: Knex.Transaction,\n tableName: string,\n columnName: string,\n column: Column\n ) => {\n // Apply NOT NULL constraint\n if (column.notNullable) {\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? SET NOT NULL`, [tableName, columnName]);\n } else {\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? DROP NOT NULL`, [tableName, columnName]);\n }\n\n // Apply default value\n if (column.defaultTo !== undefined) {\n const [defaultValue, defaultOpts] = castArray(column.defaultTo);\n if (prop('isRaw', defaultOpts)) {\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? SET DEFAULT ${defaultValue}`, [\n tableName,\n columnName,\n ]);\n } else {\n // PostgreSQL doesn't support parameterized SET DEFAULT, so we need to escape the value\n const escapedDefault =\n typeof defaultValue === 'string' ? `'${defaultValue.replace(/'/g, \"''\")}'` : defaultValue;\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? SET DEFAULT ${escapedDefault}`, [\n tableName,\n columnName,\n ]);\n }\n }\n };\n\n /**\n * Handle special type conversions that require custom SQL\n */\n const handleSpecialTypeConversions = async (\n trx: Knex.Transaction,\n table: TableDiff['diff'],\n preloadedColumnTypes: Record<string, string | null> = {}\n ) => {\n // Only PostgreSQL needs special handling for now\n if (db.config.connection.client !== 'postgres') {\n return;\n }\n\n const conversionsToApply = [];\n\n // Check each updated column for special type conversions\n for (const updatedColumn of table.columns.updated) {\n const { name: columnName, object: column } = updatedColumn;\n\n // Use pre-loaded column type if available, otherwise fetch it\n const currentType =\n preloadedColumnTypes[columnName] ?? (await getCurrentColumnType(table.name, columnName));\n\n if (currentType) {\n // Check if dialect has special conversion SQL\n const conversionSQL = db.dialect.getColumnTypeConversionSQL(currentType, column.type);\n\n if (conversionSQL) {\n conversionsToApply.push({\n column: updatedColumn,\n sql: conversionSQL.sql,\n params: [table.name, columnName, columnName],\n currentType,\n targetType: column.type,\n warning: conversionSQL.warning,\n });\n }\n }\n }\n\n // Apply conversions\n for (const conversion of conversionsToApply) {\n const { column, sql, params, currentType, targetType, warning } = conversion;\n\n // Log warning about type conversion\n const warningMessage = warning || 'This conversion may result in data changes.';\n db.logger.warn(\n `Database type conversion: \"${table.name}.${column.name}\" from \"${currentType}\" to \"${targetType}\". ${warningMessage}`\n );\n\n debug(`Applying special type conversion for column ${column.name} on ${table.name}`);\n debug(`Executing SQL: ${sql} with params: ${JSON.stringify(params)}`);\n\n try {\n // Execute the conversion using the transaction connection\n await trx.raw(sql, params);\n debug(`Successfully converted ${column.name} from ${currentType} to ${targetType}`);\n } catch (conversionError) {\n db.logger.error(\n `Failed to convert column ${column.name}: ${conversionError instanceof Error ? conversionError.message : String(conversionError)}`\n );\n throw conversionError;\n }\n\n // Apply other column properties\n await applyColumnProperties(trx, table.name, column.name, column.object);\n\n // Remove from standard updates to prevent double processing\n table.columns.updated = table.columns.updated.filter((col) => col.name !== column.name);\n }\n };\n\n return {\n createTable,\n alterTable,\n dropTable,\n createTableForeignKeys,\n dropTableForeignKeys,\n handleSpecialTypeConversions,\n getCurrentColumnType,\n };\n};\n"],"names":["debug","createDebug","db","helpers","createHelpers","getSchemaBuilder","trx","getSchemaConnection","createSchema","schema","connection","transaction","createTables","tables","table","name","schemaBuilder","createTable","createTableForeignKeys","dropSchema","dropDatabase","reverse","dropTable","updateSchema","schemaDiff","forceMigration","config","settings","dialect","startSchemaUpdate","existingMetadata","columnTypes","updated","indexes","schemaInspector","getIndexes","foreignKeys","getForeignKeys","client","updatedColumn","columns","getCurrentColumnType","added","removed","dropTableForeignKeys","handleSpecialTypeConversions","alterTable","endSchemaUpdate","createForeignKey","tableBuilder","foreignKey","referencedColumns","referencedTable","onDelete","onUpdate","constraint","foreign","references","inTable","getSchemaName","dropForeignKey","existingForeignKeys","some","existingIndex","dropForeign","createIndex","index","type","primary","constraintName","unique","indexName","dropIndex","existingIndexes","dropPrimary","dropUnique","createColumn","column","args","defaultTo","unsigned","notNullable","col","isNil","value","opts","castArray","prop","raw","omit","nullable","dropColumn","forEach","canAlterConstraints","droppedForeignKeyNames","removedForeignKey","push","updatedForeignKey","object","filter","includes","removedIndex","updatedIndex","removedColumn","alter","addedColumn","canAddIncrements","integer","addedForeignKey","addedIndex","dropTableIfExists","tableName","columnName","schemaName","result","rows","data_type","error","Error","message","String","applyColumnProperties","undefined","defaultValue","defaultOpts","escapedDefault","replace","preloadedColumnTypes","conversionsToApply","currentType","conversionSQL","getColumnTypeConversionSQL","sql","params","targetType","warning","conversion","warningMessage","logger","warn","JSON","stringify","conversionError"],"mappings":";;;;;AAOA,MAAMA,QAAQC,WAAY,CAAA,kBAAA,CAAA;AAE1B,0BAAe,CAAA,CAACC,EAAAA,GAAAA;AACd,IAAA,MAAMC,UAAUC,aAAcF,CAAAA,EAAAA,CAAAA;IAE9B,OAAO;AACL;;;AAGC,QACDG,kBAAiBC,GAAqB,EAAA;YACpC,OAAOJ,EAAAA,CAAGK,mBAAmB,CAACD,GAAAA,CAAAA;AAChC,SAAA;AAEA;;QAGA,MAAME,cAAaC,MAAc,EAAA;AAC/B,YAAA,MAAMP,EAAGQ,CAAAA,UAAU,CAACC,WAAW,CAAC,OAAOL,GAAAA,GAAAA;AACrC,gBAAA,MAAM,IAAI,CAACM,YAAY,CAACH,MAAAA,CAAOI,MAAM,EAAEP,GAAAA,CAAAA;AACzC,aAAA,CAAA;AACF,SAAA;AAEA;;;;AAIC,QACD,MAAMM,YAAAA,CAAAA,CAAaC,MAAe,EAAEP,GAAqB,EAAA;YACvD,KAAK,MAAMQ,SAASD,MAAQ,CAAA;AAC1Bb,gBAAAA,KAAAA,CAAM,CAAC,gBAAgB,EAAEc,KAAMC,CAAAA,IAAI,CAAC,CAAC,CAAA;AACrC,gBAAA,MAAMC,aAAgB,GAAA,IAAI,CAACX,gBAAgB,CAACC,GAAAA,CAAAA;gBAC5C,MAAMH,OAAAA,CAAQc,WAAW,CAACD,aAAeF,EAAAA,KAAAA,CAAAA;AAC3C;;YAGA,KAAK,MAAMA,SAASD,MAAQ,CAAA;AAC1Bb,gBAAAA,KAAAA,CAAM,CAAC,6BAA6B,EAAEc,KAAMC,CAAAA,IAAI,CAAC,CAAC,CAAA;AAClD,gBAAA,MAAMC,aAAgB,GAAA,IAAI,CAACX,gBAAgB,CAACC,GAAAA,CAAAA;gBAC5C,MAAMH,OAAAA,CAAQe,sBAAsB,CAACF,aAAeF,EAAAA,KAAAA,CAAAA;AACtD;AACF,SAAA;AACA;;QAGA,MAAMK,UAAWV,CAAAA,CAAAA,MAAc,EAAE,EAAEW,eAAe,KAAK,EAAE,GAAG,EAAE,EAAA;AAC5D,YAAA,IAAIA,YAAc,EAAA;;AAEhB,gBAAA;AACF;AAEA,YAAA,MAAMlB,EAAGQ,CAAAA,UAAU,CAACC,WAAW,CAAC,OAAOL,GAAAA,GAAAA;AACrC,gBAAA,KAAK,MAAMQ,KAASL,IAAAA,MAAAA,CAAOI,MAAM,CAACQ,OAAO,EAAI,CAAA;AAC3C,oBAAA,MAAML,aAAgB,GAAA,IAAI,CAACX,gBAAgB,CAACC,GAAAA,CAAAA;oBAC5C,MAAMH,OAAAA,CAAQmB,SAAS,CAACN,aAAeF,EAAAA,KAAAA,CAAAA;AACzC;AACF,aAAA,CAAA;AACF,SAAA;AAEA;;;AAGC;AAED,QAAA,MAAMS,cAAaC,UAA8B,EAAA;AAC/C,YAAA,MAAMC,cAAiBvB,GAAAA,EAAAA,CAAGwB,MAAM,CAACC,QAAQ,EAAEF,cAAAA;YAE3C,MAAMvB,EAAAA,CAAG0B,OAAO,CAACC,iBAAiB,EAAA;;AAGlC,YAAA,MAAMC,mBAAoF,EAAC;AAC3F,YAAA,MAAMC,cAA6D,EAAC;AAEpE,YAAA,KAAK,MAAMjB,KAASU,IAAAA,UAAAA,CAAWX,MAAM,CAACmB,OAAO,CAAE;AAC7CF,gBAAAA,gBAAgB,CAAChB,KAAAA,CAAMC,IAAI,CAAC,GAAG;oBAC7BkB,OAAS,EAAA,MAAM/B,GAAG0B,OAAO,CAACM,eAAe,CAACC,UAAU,CAACrB,KAAAA,CAAMC,IAAI,CAAA;oBAC/DqB,WAAa,EAAA,MAAMlC,GAAG0B,OAAO,CAACM,eAAe,CAACG,cAAc,CAACvB,KAAAA,CAAMC,IAAI;AACzE,iBAAA;;AAGA,gBAAA,IAAIb,GAAGwB,MAAM,CAAChB,UAAU,CAAC4B,MAAM,KAAK,UAAY,EAAA;AAC9CP,oBAAAA,WAAW,CAACjB,KAAAA,CAAMC,IAAI,CAAC,GAAG,EAAC;AAC3B,oBAAA,KAAK,MAAMwB,aAAiBzB,IAAAA,KAAAA,CAAM0B,OAAO,CAACR,OAAO,CAAE;AACjDD,wBAAAA,WAAW,CAACjB,KAAMC,CAAAA,IAAI,CAAC,CAACwB,cAAcxB,IAAI,CAAC,GAAG,MAAMZ,QAAQsC,oBAAoB,CAC9E3B,MAAMC,IAAI,EACVwB,cAAcxB,IAAI,CAAA;AAEtB;AACF;AACF;AAEA,YAAA,MAAMb,EAAGQ,CAAAA,UAAU,CAACC,WAAW,CAAC,OAAOL,GAAAA,GAAAA;gBACrC,MAAM,IAAI,CAACM,YAAY,CAACY,WAAWX,MAAM,CAAC6B,KAAK,EAAEpC,GAAAA,CAAAA;AAEjD,gBAAA,IAAImB,cAAgB,EAAA;;AAElB,oBAAA,KAAK,MAAMX,KAASU,IAAAA,UAAAA,CAAWX,MAAM,CAAC8B,OAAO,CAAE;AAC7C3C,wBAAAA,KAAAA,CAAM,CAAC,6BAA6B,EAAEc,KAAMC,CAAAA,IAAI,CAAC,CAAC,CAAA;AAElD,wBAAA,MAAMC,aAAgB,GAAA,IAAI,CAACX,gBAAgB,CAACC,GAAAA,CAAAA;wBAC5C,MAAMH,OAAAA,CAAQyC,oBAAoB,CAAC5B,aAAeF,EAAAA,KAAAA,CAAAA;AACpD;AAEA,oBAAA,KAAK,MAAMA,KAASU,IAAAA,UAAAA,CAAWX,MAAM,CAAC8B,OAAO,CAAE;AAC7C3C,wBAAAA,KAAAA,CAAM,CAAC,gBAAgB,EAAEc,KAAMC,CAAAA,IAAI,CAAC,CAAC,CAAA;AAErC,wBAAA,MAAMC,aAAgB,GAAA,IAAI,CAACX,gBAAgB,CAACC,GAAAA,CAAAA;wBAC5C,MAAMH,OAAAA,CAAQmB,SAAS,CAACN,aAAeF,EAAAA,KAAAA,CAAAA;AACzC;AACF;AAEA,gBAAA,KAAK,MAAMA,KAASU,IAAAA,UAAAA,CAAWX,MAAM,CAACmB,OAAO,CAAE;AAC7ChC,oBAAAA,KAAAA,CAAM,CAAC,gBAAgB,EAAEc,KAAMC,CAAAA,IAAI,CAAC,CAAC,CAAA;;oBAGrC,MAAMZ,OAAAA,CAAQ0C,4BAA4B,CAACvC,GAAKQ,EAAAA,KAAAA,EAAOiB,WAAW,CAACjB,KAAMC,CAAAA,IAAI,CAAC,IAAI,EAAC,CAAA;;AAGnF,oBAAA,MAAMC,aAAgB,GAAA,IAAI,CAACX,gBAAgB,CAACC,GAAAA,CAAAA;oBAE5C,MAAM,EAAE2B,OAAO,EAAEG,WAAW,EAAE,GAAGN,gBAAgB,CAAChB,KAAMC,CAAAA,IAAI,CAAC;AAC7D,oBAAA,MAAMZ,OAAQ2C,CAAAA,UAAU,CAAC9B,aAAAA,EAAeF,KAAO,EAAA;AAAEmB,wBAAAA,OAAAA;AAASG,wBAAAA;AAAY,qBAAA,CAAA;AACxE;AACF,aAAA,CAAA;YAEA,MAAMlC,EAAAA,CAAG0B,OAAO,CAACmB,eAAe,EAAA;AAClC;AACF,KAAA;AACF,CAAA;AAEA,MAAM3C,gBAAgB,CAACF,EAAAA,GAAAA;AACrB;;MAGA,MAAM8C,gBAAmB,GAAA,CAACC,YAAiCC,EAAAA,UAAAA,GAAAA;AACzD,QAAA,MAAM,EAAEnC,IAAI,EAAEyB,OAAO,EAAEW,iBAAiB,EAAEC,eAAe,EAAEC,QAAQ,EAAEC,QAAQ,EAAE,GAAGJ,UAAAA;QAElF,MAAMK,UAAAA,GAAaN,aAChBO,OAAO,CAAChB,SAASzB,IACjB0C,CAAAA,CAAAA,UAAU,CAACN,iBAAAA,CAAAA,CACXO,OAAO,CAACxD,GAAGyD,aAAa,EAAA,GAAK,CAAC,EAAEzD,EAAGyD,CAAAA,aAAa,GAAG,CAAC,EAAEP,eAAgB,CAAA,CAAC,GAAGA,eAAAA,CAAAA;AAE7E,QAAA,IAAIC,QAAU,EAAA;AACZE,YAAAA,UAAAA,CAAWF,QAAQ,CAACA,QAAAA,CAAAA;AACtB;AAEA,QAAA,IAAIC,QAAU,EAAA;AACZC,YAAAA,UAAAA,CAAWD,QAAQ,CAACA,QAAAA,CAAAA;AACtB;AACF,KAAA;AAEA;;AAEC,MACD,MAAMM,cAAAA,GAAiB,CACrBX,YAAAA,EACAC,UACAW,EAAAA,mBAAAA,GAAAA;AAEA,QAAA,MAAM,EAAE9C,IAAI,EAAEyB,OAAO,EAAE,GAAGU,UAAAA;;QAG1B,IACEW,mBAAAA,IACA,CAACA,mBAAoBC,CAAAA,IAAI,CAAC,CAACC,aAAAA,GAAkBA,aAAehD,EAAAA,IAAAA,KAASA,IACrE,CAAA,EAAA;AACAf,YAAAA,KAAAA,CAAM,CAAC,YAAY,EAAEe,IAAAA,CAAK,mDAAmD,CAAC,CAAA;AAC9E,YAAA;AACF;QAEAkC,YAAae,CAAAA,WAAW,CAACxB,OAASzB,EAAAA,IAAAA,CAAAA;AACpC,KAAA;AAEA;;MAGA,MAAMkD,WAAc,GAAA,CAAChB,YAAiCiB,EAAAA,KAAAA,GAAAA;AACpD,QAAA,MAAM,EAAEC,IAAI,EAAE3B,OAAO,EAAEzB,IAAI,EAAE,GAAGmD,KAAAA;QAEhC,OAAQC,IAAAA;YACN,KAAK,SAAA;AAAW,gBAAA;oBACd,OAAOlB,YAAAA,CAAamB,OAAO,CAAC5B,OAAS,EAAA;wBAAE6B,cAAgBtD,EAAAA;AAAK,qBAAA,CAAA;AAC9D;YACA,KAAK,QAAA;AAAU,gBAAA;oBACb,OAAOkC,YAAAA,CAAaqB,MAAM,CAAC9B,OAAS,EAAA;wBAAE+B,SAAWxD,EAAAA;AAAK,qBAAA,CAAA;AACxD;AACA,YAAA;AAAS,gBAAA;AACP,oBAAA,OAAOkC,YAAaiB,CAAAA,KAAK,CAAC1B,OAAAA,EAASzB,IAAMoD,EAAAA,IAAAA,CAAAA;AAC3C;AACF;AACF,KAAA;AAEA;;;;AAIC,MACD,MAAMK,SAAAA,GAAY,CAACvB,YAAAA,EAAiCiB,KAAcO,EAAAA,eAAAA,GAAAA;AAChE,QAAA,IAAI,CAACvE,EAAGwB,CAAAA,MAAM,CAACC,QAAQ,EAAEF,cAAgB,EAAA;AACvC,YAAA;AACF;AAEA,QAAA,MAAM,EAAE0C,IAAI,EAAE3B,OAAO,EAAEzB,IAAI,EAAE,GAAGmD,KAAAA;;QAGhC,IAAIO,eAAAA,IAAmB,CAACA,eAAgBX,CAAAA,IAAI,CAAC,CAACC,aAAAA,GAAkBA,aAAehD,EAAAA,IAAAA,KAASA,IAAO,CAAA,EAAA;AAC7Ff,YAAAA,KAAAA,CAAM,CAAC,MAAM,EAAEkE,MAAMnD,IAAI,CAAC,6CAA6C,CAAC,CAAA;AACxE,YAAA;AACF;QAEA,OAAQoD,IAAAA;YACN,KAAK,SAAA;AAAW,gBAAA;oBACd,OAAOlB,YAAAA,CAAayB,WAAW,CAAC3D,IAAAA,CAAAA;AAClC;YACA,KAAK,QAAA;AAAU,gBAAA;oBACb,OAAOkC,YAAAA,CAAa0B,UAAU,CAACnC,OAASzB,EAAAA,IAAAA,CAAAA;AAC1C;AACA,YAAA;AAAS,gBAAA;oBACP,OAAOkC,YAAAA,CAAauB,SAAS,CAAChC,OAASzB,EAAAA,IAAAA,CAAAA;AACzC;AACF;AACF,KAAA;AAEA;;MAGA,MAAM6D,YAAe,GAAA,CAAC3B,YAAiC4B,EAAAA,MAAAA,GAAAA;AACrD,QAAA,MAAM,EAAEV,IAAI,EAAEpD,IAAI,EAAE+D,IAAO,GAAA,EAAE,EAAEC,SAAS,EAAEC,QAAQ,EAAEC,WAAW,EAAE,GAAGJ,MAAAA;AAEpE,QAAA,MAAMK,MAAM,YAAa,CAACf,IAAAA,CAAgC,CAASpD,IAAS+D,EAAAA,GAAAA,IAAAA,CAAAA;AAE5E,QAAA,IAAIE,aAAa,IAAM,EAAA;AACrBE,YAAAA,GAAAA,CAAIF,QAAQ,EAAA;AACd;QAEA,IAAI,CAACG,QAAMJ,SAAY,CAAA,EAAA;AACrB,YAAA,MAAM,CAACK,KAAAA,EAAOC,IAAK,CAAA,GAAGC,WAAUP,CAAAA,SAAAA,CAAAA;YAEhC,IAAIQ,MAAAA,CAAK,SAASF,IAAO,CAAA,EAAA;gBACvBH,GAAIH,CAAAA,SAAS,CAAC7E,EAAGQ,CAAAA,UAAU,CAAC8E,GAAG,CAACJ,KAAQK,CAAAA,EAAAA,MAAAA,CAAK,OAASJ,EAAAA,IAAAA,CAAAA,CAAAA;aACjD,MAAA;gBACLH,GAAIH,CAAAA,SAAS,CAACK,KAAOC,EAAAA,IAAAA,CAAAA;AACvB;AACF;AAEA,QAAA,IAAIJ,gBAAgB,IAAM,EAAA;AACxBC,YAAAA,GAAAA,CAAID,WAAW,EAAA;SACV,MAAA;AACLC,YAAAA,GAAAA,CAAIQ,QAAQ,EAAA;AACd;QAEA,OAAOR,GAAAA;AACT,KAAA;AAEA;;MAGA,MAAMS,UAAa,GAAA,CAAC1C,YAAiC4B,EAAAA,MAAAA,GAAAA;AACnD,QAAA,IAAI,CAAC3E,EAAGwB,CAAAA,MAAM,CAACC,QAAQ,EAAEF,cAAgB,EAAA;AACvC,YAAA;AACF;AAEA,QAAA,OAAOwB,YAAa0C,CAAAA,UAAU,CAACd,MAAAA,CAAO9D,IAAI,CAAA;AAC5C,KAAA;AAEA;;MAGA,MAAME,WAAc,GAAA,OAAOD,aAAmCF,EAAAA,KAAAA,GAAAA;AAC5D,QAAA,MAAME,cAAcC,WAAW,CAACH,KAAMC,CAAAA,IAAI,EAAE,CAACkC,YAAAA,GAAAA;;YAE1CnC,CAAAA,KAAAA,CAAM0B,OAAO,IAAI,EAAC,EAAGoD,OAAO,CAAC,CAACf,MAAWD,GAAAA,YAAAA,CAAa3B,YAAc4B,EAAAA,MAAAA,CAAAA,CAAAA;;YAGpE/D,CAAAA,KAAAA,CAAMmB,OAAO,IAAI,EAAC,EAAG2D,OAAO,CAAC,CAAC1B,KAAUD,GAAAA,WAAAA,CAAYhB,YAAciB,EAAAA,KAAAA,CAAAA,CAAAA;;AAInE,YAAA,IAAI,CAAChE,EAAAA,CAAG0B,OAAO,CAACiE,mBAAmB,EAAI,EAAA;gBACpC/E,CAAAA,KAAAA,CAAMsB,WAAW,IAAI,EAAC,EAAGwD,OAAO,CAAC,CAAC1C,UACjCF,GAAAA,gBAAAA,CAAiBC,YAAcC,EAAAA,UAAAA,CAAAA,CAAAA;AAEnC;AACF,SAAA,CAAA;AACF,KAAA;AAEA;;;;;;;;;;;AAWC,MACD,MAAMJ,UAAAA,GAAa,OACjB9B,aAAAA,EACAF,OACAgB,gBAAoE,GAAA;AAClEG,QAAAA,OAAAA,EAAS,EAAE;AACXG,QAAAA,WAAAA,EAAa;KACd,GAAA;AAED,QAAA,IAAIqC,eAAkB,GAAA;AAAI3C,YAAAA,GAAAA,gBAAAA,CAAiBG;AAAQ,SAAA;AACnD,QAAA,MAAM4B,mBAAsB,GAAA;AAAI/B,YAAAA,GAAAA,gBAAAA,CAAiBM;AAAY,SAAA;;AAG7D,QAAA,MAAM0D,yBAAmC,EAAE;AAE3C,QAAA,MAAM9E,cAAc8B,UAAU,CAAChC,KAAMC,CAAAA,IAAI,EAAE,OAAOkC,YAAAA,GAAAA;;AAEhD,YAAA,KAAK,MAAM8C,iBAAqBjF,IAAAA,KAAAA,CAAMsB,WAAW,CAACO,OAAO,CAAE;gBACzD3C,KAAM,CAAA,CAAC,qBAAqB,EAAE+F,iBAAkBhF,CAAAA,IAAI,CAAC,IAAI,EAAED,KAAAA,CAAMC,IAAI,CAAC,CAAC,CAAA;AACvE6C,gBAAAA,cAAAA,CAAeX,cAAc8C,iBAAmBlC,EAAAA,mBAAAA,CAAAA;gBAEhDiC,sBAAuBE,CAAAA,IAAI,CAACD,iBAAAA,CAAkBhF,IAAI,CAAA;AACpD;AAEA,YAAA,KAAK,MAAMkF,iBAAqBnF,IAAAA,KAAAA,CAAMsB,WAAW,CAACJ,OAAO,CAAE;gBACzDhC,KAAM,CAAA,CAAC,6BAA6B,EAAEiG,iBAAkBlF,CAAAA,IAAI,CAAC,IAAI,EAAED,KAAAA,CAAMC,IAAI,CAAC,CAAC,CAAA;gBAC/E6C,cAAeX,CAAAA,YAAAA,EAAcgD,iBAAkBC,CAAAA,MAAM,EAAErC,mBAAAA,CAAAA;AAEvDiC,gBAAAA,sBAAAA,CAAuBE,IAAI,CAACC,iBAAkBC,CAAAA,MAAM,CAACnF,IAAI,CAAA;AAC3D;;;AAIA,YAAA,IAAIb,GAAGwB,MAAM,CAAChB,UAAU,CAAC4B,MAAM,KAAK,OAAS,EAAA;gBAC3CmC,eAAkBA,GAAAA,eAAAA,CAAgB0B,MAAM,CACtC,CAACjC,KAAAA,GAAU,CAAC4B,sBAAuBM,CAAAA,QAAQ,CAAClC,KAAAA,CAAMnD,IAAI,CAAA,CAAA;AAE1D;AAEA,YAAA,KAAK,MAAMsF,YAAgBvF,IAAAA,KAAAA,CAAMmB,OAAO,CAACU,OAAO,CAAE;gBAChD3C,KAAM,CAAA,CAAC,eAAe,EAAEqG,YAAatF,CAAAA,IAAI,CAAC,IAAI,EAAED,KAAAA,CAAMC,IAAI,CAAC,CAAC,CAAA;AAC5DyD,gBAAAA,SAAAA,CAAUvB,cAAcoD,YAAc5B,EAAAA,eAAAA,CAAAA;AACxC;AAEA,YAAA,KAAK,MAAM6B,YAAgBxF,IAAAA,KAAAA,CAAMmB,OAAO,CAACD,OAAO,CAAE;gBAChDhC,KAAM,CAAA,CAAC,uBAAuB,EAAEsG,YAAavF,CAAAA,IAAI,CAAC,IAAI,EAAED,KAAAA,CAAMC,IAAI,CAAC,CAAC,CAAA;gBACpEyD,SAAUvB,CAAAA,YAAAA,EAAcqD,YAAaJ,CAAAA,MAAM,EAAEzB,eAAAA,CAAAA;AAC/C;;AAGA,YAAA,KAAK,MAAM8B,aAAiBzF,IAAAA,KAAAA,CAAM0B,OAAO,CAACG,OAAO,CAAE;gBACjD3C,KAAM,CAAA,CAAC,gBAAgB,EAAEuG,aAAcxF,CAAAA,IAAI,CAAC,IAAI,EAAED,KAAAA,CAAMC,IAAI,CAAC,CAAC,CAAA;AAC9D4E,gBAAAA,UAAAA,CAAW1C,YAAcsD,EAAAA,aAAAA,CAAAA;AAC3B;;AAGA,YAAA,KAAK,MAAMhE,aAAiBzB,IAAAA,KAAAA,CAAM0B,OAAO,CAACR,OAAO,CAAE;gBACjDhC,KAAM,CAAA,CAAC,gBAAgB,EAAEuC,aAAcxB,CAAAA,IAAI,CAAC,IAAI,EAAED,KAAAA,CAAMC,IAAI,CAAC,CAAC,CAAA;gBAE9D,MAAM,EAAEmF,MAAM,EAAE,GAAG3D,aAAAA;gBAEnB,IAAI2D,MAAAA,CAAO/B,IAAI,KAAK,YAAc,EAAA;AAChCS,oBAAAA,YAAAA,CAAa3B,YAAc,EAAA;AAAE,wBAAA,GAAGiD,MAAM;wBAAE/B,IAAM,EAAA;AAAU,qBAAA,CAAA,CAAGqC,KAAK,EAAA;iBAC3D,MAAA;oBACL5B,YAAa3B,CAAAA,YAAAA,EAAciD,QAAQM,KAAK,EAAA;AAC1C;AACF;;AAGA,YAAA,KAAK,MAAMC,WAAe3F,IAAAA,KAAAA,CAAM0B,OAAO,CAACE,KAAK,CAAE;gBAC7C1C,KAAM,CAAA,CAAC,gBAAgB,EAAEyG,WAAY1F,CAAAA,IAAI,CAAC,IAAI,EAAED,KAAAA,CAAMC,IAAI,CAAC,CAAC,CAAA;gBAE5D,IAAI0F,WAAAA,CAAYtC,IAAI,KAAK,YAAA,IAAgB,CAACjE,EAAG0B,CAAAA,OAAO,CAAC8E,gBAAgB,EAAI,EAAA;AACvEzD,oBAAAA,YAAAA,CAAa0D,OAAO,CAACF,WAAY1F,CAAAA,IAAI,EAAEiE,QAAQ,EAAA;AAC/C/B,oBAAAA,YAAAA,CAAamB,OAAO,CAAC;AAACqC,wBAAAA,WAAAA,CAAY1F;AAAK,qBAAA,CAAA;iBAClC,MAAA;AACL6D,oBAAAA,YAAAA,CAAa3B,YAAcwD,EAAAA,WAAAA,CAAAA;AAC7B;AACF;;AAGA,YAAA,KAAK,MAAMR,iBAAqBnF,IAAAA,KAAAA,CAAMsB,WAAW,CAACJ,OAAO,CAAE;gBACzDhC,KAAM,CAAA,CAAC,+BAA+B,EAAEiG,iBAAkBlF,CAAAA,IAAI,CAAC,IAAI,EAAED,KAAAA,CAAMC,IAAI,CAAC,CAAC,CAAA;gBACjFiC,gBAAiBC,CAAAA,YAAAA,EAAcgD,kBAAkBC,MAAM,CAAA;AACzD;AAEA,YAAA,KAAK,MAAMI,YAAgBxF,IAAAA,KAAAA,CAAMmB,OAAO,CAACD,OAAO,CAAE;gBAChDhC,KAAM,CAAA,CAAC,yBAAyB,EAAEsG,YAAavF,CAAAA,IAAI,CAAC,IAAI,EAAED,KAAAA,CAAMC,IAAI,CAAC,CAAC,CAAA;gBACtEkD,WAAYhB,CAAAA,YAAAA,EAAcqD,aAAaJ,MAAM,CAAA;AAC/C;AAEA,YAAA,KAAK,MAAMU,eAAmB9F,IAAAA,KAAAA,CAAMsB,WAAW,CAACM,KAAK,CAAE;gBACrD1C,KAAM,CAAA,CAAC,qBAAqB,EAAE4G,eAAgB7F,CAAAA,IAAI,CAAC,IAAI,EAAED,KAAAA,CAAMC,IAAI,CAAC,CAAC,CAAA;AACrEiC,gBAAAA,gBAAAA,CAAiBC,YAAc2D,EAAAA,eAAAA,CAAAA;AACjC;AAEA,YAAA,KAAK,MAAMC,UAAc/F,IAAAA,KAAAA,CAAMmB,OAAO,CAACS,KAAK,CAAE;gBAC5C1C,KAAM,CAAA,CAAC,eAAe,EAAE6G,UAAW9F,CAAAA,IAAI,CAAC,IAAI,EAAED,KAAAA,CAAMC,IAAI,CAAC,CAAC,CAAA;AAC1DkD,gBAAAA,WAAAA,CAAYhB,YAAc4D,EAAAA,UAAAA,CAAAA;AAC5B;AACF,SAAA,CAAA;AACF,KAAA;AAEA;;MAGA,MAAMvF,SAAY,GAAA,CAACN,aAAmCF,EAAAA,KAAAA,GAAAA;AACpD,QAAA,IAAI,CAACZ,EAAGwB,CAAAA,MAAM,CAACC,QAAQ,CAACF,cAAc,EAAE;AACtC,YAAA;AACF;AAEA,QAAA,OAAOT,aAAc8F,CAAAA,iBAAiB,CAAChG,KAAAA,CAAMC,IAAI,CAAA;AACnD,KAAA;AAEA;;MAGA,MAAMG,sBAAyB,GAAA,OAAOF,aAAmCF,EAAAA,KAAAA,GAAAA;;AAEvE,QAAA,MAAME,cAAcF,KAAK,CAACA,KAAMC,CAAAA,IAAI,EAAE,CAACkC,YAAAA,GAAAA;YACpCnC,CAAAA,KAAAA,CAAMsB,WAAW,IAAI,EAAC,EAAGwD,OAAO,CAAC,CAAC1C,UAAeF,GAAAA,gBAAAA,CAAiBC,YAAcC,EAAAA,UAAAA,CAAAA,CAAAA;AACnF,SAAA,CAAA;AACF,KAAA;AAEA;;MAGA,MAAMN,oBAAuB,GAAA,OAAO5B,aAAmCF,EAAAA,KAAAA,GAAAA;AACrE,QAAA,IAAI,CAACZ,EAAGwB,CAAAA,MAAM,CAACC,QAAQ,CAACF,cAAc,EAAE;AACtC,YAAA;AACF;;AAGA,QAAA,MAAMT,cAAcF,KAAK,CAACA,KAAMC,CAAAA,IAAI,EAAE,CAACkC,YAAAA,GAAAA;YACpCnC,CAAAA,KAAAA,CAAMsB,WAAW,IAAI,EAAC,EAAGwD,OAAO,CAAC,CAAC1C,UAAeU,GAAAA,cAAAA,CAAeX,YAAcC,EAAAA,UAAAA,CAAAA,CAAAA;AACjF,SAAA,CAAA;AACF,KAAA;AAEA;;MAGA,MAAMT,oBAAuB,GAAA,OAC3BsE,SACAC,EAAAA,UAAAA,GAAAA;QAEA,IAAI;YACF,MAAMC,UAAAA,GAAa/G,GAAGyD,aAAa,EAAA;AACnC,YAAA,MAAMuD,SAAS,MAAMhH,EAAAA,CAAGQ,UAAU,CAAC8E,GAAG,CACpC;;;;;UAKE,EAAEyB,UAAAA,GAAa,yBAAyB,EAAG;;AAE/C,MAAA,CAAC,EACCA,UAAa,GAAA;AAACF,gBAAAA,SAAAA;AAAWC,gBAAAA,UAAAA;AAAYC,gBAAAA;aAAW,GAAG;AAACF,gBAAAA,SAAAA;AAAWC,gBAAAA;AAAW,aAAA,CAAA;AAG5E,YAAA,OAAOE,OAAOC,IAAI,GAAG,CAAA,CAAE,EAAEC,SAAa,IAAA,IAAA;AACxC,SAAA,CAAE,OAAOC,KAAO,EAAA;;AAEdrH,YAAAA,KAAAA,CACE,CAAC,8BAA8B,EAAE+G,SAAU,CAAA,CAAC,EAAEC,UAAW,CAAA,EAAE,EAAEK,KAAAA,YAAiBC,QAAQD,KAAME,CAAAA,OAAO,GAAGC,MAAAA,CAAOH,OAAO,CAAC,CAAA;YAEvH,OAAO,IAAA;AACT;AACF,KAAA;AAEA;;AAEC,MACD,MAAMI,qBAAAA,GAAwB,OAC5BnH,GAAAA,EACAyG,WACAC,UACAnC,EAAAA,MAAAA,GAAAA;;QAGA,IAAIA,MAAAA,CAAOI,WAAW,EAAE;AACtB,YAAA,MAAM3E,IAAIkF,GAAG,CAAC,CAAC,2CAA2C,CAAC,EAAE;AAACuB,gBAAAA,SAAAA;AAAWC,gBAAAA;AAAW,aAAA,CAAA;SAC/E,MAAA;AACL,YAAA,MAAM1G,IAAIkF,GAAG,CAAC,CAAC,4CAA4C,CAAC,EAAE;AAACuB,gBAAAA,SAAAA;AAAWC,gBAAAA;AAAW,aAAA,CAAA;AACvF;;QAGA,IAAInC,MAAAA,CAAOE,SAAS,KAAK2C,SAAW,EAAA;AAClC,YAAA,MAAM,CAACC,YAAcC,EAAAA,WAAAA,CAAY,GAAGtC,WAAAA,CAAUT,OAAOE,SAAS,CAAA;YAC9D,IAAIQ,MAAAA,CAAK,SAASqC,WAAc,CAAA,EAAA;gBAC9B,MAAMtH,GAAAA,CAAIkF,GAAG,CAAC,CAAC,2CAA2C,EAAEmC,YAAAA,CAAa,CAAC,EAAE;AAC1EZ,oBAAAA,SAAAA;AACAC,oBAAAA;AACD,iBAAA,CAAA;aACI,MAAA;;AAEL,gBAAA,MAAMa,cACJ,GAAA,OAAOF,YAAiB,KAAA,QAAA,GAAW,CAAC,CAAC,EAAEA,YAAaG,CAAAA,OAAO,CAAC,IAAA,EAAM,IAAM,CAAA,CAAA,CAAC,CAAC,GAAGH,YAAAA;gBAC/E,MAAMrH,GAAAA,CAAIkF,GAAG,CAAC,CAAC,2CAA2C,EAAEqC,cAAAA,CAAe,CAAC,EAAE;AAC5Ed,oBAAAA,SAAAA;AACAC,oBAAAA;AACD,iBAAA,CAAA;AACH;AACF;AACF,KAAA;AAEA;;AAEC,MACD,MAAMnE,4BAA+B,GAAA,OACnCvC,KACAQ,KACAiH,EAAAA,oBAAAA,GAAsD,EAAE,GAAA;;AAGxD,QAAA,IAAI7H,GAAGwB,MAAM,CAAChB,UAAU,CAAC4B,MAAM,KAAK,UAAY,EAAA;AAC9C,YAAA;AACF;AAEA,QAAA,MAAM0F,qBAAqB,EAAE;;AAG7B,QAAA,KAAK,MAAMzF,aAAiBzB,IAAAA,KAAAA,CAAM0B,OAAO,CAACR,OAAO,CAAE;AACjD,YAAA,MAAM,EAAEjB,IAAMiG,EAAAA,UAAU,EAAEd,MAAQrB,EAAAA,MAAM,EAAE,GAAGtC,aAAAA;;YAG7C,MAAM0F,WAAAA,GACJF,oBAAoB,CAACf,UAAAA,CAAW,IAAK,MAAMvE,oBAAAA,CAAqB3B,KAAMC,CAAAA,IAAI,EAAEiG,UAAAA,CAAAA;AAE9E,YAAA,IAAIiB,WAAa,EAAA;;gBAEf,MAAMC,aAAAA,GAAgBhI,GAAG0B,OAAO,CAACuG,0BAA0B,CAACF,WAAAA,EAAapD,OAAOV,IAAI,CAAA;AAEpF,gBAAA,IAAI+D,aAAe,EAAA;AACjBF,oBAAAA,kBAAAA,CAAmBhC,IAAI,CAAC;wBACtBnB,MAAQtC,EAAAA,aAAAA;AACR6F,wBAAAA,GAAAA,EAAKF,cAAcE,GAAG;wBACtBC,MAAQ,EAAA;AAACvH,4BAAAA,KAAAA,CAAMC,IAAI;AAAEiG,4BAAAA,UAAAA;AAAYA,4BAAAA;AAAW,yBAAA;AAC5CiB,wBAAAA,WAAAA;AACAK,wBAAAA,UAAAA,EAAYzD,OAAOV,IAAI;AACvBoE,wBAAAA,OAAAA,EAASL,cAAcK;AACzB,qBAAA,CAAA;AACF;AACF;AACF;;QAGA,KAAK,MAAMC,cAAcR,kBAAoB,CAAA;AAC3C,YAAA,MAAM,EAAEnD,MAAM,EAAEuD,GAAG,EAAEC,MAAM,EAAEJ,WAAW,EAAEK,UAAU,EAAEC,OAAO,EAAE,GAAGC,UAAAA;;AAGlE,YAAA,MAAMC,iBAAiBF,OAAW,IAAA,6CAAA;YAClCrI,EAAGwI,CAAAA,MAAM,CAACC,IAAI,CACZ,CAAC,2BAA2B,EAAE7H,KAAAA,CAAMC,IAAI,CAAC,CAAC,EAAE8D,OAAO9D,IAAI,CAAC,QAAQ,EAAEkH,WAAY,CAAA,MAAM,EAAEK,UAAW,CAAA,GAAG,EAAEG,cAAAA,CAAe,CAAC,CAAA;YAGxHzI,KAAM,CAAA,CAAC,4CAA4C,EAAE6E,MAAO9D,CAAAA,IAAI,CAAC,IAAI,EAAED,KAAAA,CAAMC,IAAI,CAAC,CAAC,CAAA;YACnFf,KAAM,CAAA,CAAC,eAAe,EAAEoI,GAAI,CAAA,cAAc,EAAEQ,IAAKC,CAAAA,SAAS,CAACR,MAAAA,CAAAA,CAAQ,CAAC,CAAA;YAEpE,IAAI;;gBAEF,MAAM/H,GAAAA,CAAIkF,GAAG,CAAC4C,GAAKC,EAAAA,MAAAA,CAAAA;AACnBrI,gBAAAA,KAAAA,CAAM,CAAC,uBAAuB,EAAE6E,MAAAA,CAAO9D,IAAI,CAAC,MAAM,EAAEkH,WAAY,CAAA,IAAI,EAAEK,UAAAA,CAAW,CAAC,CAAA;AACpF,aAAA,CAAE,OAAOQ,eAAiB,EAAA;AACxB5I,gBAAAA,EAAAA,CAAGwI,MAAM,CAACrB,KAAK,CACb,CAAC,yBAAyB,EAAExC,MAAO9D,CAAAA,IAAI,CAAC,EAAE,EAAE+H,2BAA2BxB,KAAQwB,GAAAA,eAAAA,CAAgBvB,OAAO,GAAGC,MAAAA,CAAOsB,iBAAiB,CAAC,CAAA;gBAEpI,MAAMA,eAAAA;AACR;;YAGA,MAAMrB,qBAAAA,CAAsBnH,KAAKQ,KAAMC,CAAAA,IAAI,EAAE8D,MAAO9D,CAAAA,IAAI,EAAE8D,MAAAA,CAAOqB,MAAM,CAAA;;AAGvEpF,YAAAA,KAAAA,CAAM0B,OAAO,CAACR,OAAO,GAAGlB,KAAAA,CAAM0B,OAAO,CAACR,OAAO,CAACmE,MAAM,CAAC,CAACjB,GAAAA,GAAQA,IAAInE,IAAI,KAAK8D,OAAO9D,IAAI,CAAA;AACxF;AACF,KAAA;IAEA,OAAO;AACLE,QAAAA,WAAAA;AACA6B,QAAAA,UAAAA;AACAxB,QAAAA,SAAAA;AACAJ,QAAAA,sBAAAA;AACA0B,QAAAA,oBAAAA;AACAC,QAAAA,4BAAAA;AACAJ,QAAAA;AACF,KAAA;AACF,CAAA;;;;"}
1
+ {"version":3,"file":"builder.js","sources":["../../src/schema/builder.ts"],"sourcesContent":["import { isNil, prop, omit, castArray } from 'lodash/fp';\nimport createDebug from 'debug';\n\nimport type { Knex } from 'knex';\nimport type { Database } from '..';\nimport type { Schema, Table, SchemaDiff, TableDiff, ForeignKey, Index, Column } from './types';\n\nconst debug = createDebug('strapi::database');\n\nexport default (db: Database) => {\n const helpers = createHelpers(db);\n\n return {\n /**\n * Returns a knex schema builder instance\n * @param {string} table - table name\n */\n getSchemaBuilder(trx: Knex.Transaction) {\n return db.getSchemaConnection(trx);\n },\n\n /**\n * Creates schema in DB\n */\n async createSchema(schema: Schema) {\n await db.connection.transaction(async (trx) => {\n await this.createTables(schema.tables, trx);\n });\n },\n\n /**\n * Creates a list of tables in a schema\n * @param {KnexInstance} trx\n * @param {Table[]} tables\n */\n async createTables(tables: Table[], trx: Knex.Transaction) {\n for (const table of tables) {\n debug(`Creating table: ${table.name}`);\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.createTable(schemaBuilder, table);\n }\n\n // create FKs once all the tables exist\n for (const table of tables) {\n debug(`Creating table foreign keys: ${table.name}`);\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.createTableForeignKeys(schemaBuilder, table);\n }\n },\n /**\n * Drops schema from DB\n */\n async dropSchema(schema: Schema, { dropDatabase = false } = {}) {\n if (dropDatabase) {\n // TODO: drop database & return as it will drop everything\n return;\n }\n\n await db.connection.transaction(async (trx) => {\n for (const table of schema.tables.reverse()) {\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.dropTable(schemaBuilder, table);\n }\n });\n },\n\n /**\n * Applies a schema diff update in the DB\n * @param {*} schemaDiff\n */\n // TODO: implement force option to disable removal in DB\n async updateSchema(schemaDiff: SchemaDiff['diff']) {\n const forceMigration = db.config.settings?.forceMigration;\n\n await db.dialect.startSchemaUpdate();\n\n // Pre-fetch metadata for all updated tables\n const existingMetadata: Record<string, { indexes: Index[]; foreignKeys: ForeignKey[] }> = {};\n const columnTypes: Record<string, Record<string, string | null>> = {};\n\n for (const table of schemaDiff.tables.updated) {\n existingMetadata[table.name] = {\n indexes: await db.dialect.schemaInspector.getIndexes(table.name),\n foreignKeys: await db.dialect.schemaInspector.getForeignKeys(table.name),\n };\n\n // Pre-fetch column types for PostgreSQL to avoid transaction timeouts\n if (db.config.connection.client === 'postgres') {\n columnTypes[table.name] = {};\n for (const updatedColumn of table.columns.updated) {\n columnTypes[table.name][updatedColumn.name] = await helpers.getCurrentColumnType(\n table.name,\n updatedColumn.name\n );\n }\n }\n }\n\n await db.connection.transaction(async (trx) => {\n await this.createTables(schemaDiff.tables.added, trx);\n\n if (forceMigration) {\n // drop all delete table foreign keys then delete the tables\n for (const table of schemaDiff.tables.removed) {\n debug(`Removing table foreign keys: ${table.name}`);\n\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.dropTableForeignKeys(schemaBuilder, table);\n }\n\n for (const table of schemaDiff.tables.removed) {\n debug(`Removing table: ${table.name}`);\n\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.dropTable(schemaBuilder, table);\n }\n }\n\n for (const table of schemaDiff.tables.updated) {\n debug(`Updating table: ${table.name}`);\n\n // Handle special type conversions before standard alterations\n await helpers.handleSpecialTypeConversions(trx, table, columnTypes[table.name] || {});\n\n // alter table\n const schemaBuilder = this.getSchemaBuilder(trx);\n\n const { indexes, foreignKeys } = existingMetadata[table.name];\n await helpers.alterTable(schemaBuilder, table, { indexes, foreignKeys });\n }\n });\n\n await db.dialect.endSchemaUpdate();\n },\n };\n};\n\nconst createHelpers = (db: Database) => {\n /**\n * Creates a foreign key on a table\n */\n const createForeignKey = (tableBuilder: Knex.TableBuilder, foreignKey: ForeignKey) => {\n const { name, columns, referencedColumns, referencedTable, onDelete, onUpdate } = foreignKey;\n\n const constraint = tableBuilder\n .foreign(columns, name)\n .references(referencedColumns)\n .inTable(db.getSchemaName() ? `${db.getSchemaName()}.${referencedTable}` : referencedTable);\n\n if (onDelete) {\n constraint.onDelete(onDelete);\n }\n\n if (onUpdate) {\n constraint.onUpdate(onUpdate);\n }\n };\n\n /**\n * Drops a foreign key from a table\n */\n const dropForeignKey = (\n tableBuilder: Knex.TableBuilder,\n foreignKey: ForeignKey,\n existingForeignKeys?: ForeignKey[]\n ) => {\n const { name, columns } = foreignKey;\n\n // Check if the index exists in existingIndexes, and return early if it doesn't\n if (\n existingForeignKeys &&\n !existingForeignKeys.some((existingIndex) => existingIndex?.name === name)\n ) {\n debug(`Foreign Key ${name} not found in existing foreign keys. Skipping drop.`);\n return;\n }\n\n tableBuilder.dropForeign(columns, name);\n };\n\n /**\n * Creates an index on a table\n */\n const createIndex = (tableBuilder: Knex.TableBuilder, index: Index) => {\n const { type, columns, name } = index;\n\n switch (type) {\n case 'primary': {\n return tableBuilder.primary(columns, { constraintName: name });\n }\n case 'unique': {\n return tableBuilder.unique(columns, { indexName: name });\n }\n default: {\n return tableBuilder.index(columns, name, type);\n }\n }\n };\n\n /**\n * Drops an index from table\n * @param {Knex.TableBuilder} tableBuilder\n * @param {Index} index\n */\n const dropIndex = (tableBuilder: Knex.TableBuilder, index: Index, existingIndexes?: Index[]) => {\n if (!db.config.settings?.forceMigration) {\n return;\n }\n\n const { type, columns, name } = index;\n\n // Check if the index exists in existingIndexes, and return early if it doesn't\n if (existingIndexes && !existingIndexes.some((existingIndex) => existingIndex?.name === name)) {\n debug(`Index ${index.name} not found in existingIndexes. Skipping drop.`);\n return;\n }\n\n switch (type) {\n case 'primary': {\n return tableBuilder.dropPrimary(name);\n }\n case 'unique': {\n return tableBuilder.dropUnique(columns, name);\n }\n default: {\n return tableBuilder.dropIndex(columns, name);\n }\n }\n };\n\n /**\n * Creates a column in a table\n */\n const createColumn = (tableBuilder: Knex.TableBuilder, column: Column) => {\n const { type, name, args = [], defaultTo, unsigned, notNullable } = column;\n\n const col = (tableBuilder[type as keyof Knex.TableBuilder] as any)(name, ...args);\n\n if (unsigned === true) {\n col.unsigned();\n }\n\n if (!isNil(defaultTo)) {\n const [value, opts] = castArray(defaultTo);\n\n if (prop('isRaw', opts)) {\n col.defaultTo(db.connection.raw(value), omit('isRaw', opts));\n } else {\n col.defaultTo(value, opts);\n }\n }\n\n if (notNullable === true) {\n col.notNullable();\n } else {\n col.nullable();\n }\n\n return col;\n };\n\n /**\n * Drops a column from a table\n */\n const dropColumn = (tableBuilder: Knex.TableBuilder, column: Column) => {\n if (!db.config.settings?.forceMigration) {\n return;\n }\n\n return tableBuilder.dropColumn(column.name);\n };\n\n /**\n * Creates a table in a database\n */\n const createTable = async (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n await schemaBuilder.createTable(table.name, (tableBuilder) => {\n // columns\n (table.columns || []).forEach((column) => createColumn(tableBuilder, column));\n\n // indexes\n (table.indexes || []).forEach((index) => createIndex(tableBuilder, index));\n\n // foreign keys\n\n if (!db.dialect.canAlterConstraints()) {\n (table.foreignKeys || []).forEach((foreignKey) =>\n createForeignKey(tableBuilder, foreignKey)\n );\n }\n });\n };\n\n /**\n * Alters a database table by applying a set of schema changes including updates to columns, indexes, and foreign keys.\n * This function ensures proper ordering of operations to avoid conflicts (e.g., foreign key errors) and handles\n * MySQL-specific quirks where dropping a foreign key can implicitly drop an associated index.\n *\n * @param {Knex.SchemaBuilder} schemaBuilder - Knex SchemaBuilder instance to perform schema operations.\n * @param {TableDiff['diff']} table - A diff object representing the schema changes to be applied to the table.\n * @param {{ indexes: Index[]; foreignKeys: ForeignKey[] }} existingMetadata - Metadata about existing indexes and\n * foreign keys in the table. Used to ensure safe operations and avoid unnecessary modifications.\n * - indexes: Array of existing index definitions.\n * - foreignKeys: Array of existing foreign key definitions.\n */\n const alterTable = async (\n schemaBuilder: Knex.SchemaBuilder,\n table: TableDiff['diff'],\n existingMetadata: { indexes: Index[]; foreignKeys: ForeignKey[] } = {\n indexes: [],\n foreignKeys: [],\n }\n ) => {\n let existingIndexes = [...existingMetadata.indexes];\n const existingForeignKeys = [...existingMetadata.foreignKeys];\n\n // Track dropped foreign keys\n const droppedForeignKeyNames: string[] = [];\n\n await schemaBuilder.alterTable(table.name, async (tableBuilder) => {\n // Drop foreign keys first to avoid foreign key errors in the following steps\n for (const removedForeignKey of table.foreignKeys.removed) {\n debug(`Dropping foreign key ${removedForeignKey.name} on ${table.name}`);\n dropForeignKey(tableBuilder, removedForeignKey, existingForeignKeys);\n\n droppedForeignKeyNames.push(removedForeignKey.name);\n }\n\n for (const updatedForeignKey of table.foreignKeys.updated) {\n debug(`Dropping updated foreign key ${updatedForeignKey.name} on ${table.name}`);\n dropForeignKey(tableBuilder, updatedForeignKey.object, existingForeignKeys);\n\n droppedForeignKeyNames.push(updatedForeignKey.object.name);\n }\n\n // In MySQL, dropping a foreign key can also implicitly drop an index with the same name\n // Remove dropped foreign keys from existingIndexes for MySQL\n if (db.config.connection.client === 'mysql') {\n existingIndexes = existingIndexes.filter(\n (index) => !droppedForeignKeyNames.includes(index.name)\n );\n }\n\n for (const removedIndex of table.indexes.removed) {\n debug(`Dropping index ${removedIndex.name} on ${table.name}`);\n dropIndex(tableBuilder, removedIndex, existingIndexes);\n }\n\n for (const updatedIndex of table.indexes.updated) {\n debug(`Dropping updated index ${updatedIndex.name} on ${table.name}`);\n dropIndex(tableBuilder, updatedIndex.object, existingIndexes);\n }\n\n // Drop columns after FKs have been removed to avoid FK errors\n for (const removedColumn of table.columns.removed) {\n debug(`Dropping column ${removedColumn.name} on ${table.name}`);\n dropColumn(tableBuilder, removedColumn);\n }\n\n // Update existing columns\n for (const updatedColumn of table.columns.updated) {\n debug(`Updating column ${updatedColumn.name} on ${table.name}`);\n\n const { object } = updatedColumn;\n\n if (object.type === 'increments') {\n createColumn(tableBuilder, { ...object, type: 'integer' }).alter();\n } else {\n createColumn(tableBuilder, object).alter();\n }\n }\n\n // Add any new columns\n for (const addedColumn of table.columns.added) {\n debug(`Creating column ${addedColumn.name} on ${table.name}`);\n\n if (addedColumn.type === 'increments' && !db.dialect.canAddIncrements()) {\n tableBuilder.integer(addedColumn.name).unsigned();\n tableBuilder.primary([addedColumn.name]);\n } else {\n createColumn(tableBuilder, addedColumn);\n }\n }\n\n // once the columns have all been updated, we can create indexes again\n for (const updatedForeignKey of table.foreignKeys.updated) {\n debug(`Recreating updated foreign key ${updatedForeignKey.name} on ${table.name}`);\n createForeignKey(tableBuilder, updatedForeignKey.object);\n }\n\n for (const updatedIndex of table.indexes.updated) {\n debug(`Recreating updated index ${updatedIndex.name} on ${table.name}`);\n createIndex(tableBuilder, updatedIndex.object);\n }\n\n for (const addedForeignKey of table.foreignKeys.added) {\n debug(`Creating foreign key ${addedForeignKey.name} on ${table.name}`);\n createForeignKey(tableBuilder, addedForeignKey);\n }\n\n for (const addedIndex of table.indexes.added) {\n debug(`Creating index ${addedIndex.name} on ${table.name}`);\n createIndex(tableBuilder, addedIndex);\n }\n });\n };\n\n /**\n * Drops a table from a database\n */\n const dropTable = (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n if (!db.config.settings.forceMigration) {\n return;\n }\n\n return schemaBuilder.dropTableIfExists(table.name);\n };\n\n /**\n * Creates a table foreign keys constraints\n */\n const createTableForeignKeys = async (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n // foreign keys\n await schemaBuilder.table(table.name, (tableBuilder) => {\n (table.foreignKeys || []).forEach((foreignKey) => createForeignKey(tableBuilder, foreignKey));\n });\n };\n\n /**\n * Drops a table foreign keys constraints\n */\n const dropTableForeignKeys = async (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n if (!db.config.settings.forceMigration) {\n return;\n }\n\n // foreign keys\n await schemaBuilder.table(table.name, (tableBuilder) => {\n (table.foreignKeys || []).forEach((foreignKey) => dropForeignKey(tableBuilder, foreignKey));\n });\n };\n\n /**\n * Get the current column type from the database\n */\n const getCurrentColumnType = async (\n tableName: string,\n columnName: string\n ): Promise<string | null> => {\n try {\n const schemaName = db.getSchemaName();\n const result = await db.connection.raw(\n `\n SELECT data_type \n FROM information_schema.columns \n WHERE table_name = ? \n AND column_name = ?\n ${schemaName ? 'AND table_schema = ?' : ''}\n LIMIT 1\n `,\n schemaName ? [tableName, columnName, schemaName] : [tableName, columnName]\n );\n\n return result.rows?.[0]?.data_type || null;\n } catch (error) {\n // Log error but don't fail the migration\n debug(\n `Failed to get column type for ${tableName}.${columnName}: ${error instanceof Error ? error.message : String(error)}`\n );\n return null;\n }\n };\n\n /**\n * Apply column properties after type conversion\n */\n const applyColumnProperties = async (\n trx: Knex.Transaction,\n tableName: string,\n columnName: string,\n column: Column\n ) => {\n // Apply NOT NULL constraint\n if (column.notNullable) {\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? SET NOT NULL`, [tableName, columnName]);\n } else {\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? DROP NOT NULL`, [tableName, columnName]);\n }\n\n // Apply default value\n if (column.defaultTo !== undefined) {\n const [defaultValue, defaultOpts] = castArray(column.defaultTo);\n if (prop('isRaw', defaultOpts)) {\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? SET DEFAULT ${defaultValue}`, [\n tableName,\n columnName,\n ]);\n } else {\n // PostgreSQL doesn't support parameterized SET DEFAULT, so we need to escape the value\n const escapedDefault =\n typeof defaultValue === 'string' ? `'${defaultValue.replace(/'/g, \"''\")}'` : defaultValue;\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? SET DEFAULT ${escapedDefault}`, [\n tableName,\n columnName,\n ]);\n }\n }\n };\n\n /**\n * Handle special type conversions that require custom SQL\n */\n const handleSpecialTypeConversions = async (\n trx: Knex.Transaction,\n table: TableDiff['diff'],\n preloadedColumnTypes: Record<string, string | null> = {}\n ) => {\n // Only PostgreSQL needs special handling for now\n if (db.config.connection.client !== 'postgres') {\n return;\n }\n\n const conversionsToApply = [];\n\n // Check each updated column for special type conversions\n for (const updatedColumn of table.columns.updated) {\n const { name: columnName, object: column } = updatedColumn;\n\n // Use pre-loaded column type if available, otherwise fetch it\n const currentType =\n preloadedColumnTypes[columnName] ?? (await getCurrentColumnType(table.name, columnName));\n\n if (currentType) {\n // Check if dialect has special conversion SQL\n const conversionSQL = db.dialect.getColumnTypeConversionSQL(currentType, column.type);\n\n if (conversionSQL) {\n conversionsToApply.push({\n column: updatedColumn,\n sql: conversionSQL.sql,\n params: [table.name, columnName, columnName],\n currentType,\n targetType: column.type,\n warning: conversionSQL.warning,\n });\n }\n }\n }\n\n // Apply conversions\n for (const conversion of conversionsToApply) {\n const { column, sql, params, currentType, targetType, warning } = conversion;\n\n // Log warning about type conversion\n const warningMessage = warning || 'This conversion may result in data changes.';\n db.logger.warn(\n `Database type conversion: \"${table.name}.${column.name}\" from \"${currentType}\" to \"${targetType}\". ${warningMessage}`\n );\n\n debug(`Applying special type conversion for column ${column.name} on ${table.name}`);\n debug(`Executing SQL: ${sql} with params: ${JSON.stringify(params)}`);\n\n try {\n // Execute the conversion using the transaction connection\n await trx.raw(sql, params);\n debug(`Successfully converted ${column.name} from ${currentType} to ${targetType}`);\n } catch (conversionError) {\n db.logger.error(\n `Failed to convert column ${column.name}: ${conversionError instanceof Error ? conversionError.message : String(conversionError)}`\n );\n throw conversionError;\n }\n\n // Apply other column properties\n await applyColumnProperties(trx, table.name, column.name, column.object);\n\n // Remove from standard updates to prevent double processing\n table.columns.updated = table.columns.updated.filter((col) => col.name !== column.name);\n }\n };\n\n return {\n createTable,\n alterTable,\n dropTable,\n createTableForeignKeys,\n dropTableForeignKeys,\n handleSpecialTypeConversions,\n getCurrentColumnType,\n };\n};\n"],"names":["debug","createDebug","db","helpers","createHelpers","getSchemaBuilder","trx","getSchemaConnection","createSchema","schema","connection","transaction","createTables","tables","table","name","schemaBuilder","createTable","createTableForeignKeys","dropSchema","dropDatabase","reverse","dropTable","updateSchema","schemaDiff","forceMigration","config","settings","dialect","startSchemaUpdate","existingMetadata","columnTypes","updated","indexes","schemaInspector","getIndexes","foreignKeys","getForeignKeys","client","updatedColumn","columns","getCurrentColumnType","added","removed","dropTableForeignKeys","handleSpecialTypeConversions","alterTable","endSchemaUpdate","createForeignKey","tableBuilder","foreignKey","referencedColumns","referencedTable","onDelete","onUpdate","constraint","foreign","references","inTable","getSchemaName","dropForeignKey","existingForeignKeys","some","existingIndex","dropForeign","createIndex","index","type","primary","constraintName","unique","indexName","dropIndex","existingIndexes","dropPrimary","dropUnique","createColumn","column","args","defaultTo","unsigned","notNullable","col","isNil","value","opts","castArray","prop","raw","omit","nullable","dropColumn","forEach","canAlterConstraints","droppedForeignKeyNames","removedForeignKey","push","updatedForeignKey","object","filter","includes","removedIndex","updatedIndex","removedColumn","alter","addedColumn","canAddIncrements","integer","addedForeignKey","addedIndex","dropTableIfExists","tableName","columnName","schemaName","result","rows","data_type","error","Error","message","String","applyColumnProperties","undefined","defaultValue","defaultOpts","escapedDefault","replace","preloadedColumnTypes","conversionsToApply","currentType","conversionSQL","getColumnTypeConversionSQL","sql","params","targetType","warning","conversion","warningMessage","logger","warn","JSON","stringify","conversionError"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"builder.mjs","sources":["../../src/schema/builder.ts"],"sourcesContent":["import { isNil, prop, omit, castArray } from 'lodash/fp';\nimport createDebug from 'debug';\n\nimport type { Knex } from 'knex';\nimport type { Database } from '..';\nimport type { Schema, Table, SchemaDiff, TableDiff, ForeignKey, Index, Column } from './types';\n\nconst debug = createDebug('strapi::database');\n\nexport default (db: Database) => {\n const helpers = createHelpers(db);\n\n return {\n /**\n * Returns a knex schema builder instance\n * @param {string} table - table name\n */\n getSchemaBuilder(trx: Knex.Transaction) {\n return db.getSchemaConnection(trx);\n },\n\n /**\n * Creates schema in DB\n */\n async createSchema(schema: Schema) {\n await db.connection.transaction(async (trx) => {\n await this.createTables(schema.tables, trx);\n });\n },\n\n /**\n * Creates a list of tables in a schema\n * @param {KnexInstance} trx\n * @param {Table[]} tables\n */\n async createTables(tables: Table[], trx: Knex.Transaction) {\n for (const table of tables) {\n debug(`Creating table: ${table.name}`);\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.createTable(schemaBuilder, table);\n }\n\n // create FKs once all the tables exist\n for (const table of tables) {\n debug(`Creating table foreign keys: ${table.name}`);\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.createTableForeignKeys(schemaBuilder, table);\n }\n },\n /**\n * Drops schema from DB\n */\n async dropSchema(schema: Schema, { dropDatabase = false } = {}) {\n if (dropDatabase) {\n // TODO: drop database & return as it will drop everything\n return;\n }\n\n await db.connection.transaction(async (trx) => {\n for (const table of schema.tables.reverse()) {\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.dropTable(schemaBuilder, table);\n }\n });\n },\n\n /**\n * Applies a schema diff update in the DB\n * @param {*} schemaDiff\n */\n // TODO: implement force option to disable removal in DB\n async updateSchema(schemaDiff: SchemaDiff['diff']) {\n const forceMigration = db.config.settings?.forceMigration;\n\n await db.dialect.startSchemaUpdate();\n\n // Pre-fetch metadata for all updated tables\n const existingMetadata: Record<string, { indexes: Index[]; foreignKeys: ForeignKey[] }> = {};\n const columnTypes: Record<string, Record<string, string | null>> = {};\n\n for (const table of schemaDiff.tables.updated) {\n existingMetadata[table.name] = {\n indexes: await db.dialect.schemaInspector.getIndexes(table.name),\n foreignKeys: await db.dialect.schemaInspector.getForeignKeys(table.name),\n };\n\n // Pre-fetch column types for PostgreSQL to avoid transaction timeouts\n if (db.config.connection.client === 'postgres') {\n columnTypes[table.name] = {};\n for (const updatedColumn of table.columns.updated) {\n columnTypes[table.name][updatedColumn.name] = await helpers.getCurrentColumnType(\n table.name,\n updatedColumn.name\n );\n }\n }\n }\n\n await db.connection.transaction(async (trx) => {\n await this.createTables(schemaDiff.tables.added, trx);\n\n if (forceMigration) {\n // drop all delete table foreign keys then delete the tables\n for (const table of schemaDiff.tables.removed) {\n debug(`Removing table foreign keys: ${table.name}`);\n\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.dropTableForeignKeys(schemaBuilder, table);\n }\n\n for (const table of schemaDiff.tables.removed) {\n debug(`Removing table: ${table.name}`);\n\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.dropTable(schemaBuilder, table);\n }\n }\n\n for (const table of schemaDiff.tables.updated) {\n debug(`Updating table: ${table.name}`);\n\n // Handle special type conversions before standard alterations\n await helpers.handleSpecialTypeConversions(trx, table, columnTypes[table.name] || {});\n\n // alter table\n const schemaBuilder = this.getSchemaBuilder(trx);\n\n const { indexes, foreignKeys } = existingMetadata[table.name];\n await helpers.alterTable(schemaBuilder, table, { indexes, foreignKeys });\n }\n });\n\n await db.dialect.endSchemaUpdate();\n },\n };\n};\n\nconst createHelpers = (db: Database) => {\n /**\n * Creates a foreign key on a table\n */\n const createForeignKey = (tableBuilder: Knex.TableBuilder, foreignKey: ForeignKey) => {\n const { name, columns, referencedColumns, referencedTable, onDelete, onUpdate } = foreignKey;\n\n const constraint = tableBuilder\n .foreign(columns, name)\n .references(referencedColumns)\n .inTable(db.getSchemaName() ? `${db.getSchemaName()}.${referencedTable}` : referencedTable);\n\n if (onDelete) {\n constraint.onDelete(onDelete);\n }\n\n if (onUpdate) {\n constraint.onUpdate(onUpdate);\n }\n };\n\n /**\n * Drops a foreign key from a table\n */\n const dropForeignKey = (\n tableBuilder: Knex.TableBuilder,\n foreignKey: ForeignKey,\n existingForeignKeys?: ForeignKey[]\n ) => {\n const { name, columns } = foreignKey;\n\n // Check if the index exists in existingIndexes, and return early if it doesn't\n if (\n existingForeignKeys &&\n !existingForeignKeys.some((existingIndex) => existingIndex?.name === name)\n ) {\n debug(`Foreign Key ${name} not found in existing foreign keys. Skipping drop.`);\n return;\n }\n\n tableBuilder.dropForeign(columns, name);\n };\n\n /**\n * Creates an index on a table\n */\n const createIndex = (tableBuilder: Knex.TableBuilder, index: Index) => {\n const { type, columns, name } = index;\n\n switch (type) {\n case 'primary': {\n return tableBuilder.primary(columns, { constraintName: name });\n }\n case 'unique': {\n return tableBuilder.unique(columns, { indexName: name });\n }\n default: {\n return tableBuilder.index(columns, name, type);\n }\n }\n };\n\n /**\n * Drops an index from table\n * @param {Knex.TableBuilder} tableBuilder\n * @param {Index} index\n */\n const dropIndex = (tableBuilder: Knex.TableBuilder, index: Index, existingIndexes?: Index[]) => {\n if (!db.config.settings?.forceMigration) {\n return;\n }\n\n const { type, columns, name } = index;\n\n // Check if the index exists in existingIndexes, and return early if it doesn't\n if (existingIndexes && !existingIndexes.some((existingIndex) => existingIndex?.name === name)) {\n debug(`Index ${index.name} not found in existingIndexes. Skipping drop.`);\n return;\n }\n\n switch (type) {\n case 'primary': {\n return tableBuilder.dropPrimary(name);\n }\n case 'unique': {\n return tableBuilder.dropUnique(columns, name);\n }\n default: {\n return tableBuilder.dropIndex(columns, name);\n }\n }\n };\n\n /**\n * Creates a column in a table\n */\n const createColumn = (tableBuilder: Knex.TableBuilder, column: Column) => {\n const { type, name, args = [], defaultTo, unsigned, notNullable } = column;\n\n const col = (tableBuilder[type as keyof Knex.TableBuilder] as any)(name, ...args);\n\n if (unsigned === true) {\n col.unsigned();\n }\n\n if (!isNil(defaultTo)) {\n const [value, opts] = castArray(defaultTo);\n\n if (prop('isRaw', opts)) {\n col.defaultTo(db.connection.raw(value), omit('isRaw', opts));\n } else {\n col.defaultTo(value, opts);\n }\n }\n\n if (notNullable === true) {\n col.notNullable();\n } else {\n col.nullable();\n }\n\n return col;\n };\n\n /**\n * Drops a column from a table\n */\n const dropColumn = (tableBuilder: Knex.TableBuilder, column: Column) => {\n if (!db.config.settings?.forceMigration) {\n return;\n }\n\n return tableBuilder.dropColumn(column.name);\n };\n\n /**\n * Creates a table in a database\n */\n const createTable = async (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n await schemaBuilder.createTable(table.name, (tableBuilder) => {\n // columns\n (table.columns || []).forEach((column) => createColumn(tableBuilder, column));\n\n // indexes\n (table.indexes || []).forEach((index) => createIndex(tableBuilder, index));\n\n // foreign keys\n\n if (!db.dialect.canAlterConstraints()) {\n (table.foreignKeys || []).forEach((foreignKey) =>\n createForeignKey(tableBuilder, foreignKey)\n );\n }\n });\n };\n\n /**\n * Alters a database table by applying a set of schema changes including updates to columns, indexes, and foreign keys.\n * This function ensures proper ordering of operations to avoid conflicts (e.g., foreign key errors) and handles\n * MySQL-specific quirks where dropping a foreign key can implicitly drop an associated index.\n *\n * @param {Knex.SchemaBuilder} schemaBuilder - Knex SchemaBuilder instance to perform schema operations.\n * @param {TableDiff['diff']} table - A diff object representing the schema changes to be applied to the table.\n * @param {{ indexes: Index[]; foreignKeys: ForeignKey[] }} existingMetadata - Metadata about existing indexes and\n * foreign keys in the table. Used to ensure safe operations and avoid unnecessary modifications.\n * - indexes: Array of existing index definitions.\n * - foreignKeys: Array of existing foreign key definitions.\n */\n const alterTable = async (\n schemaBuilder: Knex.SchemaBuilder,\n table: TableDiff['diff'],\n existingMetadata: { indexes: Index[]; foreignKeys: ForeignKey[] } = {\n indexes: [],\n foreignKeys: [],\n }\n ) => {\n let existingIndexes = [...existingMetadata.indexes];\n const existingForeignKeys = [...existingMetadata.foreignKeys];\n\n // Track dropped foreign keys\n const droppedForeignKeyNames: string[] = [];\n\n await schemaBuilder.alterTable(table.name, async (tableBuilder) => {\n // Drop foreign keys first to avoid foreign key errors in the following steps\n for (const removedForeignKey of table.foreignKeys.removed) {\n debug(`Dropping foreign key ${removedForeignKey.name} on ${table.name}`);\n dropForeignKey(tableBuilder, removedForeignKey, existingForeignKeys);\n\n droppedForeignKeyNames.push(removedForeignKey.name);\n }\n\n for (const updatedForeignKey of table.foreignKeys.updated) {\n debug(`Dropping updated foreign key ${updatedForeignKey.name} on ${table.name}`);\n dropForeignKey(tableBuilder, updatedForeignKey.object, existingForeignKeys);\n\n droppedForeignKeyNames.push(updatedForeignKey.object.name);\n }\n\n // In MySQL, dropping a foreign key can also implicitly drop an index with the same name\n // Remove dropped foreign keys from existingIndexes for MySQL\n if (db.config.connection.client === 'mysql') {\n existingIndexes = existingIndexes.filter(\n (index) => !droppedForeignKeyNames.includes(index.name)\n );\n }\n\n for (const removedIndex of table.indexes.removed) {\n debug(`Dropping index ${removedIndex.name} on ${table.name}`);\n dropIndex(tableBuilder, removedIndex, existingIndexes);\n }\n\n for (const updatedIndex of table.indexes.updated) {\n debug(`Dropping updated index ${updatedIndex.name} on ${table.name}`);\n dropIndex(tableBuilder, updatedIndex.object, existingIndexes);\n }\n\n // Drop columns after FKs have been removed to avoid FK errors\n for (const removedColumn of table.columns.removed) {\n debug(`Dropping column ${removedColumn.name} on ${table.name}`);\n dropColumn(tableBuilder, removedColumn);\n }\n\n // Update existing columns\n for (const updatedColumn of table.columns.updated) {\n debug(`Updating column ${updatedColumn.name} on ${table.name}`);\n\n const { object } = updatedColumn;\n\n if (object.type === 'increments') {\n createColumn(tableBuilder, { ...object, type: 'integer' }).alter();\n } else {\n createColumn(tableBuilder, object).alter();\n }\n }\n\n // Add any new columns\n for (const addedColumn of table.columns.added) {\n debug(`Creating column ${addedColumn.name} on ${table.name}`);\n\n if (addedColumn.type === 'increments' && !db.dialect.canAddIncrements()) {\n tableBuilder.integer(addedColumn.name).unsigned();\n tableBuilder.primary([addedColumn.name]);\n } else {\n createColumn(tableBuilder, addedColumn);\n }\n }\n\n // once the columns have all been updated, we can create indexes again\n for (const updatedForeignKey of table.foreignKeys.updated) {\n debug(`Recreating updated foreign key ${updatedForeignKey.name} on ${table.name}`);\n createForeignKey(tableBuilder, updatedForeignKey.object);\n }\n\n for (const updatedIndex of table.indexes.updated) {\n debug(`Recreating updated index ${updatedIndex.name} on ${table.name}`);\n createIndex(tableBuilder, updatedIndex.object);\n }\n\n for (const addedForeignKey of table.foreignKeys.added) {\n debug(`Creating foreign key ${addedForeignKey.name} on ${table.name}`);\n createForeignKey(tableBuilder, addedForeignKey);\n }\n\n for (const addedIndex of table.indexes.added) {\n debug(`Creating index ${addedIndex.name} on ${table.name}`);\n createIndex(tableBuilder, addedIndex);\n }\n });\n };\n\n /**\n * Drops a table from a database\n */\n const dropTable = (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n if (!db.config.settings.forceMigration) {\n return;\n }\n\n return schemaBuilder.dropTableIfExists(table.name);\n };\n\n /**\n * Creates a table foreign keys constraints\n */\n const createTableForeignKeys = async (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n // foreign keys\n await schemaBuilder.table(table.name, (tableBuilder) => {\n (table.foreignKeys || []).forEach((foreignKey) => createForeignKey(tableBuilder, foreignKey));\n });\n };\n\n /**\n * Drops a table foreign keys constraints\n */\n const dropTableForeignKeys = async (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n if (!db.config.settings.forceMigration) {\n return;\n }\n\n // foreign keys\n await schemaBuilder.table(table.name, (tableBuilder) => {\n (table.foreignKeys || []).forEach((foreignKey) => dropForeignKey(tableBuilder, foreignKey));\n });\n };\n\n /**\n * Get the current column type from the database\n */\n const getCurrentColumnType = async (\n tableName: string,\n columnName: string\n ): Promise<string | null> => {\n try {\n const schemaName = db.getSchemaName();\n const result = await db.connection.raw(\n `\n SELECT data_type \n FROM information_schema.columns \n WHERE table_name = ? \n AND column_name = ?\n ${schemaName ? 'AND table_schema = ?' : ''}\n LIMIT 1\n `,\n schemaName ? [tableName, columnName, schemaName] : [tableName, columnName]\n );\n\n return result.rows?.[0]?.data_type || null;\n } catch (error) {\n // Log error but don't fail the migration\n debug(\n `Failed to get column type for ${tableName}.${columnName}: ${error instanceof Error ? error.message : String(error)}`\n );\n return null;\n }\n };\n\n /**\n * Apply column properties after type conversion\n */\n const applyColumnProperties = async (\n trx: Knex.Transaction,\n tableName: string,\n columnName: string,\n column: Column\n ) => {\n // Apply NOT NULL constraint\n if (column.notNullable) {\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? SET NOT NULL`, [tableName, columnName]);\n } else {\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? DROP NOT NULL`, [tableName, columnName]);\n }\n\n // Apply default value\n if (column.defaultTo !== undefined) {\n const [defaultValue, defaultOpts] = castArray(column.defaultTo);\n if (prop('isRaw', defaultOpts)) {\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? SET DEFAULT ${defaultValue}`, [\n tableName,\n columnName,\n ]);\n } else {\n // PostgreSQL doesn't support parameterized SET DEFAULT, so we need to escape the value\n const escapedDefault =\n typeof defaultValue === 'string' ? `'${defaultValue.replace(/'/g, \"''\")}'` : defaultValue;\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? SET DEFAULT ${escapedDefault}`, [\n tableName,\n columnName,\n ]);\n }\n }\n };\n\n /**\n * Handle special type conversions that require custom SQL\n */\n const handleSpecialTypeConversions = async (\n trx: Knex.Transaction,\n table: TableDiff['diff'],\n preloadedColumnTypes: Record<string, string | null> = {}\n ) => {\n // Only PostgreSQL needs special handling for now\n if (db.config.connection.client !== 'postgres') {\n return;\n }\n\n const conversionsToApply = [];\n\n // Check each updated column for special type conversions\n for (const updatedColumn of table.columns.updated) {\n const { name: columnName, object: column } = updatedColumn;\n\n // Use pre-loaded column type if available, otherwise fetch it\n const currentType =\n preloadedColumnTypes[columnName] ?? (await getCurrentColumnType(table.name, columnName));\n\n if (currentType) {\n // Check if dialect has special conversion SQL\n const conversionSQL = db.dialect.getColumnTypeConversionSQL(currentType, column.type);\n\n if (conversionSQL) {\n conversionsToApply.push({\n column: updatedColumn,\n sql: conversionSQL.sql,\n params: [table.name, columnName, columnName],\n currentType,\n targetType: column.type,\n warning: conversionSQL.warning,\n });\n }\n }\n }\n\n // Apply conversions\n for (const conversion of conversionsToApply) {\n const { column, sql, params, currentType, targetType, warning } = conversion;\n\n // Log warning about type conversion\n const warningMessage = warning || 'This conversion may result in data changes.';\n db.logger.warn(\n `Database type conversion: \"${table.name}.${column.name}\" from \"${currentType}\" to \"${targetType}\". ${warningMessage}`\n );\n\n debug(`Applying special type conversion for column ${column.name} on ${table.name}`);\n debug(`Executing SQL: ${sql} with params: ${JSON.stringify(params)}`);\n\n try {\n // Execute the conversion using the transaction connection\n await trx.raw(sql, params);\n debug(`Successfully converted ${column.name} from ${currentType} to ${targetType}`);\n } catch (conversionError) {\n db.logger.error(\n `Failed to convert column ${column.name}: ${conversionError instanceof Error ? conversionError.message : String(conversionError)}`\n );\n throw conversionError;\n }\n\n // Apply other column properties\n await applyColumnProperties(trx, table.name, column.name, column.object);\n\n // Remove from standard updates to prevent double processing\n table.columns.updated = table.columns.updated.filter((col) => col.name !== column.name);\n }\n };\n\n return {\n createTable,\n alterTable,\n dropTable,\n createTableForeignKeys,\n dropTableForeignKeys,\n handleSpecialTypeConversions,\n getCurrentColumnType,\n };\n};\n"],"names":["debug","createDebug","db","helpers","createHelpers","getSchemaBuilder","trx","getSchemaConnection","createSchema","schema","connection","transaction","createTables","tables","table","name","schemaBuilder","createTable","createTableForeignKeys","dropSchema","dropDatabase","reverse","dropTable","updateSchema","schemaDiff","forceMigration","config","settings","dialect","startSchemaUpdate","existingMetadata","columnTypes","updated","indexes","schemaInspector","getIndexes","foreignKeys","getForeignKeys","client","updatedColumn","columns","getCurrentColumnType","added","removed","dropTableForeignKeys","handleSpecialTypeConversions","alterTable","endSchemaUpdate","createForeignKey","tableBuilder","foreignKey","referencedColumns","referencedTable","onDelete","onUpdate","constraint","foreign","references","inTable","getSchemaName","dropForeignKey","existingForeignKeys","some","existingIndex","dropForeign","createIndex","index","type","primary","constraintName","unique","indexName","dropIndex","existingIndexes","dropPrimary","dropUnique","createColumn","column","args","defaultTo","unsigned","notNullable","col","isNil","value","opts","castArray","prop","raw","omit","nullable","dropColumn","forEach","canAlterConstraints","droppedForeignKeyNames","removedForeignKey","push","updatedForeignKey","object","filter","includes","removedIndex","updatedIndex","removedColumn","alter","addedColumn","canAddIncrements","integer","addedForeignKey","addedIndex","dropTableIfExists","tableName","columnName","schemaName","result","rows","data_type","error","Error","message","String","applyColumnProperties","undefined","defaultValue","defaultOpts","escapedDefault","replace","preloadedColumnTypes","conversionsToApply","currentType","conversionSQL","getColumnTypeConversionSQL","sql","params","targetType","warning","conversion","warningMessage","logger","warn","JSON","stringify","conversionError"],"mappings":"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"}
1
+ {"version":3,"file":"builder.mjs","sources":["../../src/schema/builder.ts"],"sourcesContent":["import { isNil, prop, omit, castArray } from 'lodash/fp';\nimport createDebug from 'debug';\n\nimport type { Knex } from 'knex';\nimport type { Database } from '..';\nimport type { Schema, Table, SchemaDiff, TableDiff, ForeignKey, Index, Column } from './types';\n\nconst debug = createDebug('strapi::database');\n\nexport default (db: Database) => {\n const helpers = createHelpers(db);\n\n return {\n /**\n * Returns a knex schema builder instance\n * @param {string} table - table name\n */\n getSchemaBuilder(trx: Knex.Transaction) {\n return db.getSchemaConnection(trx);\n },\n\n /**\n * Creates schema in DB\n */\n async createSchema(schema: Schema) {\n await db.connection.transaction(async (trx) => {\n await this.createTables(schema.tables, trx);\n });\n },\n\n /**\n * Creates a list of tables in a schema\n * @param {KnexInstance} trx\n * @param {Table[]} tables\n */\n async createTables(tables: Table[], trx: Knex.Transaction) {\n for (const table of tables) {\n debug(`Creating table: ${table.name}`);\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.createTable(schemaBuilder, table);\n }\n\n // create FKs once all the tables exist\n for (const table of tables) {\n debug(`Creating table foreign keys: ${table.name}`);\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.createTableForeignKeys(schemaBuilder, table);\n }\n },\n /**\n * Drops schema from DB\n */\n async dropSchema(schema: Schema, { dropDatabase = false } = {}) {\n if (dropDatabase) {\n // TODO: drop database & return as it will drop everything\n return;\n }\n\n await db.connection.transaction(async (trx) => {\n for (const table of schema.tables.reverse()) {\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.dropTable(schemaBuilder, table);\n }\n });\n },\n\n /**\n * Applies a schema diff update in the DB\n * @param {*} schemaDiff\n */\n // TODO: implement force option to disable removal in DB\n async updateSchema(schemaDiff: SchemaDiff['diff']) {\n const forceMigration = db.config.settings?.forceMigration;\n\n await db.dialect.startSchemaUpdate();\n\n // Pre-fetch metadata for all updated tables\n const existingMetadata: Record<string, { indexes: Index[]; foreignKeys: ForeignKey[] }> = {};\n const columnTypes: Record<string, Record<string, string | null>> = {};\n\n for (const table of schemaDiff.tables.updated) {\n existingMetadata[table.name] = {\n indexes: await db.dialect.schemaInspector.getIndexes(table.name),\n foreignKeys: await db.dialect.schemaInspector.getForeignKeys(table.name),\n };\n\n // Pre-fetch column types for PostgreSQL to avoid transaction timeouts\n if (db.config.connection.client === 'postgres') {\n columnTypes[table.name] = {};\n for (const updatedColumn of table.columns.updated) {\n columnTypes[table.name][updatedColumn.name] = await helpers.getCurrentColumnType(\n table.name,\n updatedColumn.name\n );\n }\n }\n }\n\n await db.connection.transaction(async (trx) => {\n await this.createTables(schemaDiff.tables.added, trx);\n\n if (forceMigration) {\n // drop all delete table foreign keys then delete the tables\n for (const table of schemaDiff.tables.removed) {\n debug(`Removing table foreign keys: ${table.name}`);\n\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.dropTableForeignKeys(schemaBuilder, table);\n }\n\n for (const table of schemaDiff.tables.removed) {\n debug(`Removing table: ${table.name}`);\n\n const schemaBuilder = this.getSchemaBuilder(trx);\n await helpers.dropTable(schemaBuilder, table);\n }\n }\n\n for (const table of schemaDiff.tables.updated) {\n debug(`Updating table: ${table.name}`);\n\n // Handle special type conversions before standard alterations\n await helpers.handleSpecialTypeConversions(trx, table, columnTypes[table.name] || {});\n\n // alter table\n const schemaBuilder = this.getSchemaBuilder(trx);\n\n const { indexes, foreignKeys } = existingMetadata[table.name];\n await helpers.alterTable(schemaBuilder, table, { indexes, foreignKeys });\n }\n });\n\n await db.dialect.endSchemaUpdate();\n },\n };\n};\n\nconst createHelpers = (db: Database) => {\n /**\n * Creates a foreign key on a table\n */\n const createForeignKey = (tableBuilder: Knex.TableBuilder, foreignKey: ForeignKey) => {\n const { name, columns, referencedColumns, referencedTable, onDelete, onUpdate } = foreignKey;\n\n const constraint = tableBuilder\n .foreign(columns, name)\n .references(referencedColumns)\n .inTable(db.getSchemaName() ? `${db.getSchemaName()}.${referencedTable}` : referencedTable);\n\n if (onDelete) {\n constraint.onDelete(onDelete);\n }\n\n if (onUpdate) {\n constraint.onUpdate(onUpdate);\n }\n };\n\n /**\n * Drops a foreign key from a table\n */\n const dropForeignKey = (\n tableBuilder: Knex.TableBuilder,\n foreignKey: ForeignKey,\n existingForeignKeys?: ForeignKey[]\n ) => {\n const { name, columns } = foreignKey;\n\n // Check if the index exists in existingIndexes, and return early if it doesn't\n if (\n existingForeignKeys &&\n !existingForeignKeys.some((existingIndex) => existingIndex?.name === name)\n ) {\n debug(`Foreign Key ${name} not found in existing foreign keys. Skipping drop.`);\n return;\n }\n\n tableBuilder.dropForeign(columns, name);\n };\n\n /**\n * Creates an index on a table\n */\n const createIndex = (tableBuilder: Knex.TableBuilder, index: Index) => {\n const { type, columns, name } = index;\n\n switch (type) {\n case 'primary': {\n return tableBuilder.primary(columns, { constraintName: name });\n }\n case 'unique': {\n return tableBuilder.unique(columns, { indexName: name });\n }\n default: {\n return tableBuilder.index(columns, name, type);\n }\n }\n };\n\n /**\n * Drops an index from table\n * @param {Knex.TableBuilder} tableBuilder\n * @param {Index} index\n */\n const dropIndex = (tableBuilder: Knex.TableBuilder, index: Index, existingIndexes?: Index[]) => {\n if (!db.config.settings?.forceMigration) {\n return;\n }\n\n const { type, columns, name } = index;\n\n // Check if the index exists in existingIndexes, and return early if it doesn't\n if (existingIndexes && !existingIndexes.some((existingIndex) => existingIndex?.name === name)) {\n debug(`Index ${index.name} not found in existingIndexes. Skipping drop.`);\n return;\n }\n\n switch (type) {\n case 'primary': {\n return tableBuilder.dropPrimary(name);\n }\n case 'unique': {\n return tableBuilder.dropUnique(columns, name);\n }\n default: {\n return tableBuilder.dropIndex(columns, name);\n }\n }\n };\n\n /**\n * Creates a column in a table\n */\n const createColumn = (tableBuilder: Knex.TableBuilder, column: Column) => {\n const { type, name, args = [], defaultTo, unsigned, notNullable } = column;\n\n const col = (tableBuilder[type as keyof Knex.TableBuilder] as any)(name, ...args);\n\n if (unsigned === true) {\n col.unsigned();\n }\n\n if (!isNil(defaultTo)) {\n const [value, opts] = castArray(defaultTo);\n\n if (prop('isRaw', opts)) {\n col.defaultTo(db.connection.raw(value), omit('isRaw', opts));\n } else {\n col.defaultTo(value, opts);\n }\n }\n\n if (notNullable === true) {\n col.notNullable();\n } else {\n col.nullable();\n }\n\n return col;\n };\n\n /**\n * Drops a column from a table\n */\n const dropColumn = (tableBuilder: Knex.TableBuilder, column: Column) => {\n if (!db.config.settings?.forceMigration) {\n return;\n }\n\n return tableBuilder.dropColumn(column.name);\n };\n\n /**\n * Creates a table in a database\n */\n const createTable = async (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n await schemaBuilder.createTable(table.name, (tableBuilder) => {\n // columns\n (table.columns || []).forEach((column) => createColumn(tableBuilder, column));\n\n // indexes\n (table.indexes || []).forEach((index) => createIndex(tableBuilder, index));\n\n // foreign keys\n\n if (!db.dialect.canAlterConstraints()) {\n (table.foreignKeys || []).forEach((foreignKey) =>\n createForeignKey(tableBuilder, foreignKey)\n );\n }\n });\n };\n\n /**\n * Alters a database table by applying a set of schema changes including updates to columns, indexes, and foreign keys.\n * This function ensures proper ordering of operations to avoid conflicts (e.g., foreign key errors) and handles\n * MySQL-specific quirks where dropping a foreign key can implicitly drop an associated index.\n *\n * @param {Knex.SchemaBuilder} schemaBuilder - Knex SchemaBuilder instance to perform schema operations.\n * @param {TableDiff['diff']} table - A diff object representing the schema changes to be applied to the table.\n * @param {{ indexes: Index[]; foreignKeys: ForeignKey[] }} existingMetadata - Metadata about existing indexes and\n * foreign keys in the table. Used to ensure safe operations and avoid unnecessary modifications.\n * - indexes: Array of existing index definitions.\n * - foreignKeys: Array of existing foreign key definitions.\n */\n const alterTable = async (\n schemaBuilder: Knex.SchemaBuilder,\n table: TableDiff['diff'],\n existingMetadata: { indexes: Index[]; foreignKeys: ForeignKey[] } = {\n indexes: [],\n foreignKeys: [],\n }\n ) => {\n let existingIndexes = [...existingMetadata.indexes];\n const existingForeignKeys = [...existingMetadata.foreignKeys];\n\n // Track dropped foreign keys\n const droppedForeignKeyNames: string[] = [];\n\n await schemaBuilder.alterTable(table.name, async (tableBuilder) => {\n // Drop foreign keys first to avoid foreign key errors in the following steps\n for (const removedForeignKey of table.foreignKeys.removed) {\n debug(`Dropping foreign key ${removedForeignKey.name} on ${table.name}`);\n dropForeignKey(tableBuilder, removedForeignKey, existingForeignKeys);\n\n droppedForeignKeyNames.push(removedForeignKey.name);\n }\n\n for (const updatedForeignKey of table.foreignKeys.updated) {\n debug(`Dropping updated foreign key ${updatedForeignKey.name} on ${table.name}`);\n dropForeignKey(tableBuilder, updatedForeignKey.object, existingForeignKeys);\n\n droppedForeignKeyNames.push(updatedForeignKey.object.name);\n }\n\n // In MySQL, dropping a foreign key can also implicitly drop an index with the same name\n // Remove dropped foreign keys from existingIndexes for MySQL\n if (db.config.connection.client === 'mysql') {\n existingIndexes = existingIndexes.filter(\n (index) => !droppedForeignKeyNames.includes(index.name)\n );\n }\n\n for (const removedIndex of table.indexes.removed) {\n debug(`Dropping index ${removedIndex.name} on ${table.name}`);\n dropIndex(tableBuilder, removedIndex, existingIndexes);\n }\n\n for (const updatedIndex of table.indexes.updated) {\n debug(`Dropping updated index ${updatedIndex.name} on ${table.name}`);\n dropIndex(tableBuilder, updatedIndex.object, existingIndexes);\n }\n\n // Drop columns after FKs have been removed to avoid FK errors\n for (const removedColumn of table.columns.removed) {\n debug(`Dropping column ${removedColumn.name} on ${table.name}`);\n dropColumn(tableBuilder, removedColumn);\n }\n\n // Update existing columns\n for (const updatedColumn of table.columns.updated) {\n debug(`Updating column ${updatedColumn.name} on ${table.name}`);\n\n const { object } = updatedColumn;\n\n if (object.type === 'increments') {\n createColumn(tableBuilder, { ...object, type: 'integer' }).alter();\n } else {\n createColumn(tableBuilder, object).alter();\n }\n }\n\n // Add any new columns\n for (const addedColumn of table.columns.added) {\n debug(`Creating column ${addedColumn.name} on ${table.name}`);\n\n if (addedColumn.type === 'increments' && !db.dialect.canAddIncrements()) {\n tableBuilder.integer(addedColumn.name).unsigned();\n tableBuilder.primary([addedColumn.name]);\n } else {\n createColumn(tableBuilder, addedColumn);\n }\n }\n\n // once the columns have all been updated, we can create indexes again\n for (const updatedForeignKey of table.foreignKeys.updated) {\n debug(`Recreating updated foreign key ${updatedForeignKey.name} on ${table.name}`);\n createForeignKey(tableBuilder, updatedForeignKey.object);\n }\n\n for (const updatedIndex of table.indexes.updated) {\n debug(`Recreating updated index ${updatedIndex.name} on ${table.name}`);\n createIndex(tableBuilder, updatedIndex.object);\n }\n\n for (const addedForeignKey of table.foreignKeys.added) {\n debug(`Creating foreign key ${addedForeignKey.name} on ${table.name}`);\n createForeignKey(tableBuilder, addedForeignKey);\n }\n\n for (const addedIndex of table.indexes.added) {\n debug(`Creating index ${addedIndex.name} on ${table.name}`);\n createIndex(tableBuilder, addedIndex);\n }\n });\n };\n\n /**\n * Drops a table from a database\n */\n const dropTable = (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n if (!db.config.settings.forceMigration) {\n return;\n }\n\n return schemaBuilder.dropTableIfExists(table.name);\n };\n\n /**\n * Creates a table foreign keys constraints\n */\n const createTableForeignKeys = async (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n // foreign keys\n await schemaBuilder.table(table.name, (tableBuilder) => {\n (table.foreignKeys || []).forEach((foreignKey) => createForeignKey(tableBuilder, foreignKey));\n });\n };\n\n /**\n * Drops a table foreign keys constraints\n */\n const dropTableForeignKeys = async (schemaBuilder: Knex.SchemaBuilder, table: Table) => {\n if (!db.config.settings.forceMigration) {\n return;\n }\n\n // foreign keys\n await schemaBuilder.table(table.name, (tableBuilder) => {\n (table.foreignKeys || []).forEach((foreignKey) => dropForeignKey(tableBuilder, foreignKey));\n });\n };\n\n /**\n * Get the current column type from the database\n */\n const getCurrentColumnType = async (\n tableName: string,\n columnName: string\n ): Promise<string | null> => {\n try {\n const schemaName = db.getSchemaName();\n const result = await db.connection.raw(\n `\n SELECT data_type \n FROM information_schema.columns \n WHERE table_name = ? \n AND column_name = ?\n ${schemaName ? 'AND table_schema = ?' : ''}\n LIMIT 1\n `,\n schemaName ? [tableName, columnName, schemaName] : [tableName, columnName]\n );\n\n return result.rows?.[0]?.data_type || null;\n } catch (error) {\n // Log error but don't fail the migration\n debug(\n `Failed to get column type for ${tableName}.${columnName}: ${error instanceof Error ? error.message : String(error)}`\n );\n return null;\n }\n };\n\n /**\n * Apply column properties after type conversion\n */\n const applyColumnProperties = async (\n trx: Knex.Transaction,\n tableName: string,\n columnName: string,\n column: Column\n ) => {\n // Apply NOT NULL constraint\n if (column.notNullable) {\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? SET NOT NULL`, [tableName, columnName]);\n } else {\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? DROP NOT NULL`, [tableName, columnName]);\n }\n\n // Apply default value\n if (column.defaultTo !== undefined) {\n const [defaultValue, defaultOpts] = castArray(column.defaultTo);\n if (prop('isRaw', defaultOpts)) {\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? SET DEFAULT ${defaultValue}`, [\n tableName,\n columnName,\n ]);\n } else {\n // PostgreSQL doesn't support parameterized SET DEFAULT, so we need to escape the value\n const escapedDefault =\n typeof defaultValue === 'string' ? `'${defaultValue.replace(/'/g, \"''\")}'` : defaultValue;\n await trx.raw(`ALTER TABLE ?? ALTER COLUMN ?? SET DEFAULT ${escapedDefault}`, [\n tableName,\n columnName,\n ]);\n }\n }\n };\n\n /**\n * Handle special type conversions that require custom SQL\n */\n const handleSpecialTypeConversions = async (\n trx: Knex.Transaction,\n table: TableDiff['diff'],\n preloadedColumnTypes: Record<string, string | null> = {}\n ) => {\n // Only PostgreSQL needs special handling for now\n if (db.config.connection.client !== 'postgres') {\n return;\n }\n\n const conversionsToApply = [];\n\n // Check each updated column for special type conversions\n for (const updatedColumn of table.columns.updated) {\n const { name: columnName, object: column } = updatedColumn;\n\n // Use pre-loaded column type if available, otherwise fetch it\n const currentType =\n preloadedColumnTypes[columnName] ?? (await getCurrentColumnType(table.name, columnName));\n\n if (currentType) {\n // Check if dialect has special conversion SQL\n const conversionSQL = db.dialect.getColumnTypeConversionSQL(currentType, column.type);\n\n if (conversionSQL) {\n conversionsToApply.push({\n column: updatedColumn,\n sql: conversionSQL.sql,\n params: [table.name, columnName, columnName],\n currentType,\n targetType: column.type,\n warning: conversionSQL.warning,\n });\n }\n }\n }\n\n // Apply conversions\n for (const conversion of conversionsToApply) {\n const { column, sql, params, currentType, targetType, warning } = conversion;\n\n // Log warning about type conversion\n const warningMessage = warning || 'This conversion may result in data changes.';\n db.logger.warn(\n `Database type conversion: \"${table.name}.${column.name}\" from \"${currentType}\" to \"${targetType}\". ${warningMessage}`\n );\n\n debug(`Applying special type conversion for column ${column.name} on ${table.name}`);\n debug(`Executing SQL: ${sql} with params: ${JSON.stringify(params)}`);\n\n try {\n // Execute the conversion using the transaction connection\n await trx.raw(sql, params);\n debug(`Successfully converted ${column.name} from ${currentType} to ${targetType}`);\n } catch (conversionError) {\n db.logger.error(\n `Failed to convert column ${column.name}: ${conversionError instanceof Error ? conversionError.message : String(conversionError)}`\n );\n throw conversionError;\n }\n\n // Apply other column properties\n await applyColumnProperties(trx, table.name, column.name, column.object);\n\n // Remove from standard updates to prevent double processing\n table.columns.updated = table.columns.updated.filter((col) => col.name !== column.name);\n }\n };\n\n return {\n createTable,\n alterTable,\n dropTable,\n createTableForeignKeys,\n dropTableForeignKeys,\n handleSpecialTypeConversions,\n getCurrentColumnType,\n };\n};\n"],"names":["debug","createDebug","db","helpers","createHelpers","getSchemaBuilder","trx","getSchemaConnection","createSchema","schema","connection","transaction","createTables","tables","table","name","schemaBuilder","createTable","createTableForeignKeys","dropSchema","dropDatabase","reverse","dropTable","updateSchema","schemaDiff","forceMigration","config","settings","dialect","startSchemaUpdate","existingMetadata","columnTypes","updated","indexes","schemaInspector","getIndexes","foreignKeys","getForeignKeys","client","updatedColumn","columns","getCurrentColumnType","added","removed","dropTableForeignKeys","handleSpecialTypeConversions","alterTable","endSchemaUpdate","createForeignKey","tableBuilder","foreignKey","referencedColumns","referencedTable","onDelete","onUpdate","constraint","foreign","references","inTable","getSchemaName","dropForeignKey","existingForeignKeys","some","existingIndex","dropForeign","createIndex","index","type","primary","constraintName","unique","indexName","dropIndex","existingIndexes","dropPrimary","dropUnique","createColumn","column","args","defaultTo","unsigned","notNullable","col","isNil","value","opts","castArray","prop","raw","omit","nullable","dropColumn","forEach","canAlterConstraints","droppedForeignKeyNames","removedForeignKey","push","updatedForeignKey","object","filter","includes","removedIndex","updatedIndex","removedColumn","alter","addedColumn","canAddIncrements","integer","addedForeignKey","addedIndex","dropTableIfExists","tableName","columnName","schemaName","result","rows","data_type","error","Error","message","String","applyColumnProperties","undefined","defaultValue","defaultOpts","escapedDefault","replace","preloadedColumnTypes","conversionsToApply","currentType","conversionSQL","getColumnTypeConversionSQL","sql","params","targetType","warning","conversion","warningMessage","logger","warn","JSON","stringify","conversionError"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"schema.js","sources":["../../src/schema/schema.ts"],"sourcesContent":["import * as types from '../utils/types';\nimport { identifiers } from '../utils/identifiers';\nimport type { Metadata, Meta } from '../metadata';\nimport type { Column, Schema, Table } from './types';\nimport type { Attribute } from '../types';\n\n/**\n * TODO: This needs to be refactored to support incoming names such as\n * (column, table, index) that are of the form string | NameToken[] so\n * that pieces can be passed through and shortened here.\n *\n * Currently, we are potentially shortening twice, although in reality\n * that won't happen since the shortened attribute column names will\n * fit here because they are already shortened to the max identifier\n * length\n *\n * That is the reason we use getName() here and not getColumnName();\n * we just want the exact shortened name for the value without doing\n * any other potential manipulation to it\n * */\n\nconst createColumn = (name: string, attribute: Attribute): Column => {\n const { type, args = [], ...opts } = getColumnType(attribute);\n\n return {\n name: identifiers.getName(name),\n type,\n args,\n defaultTo: null,\n notNullable: false,\n unsigned: false,\n ...opts,\n ...('column' in attribute ? (attribute.column ?? {}) : {}),\n };\n};\n\nconst createTable = (meta: Meta): Table => {\n const table: Table = {\n name: meta.tableName,\n indexes: meta.indexes || [],\n foreignKeys: meta.foreignKeys || [],\n columns: [],\n };\n\n for (const key of Object.keys(meta.attributes)) {\n const attribute = meta.attributes[key];\n\n // if (types.isRelation(attribute.type)) {\n if (attribute.type === 'relation') {\n if ('morphColumn' in attribute && attribute.morphColumn && attribute.owner) {\n const { idColumn, typeColumn } = attribute.morphColumn;\n\n const idColumnName = identifiers.getName(idColumn.name);\n const typeColumnName = identifiers.getName(typeColumn.name);\n\n table.columns.push(\n createColumn(idColumnName, {\n type: 'integer',\n column: {\n unsigned: true,\n },\n })\n );\n\n table.columns.push(createColumn(typeColumnName, { type: 'string' }));\n } else if (\n 'joinColumn' in attribute &&\n attribute.joinColumn &&\n attribute.owner &&\n attribute.joinColumn.referencedTable\n ) {\n // NOTE: we could pass uniquness for oneToOne to avoid creating more than one to one\n\n const {\n name: columnNameFull,\n referencedColumn,\n referencedTable,\n columnType = 'integer',\n } = attribute.joinColumn;\n\n const columnName = identifiers.getName(columnNameFull);\n\n const column = createColumn(columnName, {\n // TODO: find the column type automatically, or allow passing all the column params\n type: columnType,\n column: {\n unsigned: true,\n },\n });\n\n table.columns.push(column);\n\n const fkName = identifiers.getFkIndexName([table.name, columnName]);\n table.foreignKeys.push({\n name: fkName,\n columns: [column.name],\n referencedTable,\n referencedColumns: [referencedColumn],\n // NOTE: could allow configuration\n onDelete: 'SET NULL',\n });\n\n table.indexes.push({\n name: fkName,\n columns: [column.name],\n });\n }\n } else if (types.isScalarAttribute(attribute)) {\n const columnName = identifiers.getName(attribute.columnName || key);\n\n const column = createColumn(columnName, attribute);\n\n if (column.unique) {\n table.indexes.push({\n type: 'unique',\n name: identifiers.getUniqueIndexName([table.name, column.name]),\n columns: [columnName],\n });\n }\n\n if (column.primary) {\n table.indexes.push({\n type: 'primary',\n name: identifiers.getPrimaryIndexName([table.name, column.name]),\n columns: [columnName],\n });\n }\n\n table.columns.push(column);\n }\n }\n\n return table;\n};\n\nconst getColumnType = (attribute: Attribute) => {\n if ('columnType' in attribute && attribute.columnType) {\n return attribute.columnType;\n }\n\n switch (attribute.type) {\n case 'increments': {\n return {\n type: 'increments',\n args: [{ primary: true, primaryKey: true }],\n notNullable: true,\n };\n }\n\n // We might want to convert email/password to string types before going into the orm with specific validators & transformers\n case 'password':\n case 'email':\n case 'string':\n case 'enumeration': {\n return { type: 'string' };\n }\n case 'uid': {\n return {\n type: 'string',\n };\n }\n case 'richtext':\n case 'text': {\n return {\n type: 'text',\n args: ['longtext'],\n };\n }\n case 'blocks':\n case 'json': {\n return { type: 'jsonb' };\n }\n case 'integer': {\n return { type: 'integer' };\n }\n case 'biginteger': {\n return { type: 'bigInteger' };\n }\n case 'float': {\n return { type: 'double' };\n }\n case 'decimal': {\n return { type: 'decimal', args: [10, 2] };\n }\n case 'date': {\n return { type: 'date' };\n }\n case 'time': {\n return { type: 'time', args: [{ precision: 3 }] };\n }\n case 'datetime': {\n return {\n type: 'datetime',\n args: [\n {\n useTz: false,\n precision: 6,\n },\n ],\n };\n }\n case 'timestamp': {\n return {\n type: 'timestamp',\n args: [\n {\n useTz: false,\n precision: 6,\n },\n ],\n };\n }\n case 'boolean': {\n return { type: 'boolean' };\n }\n default: {\n throw new Error(`Unknown type ${attribute.type}`);\n }\n }\n};\n\nexport const metadataToSchema = (metadata: Metadata): Schema => {\n const schema: Schema = {\n tables: [],\n };\n\n metadata.forEach((metadata) => {\n schema.tables.push(createTable(metadata));\n });\n\n return schema;\n};\n"],"names":["createColumn","name","attribute","type","args","opts","getColumnType","identifiers","getName","defaultTo","notNullable","unsigned","column","createTable","meta","table","tableName","indexes","foreignKeys","columns","key","Object","keys","attributes","morphColumn","owner","idColumn","typeColumn","idColumnName","typeColumnName","push","joinColumn","referencedTable","columnNameFull","referencedColumn","columnType","columnName","fkName","getFkIndexName","referencedColumns","onDelete","types","unique","getUniqueIndexName","primary","getPrimaryIndexName","primaryKey","precision","useTz","Error","metadataToSchema","metadata","schema","tables","forEach"],"mappings":"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"}
1
+ {"version":3,"file":"schema.js","sources":["../../src/schema/schema.ts"],"sourcesContent":["import * as types from '../utils/types';\nimport { identifiers } from '../utils/identifiers';\nimport type { Metadata, Meta } from '../metadata';\nimport type { Column, Schema, Table } from './types';\nimport type { Attribute } from '../types';\n\n/**\n * TODO: This needs to be refactored to support incoming names such as\n * (column, table, index) that are of the form string | NameToken[] so\n * that pieces can be passed through and shortened here.\n *\n * Currently, we are potentially shortening twice, although in reality\n * that won't happen since the shortened attribute column names will\n * fit here because they are already shortened to the max identifier\n * length\n *\n * That is the reason we use getName() here and not getColumnName();\n * we just want the exact shortened name for the value without doing\n * any other potential manipulation to it\n * */\n\nconst createColumn = (name: string, attribute: Attribute): Column => {\n const { type, args = [], ...opts } = getColumnType(attribute);\n\n return {\n name: identifiers.getName(name),\n type,\n args,\n defaultTo: null,\n notNullable: false,\n unsigned: false,\n ...opts,\n ...('column' in attribute ? (attribute.column ?? {}) : {}),\n };\n};\n\nconst createTable = (meta: Meta): Table => {\n const table: Table = {\n name: meta.tableName,\n indexes: meta.indexes || [],\n foreignKeys: meta.foreignKeys || [],\n columns: [],\n };\n\n for (const key of Object.keys(meta.attributes)) {\n const attribute = meta.attributes[key];\n\n // if (types.isRelation(attribute.type)) {\n if (attribute.type === 'relation') {\n if ('morphColumn' in attribute && attribute.morphColumn && attribute.owner) {\n const { idColumn, typeColumn } = attribute.morphColumn;\n\n const idColumnName = identifiers.getName(idColumn.name);\n const typeColumnName = identifiers.getName(typeColumn.name);\n\n table.columns.push(\n createColumn(idColumnName, {\n type: 'integer',\n column: {\n unsigned: true,\n },\n })\n );\n\n table.columns.push(createColumn(typeColumnName, { type: 'string' }));\n } else if (\n 'joinColumn' in attribute &&\n attribute.joinColumn &&\n attribute.owner &&\n attribute.joinColumn.referencedTable\n ) {\n // NOTE: we could pass uniquness for oneToOne to avoid creating more than one to one\n\n const {\n name: columnNameFull,\n referencedColumn,\n referencedTable,\n columnType = 'integer',\n } = attribute.joinColumn;\n\n const columnName = identifiers.getName(columnNameFull);\n\n const column = createColumn(columnName, {\n // TODO: find the column type automatically, or allow passing all the column params\n type: columnType,\n column: {\n unsigned: true,\n },\n });\n\n table.columns.push(column);\n\n const fkName = identifiers.getFkIndexName([table.name, columnName]);\n table.foreignKeys.push({\n name: fkName,\n columns: [column.name],\n referencedTable,\n referencedColumns: [referencedColumn],\n // NOTE: could allow configuration\n onDelete: 'SET NULL',\n });\n\n table.indexes.push({\n name: fkName,\n columns: [column.name],\n });\n }\n } else if (types.isScalarAttribute(attribute)) {\n const columnName = identifiers.getName(attribute.columnName || key);\n\n const column = createColumn(columnName, attribute);\n\n if (column.unique) {\n table.indexes.push({\n type: 'unique',\n name: identifiers.getUniqueIndexName([table.name, column.name]),\n columns: [columnName],\n });\n }\n\n if (column.primary) {\n table.indexes.push({\n type: 'primary',\n name: identifiers.getPrimaryIndexName([table.name, column.name]),\n columns: [columnName],\n });\n }\n\n table.columns.push(column);\n }\n }\n\n return table;\n};\n\nconst getColumnType = (attribute: Attribute) => {\n if ('columnType' in attribute && attribute.columnType) {\n return attribute.columnType;\n }\n\n switch (attribute.type) {\n case 'increments': {\n return {\n type: 'increments',\n args: [{ primary: true, primaryKey: true }],\n notNullable: true,\n };\n }\n\n // We might want to convert email/password to string types before going into the orm with specific validators & transformers\n case 'password':\n case 'email':\n case 'string':\n case 'enumeration': {\n return { type: 'string' };\n }\n case 'uid': {\n return {\n type: 'string',\n };\n }\n case 'richtext':\n case 'text': {\n return {\n type: 'text',\n args: ['longtext'],\n };\n }\n case 'blocks':\n case 'json': {\n return { type: 'jsonb' };\n }\n case 'integer': {\n return { type: 'integer' };\n }\n case 'biginteger': {\n return { type: 'bigInteger' };\n }\n case 'float': {\n return { type: 'double' };\n }\n case 'decimal': {\n return { type: 'decimal', args: [10, 2] };\n }\n case 'date': {\n return { type: 'date' };\n }\n case 'time': {\n return { type: 'time', args: [{ precision: 3 }] };\n }\n case 'datetime': {\n return {\n type: 'datetime',\n args: [\n {\n useTz: false,\n precision: 6,\n },\n ],\n };\n }\n case 'timestamp': {\n return {\n type: 'timestamp',\n args: [\n {\n useTz: false,\n precision: 6,\n },\n ],\n };\n }\n case 'boolean': {\n return { type: 'boolean' };\n }\n default: {\n throw new Error(`Unknown type ${attribute.type}`);\n }\n }\n};\n\nexport const metadataToSchema = (metadata: Metadata): Schema => {\n const schema: Schema = {\n tables: [],\n };\n\n metadata.forEach((metadata) => {\n schema.tables.push(createTable(metadata));\n });\n\n return schema;\n};\n"],"names":["createColumn","name","attribute","type","args","opts","getColumnType","identifiers","getName","defaultTo","notNullable","unsigned","column","createTable","meta","table","tableName","indexes","foreignKeys","columns","key","Object","keys","attributes","morphColumn","owner","idColumn","typeColumn","idColumnName","typeColumnName","push","joinColumn","referencedTable","columnNameFull","referencedColumn","columnType","columnName","fkName","getFkIndexName","referencedColumns","onDelete","types","unique","getUniqueIndexName","primary","getPrimaryIndexName","primaryKey","precision","useTz","Error","metadataToSchema","metadata","schema","tables","forEach"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"schema.mjs","sources":["../../src/schema/schema.ts"],"sourcesContent":["import * as types from '../utils/types';\nimport { identifiers } from '../utils/identifiers';\nimport type { Metadata, Meta } from '../metadata';\nimport type { Column, Schema, Table } from './types';\nimport type { Attribute } from '../types';\n\n/**\n * TODO: This needs to be refactored to support incoming names such as\n * (column, table, index) that are of the form string | NameToken[] so\n * that pieces can be passed through and shortened here.\n *\n * Currently, we are potentially shortening twice, although in reality\n * that won't happen since the shortened attribute column names will\n * fit here because they are already shortened to the max identifier\n * length\n *\n * That is the reason we use getName() here and not getColumnName();\n * we just want the exact shortened name for the value without doing\n * any other potential manipulation to it\n * */\n\nconst createColumn = (name: string, attribute: Attribute): Column => {\n const { type, args = [], ...opts } = getColumnType(attribute);\n\n return {\n name: identifiers.getName(name),\n type,\n args,\n defaultTo: null,\n notNullable: false,\n unsigned: false,\n ...opts,\n ...('column' in attribute ? (attribute.column ?? {}) : {}),\n };\n};\n\nconst createTable = (meta: Meta): Table => {\n const table: Table = {\n name: meta.tableName,\n indexes: meta.indexes || [],\n foreignKeys: meta.foreignKeys || [],\n columns: [],\n };\n\n for (const key of Object.keys(meta.attributes)) {\n const attribute = meta.attributes[key];\n\n // if (types.isRelation(attribute.type)) {\n if (attribute.type === 'relation') {\n if ('morphColumn' in attribute && attribute.morphColumn && attribute.owner) {\n const { idColumn, typeColumn } = attribute.morphColumn;\n\n const idColumnName = identifiers.getName(idColumn.name);\n const typeColumnName = identifiers.getName(typeColumn.name);\n\n table.columns.push(\n createColumn(idColumnName, {\n type: 'integer',\n column: {\n unsigned: true,\n },\n })\n );\n\n table.columns.push(createColumn(typeColumnName, { type: 'string' }));\n } else if (\n 'joinColumn' in attribute &&\n attribute.joinColumn &&\n attribute.owner &&\n attribute.joinColumn.referencedTable\n ) {\n // NOTE: we could pass uniquness for oneToOne to avoid creating more than one to one\n\n const {\n name: columnNameFull,\n referencedColumn,\n referencedTable,\n columnType = 'integer',\n } = attribute.joinColumn;\n\n const columnName = identifiers.getName(columnNameFull);\n\n const column = createColumn(columnName, {\n // TODO: find the column type automatically, or allow passing all the column params\n type: columnType,\n column: {\n unsigned: true,\n },\n });\n\n table.columns.push(column);\n\n const fkName = identifiers.getFkIndexName([table.name, columnName]);\n table.foreignKeys.push({\n name: fkName,\n columns: [column.name],\n referencedTable,\n referencedColumns: [referencedColumn],\n // NOTE: could allow configuration\n onDelete: 'SET NULL',\n });\n\n table.indexes.push({\n name: fkName,\n columns: [column.name],\n });\n }\n } else if (types.isScalarAttribute(attribute)) {\n const columnName = identifiers.getName(attribute.columnName || key);\n\n const column = createColumn(columnName, attribute);\n\n if (column.unique) {\n table.indexes.push({\n type: 'unique',\n name: identifiers.getUniqueIndexName([table.name, column.name]),\n columns: [columnName],\n });\n }\n\n if (column.primary) {\n table.indexes.push({\n type: 'primary',\n name: identifiers.getPrimaryIndexName([table.name, column.name]),\n columns: [columnName],\n });\n }\n\n table.columns.push(column);\n }\n }\n\n return table;\n};\n\nconst getColumnType = (attribute: Attribute) => {\n if ('columnType' in attribute && attribute.columnType) {\n return attribute.columnType;\n }\n\n switch (attribute.type) {\n case 'increments': {\n return {\n type: 'increments',\n args: [{ primary: true, primaryKey: true }],\n notNullable: true,\n };\n }\n\n // We might want to convert email/password to string types before going into the orm with specific validators & transformers\n case 'password':\n case 'email':\n case 'string':\n case 'enumeration': {\n return { type: 'string' };\n }\n case 'uid': {\n return {\n type: 'string',\n };\n }\n case 'richtext':\n case 'text': {\n return {\n type: 'text',\n args: ['longtext'],\n };\n }\n case 'blocks':\n case 'json': {\n return { type: 'jsonb' };\n }\n case 'integer': {\n return { type: 'integer' };\n }\n case 'biginteger': {\n return { type: 'bigInteger' };\n }\n case 'float': {\n return { type: 'double' };\n }\n case 'decimal': {\n return { type: 'decimal', args: [10, 2] };\n }\n case 'date': {\n return { type: 'date' };\n }\n case 'time': {\n return { type: 'time', args: [{ precision: 3 }] };\n }\n case 'datetime': {\n return {\n type: 'datetime',\n args: [\n {\n useTz: false,\n precision: 6,\n },\n ],\n };\n }\n case 'timestamp': {\n return {\n type: 'timestamp',\n args: [\n {\n useTz: false,\n precision: 6,\n },\n ],\n };\n }\n case 'boolean': {\n return { type: 'boolean' };\n }\n default: {\n throw new Error(`Unknown type ${attribute.type}`);\n }\n }\n};\n\nexport const metadataToSchema = (metadata: Metadata): Schema => {\n const schema: Schema = {\n tables: [],\n };\n\n metadata.forEach((metadata) => {\n schema.tables.push(createTable(metadata));\n });\n\n return schema;\n};\n"],"names":["createColumn","name","attribute","type","args","opts","getColumnType","identifiers","getName","defaultTo","notNullable","unsigned","column","createTable","meta","table","tableName","indexes","foreignKeys","columns","key","Object","keys","attributes","morphColumn","owner","idColumn","typeColumn","idColumnName","typeColumnName","push","joinColumn","referencedTable","columnNameFull","referencedColumn","columnType","columnName","fkName","getFkIndexName","referencedColumns","onDelete","types","unique","getUniqueIndexName","primary","getPrimaryIndexName","primaryKey","precision","useTz","Error","metadataToSchema","metadata","schema","tables","forEach"],"mappings":"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"}
1
+ {"version":3,"file":"schema.mjs","sources":["../../src/schema/schema.ts"],"sourcesContent":["import * as types from '../utils/types';\nimport { identifiers } from '../utils/identifiers';\nimport type { Metadata, Meta } from '../metadata';\nimport type { Column, Schema, Table } from './types';\nimport type { Attribute } from '../types';\n\n/**\n * TODO: This needs to be refactored to support incoming names such as\n * (column, table, index) that are of the form string | NameToken[] so\n * that pieces can be passed through and shortened here.\n *\n * Currently, we are potentially shortening twice, although in reality\n * that won't happen since the shortened attribute column names will\n * fit here because they are already shortened to the max identifier\n * length\n *\n * That is the reason we use getName() here and not getColumnName();\n * we just want the exact shortened name for the value without doing\n * any other potential manipulation to it\n * */\n\nconst createColumn = (name: string, attribute: Attribute): Column => {\n const { type, args = [], ...opts } = getColumnType(attribute);\n\n return {\n name: identifiers.getName(name),\n type,\n args,\n defaultTo: null,\n notNullable: false,\n unsigned: false,\n ...opts,\n ...('column' in attribute ? (attribute.column ?? {}) : {}),\n };\n};\n\nconst createTable = (meta: Meta): Table => {\n const table: Table = {\n name: meta.tableName,\n indexes: meta.indexes || [],\n foreignKeys: meta.foreignKeys || [],\n columns: [],\n };\n\n for (const key of Object.keys(meta.attributes)) {\n const attribute = meta.attributes[key];\n\n // if (types.isRelation(attribute.type)) {\n if (attribute.type === 'relation') {\n if ('morphColumn' in attribute && attribute.morphColumn && attribute.owner) {\n const { idColumn, typeColumn } = attribute.morphColumn;\n\n const idColumnName = identifiers.getName(idColumn.name);\n const typeColumnName = identifiers.getName(typeColumn.name);\n\n table.columns.push(\n createColumn(idColumnName, {\n type: 'integer',\n column: {\n unsigned: true,\n },\n })\n );\n\n table.columns.push(createColumn(typeColumnName, { type: 'string' }));\n } else if (\n 'joinColumn' in attribute &&\n attribute.joinColumn &&\n attribute.owner &&\n attribute.joinColumn.referencedTable\n ) {\n // NOTE: we could pass uniquness for oneToOne to avoid creating more than one to one\n\n const {\n name: columnNameFull,\n referencedColumn,\n referencedTable,\n columnType = 'integer',\n } = attribute.joinColumn;\n\n const columnName = identifiers.getName(columnNameFull);\n\n const column = createColumn(columnName, {\n // TODO: find the column type automatically, or allow passing all the column params\n type: columnType,\n column: {\n unsigned: true,\n },\n });\n\n table.columns.push(column);\n\n const fkName = identifiers.getFkIndexName([table.name, columnName]);\n table.foreignKeys.push({\n name: fkName,\n columns: [column.name],\n referencedTable,\n referencedColumns: [referencedColumn],\n // NOTE: could allow configuration\n onDelete: 'SET NULL',\n });\n\n table.indexes.push({\n name: fkName,\n columns: [column.name],\n });\n }\n } else if (types.isScalarAttribute(attribute)) {\n const columnName = identifiers.getName(attribute.columnName || key);\n\n const column = createColumn(columnName, attribute);\n\n if (column.unique) {\n table.indexes.push({\n type: 'unique',\n name: identifiers.getUniqueIndexName([table.name, column.name]),\n columns: [columnName],\n });\n }\n\n if (column.primary) {\n table.indexes.push({\n type: 'primary',\n name: identifiers.getPrimaryIndexName([table.name, column.name]),\n columns: [columnName],\n });\n }\n\n table.columns.push(column);\n }\n }\n\n return table;\n};\n\nconst getColumnType = (attribute: Attribute) => {\n if ('columnType' in attribute && attribute.columnType) {\n return attribute.columnType;\n }\n\n switch (attribute.type) {\n case 'increments': {\n return {\n type: 'increments',\n args: [{ primary: true, primaryKey: true }],\n notNullable: true,\n };\n }\n\n // We might want to convert email/password to string types before going into the orm with specific validators & transformers\n case 'password':\n case 'email':\n case 'string':\n case 'enumeration': {\n return { type: 'string' };\n }\n case 'uid': {\n return {\n type: 'string',\n };\n }\n case 'richtext':\n case 'text': {\n return {\n type: 'text',\n args: ['longtext'],\n };\n }\n case 'blocks':\n case 'json': {\n return { type: 'jsonb' };\n }\n case 'integer': {\n return { type: 'integer' };\n }\n case 'biginteger': {\n return { type: 'bigInteger' };\n }\n case 'float': {\n return { type: 'double' };\n }\n case 'decimal': {\n return { type: 'decimal', args: [10, 2] };\n }\n case 'date': {\n return { type: 'date' };\n }\n case 'time': {\n return { type: 'time', args: [{ precision: 3 }] };\n }\n case 'datetime': {\n return {\n type: 'datetime',\n args: [\n {\n useTz: false,\n precision: 6,\n },\n ],\n };\n }\n case 'timestamp': {\n return {\n type: 'timestamp',\n args: [\n {\n useTz: false,\n precision: 6,\n },\n ],\n };\n }\n case 'boolean': {\n return { type: 'boolean' };\n }\n default: {\n throw new Error(`Unknown type ${attribute.type}`);\n }\n }\n};\n\nexport const metadataToSchema = (metadata: Metadata): Schema => {\n const schema: Schema = {\n tables: [],\n };\n\n metadata.forEach((metadata) => {\n schema.tables.push(createTable(metadata));\n });\n\n return schema;\n};\n"],"names":["createColumn","name","attribute","type","args","opts","getColumnType","identifiers","getName","defaultTo","notNullable","unsigned","column","createTable","meta","table","tableName","indexes","foreignKeys","columns","key","Object","keys","attributes","morphColumn","owner","idColumn","typeColumn","idColumnName","typeColumnName","push","joinColumn","referencedTable","columnNameFull","referencedColumn","columnType","columnName","fkName","getFkIndexName","referencedColumns","onDelete","types","unique","getUniqueIndexName","primary","getPrimaryIndexName","primaryKey","precision","useTz","Error","metadataToSchema","metadata","schema","tables","forEach"],"mappings":";;;AAMA;;;;;;;;;;;;;MAeA,MAAMA,YAAe,GAAA,CAACC,IAAcC,EAAAA,SAAAA,GAAAA;IAClC,MAAM,EAAEC,IAAI,EAAEC,IAAAA,GAAO,EAAE,EAAE,GAAGC,IAAM,EAAA,GAAGC,aAAcJ,CAAAA,SAAAA,CAAAA;IAEnD,OAAO;QACLD,IAAMM,EAAAA,WAAAA,CAAYC,OAAO,CAACP,IAAAA,CAAAA;AAC1BE,QAAAA,IAAAA;AACAC,QAAAA,IAAAA;QACAK,SAAW,EAAA,IAAA;QACXC,WAAa,EAAA,KAAA;QACbC,QAAU,EAAA,KAAA;AACV,QAAA,GAAGN,IAAI;QACP,GAAI,QAAA,IAAYH,YAAaA,SAAUU,CAAAA,MAAM,IAAI,EAAC,GAAK;AACzD,KAAA;AACF,CAAA;AAEA,MAAMC,cAAc,CAACC,IAAAA,GAAAA;AACnB,IAAA,MAAMC,KAAe,GAAA;AACnBd,QAAAA,IAAAA,EAAMa,KAAKE,SAAS;QACpBC,OAASH,EAAAA,IAAAA,CAAKG,OAAO,IAAI,EAAE;QAC3BC,WAAaJ,EAAAA,IAAAA,CAAKI,WAAW,IAAI,EAAE;AACnCC,QAAAA,OAAAA,EAAS;AACX,KAAA;AAEA,IAAA,KAAK,MAAMC,GAAOC,IAAAA,MAAAA,CAAOC,IAAI,CAACR,IAAAA,CAAKS,UAAU,CAAG,CAAA;AAC9C,QAAA,MAAMrB,SAAYY,GAAAA,IAAAA,CAAKS,UAAU,CAACH,GAAI,CAAA;;QAGtC,IAAIlB,SAAAA,CAAUC,IAAI,KAAK,UAAY,EAAA;AACjC,YAAA,IAAI,iBAAiBD,SAAaA,IAAAA,SAAAA,CAAUsB,WAAW,IAAItB,SAAAA,CAAUuB,KAAK,EAAE;AAC1E,gBAAA,MAAM,EAAEC,QAAQ,EAAEC,UAAU,EAAE,GAAGzB,UAAUsB,WAAW;AAEtD,gBAAA,MAAMI,YAAerB,GAAAA,WAAAA,CAAYC,OAAO,CAACkB,SAASzB,IAAI,CAAA;AACtD,gBAAA,MAAM4B,cAAiBtB,GAAAA,WAAAA,CAAYC,OAAO,CAACmB,WAAW1B,IAAI,CAAA;AAE1Dc,gBAAAA,KAAAA,CAAMI,OAAO,CAACW,IAAI,CAChB9B,aAAa4B,YAAc,EAAA;oBACzBzB,IAAM,EAAA,SAAA;oBACNS,MAAQ,EAAA;wBACND,QAAU,EAAA;AACZ;AACF,iBAAA,CAAA,CAAA;AAGFI,gBAAAA,KAAAA,CAAMI,OAAO,CAACW,IAAI,CAAC9B,aAAa6B,cAAgB,EAAA;oBAAE1B,IAAM,EAAA;AAAS,iBAAA,CAAA,CAAA;AACnE,aAAA,MAAO,IACL,YAAA,IAAgBD,SAChBA,IAAAA,SAAAA,CAAU6B,UAAU,IACpB7B,SAAUuB,CAAAA,KAAK,IACfvB,SAAAA,CAAU6B,UAAU,CAACC,eAAe,EACpC;;AAGA,gBAAA,MAAM,EACJ/B,IAAAA,EAAMgC,cAAc,EACpBC,gBAAgB,EAChBF,eAAe,EACfG,UAAa,GAAA,SAAS,EACvB,GAAGjC,UAAU6B,UAAU;gBAExB,MAAMK,UAAAA,GAAa7B,WAAYC,CAAAA,OAAO,CAACyB,cAAAA,CAAAA;gBAEvC,MAAMrB,MAAAA,GAASZ,aAAaoC,UAAY,EAAA;;oBAEtCjC,IAAMgC,EAAAA,UAAAA;oBACNvB,MAAQ,EAAA;wBACND,QAAU,EAAA;AACZ;AACF,iBAAA,CAAA;gBAEAI,KAAMI,CAAAA,OAAO,CAACW,IAAI,CAAClB,MAAAA,CAAAA;gBAEnB,MAAMyB,MAAAA,GAAS9B,WAAY+B,CAAAA,cAAc,CAAC;AAACvB,oBAAAA,KAAAA,CAAMd,IAAI;AAAEmC,oBAAAA;AAAW,iBAAA,CAAA;gBAClErB,KAAMG,CAAAA,WAAW,CAACY,IAAI,CAAC;oBACrB7B,IAAMoC,EAAAA,MAAAA;oBACNlB,OAAS,EAAA;AAACP,wBAAAA,MAAAA,CAAOX;AAAK,qBAAA;AACtB+B,oBAAAA,eAAAA;oBACAO,iBAAmB,EAAA;AAACL,wBAAAA;AAAiB,qBAAA;;oBAErCM,QAAU,EAAA;AACZ,iBAAA,CAAA;gBAEAzB,KAAME,CAAAA,OAAO,CAACa,IAAI,CAAC;oBACjB7B,IAAMoC,EAAAA,MAAAA;oBACNlB,OAAS,EAAA;AAACP,wBAAAA,MAAAA,CAAOX;AAAK;AACxB,iBAAA,CAAA;AACF;AACF,SAAA,MAAO,IAAIwC,iBAAuB,CAACvC,SAAY,CAAA,EAAA;AAC7C,YAAA,MAAMkC,aAAa7B,WAAYC,CAAAA,OAAO,CAACN,SAAAA,CAAUkC,UAAU,IAAIhB,GAAAA,CAAAA;YAE/D,MAAMR,MAAAA,GAASZ,aAAaoC,UAAYlC,EAAAA,SAAAA,CAAAA;YAExC,IAAIU,MAAAA,CAAO8B,MAAM,EAAE;gBACjB3B,KAAME,CAAAA,OAAO,CAACa,IAAI,CAAC;oBACjB3B,IAAM,EAAA,QAAA;oBACNF,IAAMM,EAAAA,WAAAA,CAAYoC,kBAAkB,CAAC;AAAC5B,wBAAAA,KAAAA,CAAMd,IAAI;AAAEW,wBAAAA,MAAAA,CAAOX;AAAK,qBAAA,CAAA;oBAC9DkB,OAAS,EAAA;AAACiB,wBAAAA;AAAW;AACvB,iBAAA,CAAA;AACF;YAEA,IAAIxB,MAAAA,CAAOgC,OAAO,EAAE;gBAClB7B,KAAME,CAAAA,OAAO,CAACa,IAAI,CAAC;oBACjB3B,IAAM,EAAA,SAAA;oBACNF,IAAMM,EAAAA,WAAAA,CAAYsC,mBAAmB,CAAC;AAAC9B,wBAAAA,KAAAA,CAAMd,IAAI;AAAEW,wBAAAA,MAAAA,CAAOX;AAAK,qBAAA,CAAA;oBAC/DkB,OAAS,EAAA;AAACiB,wBAAAA;AAAW;AACvB,iBAAA,CAAA;AACF;YAEArB,KAAMI,CAAAA,OAAO,CAACW,IAAI,CAAClB,MAAAA,CAAAA;AACrB;AACF;IAEA,OAAOG,KAAAA;AACT,CAAA;AAEA,MAAMT,gBAAgB,CAACJ,SAAAA,GAAAA;AACrB,IAAA,IAAI,YAAgBA,IAAAA,SAAAA,IAAaA,SAAUiC,CAAAA,UAAU,EAAE;AACrD,QAAA,OAAOjC,UAAUiC,UAAU;AAC7B;AAEA,IAAA,OAAQjC,UAAUC,IAAI;QACpB,KAAK,YAAA;AAAc,YAAA;gBACjB,OAAO;oBACLA,IAAM,EAAA,YAAA;oBACNC,IAAM,EAAA;AAAC,wBAAA;4BAAEwC,OAAS,EAAA,IAAA;4BAAME,UAAY,EAAA;AAAK;AAAE,qBAAA;oBAC3CpC,WAAa,EAAA;AACf,iBAAA;AACF;;QAGA,KAAK,UAAA;QACL,KAAK,OAAA;QACL,KAAK,QAAA;QACL,KAAK,aAAA;AAAe,YAAA;gBAClB,OAAO;oBAAEP,IAAM,EAAA;AAAS,iBAAA;AAC1B;QACA,KAAK,KAAA;AAAO,YAAA;gBACV,OAAO;oBACLA,IAAM,EAAA;AACR,iBAAA;AACF;QACA,KAAK,UAAA;QACL,KAAK,MAAA;AAAQ,YAAA;gBACX,OAAO;oBACLA,IAAM,EAAA,MAAA;oBACNC,IAAM,EAAA;AAAC,wBAAA;AAAW;AACpB,iBAAA;AACF;QACA,KAAK,QAAA;QACL,KAAK,MAAA;AAAQ,YAAA;gBACX,OAAO;oBAAED,IAAM,EAAA;AAAQ,iBAAA;AACzB;QACA,KAAK,SAAA;AAAW,YAAA;gBACd,OAAO;oBAAEA,IAAM,EAAA;AAAU,iBAAA;AAC3B;QACA,KAAK,YAAA;AAAc,YAAA;gBACjB,OAAO;oBAAEA,IAAM,EAAA;AAAa,iBAAA;AAC9B;QACA,KAAK,OAAA;AAAS,YAAA;gBACZ,OAAO;oBAAEA,IAAM,EAAA;AAAS,iBAAA;AAC1B;QACA,KAAK,SAAA;AAAW,YAAA;gBACd,OAAO;oBAAEA,IAAM,EAAA,SAAA;oBAAWC,IAAM,EAAA;AAAC,wBAAA,EAAA;AAAI,wBAAA;AAAE;AAAC,iBAAA;AAC1C;QACA,KAAK,MAAA;AAAQ,YAAA;gBACX,OAAO;oBAAED,IAAM,EAAA;AAAO,iBAAA;AACxB;QACA,KAAK,MAAA;AAAQ,YAAA;gBACX,OAAO;oBAAEA,IAAM,EAAA,MAAA;oBAAQC,IAAM,EAAA;AAAC,wBAAA;4BAAE2C,SAAW,EAAA;AAAE;AAAE;AAAC,iBAAA;AAClD;QACA,KAAK,UAAA;AAAY,YAAA;gBACf,OAAO;oBACL5C,IAAM,EAAA,UAAA;oBACNC,IAAM,EAAA;AACJ,wBAAA;4BACE4C,KAAO,EAAA,KAAA;4BACPD,SAAW,EAAA;AACb;AACD;AACH,iBAAA;AACF;QACA,KAAK,WAAA;AAAa,YAAA;gBAChB,OAAO;oBACL5C,IAAM,EAAA,WAAA;oBACNC,IAAM,EAAA;AACJ,wBAAA;4BACE4C,KAAO,EAAA,KAAA;4BACPD,SAAW,EAAA;AACb;AACD;AACH,iBAAA;AACF;QACA,KAAK,SAAA;AAAW,YAAA;gBACd,OAAO;oBAAE5C,IAAM,EAAA;AAAU,iBAAA;AAC3B;AACA,QAAA;AAAS,YAAA;AACP,gBAAA,MAAM,IAAI8C,KAAM,CAAA,CAAC,aAAa,EAAE/C,SAAAA,CAAUC,IAAI,CAAE,CAAA,CAAA;AAClD;AACF;AACF,CAAA;AAEO,MAAM+C,mBAAmB,CAACC,QAAAA,GAAAA;AAC/B,IAAA,MAAMC,MAAiB,GAAA;AACrBC,QAAAA,MAAAA,EAAQ;AACV,KAAA;IAEAF,QAASG,CAAAA,OAAO,CAAC,CAACH,QAAAA,GAAAA;AAChBC,QAAAA,MAAAA,CAAOC,MAAM,CAACvB,IAAI,CAACjB,WAAYsC,CAAAA,QAAAA,CAAAA,CAAAA;AACjC,KAAA,CAAA;IAEA,OAAOC,MAAAA;AACT;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"hash.js","sources":["../../../src/utils/identifiers/hash.ts"],"sourcesContent":["/**\n * @fileoverview This file contains utility functions for shortening identifiers for use in a database schema.\n * The functions in this file are used to generate shorter names for database tables and columns\n * to avoid breaking the constraints of databases.\n *\n * IMPORTANT\n * Any changes here that result in a different output string from any of the naming methods will\n * cause the schema creation to delete data it doesn't recognize because the name\n * is different.\n *\n * If there are any test failures after updating this code, it means there is a breaking change that\n * will cause data loss, so beware; do not update the test to match your changes\n *\n * @internal\n */\n\nimport crypto from 'node:crypto';\nimport { isInteger } from 'lodash/fp';\n\n/**\n * Creates a hash of the given data with the specified string length as a string of hex characters\n *\n * @example\n * createHash(\"myData\", 5); // \"03f85\"\n * createHash(\"myData\", 2); // \"03\"\n * createHash(\"myData\", 1); // \"0\"\n *\n * @param data - The data to be hashed\n * @param len - The length of the hash\n * @returns The generated hash\n * @throws Error if the length is not a positive integer\n * @internal\n */\nexport function createHash(data: string, len: number): string {\n if (!isInteger(len) || len <= 0) {\n throw new Error(`createHash length must be a positive integer, received ${len}`);\n }\n\n const hash = crypto.createHash('shake256', { outputLength: Math.ceil(len / 2) }).update(data);\n return hash.digest('hex').substring(0, len);\n}\n"],"names":["createHash","data","len","isInteger","Error","hash","crypto","outputLength","Math","ceil","update","digest","substring"],"mappings":";;;;;AAmBA;;;;;;;;;;;;;AAaC,IACM,SAASA,UAAWC,CAAAA,IAAY,EAAEC,GAAW,EAAA;AAClD,IAAA,IAAI,CAACC,WAAAA,CAAUD,GAAQA,CAAAA,IAAAA,GAAAA,IAAO,CAAG,EAAA;AAC/B,QAAA,MAAM,IAAIE,KAAM,CAAA,CAAC,uDAAuD,EAAEF,IAAI,CAAC,CAAA;AACjF;AAEA,IAAA,MAAMG,IAAOC,GAAAA,MAAAA,CAAON,UAAU,CAAC,UAAY,EAAA;QAAEO,YAAcC,EAAAA,IAAAA,CAAKC,IAAI,CAACP,GAAM,GAAA,CAAA;AAAG,KAAA,CAAA,CAAGQ,MAAM,CAACT,IAAAA,CAAAA;AACxF,IAAA,OAAOI,KAAKM,MAAM,CAAC,KAAOC,CAAAA,CAAAA,SAAS,CAAC,CAAGV,EAAAA,GAAAA,CAAAA;AACzC;;;;"}
1
+ {"version":3,"file":"hash.js","sources":["../../../src/utils/identifiers/hash.ts"],"sourcesContent":["/**\n * @fileoverview This file contains utility functions for shortening identifiers for use in a database schema.\n * The functions in this file are used to generate shorter names for database tables and columns\n * to avoid breaking the constraints of databases.\n *\n * IMPORTANT\n * Any changes here that result in a different output string from any of the naming methods will\n * cause the schema creation to delete data it doesn't recognize because the name\n * is different.\n *\n * If there are any test failures after updating this code, it means there is a breaking change that\n * will cause data loss, so beware; do not update the test to match your changes\n *\n * @internal\n */\n\nimport crypto from 'node:crypto';\nimport { isInteger } from 'lodash/fp';\n\n/**\n * Creates a hash of the given data with the specified string length as a string of hex characters\n *\n * @example\n * createHash(\"myData\", 5); // \"03f85\"\n * createHash(\"myData\", 2); // \"03\"\n * createHash(\"myData\", 1); // \"0\"\n *\n * @param data - The data to be hashed\n * @param len - The length of the hash\n * @returns The generated hash\n * @throws Error if the length is not a positive integer\n * @internal\n */\nexport function createHash(data: string, len: number): string {\n if (!isInteger(len) || len <= 0) {\n throw new Error(`createHash length must be a positive integer, received ${len}`);\n }\n\n const hash = crypto.createHash('shake256', { outputLength: Math.ceil(len / 2) }).update(data);\n return hash.digest('hex').substring(0, len);\n}\n"],"names":["createHash","data","len","isInteger","Error","hash","crypto","outputLength","Math","ceil","update","digest","substring"],"mappings":";;;;;AAmBA;;;;;;;;;;;;;AAaC,IACM,SAASA,UAAWC,CAAAA,IAAY,EAAEC,GAAW,EAAA;AAClD,IAAA,IAAI,CAACC,WAAAA,CAAUD,GAAQA,CAAAA,IAAAA,GAAAA,IAAO,CAAG,EAAA;AAC/B,QAAA,MAAM,IAAIE,KAAAA,CAAM,CAAC,uDAAuD,EAAEF,GAAK,CAAA,CAAA,CAAA;AACjF;AAEA,IAAA,MAAMG,IAAOC,GAAAA,MAAAA,CAAON,UAAU,CAAC,UAAY,EAAA;QAAEO,YAAcC,EAAAA,IAAAA,CAAKC,IAAI,CAACP,GAAM,GAAA,CAAA;AAAG,KAAA,CAAA,CAAGQ,MAAM,CAACT,IAAAA,CAAAA;AACxF,IAAA,OAAOI,KAAKM,MAAM,CAAC,KAAOC,CAAAA,CAAAA,SAAS,CAAC,CAAGV,EAAAA,GAAAA,CAAAA;AACzC;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"hash.mjs","sources":["../../../src/utils/identifiers/hash.ts"],"sourcesContent":["/**\n * @fileoverview This file contains utility functions for shortening identifiers for use in a database schema.\n * The functions in this file are used to generate shorter names for database tables and columns\n * to avoid breaking the constraints of databases.\n *\n * IMPORTANT\n * Any changes here that result in a different output string from any of the naming methods will\n * cause the schema creation to delete data it doesn't recognize because the name\n * is different.\n *\n * If there are any test failures after updating this code, it means there is a breaking change that\n * will cause data loss, so beware; do not update the test to match your changes\n *\n * @internal\n */\n\nimport crypto from 'node:crypto';\nimport { isInteger } from 'lodash/fp';\n\n/**\n * Creates a hash of the given data with the specified string length as a string of hex characters\n *\n * @example\n * createHash(\"myData\", 5); // \"03f85\"\n * createHash(\"myData\", 2); // \"03\"\n * createHash(\"myData\", 1); // \"0\"\n *\n * @param data - The data to be hashed\n * @param len - The length of the hash\n * @returns The generated hash\n * @throws Error if the length is not a positive integer\n * @internal\n */\nexport function createHash(data: string, len: number): string {\n if (!isInteger(len) || len <= 0) {\n throw new Error(`createHash length must be a positive integer, received ${len}`);\n }\n\n const hash = crypto.createHash('shake256', { outputLength: Math.ceil(len / 2) }).update(data);\n return hash.digest('hex').substring(0, len);\n}\n"],"names":["createHash","data","len","isInteger","Error","hash","crypto","outputLength","Math","ceil","update","digest","substring"],"mappings":";;;AAmBA;;;;;;;;;;;;;AAaC,IACM,SAASA,UAAWC,CAAAA,IAAY,EAAEC,GAAW,EAAA;AAClD,IAAA,IAAI,CAACC,SAAAA,CAAUD,GAAQA,CAAAA,IAAAA,GAAAA,IAAO,CAAG,EAAA;AAC/B,QAAA,MAAM,IAAIE,KAAM,CAAA,CAAC,uDAAuD,EAAEF,IAAI,CAAC,CAAA;AACjF;AAEA,IAAA,MAAMG,IAAOC,GAAAA,MAAAA,CAAON,UAAU,CAAC,UAAY,EAAA;QAAEO,YAAcC,EAAAA,IAAAA,CAAKC,IAAI,CAACP,GAAM,GAAA,CAAA;AAAG,KAAA,CAAA,CAAGQ,MAAM,CAACT,IAAAA,CAAAA;AACxF,IAAA,OAAOI,KAAKM,MAAM,CAAC,KAAOC,CAAAA,CAAAA,SAAS,CAAC,CAAGV,EAAAA,GAAAA,CAAAA;AACzC;;;;"}
1
+ {"version":3,"file":"hash.mjs","sources":["../../../src/utils/identifiers/hash.ts"],"sourcesContent":["/**\n * @fileoverview This file contains utility functions for shortening identifiers for use in a database schema.\n * The functions in this file are used to generate shorter names for database tables and columns\n * to avoid breaking the constraints of databases.\n *\n * IMPORTANT\n * Any changes here that result in a different output string from any of the naming methods will\n * cause the schema creation to delete data it doesn't recognize because the name\n * is different.\n *\n * If there are any test failures after updating this code, it means there is a breaking change that\n * will cause data loss, so beware; do not update the test to match your changes\n *\n * @internal\n */\n\nimport crypto from 'node:crypto';\nimport { isInteger } from 'lodash/fp';\n\n/**\n * Creates a hash of the given data with the specified string length as a string of hex characters\n *\n * @example\n * createHash(\"myData\", 5); // \"03f85\"\n * createHash(\"myData\", 2); // \"03\"\n * createHash(\"myData\", 1); // \"0\"\n *\n * @param data - The data to be hashed\n * @param len - The length of the hash\n * @returns The generated hash\n * @throws Error if the length is not a positive integer\n * @internal\n */\nexport function createHash(data: string, len: number): string {\n if (!isInteger(len) || len <= 0) {\n throw new Error(`createHash length must be a positive integer, received ${len}`);\n }\n\n const hash = crypto.createHash('shake256', { outputLength: Math.ceil(len / 2) }).update(data);\n return hash.digest('hex').substring(0, len);\n}\n"],"names":["createHash","data","len","isInteger","Error","hash","crypto","outputLength","Math","ceil","update","digest","substring"],"mappings":";;;AAmBA;;;;;;;;;;;;;AAaC,IACM,SAASA,UAAWC,CAAAA,IAAY,EAAEC,GAAW,EAAA;AAClD,IAAA,IAAI,CAACC,SAAAA,CAAUD,GAAQA,CAAAA,IAAAA,GAAAA,IAAO,CAAG,EAAA;AAC/B,QAAA,MAAM,IAAIE,KAAAA,CAAM,CAAC,uDAAuD,EAAEF,GAAK,CAAA,CAAA,CAAA;AACjF;AAEA,IAAA,MAAMG,IAAOC,GAAAA,MAAAA,CAAON,UAAU,CAAC,UAAY,EAAA;QAAEO,YAAcC,EAAAA,IAAAA,CAAKC,IAAI,CAACP,GAAM,GAAA,CAAA;AAAG,KAAA,CAAA,CAAGQ,MAAM,CAACT,IAAAA,CAAAA;AACxF,IAAA,OAAOI,KAAKM,MAAM,CAAC,KAAOC,CAAAA,CAAAA,SAAS,CAAC,CAAGV,EAAAA,GAAAA,CAAAA;AACzC;;;;"}
@@ -45,11 +45,9 @@ class Identifiers {
45
45
  this.ORDER_COLUMN = 'order';
46
46
  this.FIELD_COLUMN = 'field';
47
47
  this.HASH_LENGTH = 5;
48
- this.HASH_SEPARATOR = '' // no separator is needed, we will just attach hash directly to shortened name
49
- ;
48
+ this.HASH_SEPARATOR = ''; // no separator is needed, we will just attach hash directly to shortened name
50
49
  this.IDENTIFIER_SEPARATOR = '_';
51
- this.MIN_TOKEN_LENGTH = 3 // the min characters required at the beginning of a name part
52
- ;
50
+ this.MIN_TOKEN_LENGTH = 3; // the min characters required at the beginning of a name part
53
51
  _class_private_field_loose_base(this, _replacementMap)[_replacementMap] = {
54
52
  links: 'lnk',
55
53
  order_inv_fk: 'oifk',