velocious 1.0.351 → 1.0.353
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/src/database/drivers/sqlite/sql/alter-table.d.ts +22 -0
- package/build/src/database/drivers/sqlite/sql/alter-table.d.ts.map +1 -1
- package/build/src/database/drivers/sqlite/sql/alter-table.js +122 -91
- package/build/src/database/drivers/sqlite/table-rebuilder.d.ts +41 -0
- package/build/src/database/drivers/sqlite/table-rebuilder.d.ts.map +1 -0
- package/build/src/database/drivers/sqlite/table-rebuilder.js +81 -0
- package/build/src/database/query/alter-table-base.d.ts.map +1 -1
- package/build/src/database/query/alter-table-base.js +22 -5
- package/build/src/database/query/create-table-base.d.ts.map +1 -1
- package/build/src/database/query/create-table-base.js +11 -2
- package/build/src/database/table-data/table-column.d.ts +3 -1
- package/build/src/database/table-data/table-column.d.ts.map +1 -1
- package/build/src/database/table-data/table-column.js +4 -3
- package/build/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
|
@@ -1,6 +1,28 @@
|
|
|
1
1
|
export default class VelociousDatabaseConnectionDriversSqliteSqlAlterTable extends AlterTableBase {
|
|
2
2
|
logger: Logger;
|
|
3
|
+
/**
|
|
4
|
+
* Merges the current schema with the alter request to produce the desired final schema
|
|
5
|
+
* and the column copy plan.
|
|
6
|
+
* @param {TableData} currentTableData - Current schema as introspected from the database.
|
|
7
|
+
* @param {TableData} alterTableData - Alter request: new columns (`isNewColumn`), renames (`newName`), drops (`dropColumn`), modifies, and new foreign keys.
|
|
8
|
+
* @returns {{targetTableData: TableData, columnPairs: Array<[string, string]>}} - The merged target schema and the [oldName, newName] pairs for INSERT...SELECT.
|
|
9
|
+
*/
|
|
10
|
+
_buildTargetSchema(currentTableData: TableData, alterTableData: TableData): {
|
|
11
|
+
targetTableData: TableData;
|
|
12
|
+
columnPairs: Array<[string, string]>;
|
|
13
|
+
};
|
|
14
|
+
/**
|
|
15
|
+
* Returns the foreign key with its column name updated when the column was renamed in the
|
|
16
|
+
* alter request. SQLite re-creates the constraint inside the rebuilt CREATE TABLE, so a
|
|
17
|
+
* stale column name there would reference a column that no longer exists.
|
|
18
|
+
* @param {TableForeignKey} foreignKey - Foreign key to evaluate.
|
|
19
|
+
* @param {Map<string, string>} columnRenames - Map of old → new column names from the alter request.
|
|
20
|
+
* @returns {TableForeignKey} - The original foreign key, or a fresh instance with the renamed column.
|
|
21
|
+
*/
|
|
22
|
+
_renameForeignKeyColumn(foreignKey: TableForeignKey, columnRenames: Map<string, string>): TableForeignKey;
|
|
3
23
|
}
|
|
4
24
|
import AlterTableBase from "../../../query/alter-table-base.js";
|
|
5
25
|
import Logger from "../../../../logger.js";
|
|
26
|
+
import TableData from "../../../table-data/index.js";
|
|
27
|
+
import TableForeignKey from "../../../table-data/table-foreign-key.js";
|
|
6
28
|
//# sourceMappingURL=alter-table.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"alter-table.d.ts","sourceRoot":"","sources":["../../../../../../src/database/drivers/sqlite/sql/alter-table.js"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"alter-table.d.ts","sourceRoot":"","sources":["../../../../../../src/database/drivers/sqlite/sql/alter-table.js"],"names":[],"mappings":"AAUA;IAYI,eAA8B;IA8ChC;;;;;;OAMG;IACH,qCAJW,SAAS,kBACT,SAAS,GACP;QAAC,eAAe,EAAE,SAAS,CAAC;QAAC,WAAW,EAAE,KAAK,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAA;KAAC,CAmF9E;IAED;;;;;;;OAOG;IACH,oCAJW,eAAe,iBACf,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,GACjB,eAAe,CAe3B;CACF;2BAlL0B,oCAAoC;mBAC5C,uBAAuB;sBAEpB,8BAA8B;4BACxB,0CAA0C"}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
// @ts-check
|
|
2
2
|
import AlterTableBase from "../../../query/alter-table-base.js";
|
|
3
|
-
import CreateIndexBase from "../../../query/create-index-base.js";
|
|
4
3
|
import Logger from "../../../../logger.js";
|
|
5
4
|
import restArgsError from "../../../../utils/rest-args-error.js";
|
|
6
5
|
import TableData from "../../../table-data/index.js";
|
|
6
|
+
import TableForeignKey from "../../../table-data/table-foreign-key.js";
|
|
7
|
+
import TableIndex from "../../../table-data/table-index.js";
|
|
8
|
+
import TableRebuilder from "../table-rebuilder.js";
|
|
7
9
|
export default class VelociousDatabaseConnectionDriversSqliteSqlAlterTable extends AlterTableBase {
|
|
8
10
|
/**
|
|
9
11
|
* @param {object} args - Options object.
|
|
@@ -22,109 +24,138 @@ export default class VelociousDatabaseConnectionDriversSqliteSqlAlterTable exten
|
|
|
22
24
|
* @returns {Promise<string[]>} - Resolves with SQL statements.
|
|
23
25
|
*/
|
|
24
26
|
async toSQLs() {
|
|
25
|
-
const
|
|
26
|
-
const
|
|
27
|
+
const driver = this.getDriver();
|
|
28
|
+
const { tableData: alterTableData } = this;
|
|
29
|
+
const tableName = alterTableData.getName();
|
|
30
|
+
const table = await driver.getTableByName(tableName);
|
|
27
31
|
if (!table)
|
|
28
|
-
throw new Error(`Table ${
|
|
32
|
+
throw new Error(`Table ${tableName} does not exist`);
|
|
29
33
|
const currentTableData = await table.getTableData();
|
|
30
|
-
const
|
|
31
|
-
const
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
const newTableColumn = tableData.getColumns().find((tableColumn) => tableColumn.getName() == column.getName());
|
|
37
|
-
return newTableColumn?.getNewName() || newTableColumn?.getName() || column.getNewName() || column.getName();
|
|
34
|
+
const { targetTableData, columnPairs } = this._buildTargetSchema(currentTableData, alterTableData);
|
|
35
|
+
const rebuilder = new TableRebuilder({
|
|
36
|
+
columnPairs,
|
|
37
|
+
driver,
|
|
38
|
+
originalTableName: tableName,
|
|
39
|
+
targetTableData
|
|
38
40
|
});
|
|
39
|
-
const
|
|
40
|
-
const
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
41
|
+
const rebuildSQLs = await rebuilder.toSQLs();
|
|
42
|
+
const sqls = [];
|
|
43
|
+
// PRAGMA foreign_keys can only be toggled outside an active transaction; when the
|
|
44
|
+
// caller is already inside one these become no-ops (matching prior behavior). Outside
|
|
45
|
+
// a transaction they protect the rebuild from cross-table FK enforcement during the
|
|
46
|
+
// DROP/RENAME swap. Capture the prior state so we restore it instead of unconditionally
|
|
47
|
+
// forcing ON — callers that deliberately disabled FK enforcement (e.g. bulk data fixes)
|
|
48
|
+
// shouldn't be silently flipped back on by a migration.
|
|
49
|
+
const priorState = await driver.query("PRAGMA foreign_keys");
|
|
50
|
+
const wasEnabled = priorState[0]?.foreign_keys == 1;
|
|
51
|
+
sqls.push("PRAGMA foreign_keys = OFF");
|
|
52
|
+
for (const sql of rebuildSQLs)
|
|
53
|
+
sqls.push(sql);
|
|
54
|
+
sqls.push(`PRAGMA foreign_keys = ${wasEnabled ? "ON" : "OFF"}`);
|
|
55
|
+
return sqls;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Merges the current schema with the alter request to produce the desired final schema
|
|
59
|
+
* and the column copy plan.
|
|
60
|
+
* @param {TableData} currentTableData - Current schema as introspected from the database.
|
|
61
|
+
* @param {TableData} alterTableData - Alter request: new columns (`isNewColumn`), renames (`newName`), drops (`dropColumn`), modifies, and new foreign keys.
|
|
62
|
+
* @returns {{targetTableData: TableData, columnPairs: Array<[string, string]>}} - The merged target schema and the [oldName, newName] pairs for INSERT...SELECT.
|
|
63
|
+
*/
|
|
64
|
+
_buildTargetSchema(currentTableData, alterTableData) {
|
|
65
|
+
const targetTableData = new TableData(currentTableData.getName());
|
|
66
|
+
/** @type {Array<[string, string]>} */
|
|
67
|
+
const columnPairs = [];
|
|
68
|
+
const alterColumns = alterTableData.getColumns();
|
|
69
|
+
const existingNames = new Set(currentTableData.getColumns().map((column) => column.getName()));
|
|
70
|
+
/** @type {Map<string, string>} */
|
|
71
|
+
const columnRenames = new Map();
|
|
72
|
+
for (const alterColumn of alterColumns) {
|
|
73
|
+
if (alterColumn.isNewColumn())
|
|
74
|
+
continue;
|
|
75
|
+
const newName = alterColumn.getNewName();
|
|
76
|
+
if (newName)
|
|
77
|
+
columnRenames.set(alterColumn.getName(), newName);
|
|
78
|
+
}
|
|
79
|
+
for (const currentColumn of currentTableData.getColumns()) {
|
|
80
|
+
const alterColumn = alterColumns.find((column) => column.getName() == currentColumn.getName() && !column.isNewColumn());
|
|
81
|
+
if (alterColumn?.getDropColumn())
|
|
82
|
+
continue;
|
|
83
|
+
let targetColumn;
|
|
84
|
+
if (alterColumn) {
|
|
85
|
+
// The alter request supplies a partial column spec (e.g. just a rename or a type change);
|
|
86
|
+
// inherit unset properties from the current column so we don't lose existing definitions.
|
|
87
|
+
alterColumn.setAutoIncrement(alterColumn.getAutoIncrement() || currentColumn.getAutoIncrement());
|
|
88
|
+
if (alterColumn.getDefault() === undefined)
|
|
89
|
+
alterColumn.setDefault(currentColumn.getDefault());
|
|
90
|
+
if (!alterColumn.getIndex())
|
|
91
|
+
alterColumn.setIndex(currentColumn.getIndex());
|
|
92
|
+
if (!alterColumn.getForeignKey())
|
|
93
|
+
alterColumn.setForeignKey(currentColumn.getForeignKey());
|
|
94
|
+
if (alterColumn.getMaxLength() === undefined)
|
|
95
|
+
alterColumn.setMaxLength(currentColumn.getMaxLength());
|
|
96
|
+
alterColumn.setPrimaryKey(alterColumn.getPrimaryKey() || currentColumn.getPrimaryKey());
|
|
97
|
+
if (!alterColumn.getType())
|
|
98
|
+
alterColumn.setType(currentColumn.getType());
|
|
99
|
+
targetColumn = alterColumn;
|
|
48
100
|
}
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
newTableDataColumn.setDefault(tableDataColumn.getDefault());
|
|
52
|
-
newTableDataColumn.setIndex(tableDataColumn.getIndex());
|
|
53
|
-
newTableDataColumn.setForeignKey(tableDataColumn.getForeignKey());
|
|
54
|
-
newTableDataColumn.setMaxLength(tableDataColumn.getMaxLength());
|
|
55
|
-
newTableDataColumn.setPrimaryKey(tableDataColumn.getPrimaryKey());
|
|
56
|
-
newTableDataColumn.setType(tableDataColumn.getType());
|
|
101
|
+
else {
|
|
102
|
+
targetColumn = currentColumn;
|
|
57
103
|
}
|
|
58
|
-
|
|
104
|
+
targetTableData.addColumn(targetColumn);
|
|
105
|
+
columnPairs.push([currentColumn.getName(), targetColumn.getNewName() || targetColumn.getName()]);
|
|
59
106
|
}
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
for (const tableDataColumn of tableData.getColumns()) {
|
|
63
|
-
if (!tableDataColumn.isNewColumn())
|
|
107
|
+
for (const alterColumn of alterColumns) {
|
|
108
|
+
if (!alterColumn.isNewColumn())
|
|
64
109
|
continue;
|
|
65
|
-
if (
|
|
110
|
+
if (existingNames.has(alterColumn.getName()))
|
|
66
111
|
continue;
|
|
67
|
-
|
|
112
|
+
targetTableData.addColumn(alterColumn);
|
|
68
113
|
}
|
|
69
|
-
const
|
|
70
|
-
for (const
|
|
71
|
-
const
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
// Register foreign key on the table
|
|
76
|
-
newTableData.addForeignKey(actualTableDataForeignKey);
|
|
77
|
-
// Register foreign key on the column
|
|
78
|
-
const tableDataColumn = newTableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == actualTableDataForeignKey.getColumnName());
|
|
79
|
-
if (!tableDataColumn)
|
|
80
|
-
throw new Error(`Couldn't find column for foreign key: ${actualTableDataForeignKey.getName()}`);
|
|
81
|
-
this.logger.debugLowLevel(() => `Setting foreign key on column ${tableDataColumn.getName()}`);
|
|
82
|
-
tableDataColumn.setForeignKey(actualTableDataForeignKey);
|
|
114
|
+
const seenForeignKeyNames = new Set();
|
|
115
|
+
for (const currentForeignKey of currentTableData.getForeignKeys()) {
|
|
116
|
+
const alterForeignKey = alterTableData.getForeignKeys().find((foreignKey) => foreignKey.getName() == currentForeignKey.getName());
|
|
117
|
+
const finalForeignKey = this._renameForeignKeyColumn(alterForeignKey || currentForeignKey, columnRenames);
|
|
118
|
+
seenForeignKeyNames.add(finalForeignKey.getName());
|
|
119
|
+
targetTableData.addForeignKey(finalForeignKey);
|
|
83
120
|
}
|
|
84
|
-
for (const
|
|
85
|
-
if (
|
|
121
|
+
for (const alterForeignKey of alterTableData.getForeignKeys()) {
|
|
122
|
+
if (seenForeignKeyNames.has(alterForeignKey.getName()))
|
|
86
123
|
continue;
|
|
87
|
-
|
|
88
|
-
newTableData.addForeignKey(foreignKey);
|
|
89
|
-
// Register foreign key on the column
|
|
90
|
-
const tableDataColumn = newTableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == foreignKey.getColumnName());
|
|
91
|
-
if (!tableDataColumn)
|
|
92
|
-
throw new Error(`Couldn't find column for foreign key: ${foreignKey.getName()}`);
|
|
93
|
-
this.logger.debugLowLevel(() => `Setting foreign key on column ${tableDataColumn.getName()}`);
|
|
94
|
-
tableDataColumn.setForeignKey(foreignKey);
|
|
124
|
+
targetTableData.addForeignKey(this._renameForeignKeyColumn(alterForeignKey, columnRenames));
|
|
95
125
|
}
|
|
96
|
-
const
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
for (const sql of createNewTableSQL) {
|
|
102
|
-
sqls.push(sql);
|
|
103
|
-
}
|
|
104
|
-
sqls.push(insertSQL);
|
|
105
|
-
sqls.push(dropTableSQLs);
|
|
106
|
-
sqls.push(renameTableSQL);
|
|
107
|
-
for (const tableDataIndex of currentTableData.getIndexes()) {
|
|
108
|
-
const newTableDataIndex = newTableData.getIndexes().find((newTableDataIndex) => newTableDataIndex.getName() == tableDataIndex.getName());
|
|
109
|
-
const actualTableIndex = newTableDataIndex || tableDataIndex;
|
|
110
|
-
newTableData.addIndex(actualTableIndex);
|
|
111
|
-
const columnNames = actualTableIndex.getColumns().map((columnName) => {
|
|
112
|
-
const newTableColumn = tableData.getColumns().find((tableColumn) => tableColumn.getName() == columnName);
|
|
113
|
-
return newTableColumn?.getNewName() || newTableColumn?.getName() || columnName;
|
|
126
|
+
for (const currentIndex of currentTableData.getIndexes()) {
|
|
127
|
+
const renamedColumns = currentIndex.getColumns().map((columnName) => {
|
|
128
|
+
if (typeof columnName != "string")
|
|
129
|
+
return columnName;
|
|
130
|
+
return columnRenames.get(columnName) || columnName;
|
|
114
131
|
});
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
tableName,
|
|
120
|
-
unique: actualTableIndex.getUnique()
|
|
121
|
-
};
|
|
122
|
-
const createIndexSQLs = await new CreateIndexBase(createIndexArgs).toSQLs();
|
|
123
|
-
for (const createIndexSQL of createIndexSQLs) {
|
|
124
|
-
sqls.push(createIndexSQL);
|
|
125
|
-
}
|
|
132
|
+
targetTableData.addIndex(new TableIndex(renamedColumns, {
|
|
133
|
+
name: currentIndex.getName(),
|
|
134
|
+
unique: currentIndex.getUnique()
|
|
135
|
+
}));
|
|
126
136
|
}
|
|
127
|
-
return
|
|
137
|
+
return { targetTableData, columnPairs };
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Returns the foreign key with its column name updated when the column was renamed in the
|
|
141
|
+
* alter request. SQLite re-creates the constraint inside the rebuilt CREATE TABLE, so a
|
|
142
|
+
* stale column name there would reference a column that no longer exists.
|
|
143
|
+
* @param {TableForeignKey} foreignKey - Foreign key to evaluate.
|
|
144
|
+
* @param {Map<string, string>} columnRenames - Map of old → new column names from the alter request.
|
|
145
|
+
* @returns {TableForeignKey} - The original foreign key, or a fresh instance with the renamed column.
|
|
146
|
+
*/
|
|
147
|
+
_renameForeignKeyColumn(foreignKey, columnRenames) {
|
|
148
|
+
const renamed = columnRenames.get(foreignKey.getColumnName());
|
|
149
|
+
if (!renamed)
|
|
150
|
+
return foreignKey;
|
|
151
|
+
return new TableForeignKey({
|
|
152
|
+
columnName: renamed,
|
|
153
|
+
isNewForeignKey: foreignKey.getIsNewForeignKey(),
|
|
154
|
+
name: foreignKey.getName(),
|
|
155
|
+
referencedColumnName: foreignKey.getReferencedColumnName(),
|
|
156
|
+
referencedTableName: foreignKey.getReferencedTableName(),
|
|
157
|
+
tableName: foreignKey.getTableName()
|
|
158
|
+
});
|
|
128
159
|
}
|
|
129
160
|
}
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alter-table.js","sourceRoot":"","sources":["../../../../../../src/database/drivers/sqlite/sql/alter-table.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport AlterTableBase from \"../../../query/alter-table-base.js\"\nimport CreateIndexBase from \"../../../query/create-index-base.js\"\nimport Logger from \"../../../../logger.js\"\nimport restArgsError from \"../../../../utils/rest-args-error.js\"\nimport TableData from \"../../../table-data/index.js\"\n\nexport default class VelociousDatabaseConnectionDriversSqliteSqlAlterTable extends AlterTableBase {\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../../base.js\").default} args.driver - Database driver instance.\n   * @param {import(\"../../../table-data/index.js\").default} args.tableData - Table data.\n   */\n  constructor({driver, tableData, ...restArgs}) {\n    restArgsError(restArgs)\n\n    if (!(tableData instanceof TableData)) throw new Error(\"Invalid table data was given\")\n\n    super({driver, tableData})\n    this.logger = new Logger(this)\n    this.tableData = tableData\n  }\n\n  /**\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async toSQLs() {\n    const {tableData} = this\n    const table = await this.getDriver().getTableByName(tableData.getName())\n\n    if (!table) throw new Error(`Table ${tableData.getName()} does not exist`)\n\n    const currentTableData = await table.getTableData()\n    const options = this.getOptions()\n    const tableName = tableData.getName()\n    const tempTableName = `${tableData.getName()}AlterTableTemp`\n    const newColumnNames = currentTableData.getColumns()\n      .filter((column) => !column.isNewColumn())\n      .map((column) => {\n        const newTableColumn = tableData.getColumns().find((tableColumn) => tableColumn.getName() == column.getName())\n\n        return newTableColumn?.getNewName() || newTableColumn?.getName() || column.getNewName() || column.getName()\n      })\n    const oldColumnNames = currentTableData.getColumns().filter((column) => !column.isNewColumn()).map((column) => column.getName())\n    const newColumnsSQL = newColumnNames.map((name) => options.quoteColumnName(name)).join(\", \")\n    const oldColumnsSQL = oldColumnNames.map((name) => options.quoteColumnName(name)).join(\", \")\n\n    tableData.setName(tempTableName)\n\n    const newTableData = new TableData(tempTableName)\n\n    for (const tableDataColumn of currentTableData.getColumns()) {\n      let newTableDataColumn = tableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == tableDataColumn.getName())\n\n      if (newTableDataColumn && newTableDataColumn.isNewColumn()) {\n        newTableDataColumn = undefined\n      }\n\n      if (newTableDataColumn) {\n        newTableDataColumn.setAutoIncrement(tableDataColumn.getAutoIncrement())\n        newTableDataColumn.setDefault(tableDataColumn.getDefault())\n        newTableDataColumn.setIndex(tableDataColumn.getIndex())\n        newTableDataColumn.setForeignKey(tableDataColumn.getForeignKey())\n        newTableDataColumn.setMaxLength(tableDataColumn.getMaxLength())\n        newTableDataColumn.setPrimaryKey(tableDataColumn.getPrimaryKey())\n        newTableDataColumn.setType(tableDataColumn.getType())\n      }\n\n      newTableData.addColumn(newTableDataColumn || tableDataColumn)\n    }\n\n    // SQLite rebuilds use existing columns plus new ones; avoid duplicating a column that already exists.\n    const existingColumnNames = new Set(currentTableData.getColumns().map((column) => column.getName()))\n\n    for (const tableDataColumn of tableData.getColumns()) {\n      if (!tableDataColumn.isNewColumn()) continue\n      if (existingColumnNames.has(tableDataColumn.getName())) continue\n\n      newTableData.addColumn(tableDataColumn)\n    }\n\n    const foundForeignKeys = []\n\n    for (const tableDataForeignKey of currentTableData.getForeignKeys()) {\n      const newTableDataForeignKey = newTableData.getForeignKeys().find((newTableDataForeignKey) => newTableDataForeignKey.getName() == tableDataForeignKey.getName())\n\n      if (newTableDataForeignKey) foundForeignKeys.push(newTableDataForeignKey.getName())\n\n      const actualTableDataForeignKey = newTableDataForeignKey || tableDataForeignKey\n\n      // Register foreign key on the table\n      newTableData.addForeignKey(actualTableDataForeignKey)\n\n      // Register foreign key on the column\n      const tableDataColumn = newTableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == actualTableDataForeignKey.getColumnName())\n\n      if (!tableDataColumn) throw new Error(`Couldn't find column for foreign key: ${actualTableDataForeignKey.getName()}`)\n\n      this.logger.debugLowLevel(() => `Setting foreign key on column ${tableDataColumn.getName()}`)\n      tableDataColumn.setForeignKey(actualTableDataForeignKey)\n    }\n\n    for (const foreignKey of tableData.getForeignKeys()) {\n      if (foundForeignKeys.includes(foreignKey.getName())) continue\n\n      // Register foreign key on the table\n      newTableData.addForeignKey(foreignKey)\n\n      // Register foreign key on the column\n      const tableDataColumn = newTableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == foreignKey.getColumnName())\n\n      if (!tableDataColumn) throw new Error(`Couldn't find column for foreign key: ${foreignKey.getName()}`)\n\n      this.logger.debugLowLevel(() => `Setting foreign key on column ${tableDataColumn.getName()}`)\n      tableDataColumn.setForeignKey(foreignKey)\n    }\n\n    const createNewTableSQL = await this.getDriver().createTableSql(newTableData)\n    const insertSQL = `INSERT INTO ${options.quoteTableName(tempTableName)} (${newColumnsSQL}) SELECT ${oldColumnsSQL} FROM ${options.quoteTableName(tableName)}`\n    const dropTableSQLs = `DROP TABLE ${options.quoteTableName(tableName)}`\n    const renameTableSQL = `ALTER TABLE ${options.quoteTableName(tempTableName)} RENAME TO ${options.quoteTableName(tableName)}`\n    const sqls = []\n\n    for (const sql of createNewTableSQL) {\n      sqls.push(sql)\n    }\n\n    sqls.push(insertSQL)\n    sqls.push(dropTableSQLs)\n    sqls.push(renameTableSQL)\n\n    for (const tableDataIndex of currentTableData.getIndexes()) {\n      const newTableDataIndex = newTableData.getIndexes().find((newTableDataIndex) => newTableDataIndex.getName() == tableDataIndex.getName())\n      const actualTableIndex = newTableDataIndex || tableDataIndex\n\n      newTableData.addIndex(actualTableIndex)\n\n      const columnNames = actualTableIndex.getColumns().map((columnName) => {\n        const newTableColumn = tableData.getColumns().find((tableColumn) => tableColumn.getName() == columnName)\n\n        return newTableColumn?.getNewName() || newTableColumn?.getName() || columnName\n      })\n\n      const createIndexArgs = {\n        columns: columnNames,\n        driver: this.getDriver(),\n        name: actualTableIndex.getName(),\n        tableName,\n        unique: actualTableIndex.getUnique()\n      }\n      const createIndexSQLs = await new CreateIndexBase(createIndexArgs).toSQLs()\n\n      for (const createIndexSQL of createIndexSQLs) {\n        sqls.push(createIndexSQL)\n      }\n    }\n\n    return sqls\n  }\n}\n"]}
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alter-table.js","sourceRoot":"","sources":["../../../../../../src/database/drivers/sqlite/sql/alter-table.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport AlterTableBase from \"../../../query/alter-table-base.js\"\nimport Logger from \"../../../../logger.js\"\nimport restArgsError from \"../../../../utils/rest-args-error.js\"\nimport TableData from \"../../../table-data/index.js\"\nimport TableForeignKey from \"../../../table-data/table-foreign-key.js\"\nimport TableIndex from \"../../../table-data/table-index.js\"\nimport TableRebuilder from \"../table-rebuilder.js\"\n\nexport default class VelociousDatabaseConnectionDriversSqliteSqlAlterTable extends AlterTableBase {\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../../base.js\").default} args.driver - Database driver instance.\n   * @param {import(\"../../../table-data/index.js\").default} args.tableData - Table data.\n   */\n  constructor({driver, tableData, ...restArgs}) {\n    restArgsError(restArgs)\n\n    if (!(tableData instanceof TableData)) throw new Error(\"Invalid table data was given\")\n\n    super({driver, tableData})\n    this.logger = new Logger(this)\n    this.tableData = tableData\n  }\n\n  /**\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async toSQLs() {\n    const driver = this.getDriver()\n    const {tableData: alterTableData} = this\n    const tableName = alterTableData.getName()\n    const table = await driver.getTableByName(tableName)\n\n    if (!table) throw new Error(`Table ${tableName} does not exist`)\n\n    const currentTableData = await table.getTableData()\n    const {targetTableData, columnPairs} = this._buildTargetSchema(currentTableData, alterTableData)\n\n    const rebuilder = new TableRebuilder({\n      columnPairs,\n      driver,\n      originalTableName: tableName,\n      targetTableData\n    })\n\n    const rebuildSQLs = await rebuilder.toSQLs()\n    const sqls = []\n\n    // PRAGMA foreign_keys can only be toggled outside an active transaction; when the\n    // caller is already inside one these become no-ops (matching prior behavior). Outside\n    // a transaction they protect the rebuild from cross-table FK enforcement during the\n    // DROP/RENAME swap. Capture the prior state so we restore it instead of unconditionally\n    // forcing ON — callers that deliberately disabled FK enforcement (e.g. bulk data fixes)\n    // shouldn't be silently flipped back on by a migration.\n    const priorState = await driver.query(\"PRAGMA foreign_keys\")\n    const wasEnabled = priorState[0]?.foreign_keys == 1\n\n    sqls.push(\"PRAGMA foreign_keys = OFF\")\n\n    for (const sql of rebuildSQLs) sqls.push(sql)\n\n    sqls.push(`PRAGMA foreign_keys = ${wasEnabled ? \"ON\" : \"OFF\"}`)\n\n    return sqls\n  }\n\n  /**\n   * Merges the current schema with the alter request to produce the desired final schema\n   * and the column copy plan.\n   * @param {TableData} currentTableData - Current schema as introspected from the database.\n   * @param {TableData} alterTableData - Alter request: new columns (`isNewColumn`), renames (`newName`), drops (`dropColumn`), modifies, and new foreign keys.\n   * @returns {{targetTableData: TableData, columnPairs: Array<[string, string]>}} - The merged target schema and the [oldName, newName] pairs for INSERT...SELECT.\n   */\n  _buildTargetSchema(currentTableData, alterTableData) {\n    const targetTableData = new TableData(currentTableData.getName())\n    /** @type {Array<[string, string]>} */\n    const columnPairs = []\n    const alterColumns = alterTableData.getColumns()\n    const existingNames = new Set(currentTableData.getColumns().map((column) => column.getName()))\n    /** @type {Map<string, string>} */\n    const columnRenames = new Map()\n\n    for (const alterColumn of alterColumns) {\n      if (alterColumn.isNewColumn()) continue\n\n      const newName = alterColumn.getNewName()\n\n      if (newName) columnRenames.set(alterColumn.getName(), newName)\n    }\n\n    for (const currentColumn of currentTableData.getColumns()) {\n      const alterColumn = alterColumns.find((column) => column.getName() == currentColumn.getName() && !column.isNewColumn())\n\n      if (alterColumn?.getDropColumn()) continue\n\n      let targetColumn\n\n      if (alterColumn) {\n        // The alter request supplies a partial column spec (e.g. just a rename or a type change);\n        // inherit unset properties from the current column so we don't lose existing definitions.\n        alterColumn.setAutoIncrement(alterColumn.getAutoIncrement() || currentColumn.getAutoIncrement())\n        if (alterColumn.getDefault() === undefined) alterColumn.setDefault(currentColumn.getDefault())\n        if (!alterColumn.getIndex()) alterColumn.setIndex(currentColumn.getIndex())\n        if (!alterColumn.getForeignKey()) alterColumn.setForeignKey(currentColumn.getForeignKey())\n        if (alterColumn.getMaxLength() === undefined) alterColumn.setMaxLength(currentColumn.getMaxLength())\n        alterColumn.setPrimaryKey(alterColumn.getPrimaryKey() || currentColumn.getPrimaryKey())\n        if (!alterColumn.getType()) alterColumn.setType(currentColumn.getType())\n\n        targetColumn = alterColumn\n      } else {\n        targetColumn = currentColumn\n      }\n\n      targetTableData.addColumn(targetColumn)\n      columnPairs.push([currentColumn.getName(), targetColumn.getNewName() || targetColumn.getName()])\n    }\n\n    for (const alterColumn of alterColumns) {\n      if (!alterColumn.isNewColumn()) continue\n      if (existingNames.has(alterColumn.getName())) continue\n\n      targetTableData.addColumn(alterColumn)\n    }\n\n    const seenForeignKeyNames = new Set()\n\n    for (const currentForeignKey of currentTableData.getForeignKeys()) {\n      const alterForeignKey = alterTableData.getForeignKeys().find((foreignKey) => foreignKey.getName() == currentForeignKey.getName())\n      const finalForeignKey = this._renameForeignKeyColumn(alterForeignKey || currentForeignKey, columnRenames)\n\n      seenForeignKeyNames.add(finalForeignKey.getName())\n      targetTableData.addForeignKey(finalForeignKey)\n    }\n\n    for (const alterForeignKey of alterTableData.getForeignKeys()) {\n      if (seenForeignKeyNames.has(alterForeignKey.getName())) continue\n\n      targetTableData.addForeignKey(this._renameForeignKeyColumn(alterForeignKey, columnRenames))\n    }\n\n    for (const currentIndex of currentTableData.getIndexes()) {\n      const renamedColumns = currentIndex.getColumns().map((columnName) => {\n        if (typeof columnName != \"string\") return columnName\n\n        return columnRenames.get(columnName) || columnName\n      })\n\n      targetTableData.addIndex(new TableIndex(renamedColumns, {\n        name: currentIndex.getName(),\n        unique: currentIndex.getUnique()\n      }))\n    }\n\n    return {targetTableData, columnPairs}\n  }\n\n  /**\n   * Returns the foreign key with its column name updated when the column was renamed in the\n   * alter request. SQLite re-creates the constraint inside the rebuilt CREATE TABLE, so a\n   * stale column name there would reference a column that no longer exists.\n   * @param {TableForeignKey} foreignKey - Foreign key to evaluate.\n   * @param {Map<string, string>} columnRenames - Map of old → new column names from the alter request.\n   * @returns {TableForeignKey} - The original foreign key, or a fresh instance with the renamed column.\n   */\n  _renameForeignKeyColumn(foreignKey, columnRenames) {\n    const renamed = columnRenames.get(foreignKey.getColumnName())\n\n    if (!renamed) return foreignKey\n\n    return new TableForeignKey({\n      columnName: renamed,\n      isNewForeignKey: foreignKey.getIsNewForeignKey(),\n      name: foreignKey.getName(),\n      referencedColumnName: foreignKey.getReferencedColumnName(),\n      referencedTableName: foreignKey.getReferencedTableName(),\n      tableName: foreignKey.getTableName()\n    })\n  }\n}\n"]}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Emits the SQL sequence for SQLite's "rebuild" approach to schema changes.
|
|
3
|
+
*
|
|
4
|
+
* SQLite cannot add/drop foreign-key constraints, drop columns on older
|
|
5
|
+
* versions, change column types, or add CHECK constraints via ALTER TABLE.
|
|
6
|
+
* The standard workaround (https://sqlite.org/lang_altertable.html) is to
|
|
7
|
+
* create a new table with the desired schema, copy rows over, drop the
|
|
8
|
+
* original, and rename the replacement.
|
|
9
|
+
*
|
|
10
|
+
* Caller passes the desired final schema; this class handles the mechanical
|
|
11
|
+
* sequence (CREATE temp / INSERT...SELECT / DROP / RENAME / recreate
|
|
12
|
+
* indexes). Caller is responsible for any FK toggling or transaction setup
|
|
13
|
+
* around the returned SQL — `PRAGMA foreign_keys` is connection-scoped and
|
|
14
|
+
* cannot be flipped inside a transaction, so wrapping policy is left to the
|
|
15
|
+
* caller (see `sql/alter-table.js`).
|
|
16
|
+
*/
|
|
17
|
+
export default class VelociousDatabaseDriversSqliteTableRebuilder {
|
|
18
|
+
/**
|
|
19
|
+
* @param {object} args - Options object.
|
|
20
|
+
* @param {import("../base.js").default} args.driver - Database driver instance.
|
|
21
|
+
* @param {string} args.originalTableName - Name of the existing table to rebuild.
|
|
22
|
+
* @param {TableData} args.targetTableData - Desired final schema (columns + foreign keys + indexes). The instance's name is overwritten internally during emission.
|
|
23
|
+
* @param {Array<[string, string]>} args.columnPairs - Pairs of [oldColumnName, newColumnName] describing how rows from the original table should populate the rebuilt table.
|
|
24
|
+
*/
|
|
25
|
+
constructor({ driver, originalTableName, targetTableData, columnPairs, ...restArgs }: {
|
|
26
|
+
driver: import("../base.js").default;
|
|
27
|
+
originalTableName: string;
|
|
28
|
+
targetTableData: TableData;
|
|
29
|
+
columnPairs: Array<[string, string]>;
|
|
30
|
+
});
|
|
31
|
+
driver: import("../base.js").default;
|
|
32
|
+
originalTableName: string;
|
|
33
|
+
targetTableData: TableData;
|
|
34
|
+
columnPairs: [string, string][];
|
|
35
|
+
/**
|
|
36
|
+
* @returns {Promise<string[]>} - Resolves with SQL statements to execute in order.
|
|
37
|
+
*/
|
|
38
|
+
toSQLs(): Promise<string[]>;
|
|
39
|
+
}
|
|
40
|
+
import TableData from "../../table-data/index.js";
|
|
41
|
+
//# sourceMappingURL=table-rebuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"table-rebuilder.d.ts","sourceRoot":"","sources":["../../../../../src/database/drivers/sqlite/table-rebuilder.js"],"names":[],"mappings":"AAMA;;;;;;;;;;;;;;;GAeG;AACH;IACE;;;;;;OAMG;IACH,sFALG;QAA2C,MAAM,EAAzC,OAAO,YAAY,EAAE,OAAO;QACf,iBAAiB,EAA9B,MAAM;QACU,eAAe,EAA/B,SAAS;QACqB,WAAW,EAAzC,KAAK,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KACjC,EAUA;IAJC,qCAAoB;IACpB,0BAA0C;IAC1C,2BAAsC;IACtC,gCAA8B;IAGhC;;OAEG;IACH,UAFa,OAAO,CAAC,MAAM,EAAE,CAAC,CAkD7B;CACF;sBAzFqB,2BAA2B"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
// @ts-check
|
|
2
|
+
import CreateIndexBase from "../../query/create-index-base.js";
|
|
3
|
+
import restArgsError from "../../../utils/rest-args-error.js";
|
|
4
|
+
import TableData from "../../table-data/index.js";
|
|
5
|
+
/**
|
|
6
|
+
* Emits the SQL sequence for SQLite's "rebuild" approach to schema changes.
|
|
7
|
+
*
|
|
8
|
+
* SQLite cannot add/drop foreign-key constraints, drop columns on older
|
|
9
|
+
* versions, change column types, or add CHECK constraints via ALTER TABLE.
|
|
10
|
+
* The standard workaround (https://sqlite.org/lang_altertable.html) is to
|
|
11
|
+
* create a new table with the desired schema, copy rows over, drop the
|
|
12
|
+
* original, and rename the replacement.
|
|
13
|
+
*
|
|
14
|
+
* Caller passes the desired final schema; this class handles the mechanical
|
|
15
|
+
* sequence (CREATE temp / INSERT...SELECT / DROP / RENAME / recreate
|
|
16
|
+
* indexes). Caller is responsible for any FK toggling or transaction setup
|
|
17
|
+
* around the returned SQL — `PRAGMA foreign_keys` is connection-scoped and
|
|
18
|
+
* cannot be flipped inside a transaction, so wrapping policy is left to the
|
|
19
|
+
* caller (see `sql/alter-table.js`).
|
|
20
|
+
*/
|
|
21
|
+
export default class VelociousDatabaseDriversSqliteTableRebuilder {
|
|
22
|
+
/**
|
|
23
|
+
* @param {object} args - Options object.
|
|
24
|
+
* @param {import("../base.js").default} args.driver - Database driver instance.
|
|
25
|
+
* @param {string} args.originalTableName - Name of the existing table to rebuild.
|
|
26
|
+
* @param {TableData} args.targetTableData - Desired final schema (columns + foreign keys + indexes). The instance's name is overwritten internally during emission.
|
|
27
|
+
* @param {Array<[string, string]>} args.columnPairs - Pairs of [oldColumnName, newColumnName] describing how rows from the original table should populate the rebuilt table.
|
|
28
|
+
*/
|
|
29
|
+
constructor({ driver, originalTableName, targetTableData, columnPairs, ...restArgs }) {
|
|
30
|
+
restArgsError(restArgs);
|
|
31
|
+
if (!(targetTableData instanceof TableData))
|
|
32
|
+
throw new Error("Invalid target table data was given");
|
|
33
|
+
this.driver = driver;
|
|
34
|
+
this.originalTableName = originalTableName;
|
|
35
|
+
this.targetTableData = targetTableData;
|
|
36
|
+
this.columnPairs = columnPairs;
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* @returns {Promise<string[]>} - Resolves with SQL statements to execute in order.
|
|
40
|
+
*/
|
|
41
|
+
async toSQLs() {
|
|
42
|
+
const driver = this.driver;
|
|
43
|
+
const options = driver.options();
|
|
44
|
+
const originalTableName = this.originalTableName;
|
|
45
|
+
const tempTableName = `${originalTableName}_velocious_rebuild`;
|
|
46
|
+
const targetTableData = this.targetTableData;
|
|
47
|
+
const previousTargetName = targetTableData.getName();
|
|
48
|
+
targetTableData.setName(tempTableName);
|
|
49
|
+
let createTableSQLs;
|
|
50
|
+
try {
|
|
51
|
+
createTableSQLs = await driver.createTableSql(targetTableData);
|
|
52
|
+
}
|
|
53
|
+
finally {
|
|
54
|
+
targetTableData.setName(previousTargetName);
|
|
55
|
+
}
|
|
56
|
+
const newColumnsSQL = this.columnPairs.map(([, newName]) => options.quoteColumnName(newName)).join(", ");
|
|
57
|
+
const oldColumnsSQL = this.columnPairs.map(([oldName]) => options.quoteColumnName(oldName)).join(", ");
|
|
58
|
+
const sqls = [];
|
|
59
|
+
for (const sql of createTableSQLs)
|
|
60
|
+
sqls.push(sql);
|
|
61
|
+
if (this.columnPairs.length > 0) {
|
|
62
|
+
sqls.push(`INSERT INTO ${options.quoteTableName(tempTableName)} (${newColumnsSQL}) ` +
|
|
63
|
+
`SELECT ${oldColumnsSQL} FROM ${options.quoteTableName(originalTableName)}`);
|
|
64
|
+
}
|
|
65
|
+
sqls.push(`DROP TABLE ${options.quoteTableName(originalTableName)}`);
|
|
66
|
+
sqls.push(`ALTER TABLE ${options.quoteTableName(tempTableName)} RENAME TO ${options.quoteTableName(originalTableName)}`);
|
|
67
|
+
for (const tableDataIndex of targetTableData.getIndexes()) {
|
|
68
|
+
const createIndexSQLs = await new CreateIndexBase({
|
|
69
|
+
columns: tableDataIndex.getColumns(),
|
|
70
|
+
driver,
|
|
71
|
+
name: tableDataIndex.getName(),
|
|
72
|
+
tableName: originalTableName,
|
|
73
|
+
unique: tableDataIndex.getUnique()
|
|
74
|
+
}).toSQLs();
|
|
75
|
+
for (const sql of createIndexSQLs)
|
|
76
|
+
sqls.push(sql);
|
|
77
|
+
}
|
|
78
|
+
return sqls;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-rebuilder.js","sourceRoot":"","sources":["../../../../../src/database/drivers/sqlite/table-rebuilder.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport CreateIndexBase from \"../../query/create-index-base.js\"\nimport restArgsError from \"../../../utils/rest-args-error.js\"\nimport TableData from \"../../table-data/index.js\"\n\n/**\n * Emits the SQL sequence for SQLite's \"rebuild\" approach to schema changes.\n *\n * SQLite cannot add/drop foreign-key constraints, drop columns on older\n * versions, change column types, or add CHECK constraints via ALTER TABLE.\n * The standard workaround (https://sqlite.org/lang_altertable.html) is to\n * create a new table with the desired schema, copy rows over, drop the\n * original, and rename the replacement.\n *\n * Caller passes the desired final schema; this class handles the mechanical\n * sequence (CREATE temp / INSERT...SELECT / DROP / RENAME / recreate\n * indexes). Caller is responsible for any FK toggling or transaction setup\n * around the returned SQL — `PRAGMA foreign_keys` is connection-scoped and\n * cannot be flipped inside a transaction, so wrapping policy is left to the\n * caller (see `sql/alter-table.js`).\n */\nexport default class VelociousDatabaseDriversSqliteTableRebuilder {\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../base.js\").default} args.driver - Database driver instance.\n   * @param {string} args.originalTableName - Name of the existing table to rebuild.\n   * @param {TableData} args.targetTableData - Desired final schema (columns + foreign keys + indexes). The instance's name is overwritten internally during emission.\n   * @param {Array<[string, string]>} args.columnPairs - Pairs of [oldColumnName, newColumnName] describing how rows from the original table should populate the rebuilt table.\n   */\n  constructor({driver, originalTableName, targetTableData, columnPairs, ...restArgs}) {\n    restArgsError(restArgs)\n\n    if (!(targetTableData instanceof TableData)) throw new Error(\"Invalid target table data was given\")\n\n    this.driver = driver\n    this.originalTableName = originalTableName\n    this.targetTableData = targetTableData\n    this.columnPairs = columnPairs\n  }\n\n  /**\n   * @returns {Promise<string[]>} - Resolves with SQL statements to execute in order.\n   */\n  async toSQLs() {\n    const driver = this.driver\n    const options = driver.options()\n    const originalTableName = this.originalTableName\n    const tempTableName = `${originalTableName}_velocious_rebuild`\n    const targetTableData = this.targetTableData\n    const previousTargetName = targetTableData.getName()\n\n    targetTableData.setName(tempTableName)\n\n    let createTableSQLs\n\n    try {\n      createTableSQLs = await driver.createTableSql(targetTableData)\n    } finally {\n      targetTableData.setName(previousTargetName)\n    }\n\n    const newColumnsSQL = this.columnPairs.map(([, newName]) => options.quoteColumnName(newName)).join(\", \")\n    const oldColumnsSQL = this.columnPairs.map(([oldName]) => options.quoteColumnName(oldName)).join(\", \")\n\n    const sqls = []\n\n    for (const sql of createTableSQLs) sqls.push(sql)\n\n    if (this.columnPairs.length > 0) {\n      sqls.push(\n        `INSERT INTO ${options.quoteTableName(tempTableName)} (${newColumnsSQL}) ` +\n        `SELECT ${oldColumnsSQL} FROM ${options.quoteTableName(originalTableName)}`\n      )\n    }\n\n    sqls.push(`DROP TABLE ${options.quoteTableName(originalTableName)}`)\n    sqls.push(`ALTER TABLE ${options.quoteTableName(tempTableName)} RENAME TO ${options.quoteTableName(originalTableName)}`)\n\n    for (const tableDataIndex of targetTableData.getIndexes()) {\n      const createIndexSQLs = await new CreateIndexBase({\n        columns: tableDataIndex.getColumns(),\n        driver,\n        name: tableDataIndex.getName(),\n        tableName: originalTableName,\n        unique: tableDataIndex.getUnique()\n      }).toSQLs()\n\n      for (const sql of createIndexSQLs) sqls.push(sql)\n    }\n\n    return sqls\n  }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"alter-table-base.d.ts","sourceRoot":"","sources":["../../../../src/database/query/alter-table-base.js"],"names":[],"mappings":"AAMA;IACE;;;;OAIG;IACH,gDAHG;QAAmD,MAAM,EAAjD,OAAO,oBAAoB,EAAE,OAAO;QACpB,SAAS,EAAzB,SAAS;KACnB,EAQA;IADC,qBAA0B;
|
|
1
|
+
{"version":3,"file":"alter-table-base.d.ts","sourceRoot":"","sources":["../../../../src/database/query/alter-table-base.js"],"names":[],"mappings":"AAMA;IACE;;;;OAIG;IACH,gDAHG;QAAmD,MAAM,EAAjD,OAAO,oBAAoB,EAAE,OAAO;QACpB,SAAS,EAAzB,SAAS;KACnB,EAQA;IADC,qBAA0B;CAmF7B;sBAnGqB,WAAW;sBAEX,wBAAwB"}
|
|
@@ -24,9 +24,9 @@ export default class VelociousDatabaseQueryAlterTableBase extends QueryBase {
|
|
|
24
24
|
const { tableData } = this;
|
|
25
25
|
const options = this.getOptions();
|
|
26
26
|
let sql = `ALTER TABLE ${options.quoteTableName(tableData.getName())} `;
|
|
27
|
-
let
|
|
27
|
+
let actionCount = 0;
|
|
28
28
|
for (const column of tableData.getColumns()) {
|
|
29
|
-
if (
|
|
29
|
+
if (actionCount > 0)
|
|
30
30
|
sql += ", ";
|
|
31
31
|
if (column.isNewColumn()) {
|
|
32
32
|
sql += "ADD ";
|
|
@@ -50,9 +50,26 @@ export default class VelociousDatabaseQueryAlterTableBase extends QueryBase {
|
|
|
50
50
|
}
|
|
51
51
|
sql += column.getSQL({ driver: this.getDriver(), forAlterTable: true });
|
|
52
52
|
}
|
|
53
|
-
|
|
53
|
+
actionCount++;
|
|
54
|
+
}
|
|
55
|
+
// SQLite's ALTER TABLE does not support adding constraints; the SQLite driver overrides
|
|
56
|
+
// alterTableSQLs entirely (via TableRebuilder) so this base path is never invoked there.
|
|
57
|
+
for (const foreignKey of tableData.getForeignKeys()) {
|
|
58
|
+
if (!foreignKey.getIsNewForeignKey())
|
|
59
|
+
continue;
|
|
60
|
+
if (actionCount > 0)
|
|
61
|
+
sql += ", ";
|
|
62
|
+
sql += "ADD";
|
|
63
|
+
if (foreignKey.getName()) {
|
|
64
|
+
sql += ` CONSTRAINT ${options.quoteIndexName(foreignKey.getName())}`;
|
|
65
|
+
}
|
|
66
|
+
sql += ` FOREIGN KEY (${options.quoteColumnName(foreignKey.getColumnName())})`;
|
|
67
|
+
sql += ` REFERENCES ${options.quoteTableName(foreignKey.getReferencedTableName())} (${options.quoteColumnName(foreignKey.getReferencedColumnName())})`;
|
|
68
|
+
actionCount++;
|
|
69
|
+
}
|
|
70
|
+
if (actionCount > 0) {
|
|
71
|
+
sqls.push(sql);
|
|
54
72
|
}
|
|
55
|
-
sqls.push(sql);
|
|
56
73
|
if (databaseType == "pgsql") {
|
|
57
74
|
for (const column of tableData.getColumns()) {
|
|
58
75
|
if (!column.isNewColumn() || column.getDropColumn())
|
|
@@ -67,4 +84,4 @@ export default class VelociousDatabaseQueryAlterTableBase extends QueryBase {
|
|
|
67
84
|
return sqls;
|
|
68
85
|
}
|
|
69
86
|
}
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alter-table-base.js","sourceRoot":"","sources":["../../../../src/database/query/alter-table-base.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport QueryBase from \"./base.js\"\nimport restArgsError from \"../../utils/rest-args-error.js\"\nimport TableData from \"../table-data/index.js\"\n\nexport default class VelociousDatabaseQueryAlterTableBase extends QueryBase {\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../drivers/base.js\").default} args.driver - Database driver instance.\n   * @param {TableData} args.tableData - Table data.\n   */\n  constructor({driver, tableData, ...restArgs}) {\n    restArgsError(restArgs)\n\n    if (!(tableData instanceof TableData)) throw new Error(\"Invalid table data was given\")\n\n    super({driver})\n    this.tableData = tableData\n  }\n\n  /**\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async toSQLs() {\n    const databaseType = this.getDriver().getType()\n    const sqls = []\n    const {tableData} = this\n    const options = this.getOptions()\n\n    let sql = `ALTER TABLE ${options.quoteTableName(tableData.getName())} `\n    let actionCount = 0\n\n    for (const column of tableData.getColumns()) {\n      if (actionCount > 0) sql += \", \"\n\n      if (column.isNewColumn()) {\n        sql += \"ADD \"\n        sql += column.getSQL({driver: this.getDriver(), forAlterTable: false})\n      } else if (column.getNewName()) {\n        const newColumnName = column.getNewName()\n\n        if (!newColumnName) throw new Error(`Expected new column name for ${column.getName()}`)\n\n        sql += `RENAME COLUMN ${options.quoteColumnName(column.getName())} TO ${options.quoteColumnName(newColumnName)}`\n      } else if (column.getDropColumn()) {\n        sql += `DROP COLUMN ${options.quoteColumnName(column.getName())}`\n      } else {\n        if (databaseType == \"mssql\" || databaseType == \"pgsql\") {\n          sql += \"ALTER COLUMN \"\n        } else {\n          sql += \"MODIFY \"\n        }\n\n        sql += column.getSQL({driver: this.getDriver(), forAlterTable: true})\n      }\n\n\n      actionCount++\n    }\n\n    // SQLite's ALTER TABLE does not support adding constraints; the SQLite driver overrides\n    // alterTableSQLs entirely (via TableRebuilder) so this base path is never invoked there.\n    for (const foreignKey of tableData.getForeignKeys()) {\n      if (!foreignKey.getIsNewForeignKey()) continue\n\n      if (actionCount > 0) sql += \", \"\n\n      sql += \"ADD\"\n\n      if (foreignKey.getName()) {\n        sql += ` CONSTRAINT ${options.quoteIndexName(foreignKey.getName())}`\n      }\n\n      sql += ` FOREIGN KEY (${options.quoteColumnName(foreignKey.getColumnName())})`\n      sql += ` REFERENCES ${options.quoteTableName(foreignKey.getReferencedTableName())} (${options.quoteColumnName(foreignKey.getReferencedColumnName())})`\n\n      actionCount++\n    }\n\n    if (actionCount > 0) {\n      sqls.push(sql)\n    }\n\n    if (databaseType == \"pgsql\") {\n      for (const column of tableData.getColumns()) {\n      if (!column.isNewColumn() || column.getDropColumn()) continue\n\n      const notes = column.getNotesForDatabase(databaseType)\n      const actualName = column.getActualName()\n\n      if (!notes || !actualName) continue\n\n      sqls.push(\n        `COMMENT ON COLUMN ${options.quoteTableName(tableData.getName())}.${options.quoteColumnName(actualName)} IS ${options.quote(notes)}`\n      )\n      }\n    }\n\n    return sqls\n  }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-table-base.d.ts","sourceRoot":"","sources":["../../../../src/database/query/create-table-base.js"],"names":[],"mappings":"AAQA;IACE;;;;;;OAMG;IACH,oEALG;QAAmD,MAAM,EAAjD,OAAO,oBAAoB,EAAE,OAAO;QACrB,WAAW;QACX,kBAAkB;QACjB,SAAS,EAAzB,SAAS;KACnB,EAQA;IAHC,iCAA8B;IAC9B,4BAA4C;IAC5C,qBAA0B;IAG5B;;OAEG;IACH,SAFa,OAAO,CAAC,MAAM,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"create-table-base.d.ts","sourceRoot":"","sources":["../../../../src/database/query/create-table-base.js"],"names":[],"mappings":"AAQA;IACE;;;;;;OAMG;IACH,oEALG;QAAmD,MAAM,EAAjD,OAAO,oBAAoB,EAAE,OAAO;QACrB,WAAW;QACX,kBAAkB;QACjB,SAAS,EAAzB,SAAS;KACnB,EAQA;IAHC,iCAA8B;IAC9B,4BAA4C;IAC5C,qBAA0B;IAG5B;;OAEG;IACH,SAFa,OAAO,CAAC,MAAM,EAAE,CAAC,CA+K7B;CACF;sBAvMqB,WAAW;sBAEX,wBAAwB"}
|
|
@@ -38,12 +38,21 @@ export default class VelociousDatabaseQueryCreateTableBase extends QueryBase {
|
|
|
38
38
|
if (databaseType != "mssql" && ifNotExists)
|
|
39
39
|
sql += " IF NOT EXISTS";
|
|
40
40
|
sql += ` ${options.quoteTableName(tableData.getName())} (`;
|
|
41
|
+
const tableLevelFKColumnNames = new Set(tableData.getForeignKeys().map((foreignKey) => foreignKey.getColumnName()));
|
|
41
42
|
let columnCount = 0;
|
|
42
43
|
for (const column of tableData.getColumns()) {
|
|
43
44
|
columnCount++;
|
|
44
45
|
if (columnCount > 1)
|
|
45
46
|
sql += ", ";
|
|
46
|
-
sql += column.getSQL({ driver, forAlterTable: false });
|
|
47
|
+
sql += column.getSQL({ driver, forAlterTable: false, skipForeignKey: tableLevelFKColumnNames.has(column.getActualName()) });
|
|
48
|
+
}
|
|
49
|
+
for (const foreignKey of tableData.getForeignKeys()) {
|
|
50
|
+
sql += ", ";
|
|
51
|
+
if (foreignKey.getName()) {
|
|
52
|
+
sql += `CONSTRAINT ${options.quoteIndexName(foreignKey.getName())} `;
|
|
53
|
+
}
|
|
54
|
+
sql += `FOREIGN KEY (${options.quoteColumnName(foreignKey.getColumnName())})`;
|
|
55
|
+
sql += ` REFERENCES ${options.quoteTableName(foreignKey.getReferencedTableName())} (${options.quoteColumnName(foreignKey.getReferencedColumnName())})`;
|
|
47
56
|
}
|
|
48
57
|
if (this.indexInCreateTable) {
|
|
49
58
|
for (const index of tableData.getIndexes()) {
|
|
@@ -149,4 +158,4 @@ export default class VelociousDatabaseQueryCreateTableBase extends QueryBase {
|
|
|
149
158
|
return sqls;
|
|
150
159
|
}
|
|
151
160
|
}
|
|
152
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-table-base.js","sourceRoot":"","sources":["../../../../src/database/query/create-table-base.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport CreateIndexBase from \"./create-index-base.js\"\nimport QueryBase from \"./base.js\"\nimport restArgsError from \"../../utils/rest-args-error.js\"\nimport TableData from \"../table-data/index.js\"\nimport TableColumn from \"../table-data/table-column.js\"\n\nexport default class VelociousDatabaseQueryCreateTableBase extends QueryBase {\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../drivers/base.js\").default} args.driver - Database driver instance.\n   * @param {boolean} [args.ifNotExists] - Whether if not exists.\n   * @param {boolean} [args.indexInCreateTable] - Whether index in create table.\n   * @param {TableData} args.tableData - Table data.\n   */\n  constructor({driver, ifNotExists, indexInCreateTable = true, tableData}) {\n    if (!(tableData instanceof TableData)) throw new Error(\"Invalid table data was given\")\n\n    super({driver})\n    this.ifNotExists = ifNotExists\n    this.indexInCreateTable = indexInCreateTable\n    this.tableData = tableData\n  }\n\n  /**\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async toSql() {\n    const databaseType = this.getDatabaseType()\n    const driver = this.getDriver()\n    const options = this.getOptions()\n    const {tableData} = this\n    const sqls = []\n    const ifNotExists = this.ifNotExists || tableData.getIfNotExists()\n    let sql = \"\"\n\n    if (databaseType == \"mssql\" && ifNotExists) {\n      sql += `IF NOT EXISTS(SELECT * FROM [sysobjects] WHERE [name] = ${options.quote(tableData.getName())} AND [xtype] = 'U') BEGIN `\n    }\n\n    sql += \"CREATE TABLE\"\n\n    if (databaseType != \"mssql\" && ifNotExists) sql += \" IF NOT EXISTS\"\n\n    sql += ` ${options.quoteTableName(tableData.getName())} (`\n\n    let columnCount = 0\n\n    for (const column of tableData.getColumns()) {\n      columnCount++\n\n      if (columnCount > 1) sql += \", \"\n\n      sql += column.getSQL({driver, forAlterTable: false})\n    }\n\n    if (this.indexInCreateTable) {\n      for (const index of tableData.getIndexes()) {\n        sql += \",\"\n\n        if (index.getUnique()) {\n          sql += \" UNIQUE\"\n        }\n\n        sql += \" INDEX\"\n\n        if (index.getName()) {\n          const indexName = index.getName()\n\n          if (!indexName) throw new Error(\"Expected index name\")\n\n          sql += ` ${options.quoteIndexName(indexName)}`\n        }\n\n        sql += \" (\"\n\n        index.getColumns().forEach((column, columnIndex) => {\n          if (columnIndex > 0) sql += \", \"\n\n          if (column instanceof TableColumn) {\n            sql += driver.quoteColumn(column.getName())\n          } else if (typeof column == \"string\") {\n            sql += driver.quoteColumn(column)\n          } else {\n            throw new Error(`Unknown column type: ${typeof column}`)\n          }\n        })\n\n        sql += \")\"\n      }\n\n      // Create indexes for all columns with the index argument\n      for (const column of tableData.getColumns()) {\n        if (!column.getIndex()) continue\n\n        let indexName = `index_on_`\n\n        if (databaseType == \"sqlite\") sql += `${tableData.getName()}_`\n\n        indexName += column.getName()\n\n        sql += \",\"\n\n        const {unique, ...restIndexArgs} = column.getIndexArgs()\n\n        restArgsError(restIndexArgs)\n\n        if (unique) {\n          sql += \" UNIQUE\"\n        }\n\n        sql += ` INDEX ${options.quoteIndexName(indexName)} (${options.quoteColumnName(column.getName())})`\n      }\n    }\n\n    sql += \")\"\n\n    if (databaseType == \"mysql\") {\n      sql += \" DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci\"\n    }\n\n    if (databaseType == \"mssql\" && ifNotExists) {\n      sql += \" END\"\n    }\n\n    sqls.push(sql)\n\n    if (databaseType == \"pgsql\") {\n      for (const column of tableData.getColumns()) {\n        const notes = column.getNotesForDatabase(databaseType)\n        const actualName = column.getActualName()\n\n        if (!notes || !actualName) continue\n\n        sqls.push(\n          `COMMENT ON COLUMN ${options.quoteTableName(tableData.getName())}.${options.quoteColumnName(actualName)} IS ${options.quote(notes)}`\n        )\n      }\n    }\n\n    if (!this.indexInCreateTable) {\n      for (const index of tableData.getIndexes()) {\n        const createIndexArgs = {\n          columns: index.getColumns(),\n          driver: this.getDriver(),\n          ifNotExists: true,\n          name: index.getName(),\n          tableName: tableData.getName(),\n          unique: index.getUnique()\n        }\n        const createIndexSQLs = await new CreateIndexBase(createIndexArgs).toSQLs()\n\n        for (const createIndexSQL of createIndexSQLs) {\n          sqls.push(createIndexSQL)\n        }\n      }\n\n      // Create indexes for all columns with the index argument\n      for (const column of tableData.getColumns()) {\n        if (!column.getIndex()) continue\n\n        const {unique, ...restIndexArgs} = column.getIndexArgs()\n\n        restArgsError(restIndexArgs)\n\n        let indexName = `index_on_`\n\n        if (databaseType == \"sqlite\") indexName += `${tableData.getName()}_`\n\n        indexName += column.getName()\n\n        const createIndexArgs = {\n          columns: [column.getName()],\n          driver: this.getDriver(),\n          name: indexName,\n          tableName: tableData.getName(),\n          unique\n        }\n        const createIndexSQLs = await new CreateIndexBase(createIndexArgs).toSQLs()\n\n        for (const createIndexSQL of createIndexSQLs) {\n          sqls.push(createIndexSQL)\n        }\n      }\n    }\n\n    return sqls\n  }\n}\n"]}
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-table-base.js","sourceRoot":"","sources":["../../../../src/database/query/create-table-base.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport CreateIndexBase from \"./create-index-base.js\"\nimport QueryBase from \"./base.js\"\nimport restArgsError from \"../../utils/rest-args-error.js\"\nimport TableData from \"../table-data/index.js\"\nimport TableColumn from \"../table-data/table-column.js\"\n\nexport default class VelociousDatabaseQueryCreateTableBase extends QueryBase {\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../drivers/base.js\").default} args.driver - Database driver instance.\n   * @param {boolean} [args.ifNotExists] - Whether if not exists.\n   * @param {boolean} [args.indexInCreateTable] - Whether index in create table.\n   * @param {TableData} args.tableData - Table data.\n   */\n  constructor({driver, ifNotExists, indexInCreateTable = true, tableData}) {\n    if (!(tableData instanceof TableData)) throw new Error(\"Invalid table data was given\")\n\n    super({driver})\n    this.ifNotExists = ifNotExists\n    this.indexInCreateTable = indexInCreateTable\n    this.tableData = tableData\n  }\n\n  /**\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async toSql() {\n    const databaseType = this.getDatabaseType()\n    const driver = this.getDriver()\n    const options = this.getOptions()\n    const {tableData} = this\n    const sqls = []\n    const ifNotExists = this.ifNotExists || tableData.getIfNotExists()\n    let sql = \"\"\n\n    if (databaseType == \"mssql\" && ifNotExists) {\n      sql += `IF NOT EXISTS(SELECT * FROM [sysobjects] WHERE [name] = ${options.quote(tableData.getName())} AND [xtype] = 'U') BEGIN `\n    }\n\n    sql += \"CREATE TABLE\"\n\n    if (databaseType != \"mssql\" && ifNotExists) sql += \" IF NOT EXISTS\"\n\n    sql += ` ${options.quoteTableName(tableData.getName())} (`\n\n    const tableLevelFKColumnNames = new Set(tableData.getForeignKeys().map((foreignKey) => foreignKey.getColumnName()))\n\n    let columnCount = 0\n\n    for (const column of tableData.getColumns()) {\n      columnCount++\n\n      if (columnCount > 1) sql += \", \"\n\n      sql += column.getSQL({driver, forAlterTable: false, skipForeignKey: tableLevelFKColumnNames.has(column.getActualName())})\n    }\n\n    for (const foreignKey of tableData.getForeignKeys()) {\n      sql += \", \"\n\n      if (foreignKey.getName()) {\n        sql += `CONSTRAINT ${options.quoteIndexName(foreignKey.getName())} `\n      }\n\n      sql += `FOREIGN KEY (${options.quoteColumnName(foreignKey.getColumnName())})`\n      sql += ` REFERENCES ${options.quoteTableName(foreignKey.getReferencedTableName())} (${options.quoteColumnName(foreignKey.getReferencedColumnName())})`\n    }\n\n    if (this.indexInCreateTable) {\n      for (const index of tableData.getIndexes()) {\n        sql += \",\"\n\n        if (index.getUnique()) {\n          sql += \" UNIQUE\"\n        }\n\n        sql += \" INDEX\"\n\n        if (index.getName()) {\n          const indexName = index.getName()\n\n          if (!indexName) throw new Error(\"Expected index name\")\n\n          sql += ` ${options.quoteIndexName(indexName)}`\n        }\n\n        sql += \" (\"\n\n        index.getColumns().forEach((column, columnIndex) => {\n          if (columnIndex > 0) sql += \", \"\n\n          if (column instanceof TableColumn) {\n            sql += driver.quoteColumn(column.getName())\n          } else if (typeof column == \"string\") {\n            sql += driver.quoteColumn(column)\n          } else {\n            throw new Error(`Unknown column type: ${typeof column}`)\n          }\n        })\n\n        sql += \")\"\n      }\n\n      // Create indexes for all columns with the index argument\n      for (const column of tableData.getColumns()) {\n        if (!column.getIndex()) continue\n\n        let indexName = `index_on_`\n\n        if (databaseType == \"sqlite\") sql += `${tableData.getName()}_`\n\n        indexName += column.getName()\n\n        sql += \",\"\n\n        const {unique, ...restIndexArgs} = column.getIndexArgs()\n\n        restArgsError(restIndexArgs)\n\n        if (unique) {\n          sql += \" UNIQUE\"\n        }\n\n        sql += ` INDEX ${options.quoteIndexName(indexName)} (${options.quoteColumnName(column.getName())})`\n      }\n    }\n\n    sql += \")\"\n\n    if (databaseType == \"mysql\") {\n      sql += \" DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci\"\n    }\n\n    if (databaseType == \"mssql\" && ifNotExists) {\n      sql += \" END\"\n    }\n\n    sqls.push(sql)\n\n    if (databaseType == \"pgsql\") {\n      for (const column of tableData.getColumns()) {\n        const notes = column.getNotesForDatabase(databaseType)\n        const actualName = column.getActualName()\n\n        if (!notes || !actualName) continue\n\n        sqls.push(\n          `COMMENT ON COLUMN ${options.quoteTableName(tableData.getName())}.${options.quoteColumnName(actualName)} IS ${options.quote(notes)}`\n        )\n      }\n    }\n\n    if (!this.indexInCreateTable) {\n      for (const index of tableData.getIndexes()) {\n        const createIndexArgs = {\n          columns: index.getColumns(),\n          driver: this.getDriver(),\n          ifNotExists: true,\n          name: index.getName(),\n          tableName: tableData.getName(),\n          unique: index.getUnique()\n        }\n        const createIndexSQLs = await new CreateIndexBase(createIndexArgs).toSQLs()\n\n        for (const createIndexSQL of createIndexSQLs) {\n          sqls.push(createIndexSQL)\n        }\n      }\n\n      // Create indexes for all columns with the index argument\n      for (const column of tableData.getColumns()) {\n        if (!column.getIndex()) continue\n\n        const {unique, ...restIndexArgs} = column.getIndexArgs()\n\n        restArgsError(restIndexArgs)\n\n        let indexName = `index_on_`\n\n        if (databaseType == \"sqlite\") indexName += `${tableData.getName()}_`\n\n        indexName += column.getName()\n\n        const createIndexArgs = {\n          columns: [column.getName()],\n          driver: this.getDriver(),\n          name: indexName,\n          tableName: tableData.getName(),\n          unique\n        }\n        const createIndexSQLs = await new CreateIndexBase(createIndexArgs).toSQLs()\n\n        for (const createIndexSQL of createIndexSQLs) {\n          sqls.push(createIndexSQL)\n        }\n      }\n    }\n\n    return sqls\n  }\n}\n"]}
|
|
@@ -157,11 +157,13 @@ export default class TableColumn {
|
|
|
157
157
|
* @param {object} args - Options object.
|
|
158
158
|
* @param {boolean} args.forAlterTable - Whether for alter table.
|
|
159
159
|
* @param {import("../drivers/base.js").default} args.driver - Database driver instance.
|
|
160
|
+
* @param {boolean} [args.skipForeignKey] - Skip emitting the inline REFERENCES clause (the caller emits a table-level FOREIGN KEY constraint instead).
|
|
160
161
|
* @returns {string} - SQL string.
|
|
161
162
|
*/
|
|
162
|
-
getSQL({ forAlterTable, driver, ...restArgs }: {
|
|
163
|
+
getSQL({ forAlterTable, driver, skipForeignKey, ...restArgs }: {
|
|
163
164
|
forAlterTable: boolean;
|
|
164
165
|
driver: import("../drivers/base.js").default;
|
|
166
|
+
skipForeignKey?: boolean | undefined;
|
|
165
167
|
}): string;
|
|
166
168
|
}
|
|
167
169
|
export type IndexArgType = {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"table-column.d.ts","sourceRoot":"","sources":["../../../../src/database/table-data/table-column.js"],"names":[],"mappings":"AAUA;;;;;;;;;;;;;;;;;GAiBG;AAEH;IACE;;;OAGG;IACH,kBAHW,MAAM,SACN,mBAAmB,EAwB7B;IAFC,0BAAsB;IACtB,aAAgB;IAGlB;;OAEG;IACH,WAFa,MAAM,CAEW;IAE9B;;OAEG;IACH,cAFa,MAAM,GAAG,SAAS,CAEM;IAErC;;;OAGG;IACH,oBAHW,MAAM,GACJ,IAAI,CAE8B;IAAzB,6BAAuB;IAE7C;;OAEG;IACH,iBAFa,MAAM,CAE2C;IAE9D;;OAEG;IACH,oBAFa,OAAO,CAE2C;IAE/D;;;OAGG;IACH,mCAHW,OAAO,GACL,IAAI,CAEgE;IAEjF;;OAEG;IACH,cAFa,OAAO,GAAG,CAAC,MAAM,OAAO,CAAC,CAEI;IAE1C;;;OAGG;IACH,uBAHW,GAAG,GACD,IAAI,CAEwC;IAEzD;;OAEG;IACH,iBAFa,OAAO,CAEqC;IAEzD;;OAEG;IACH,iBAFa,OAAO,GAAG,MAAM,GAAG,SAAS,CAEO;IAEhD;;;OAGG;IACH,6BAHW,OAAO,GAAG,MAAM,GAAG,SAAS,GAC1B,IAAI,CAEoD;IAErE;;OAEG;IACH,YAFa,OAAO,GAAC,YAAY,CAEc;IAE/C;;OAEG;IACH,gBAFa,YAAY,CAQxB;IAED,0BAMC;IAED;;;OAGG;IACH,mBAHW,OAAO,GAAC,YAAY,GAClB,IAAI,CAEgC;IAEjD;;OAEG;IACH,gBAFa,MAAM,GAAG,SAAS,CAEe;IAE9C;;;OAGG;IACH,2BAHW,MAAM,GAAG,SAAS,GAChB,IAAI,CAEgD;IAEjE;;OAEG;IACH,YAFa,MAAM,GAAG,SAAS,CAEO;IAEtC;;;OAGG;IACH,mBAHW,MAAM,GAAG,SAAS,GAChB,IAAI,CAEgC;IAEjD;;OAEG;IACH,WAFa,OAAO,GAAG,SAAS,CAEI;IAEpC;;;OAGG;IACH,kBAHW,OAAO,GACL,IAAI,CAE8B;IAE/C;;OAEG;IACH,gBAFa,MAAM,GAAG,SAAS,CAEe;IAE9C;;OAEG;IACH,iBAFa,OAAO,CAEqC;IAEzD;;;OAGG;IACH,6BAHW,OAAO,GACL,IAAI,CAEoD;IAErE;;OAEG;IACH,YAFa,MAAM,GAAG,SAAS,CAEO;IAEtC;;OAEG;IACH,WAFa,MAAM,GAAG,SAAS,CAEK;IAEpC;;;OAGG;IACH,iBAHW,MAAM,GAAG,SAAS,GAChB,IAAI,CAE4B;IAE7C;;OAEG;IACH,oBAFa,MAAM,GAAG,SAAS,CAI9B;IAED;;;OAGG;IACH,kCAHW,MAAM,GACJ,MAAM,GAAG,SAAS,CAM9B;IAED;;OAEG;IACH,eAFa,OAAO,CAEoC;IAExD
|
|
1
|
+
{"version":3,"file":"table-column.d.ts","sourceRoot":"","sources":["../../../../src/database/table-data/table-column.js"],"names":[],"mappings":"AAUA;;;;;;;;;;;;;;;;;GAiBG;AAEH;IACE;;;OAGG;IACH,kBAHW,MAAM,SACN,mBAAmB,EAwB7B;IAFC,0BAAsB;IACtB,aAAgB;IAGlB;;OAEG;IACH,WAFa,MAAM,CAEW;IAE9B;;OAEG;IACH,cAFa,MAAM,GAAG,SAAS,CAEM;IAErC;;;OAGG;IACH,oBAHW,MAAM,GACJ,IAAI,CAE8B;IAAzB,6BAAuB;IAE7C;;OAEG;IACH,iBAFa,MAAM,CAE2C;IAE9D;;OAEG;IACH,oBAFa,OAAO,CAE2C;IAE/D;;;OAGG;IACH,mCAHW,OAAO,GACL,IAAI,CAEgE;IAEjF;;OAEG;IACH,cAFa,OAAO,GAAG,CAAC,MAAM,OAAO,CAAC,CAEI;IAE1C;;;OAGG;IACH,uBAHW,GAAG,GACD,IAAI,CAEwC;IAEzD;;OAEG;IACH,iBAFa,OAAO,CAEqC;IAEzD;;OAEG;IACH,iBAFa,OAAO,GAAG,MAAM,GAAG,SAAS,CAEO;IAEhD;;;OAGG;IACH,6BAHW,OAAO,GAAG,MAAM,GAAG,SAAS,GAC1B,IAAI,CAEoD;IAErE;;OAEG;IACH,YAFa,OAAO,GAAC,YAAY,CAEc;IAE/C;;OAEG;IACH,gBAFa,YAAY,CAQxB;IAED,0BAMC;IAED;;;OAGG;IACH,mBAHW,OAAO,GAAC,YAAY,GAClB,IAAI,CAEgC;IAEjD;;OAEG;IACH,gBAFa,MAAM,GAAG,SAAS,CAEe;IAE9C;;;OAGG;IACH,2BAHW,MAAM,GAAG,SAAS,GAChB,IAAI,CAEgD;IAEjE;;OAEG;IACH,YAFa,MAAM,GAAG,SAAS,CAEO;IAEtC;;;OAGG;IACH,mBAHW,MAAM,GAAG,SAAS,GAChB,IAAI,CAEgC;IAEjD;;OAEG;IACH,WAFa,OAAO,GAAG,SAAS,CAEI;IAEpC;;;OAGG;IACH,kBAHW,OAAO,GACL,IAAI,CAE8B;IAE/C;;OAEG;IACH,gBAFa,MAAM,GAAG,SAAS,CAEe;IAE9C;;OAEG;IACH,iBAFa,OAAO,CAEqC;IAEzD;;;OAGG;IACH,6BAHW,OAAO,GACL,IAAI,CAEoD;IAErE;;OAEG;IACH,YAFa,MAAM,GAAG,SAAS,CAEO;IAEtC;;OAEG;IACH,WAFa,MAAM,GAAG,SAAS,CAEK;IAEpC;;;OAGG;IACH,iBAHW,MAAM,GAAG,SAAS,GAChB,IAAI,CAE4B;IAE7C;;OAEG;IACH,oBAFa,MAAM,GAAG,SAAS,CAI9B;IAED;;;OAGG;IACH,kCAHW,MAAM,GACJ,MAAM,GAAG,SAAS,CAM9B;IAED;;OAEG;IACH,eAFa,OAAO,CAEoC;IAExD;;;;;;OAMG;IACH,+DALG;QAAsB,aAAa,EAA3B,OAAO;QACoC,MAAM,EAAjD,OAAO,oBAAoB,EAAE,OAAO;QACrB,cAAc;KACrC,GAAU,MAAM,CAuIlB;CACF;2BApXY;IAAC,MAAM,EAAE,OAAO,CAAA;CAAC;;;;;;;;;cAUhB,GAAG"}
|
|
@@ -197,9 +197,10 @@ export default class TableColumn {
|
|
|
197
197
|
* @param {object} args - Options object.
|
|
198
198
|
* @param {boolean} args.forAlterTable - Whether for alter table.
|
|
199
199
|
* @param {import("../drivers/base.js").default} args.driver - Database driver instance.
|
|
200
|
+
* @param {boolean} [args.skipForeignKey] - Skip emitting the inline REFERENCES clause (the caller emits a table-level FOREIGN KEY constraint instead).
|
|
200
201
|
* @returns {string} - SQL string.
|
|
201
202
|
*/
|
|
202
|
-
getSQL({ forAlterTable, driver, ...restArgs }) {
|
|
203
|
+
getSQL({ forAlterTable, driver, skipForeignKey, ...restArgs }) {
|
|
203
204
|
restArgsError(restArgs);
|
|
204
205
|
const databaseType = driver.getType();
|
|
205
206
|
const options = driver.options();
|
|
@@ -309,7 +310,7 @@ export default class TableColumn {
|
|
|
309
310
|
if (notes && databaseType == "mysql") {
|
|
310
311
|
sql += ` COMMENT ${options.quote(notes)}`;
|
|
311
312
|
}
|
|
312
|
-
const foreignKey = this.getForeignKey();
|
|
313
|
+
const foreignKey = skipForeignKey ? undefined : this.getForeignKey();
|
|
313
314
|
if (foreignKey) {
|
|
314
315
|
let foreignKeyTable, foreignKeyColumn;
|
|
315
316
|
if (foreignKey === true) {
|
|
@@ -328,4 +329,4 @@ export default class TableColumn {
|
|
|
328
329
|
return sql;
|
|
329
330
|
}
|
|
330
331
|
}
|
|
331
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-column.js","sourceRoot":"","sources":["../../../../src/database/table-data/table-column.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\n/**\n * @typedef {{unique: boolean}} IndexArgType\n */\n\nimport * as inflection from \"inflection\"\nimport restArgsError from \"../../utils/rest-args-error.js\"\nimport TableForeignKey from \"./table-foreign-key.js\"\n\n/**\n * @typedef {object} TableColumnArgsType\n * @property {boolean} [autoIncrement] - Whether the column auto-increments.\n * @property {any} [default] - Default value for the column.\n * @property {boolean} [dropColumn] - Whether the column should be dropped.\n * @property {boolean|object} [foreignKey] - Foreign key options or flag.\n * @property {boolean|IndexArgType} [index] - Whether the column should be indexed.\n * @property {boolean} [isNewColumn] - Whether this column is being added in a migration.\n * @property {number} [limit] - Alias for maxLength (varchar length limit).\n * @property {number} [maxLength] - Maximum length for the column value.\n * @property {string} [notes] - Column notes or comment.\n * @property {boolean} [null] - Whether the column allows null values.\n * @property {boolean} [polymorphic] - Whether the column is polymorphic.\n * @property {number} [precision] - Numeric precision (total digits) for decimal/numeric types.\n * @property {boolean} [primaryKey] - Whether the column is a primary key.\n * @property {number} [scale] - Numeric scale (digits after decimal point) for decimal/numeric types.\n * @property {string} [type] - Column data type.\n */\n\nexport default class TableColumn {\n  /**\n   * @param {string} name - Name.\n   * @param {TableColumnArgsType} [args] - Options object.\n   */\n  constructor(name, args) {\n    if (args) {\n      const {autoIncrement, default: columnDefault, dropColumn, foreignKey, index, isNewColumn, limit, maxLength, notes, null: argsNull, polymorphic, precision, primaryKey, scale, type, ...restArgs} = args // eslint-disable-line no-unused-vars\n\n      if (Object.keys(args).length == 0) {\n        throw new Error(\"Empty args given\")\n      }\n\n      restArgsError(restArgs)\n\n      // Normalize limit → maxLength for string-like types only.\n      if (limit !== undefined && maxLength === undefined) {\n        const normalizedType = typeof type === \"string\" ? type.toLowerCase() : \"\"\n\n        if (normalizedType === \"string\" || normalizedType === \"text\" || normalizedType === \"varchar\" || normalizedType === \"nvarchar\" || normalizedType === \"char\") {\n          args.maxLength = limit\n        }\n      }\n    }\n\n    this.args = args || {}\n    this.name = name\n  }\n\n  /**\n   * @returns {string} name\n   */\n  getName() { return this.name }\n\n  /**\n   * @returns {string | undefined} - The new name.\n   */\n  getNewName() { return this._newName }\n\n  /**\n   * @param {string} newName - New name.\n   * @returns {void} - No return value.\n   */\n  setNewName(newName) { this._newName = newName }\n\n  /**\n   * @returns {string} - The actual name.\n   */\n  getActualName() { return this.getNewName() || this.getName() }\n\n  /**\n   * @returns {boolean} - Whether auto increment.\n   */\n  getAutoIncrement() { return this.args?.autoIncrement || false }\n\n  /**\n   * @param {boolean} newAutoIncrement - New auto increment.\n   * @returns {void} - No return value.\n   */\n  setAutoIncrement(newAutoIncrement) { this.args.autoIncrement = newAutoIncrement }\n\n  /**\n   * @returns {unknown | (() => unknown)} - The default value or factory.\n   */\n  getDefault() { return this.args?.default }\n\n  /**\n   * @param {any} newDefault - New default.\n   * @returns {void} - No return value.\n   */\n  setDefault(newDefault) { this.args.default = newDefault }\n\n  /**\n   * @returns {boolean} - Whether drop column.\n   */\n  getDropColumn() { return this.args?.dropColumn || false }\n\n  /**\n   * @returns {boolean | object | undefined} - Whether foreign key.\n   */\n  getForeignKey() { return this.args?.foreignKey }\n\n  /**\n   * @param {boolean | object | undefined} newForeignKey - New foreign key.\n   * @returns {void} - No return value.\n   */\n  setForeignKey(newForeignKey) { this.args.foreignKey = newForeignKey }\n\n  /**\n   * @returns {boolean|IndexArgType} - Whether index.\n   */\n  getIndex() { return this.args?.index || false }\n\n  /**\n   * @returns {IndexArgType} - The index args.\n   */\n  getIndexArgs() {\n    if (typeof this.args?.index == \"object\") {\n      return this.args.index\n    } else {\n      return {unique: false}\n    }\n  }\n\n  getIndexUnique() {\n    const index = this.args?.index\n\n    if (typeof index == \"object\" && index.unique === true) return true\n\n    return false\n  }\n\n  /**\n   * @param {boolean|IndexArgType} newIndex - New index.\n   * @returns {void} - No return value.\n   */\n  setIndex(newIndex) { this.args.index = newIndex }\n\n  /**\n   * @returns {number | undefined} - The max length.\n   */\n  getMaxLength() { return this.args?.maxLength }\n\n  /**\n   * @param {number | undefined} newMaxLength - New max length.\n   * @returns {void} - No return value.\n   */\n  setMaxLength(newMaxLength) { this.args.maxLength = newMaxLength }\n\n  /**\n   * @returns {string | undefined} - The notes.\n   */\n  getNotes() { return this.args?.notes }\n\n  /**\n   * @param {string | undefined} newNotes - New notes.\n   * @returns {void} - No return value.\n   */\n  setNotes(newNotes) { this.args.notes = newNotes }\n\n  /**\n   * @returns {boolean | undefined} - Whether null.\n   */\n  getNull() { return this.args?.null }\n\n  /**\n   * @param {boolean} nullable - Whether nullable.\n   * @returns {void} - No return value.\n   */\n  setNull(nullable) { this.args.null = nullable }\n\n  /**\n   * @returns {number | undefined} - Numeric precision (total digits).\n   */\n  getPrecision() { return this.args?.precision }\n\n  /**\n   * @returns {boolean} - Whether primary key.\n   */\n  getPrimaryKey() { return this.args?.primaryKey || false }\n\n  /**\n   * @param {boolean} newPrimaryKey - New primary key.\n   * @returns {void} - No return value.\n   */\n  setPrimaryKey(newPrimaryKey) { this.args.primaryKey = newPrimaryKey }\n\n  /**\n   * @returns {number | undefined} - Numeric scale (digits after decimal point).\n   */\n  getScale() { return this.args?.scale }\n\n  /**\n   * @returns {string | undefined} - The type.\n   */\n  getType() { return this.args?.type }\n\n  /**\n   * @param {string | undefined} newType - New type.\n   * @returns {void} - No return value.\n   */\n  setType(newType) { this.args.type = newType }\n\n  /**\n   * @returns {string | undefined} - The type hint notes.\n   */\n  getTypeHintNotes() {\n    if (this.getType()?.toLowerCase() == \"boolean\") return \"velocious:type=boolean\"\n  }\n\n  /**\n   * @param {string} databaseType - Database type.\n   * @returns {string | undefined} - Notes for the database.\n   */\n  getNotesForDatabase(databaseType) {\n    if (![\"mysql\", \"pgsql\"].includes(databaseType)) return\n\n    return this.getNotes() || this.getTypeHintNotes()\n  }\n\n  /**\n   * @returns {boolean} - Whether new column.\n   */\n  isNewColumn() { return this.args?.isNewColumn || false }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {boolean} args.forAlterTable - Whether for alter table.\n   * @param {import(\"../drivers/base.js\").default} args.driver - Database driver instance.\n   * @returns {string} - SQL string.\n   */\n  getSQL({forAlterTable, driver, ...restArgs}) {\n    restArgsError(restArgs)\n\n    const databaseType = driver.getType()\n    const options = driver.options()\n    let maxlength = this.getMaxLength()\n    let type = this.getType()?.toUpperCase()\n\n    if (databaseType == \"pgsql\") {\n      if (type == \"DATETIME\") {\n        type = \"TIMESTAMP\"\n      } else if (type == \"TINYINT\") {\n        type = \"SMALLINT\"\n      } else if (type == \"BLOB\") {\n        type = \"BYTEA\"\n        maxlength = undefined\n      }\n    }\n\n    if (type == \"STRING\") {\n      type = databaseType == \"mssql\" ? \"NVARCHAR\" : \"VARCHAR\"\n      maxlength ||= 255\n    }\n    if (databaseType == \"pgsql\" && type == \"TINYINT\") {\n      type = \"SMALLINT\"\n    }\n\n    if (databaseType == \"mssql\") {\n      if (type == \"BOOLEAN\") {\n        type = \"BIT\"\n      } else if (type == \"UUID\") {\n        type = \"VARCHAR\"\n        maxlength ||= 36\n      } else if (type == \"JSON\") {\n        type = \"NVARCHAR(MAX)\"\n        maxlength = undefined\n      } else if (type == \"BLOB\") {\n        type = \"VARBINARY(MAX)\"\n        maxlength = undefined\n      } else if (type == \"TEXT\") {\n        type = \"NVARCHAR(MAX)\"\n        maxlength = undefined\n      }\n    }\n\n    if (databaseType == \"sqlite\" && this.getAutoIncrement() && this.getPrimaryKey()) {\n      type = \"INTEGER\"\n    }\n\n    if (databaseType == \"pgsql\" && this.getAutoIncrement() && this.getPrimaryKey()) {\n      type = \"SERIAL\"\n    }\n\n    let sql = `${options.quoteColumnName(this.getActualName())} `\n\n    if (databaseType == \"pgsql\" && forAlterTable) sql += \"TYPE \"\n    if (type) sql += type\n\n    const precision = this.getPrecision()\n    const scale = this.getScale()\n\n    if ((scale !== undefined && scale !== null) && (precision === undefined || precision === null)) {\n      throw new Error(`Column '${this.getActualName()}': scale requires precision to be set`)\n    }\n\n    if (precision !== undefined && precision !== null) {\n      sql += scale !== undefined && scale !== null ? `(${precision}, ${scale})` : `(${precision})`\n    } else if (type && maxlength !== undefined && maxlength !== null) {\n      sql += `(${maxlength})`\n    }\n\n    if (this.getAutoIncrement() && driver.shouldSetAutoIncrementWhenPrimaryKey()) {\n      if (databaseType == \"mssql\") {\n        sql += \" IDENTITY\"\n      } else if (databaseType == \"pgsql\") {\n        if (this.getAutoIncrement() && this.getPrimaryKey()) {\n          // Do nothing\n        } else {\n          throw new Error(\"pgsql auto increment must be primary key\")\n        }\n      } else {\n        sql += \" AUTO_INCREMENT\"\n      }\n    }\n\n    const defaultValue = this.getDefault()\n\n    if (typeof defaultValue == \"function\") {\n      const evaluatedDefault = defaultValue()\n\n      sql += ` DEFAULT (`\n\n      if (databaseType == \"pgsql\" && evaluatedDefault == \"UUID()\") {\n        sql += \"gen_random_uuid()\"\n      } else if (databaseType == \"mssql\" && evaluatedDefault == \"UUID()\") {\n        sql += \"NEWID()\"\n      } else {\n        sql += evaluatedDefault\n      }\n\n      sql += \")\"\n    } else if (defaultValue) {\n      sql += ` DEFAULT ${options.quote(defaultValue)}`\n    }\n\n    if (this.getPrimaryKey()) sql += \" PRIMARY KEY\"\n    if (this.getNull() === false) sql += \" NOT NULL\"\n\n    const notes = this.getNotesForDatabase(databaseType)\n\n    if (notes && databaseType == \"mysql\") {\n      sql += ` COMMENT ${options.quote(notes)}`\n    }\n\n    const foreignKey = this.getForeignKey()\n\n    if (foreignKey) {\n      let foreignKeyTable, foreignKeyColumn\n\n      if (foreignKey === true) {\n        foreignKeyColumn = \"id\"\n        foreignKeyTable = inflection.pluralize(this.getActualName().replace(/_id$/, \"\"))\n      } else if (foreignKey instanceof TableForeignKey) {\n        foreignKeyColumn = foreignKey.getReferencedColumnName()\n        foreignKeyTable = foreignKey.getReferencedTableName()\n      } else {\n        throw new Error(`Unknown foreign key type given: ${foreignKey} (${typeof foreignKey})`)\n      }\n\n      sql += ` REFERENCES ${options.quoteTableName(foreignKeyTable)}(${options.quoteColumnName(foreignKeyColumn)})`\n    }\n\n    return sql\n  }\n}\n"]}
|
|
332
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-column.js","sourceRoot":"","sources":["../../../../src/database/table-data/table-column.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\n/**\n * @typedef {{unique: boolean}} IndexArgType\n */\n\nimport * as inflection from \"inflection\"\nimport restArgsError from \"../../utils/rest-args-error.js\"\nimport TableForeignKey from \"./table-foreign-key.js\"\n\n/**\n * @typedef {object} TableColumnArgsType\n * @property {boolean} [autoIncrement] - Whether the column auto-increments.\n * @property {any} [default] - Default value for the column.\n * @property {boolean} [dropColumn] - Whether the column should be dropped.\n * @property {boolean|object} [foreignKey] - Foreign key options or flag.\n * @property {boolean|IndexArgType} [index] - Whether the column should be indexed.\n * @property {boolean} [isNewColumn] - Whether this column is being added in a migration.\n * @property {number} [limit] - Alias for maxLength (varchar length limit).\n * @property {number} [maxLength] - Maximum length for the column value.\n * @property {string} [notes] - Column notes or comment.\n * @property {boolean} [null] - Whether the column allows null values.\n * @property {boolean} [polymorphic] - Whether the column is polymorphic.\n * @property {number} [precision] - Numeric precision (total digits) for decimal/numeric types.\n * @property {boolean} [primaryKey] - Whether the column is a primary key.\n * @property {number} [scale] - Numeric scale (digits after decimal point) for decimal/numeric types.\n * @property {string} [type] - Column data type.\n */\n\nexport default class TableColumn {\n  /**\n   * @param {string} name - Name.\n   * @param {TableColumnArgsType} [args] - Options object.\n   */\n  constructor(name, args) {\n    if (args) {\n      const {autoIncrement, default: columnDefault, dropColumn, foreignKey, index, isNewColumn, limit, maxLength, notes, null: argsNull, polymorphic, precision, primaryKey, scale, type, ...restArgs} = args // eslint-disable-line no-unused-vars\n\n      if (Object.keys(args).length == 0) {\n        throw new Error(\"Empty args given\")\n      }\n\n      restArgsError(restArgs)\n\n      // Normalize limit → maxLength for string-like types only.\n      if (limit !== undefined && maxLength === undefined) {\n        const normalizedType = typeof type === \"string\" ? type.toLowerCase() : \"\"\n\n        if (normalizedType === \"string\" || normalizedType === \"text\" || normalizedType === \"varchar\" || normalizedType === \"nvarchar\" || normalizedType === \"char\") {\n          args.maxLength = limit\n        }\n      }\n    }\n\n    this.args = args || {}\n    this.name = name\n  }\n\n  /**\n   * @returns {string} name\n   */\n  getName() { return this.name }\n\n  /**\n   * @returns {string | undefined} - The new name.\n   */\n  getNewName() { return this._newName }\n\n  /**\n   * @param {string} newName - New name.\n   * @returns {void} - No return value.\n   */\n  setNewName(newName) { this._newName = newName }\n\n  /**\n   * @returns {string} - The actual name.\n   */\n  getActualName() { return this.getNewName() || this.getName() }\n\n  /**\n   * @returns {boolean} - Whether auto increment.\n   */\n  getAutoIncrement() { return this.args?.autoIncrement || false }\n\n  /**\n   * @param {boolean} newAutoIncrement - New auto increment.\n   * @returns {void} - No return value.\n   */\n  setAutoIncrement(newAutoIncrement) { this.args.autoIncrement = newAutoIncrement }\n\n  /**\n   * @returns {unknown | (() => unknown)} - The default value or factory.\n   */\n  getDefault() { return this.args?.default }\n\n  /**\n   * @param {any} newDefault - New default.\n   * @returns {void} - No return value.\n   */\n  setDefault(newDefault) { this.args.default = newDefault }\n\n  /**\n   * @returns {boolean} - Whether drop column.\n   */\n  getDropColumn() { return this.args?.dropColumn || false }\n\n  /**\n   * @returns {boolean | object | undefined} - Whether foreign key.\n   */\n  getForeignKey() { return this.args?.foreignKey }\n\n  /**\n   * @param {boolean | object | undefined} newForeignKey - New foreign key.\n   * @returns {void} - No return value.\n   */\n  setForeignKey(newForeignKey) { this.args.foreignKey = newForeignKey }\n\n  /**\n   * @returns {boolean|IndexArgType} - Whether index.\n   */\n  getIndex() { return this.args?.index || false }\n\n  /**\n   * @returns {IndexArgType} - The index args.\n   */\n  getIndexArgs() {\n    if (typeof this.args?.index == \"object\") {\n      return this.args.index\n    } else {\n      return {unique: false}\n    }\n  }\n\n  getIndexUnique() {\n    const index = this.args?.index\n\n    if (typeof index == \"object\" && index.unique === true) return true\n\n    return false\n  }\n\n  /**\n   * @param {boolean|IndexArgType} newIndex - New index.\n   * @returns {void} - No return value.\n   */\n  setIndex(newIndex) { this.args.index = newIndex }\n\n  /**\n   * @returns {number | undefined} - The max length.\n   */\n  getMaxLength() { return this.args?.maxLength }\n\n  /**\n   * @param {number | undefined} newMaxLength - New max length.\n   * @returns {void} - No return value.\n   */\n  setMaxLength(newMaxLength) { this.args.maxLength = newMaxLength }\n\n  /**\n   * @returns {string | undefined} - The notes.\n   */\n  getNotes() { return this.args?.notes }\n\n  /**\n   * @param {string | undefined} newNotes - New notes.\n   * @returns {void} - No return value.\n   */\n  setNotes(newNotes) { this.args.notes = newNotes }\n\n  /**\n   * @returns {boolean | undefined} - Whether null.\n   */\n  getNull() { return this.args?.null }\n\n  /**\n   * @param {boolean} nullable - Whether nullable.\n   * @returns {void} - No return value.\n   */\n  setNull(nullable) { this.args.null = nullable }\n\n  /**\n   * @returns {number | undefined} - Numeric precision (total digits).\n   */\n  getPrecision() { return this.args?.precision }\n\n  /**\n   * @returns {boolean} - Whether primary key.\n   */\n  getPrimaryKey() { return this.args?.primaryKey || false }\n\n  /**\n   * @param {boolean} newPrimaryKey - New primary key.\n   * @returns {void} - No return value.\n   */\n  setPrimaryKey(newPrimaryKey) { this.args.primaryKey = newPrimaryKey }\n\n  /**\n   * @returns {number | undefined} - Numeric scale (digits after decimal point).\n   */\n  getScale() { return this.args?.scale }\n\n  /**\n   * @returns {string | undefined} - The type.\n   */\n  getType() { return this.args?.type }\n\n  /**\n   * @param {string | undefined} newType - New type.\n   * @returns {void} - No return value.\n   */\n  setType(newType) { this.args.type = newType }\n\n  /**\n   * @returns {string | undefined} - The type hint notes.\n   */\n  getTypeHintNotes() {\n    if (this.getType()?.toLowerCase() == \"boolean\") return \"velocious:type=boolean\"\n  }\n\n  /**\n   * @param {string} databaseType - Database type.\n   * @returns {string | undefined} - Notes for the database.\n   */\n  getNotesForDatabase(databaseType) {\n    if (![\"mysql\", \"pgsql\"].includes(databaseType)) return\n\n    return this.getNotes() || this.getTypeHintNotes()\n  }\n\n  /**\n   * @returns {boolean} - Whether new column.\n   */\n  isNewColumn() { return this.args?.isNewColumn || false }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {boolean} args.forAlterTable - Whether for alter table.\n   * @param {import(\"../drivers/base.js\").default} args.driver - Database driver instance.\n   * @param {boolean} [args.skipForeignKey] - Skip emitting the inline REFERENCES clause (the caller emits a table-level FOREIGN KEY constraint instead).\n   * @returns {string} - SQL string.\n   */\n  getSQL({forAlterTable, driver, skipForeignKey, ...restArgs}) {\n    restArgsError(restArgs)\n\n    const databaseType = driver.getType()\n    const options = driver.options()\n    let maxlength = this.getMaxLength()\n    let type = this.getType()?.toUpperCase()\n\n    if (databaseType == \"pgsql\") {\n      if (type == \"DATETIME\") {\n        type = \"TIMESTAMP\"\n      } else if (type == \"TINYINT\") {\n        type = \"SMALLINT\"\n      } else if (type == \"BLOB\") {\n        type = \"BYTEA\"\n        maxlength = undefined\n      }\n    }\n\n    if (type == \"STRING\") {\n      type = databaseType == \"mssql\" ? \"NVARCHAR\" : \"VARCHAR\"\n      maxlength ||= 255\n    }\n    if (databaseType == \"pgsql\" && type == \"TINYINT\") {\n      type = \"SMALLINT\"\n    }\n\n    if (databaseType == \"mssql\") {\n      if (type == \"BOOLEAN\") {\n        type = \"BIT\"\n      } else if (type == \"UUID\") {\n        type = \"VARCHAR\"\n        maxlength ||= 36\n      } else if (type == \"JSON\") {\n        type = \"NVARCHAR(MAX)\"\n        maxlength = undefined\n      } else if (type == \"BLOB\") {\n        type = \"VARBINARY(MAX)\"\n        maxlength = undefined\n      } else if (type == \"TEXT\") {\n        type = \"NVARCHAR(MAX)\"\n        maxlength = undefined\n      }\n    }\n\n    if (databaseType == \"sqlite\" && this.getAutoIncrement() && this.getPrimaryKey()) {\n      type = \"INTEGER\"\n    }\n\n    if (databaseType == \"pgsql\" && this.getAutoIncrement() && this.getPrimaryKey()) {\n      type = \"SERIAL\"\n    }\n\n    let sql = `${options.quoteColumnName(this.getActualName())} `\n\n    if (databaseType == \"pgsql\" && forAlterTable) sql += \"TYPE \"\n    if (type) sql += type\n\n    const precision = this.getPrecision()\n    const scale = this.getScale()\n\n    if ((scale !== undefined && scale !== null) && (precision === undefined || precision === null)) {\n      throw new Error(`Column '${this.getActualName()}': scale requires precision to be set`)\n    }\n\n    if (precision !== undefined && precision !== null) {\n      sql += scale !== undefined && scale !== null ? `(${precision}, ${scale})` : `(${precision})`\n    } else if (type && maxlength !== undefined && maxlength !== null) {\n      sql += `(${maxlength})`\n    }\n\n    if (this.getAutoIncrement() && driver.shouldSetAutoIncrementWhenPrimaryKey()) {\n      if (databaseType == \"mssql\") {\n        sql += \" IDENTITY\"\n      } else if (databaseType == \"pgsql\") {\n        if (this.getAutoIncrement() && this.getPrimaryKey()) {\n          // Do nothing\n        } else {\n          throw new Error(\"pgsql auto increment must be primary key\")\n        }\n      } else {\n        sql += \" AUTO_INCREMENT\"\n      }\n    }\n\n    const defaultValue = this.getDefault()\n\n    if (typeof defaultValue == \"function\") {\n      const evaluatedDefault = defaultValue()\n\n      sql += ` DEFAULT (`\n\n      if (databaseType == \"pgsql\" && evaluatedDefault == \"UUID()\") {\n        sql += \"gen_random_uuid()\"\n      } else if (databaseType == \"mssql\" && evaluatedDefault == \"UUID()\") {\n        sql += \"NEWID()\"\n      } else {\n        sql += evaluatedDefault\n      }\n\n      sql += \")\"\n    } else if (defaultValue) {\n      sql += ` DEFAULT ${options.quote(defaultValue)}`\n    }\n\n    if (this.getPrimaryKey()) sql += \" PRIMARY KEY\"\n    if (this.getNull() === false) sql += \" NOT NULL\"\n\n    const notes = this.getNotesForDatabase(databaseType)\n\n    if (notes && databaseType == \"mysql\") {\n      sql += ` COMMENT ${options.quote(notes)}`\n    }\n\n    const foreignKey = skipForeignKey ? undefined : this.getForeignKey()\n\n    if (foreignKey) {\n      let foreignKeyTable, foreignKeyColumn\n\n      if (foreignKey === true) {\n        foreignKeyColumn = \"id\"\n        foreignKeyTable = inflection.pluralize(this.getActualName().replace(/_id$/, \"\"))\n      } else if (foreignKey instanceof TableForeignKey) {\n        foreignKeyColumn = foreignKey.getReferencedColumnName()\n        foreignKeyTable = foreignKey.getReferencedTableName()\n      } else {\n        throw new Error(`Unknown foreign key type given: ${foreignKey} (${typeof foreignKey})`)\n      }\n\n      sql += ` REFERENCES ${options.quoteTableName(foreignKeyTable)}(${options.quoteColumnName(foreignKeyColumn)})`\n    }\n\n    return sql\n  }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"root":["../index.js","../bin/velocious.js","../src/application.js","../src/configuration-resolver.js","../src/configuration-types.js","../src/configuration.js","../src/controller.js","../src/current.js","../src/error-logger.js","../src/frontend-model-controller.js","../src/initializer.js","../src/logger.js","../src/mailer.js","../src/velocious-error.js","../src/authorization/ability.js","../src/authorization/base-resource.js","../src/background-jobs/client.js","../src/background-jobs/cron-expression.js","../src/background-jobs/job-record.js","../src/background-jobs/job-registry.js","../src/background-jobs/job-runner.js","../src/background-jobs/job.js","../src/background-jobs/json-socket.js","../src/background-jobs/main.js","../src/background-jobs/scheduler.js","../src/background-jobs/status-reporter.js","../src/background-jobs/store.js","../src/background-jobs/types.js","../src/background-jobs/worker.js","../src/cli/base-command.js","../src/cli/browser-cli.js","../src/cli/index.js","../src/cli/use-browser-cli.js","../src/cli/commands/background-jobs-main.js","../src/cli/commands/background-jobs-runner.js","../src/cli/commands/background-jobs-worker.js","../src/cli/commands/console.js","../src/cli/commands/init.js","../src/cli/commands/routes.js","../src/cli/commands/run-script.js","../src/cli/commands/runner.js","../src/cli/commands/server.js","../src/cli/commands/test.js","../src/cli/commands/db/create.js","../src/cli/commands/db/drop.js","../src/cli/commands/db/migrate.js","../src/cli/commands/db/reset.js","../src/cli/commands/db/rollback.js","../src/cli/commands/db/seed.js","../src/cli/commands/db/schema/dump.js","../src/cli/commands/db/schema/load.js","../src/cli/commands/destroy/migration.js","../src/cli/commands/generate/base-models.js","../src/cli/commands/generate/frontend-models.js","../src/cli/commands/generate/migration.js","../src/cli/commands/generate/model.js","../src/database/handler.js","../src/database/initializer-from-require-context.js","../src/database/migrator.js","../src/database/use-database.js","../src/database/drivers/base-column.js","../src/database/drivers/base-columns-index.js","../src/database/drivers/base-foreign-key.js","../src/database/drivers/base-table.js","../src/database/drivers/base.js","../src/database/drivers/mssql/column.js","../src/database/drivers/mssql/columns-index.js","../src/database/drivers/mssql/connect-connection.js","../src/database/drivers/mssql/foreign-key.js","../src/database/drivers/mssql/index.js","../src/database/drivers/mssql/options.js","../src/database/drivers/mssql/query-parser.js","../src/database/drivers/mssql/structure-sql.js","../src/database/drivers/mssql/table.js","../src/database/drivers/mssql/sql/alter-table.js","../src/database/drivers/mssql/sql/create-database.js","../src/database/drivers/mssql/sql/create-index.js","../src/database/drivers/mssql/sql/create-table.js","../src/database/drivers/mssql/sql/delete.js","../src/database/drivers/mssql/sql/drop-database.js","../src/database/drivers/mssql/sql/drop-table.js","../src/database/drivers/mssql/sql/insert.js","../src/database/drivers/mssql/sql/update.js","../src/database/drivers/mssql/sql/upsert.js","../src/database/drivers/mysql/column.js","../src/database/drivers/mysql/columns-index.js","../src/database/drivers/mysql/foreign-key.js","../src/database/drivers/mysql/index.js","../src/database/drivers/mysql/options.js","../src/database/drivers/mysql/query-parser.js","../src/database/drivers/mysql/query.js","../src/database/drivers/mysql/structure-sql.js","../src/database/drivers/mysql/table.js","../src/database/drivers/mysql/sql/alter-table.js","../src/database/drivers/mysql/sql/create-database.js","../src/database/drivers/mysql/sql/create-index.js","../src/database/drivers/mysql/sql/create-table.js","../src/database/drivers/mysql/sql/delete.js","../src/database/drivers/mysql/sql/drop-database.js","../src/database/drivers/mysql/sql/drop-table.js","../src/database/drivers/mysql/sql/insert.js","../src/database/drivers/mysql/sql/update.js","../src/database/drivers/mysql/sql/upsert.js","../src/database/drivers/pgsql/column.js","../src/database/drivers/pgsql/columns-index.js","../src/database/drivers/pgsql/foreign-key.js","../src/database/drivers/pgsql/index.js","../src/database/drivers/pgsql/options.js","../src/database/drivers/pgsql/query-parser.js","../src/database/drivers/pgsql/structure-sql.js","../src/database/drivers/pgsql/table.js","../src/database/drivers/pgsql/sql/alter-table.js","../src/database/drivers/pgsql/sql/create-database.js","../src/database/drivers/pgsql/sql/create-index.js","../src/database/drivers/pgsql/sql/create-table.js","../src/database/drivers/pgsql/sql/delete.js","../src/database/drivers/pgsql/sql/drop-database.js","../src/database/drivers/pgsql/sql/drop-table.js","../src/database/drivers/pgsql/sql/insert.js","../src/database/drivers/pgsql/sql/update.js","../src/database/drivers/pgsql/sql/upsert.js","../src/database/drivers/sqlite/base.js","../src/database/drivers/sqlite/column.js","../src/database/drivers/sqlite/columns-index.js","../src/database/drivers/sqlite/connection-sql-js.js","../src/database/drivers/sqlite/foreign-key.js","../src/database/drivers/sqlite/index.js","../src/database/drivers/sqlite/index.native.js","../src/database/drivers/sqlite/index.web.js","../src/database/drivers/sqlite/options.js","../src/database/drivers/sqlite/query-parser.js","../src/database/drivers/sqlite/query.js","../src/database/drivers/sqlite/query.native.js","../src/database/drivers/sqlite/query.web.js","../src/database/drivers/sqlite/structure-sql.js","../src/database/drivers/sqlite/table.js","../src/database/drivers/sqlite/sql/alter-table.js","../src/database/drivers/sqlite/sql/create-index.js","../src/database/drivers/sqlite/sql/create-table.js","../src/database/drivers/sqlite/sql/delete.js","../src/database/drivers/sqlite/sql/drop-table.js","../src/database/drivers/sqlite/sql/insert.js","../src/database/drivers/sqlite/sql/update.js","../src/database/drivers/sqlite/sql/upsert.js","../src/database/drivers/structure-sql/utils.js","../src/database/migration/index.js","../src/database/migrator/files-finder.js","../src/database/migrator/types.js","../src/database/pool/async-tracked-multi-connection.js","../src/database/pool/base-methods-forward.js","../src/database/pool/base.js","../src/database/pool/single-multi-use.js","../src/database/query/alter-table-base.js","../src/database/query/base.js","../src/database/query/create-database-base.js","../src/database/query/create-index-base.js","../src/database/query/create-table-base.js","../src/database/query/delete-base.js","../src/database/query/drop-database-base.js","../src/database/query/drop-table-base.js","../src/database/query/from-base.js","../src/database/query/from-plain.js","../src/database/query/from-table.js","../src/database/query/index.js","../src/database/query/insert-base.js","../src/database/query/join-base.js","../src/database/query/join-object.js","../src/database/query/join-plain.js","../src/database/query/join-tracker.js","../src/database/query/model-class-query.js","../src/database/query/order-base.js","../src/database/query/order-plain.js","../src/database/query/preloader.js","../src/database/query/query-data.js","../src/database/query/select-base.js","../src/database/query/select-plain.js","../src/database/query/select-table-and-column.js","../src/database/query/update-base.js","../src/database/query/upsert-base.js","../src/database/query/where-base.js","../src/database/query/where-hash.js","../src/database/query/where-model-class-hash.js","../src/database/query/where-not.js","../src/database/query/where-plain.js","../src/database/query/with-count.js","../src/database/query/preloader/belongs-to.js","../src/database/query/preloader/has-many.js","../src/database/query/preloader/has-one.js","../src/database/query-parser/base-query-parser.js","../src/database/query-parser/from-parser.js","../src/database/query-parser/group-parser.js","../src/database/query-parser/joins-parser.js","../src/database/query-parser/limit-parser.js","../src/database/query-parser/options.js","../src/database/query-parser/order-parser.js","../src/database/query-parser/select-parser.js","../src/database/query-parser/where-parser.js","../src/database/record/index.js","../src/database/record/record-not-found-error.js","../src/database/record/state-machine.js","../src/database/record/user-module.js","../src/database/record/attachments/download.js","../src/database/record/attachments/handle.js","../src/database/record/attachments/normalize-input.js","../src/database/record/attachments/store.js","../src/database/record/attachments/storage-drivers/filesystem.js","../src/database/record/attachments/storage-drivers/native.js","../src/database/record/attachments/storage-drivers/s3.js","../src/database/record/instance-relationships/base.js","../src/database/record/instance-relationships/belongs-to.js","../src/database/record/instance-relationships/has-many.js","../src/database/record/instance-relationships/has-one.js","../src/database/record/relationships/base.js","../src/database/record/relationships/belongs-to.js","../src/database/record/relationships/has-many.js","../src/database/record/relationships/has-one.js","../src/database/record/validators/base.js","../src/database/record/validators/format.js","../src/database/record/validators/presence.js","../src/database/record/validators/uniqueness.js","../src/database/table-data/index.js","../src/database/table-data/table-column.js","../src/database/table-data/table-foreign-key.js","../src/database/table-data/table-index.js","../src/database/table-data/table-reference.js","../src/environment-handlers/base.js","../src/environment-handlers/browser.js","../src/environment-handlers/node.js","../src/environment-handlers/node/cli/commands/background-jobs-main.js","../src/environment-handlers/node/cli/commands/background-jobs-runner.js","../src/environment-handlers/node/cli/commands/background-jobs-worker.js","../src/environment-handlers/node/cli/commands/console.js","../src/environment-handlers/node/cli/commands/init.js","../src/environment-handlers/node/cli/commands/routes.js","../src/environment-handlers/node/cli/commands/run-script.js","../src/environment-handlers/node/cli/commands/runner.js","../src/environment-handlers/node/cli/commands/server.js","../src/environment-handlers/node/cli/commands/test.js","../src/environment-handlers/node/cli/commands/db/seed.js","../src/environment-handlers/node/cli/commands/db/schema/dump.js","../src/environment-handlers/node/cli/commands/db/schema/load.js","../src/environment-handlers/node/cli/commands/destroy/migration.js","../src/environment-handlers/node/cli/commands/generate/base-models.js","../src/environment-handlers/node/cli/commands/generate/frontend-models.js","../src/environment-handlers/node/cli/commands/generate/migration.js","../src/environment-handlers/node/cli/commands/generate/model.js","../src/frontend-model-resource/base-resource.js","../src/frontend-models/base.js","../src/frontend-models/model-registry.js","../src/frontend-models/outgoing-event-buffer.js","../src/frontend-models/query.js","../src/frontend-models/resource-config-validation.js","../src/frontend-models/resource-definition.js","../src/frontend-models/transport-serialization.js","../src/frontend-models/websocket-channel.js","../src/frontend-models/websocket-publishers.js","../src/http-client/header.js","../src/http-client/index.js","../src/http-client/request.js","../src/http-client/response.js","../src/http-client/websocket-channel.js","../src/http-client/websocket-client.js","../src/http-client/websocket-connection.js","../src/http-server/cookie.js","../src/http-server/development-reloader.js","../src/http-server/index.js","../src/http-server/server-client.js","../src/http-server/websocket-channel-subscribers.js","../src/http-server/websocket-channel.js","../src/http-server/websocket-connection.js","../src/http-server/websocket-event-log-store.js","../src/http-server/websocket-events-host.js","../src/http-server/websocket-events.js","../src/http-server/client/index.js","../src/http-server/client/params-to-object.js","../src/http-server/client/request-parser.js","../src/http-server/client/request-runner.js","../src/http-server/client/request.js","../src/http-server/client/response.js","../src/http-server/client/websocket-request.js","../src/http-server/client/websocket-session.js","../src/http-server/client/request-buffer/form-data-part.js","../src/http-server/client/request-buffer/header.js","../src/http-server/client/request-buffer/index.js","../src/http-server/client/uploaded-file/memory-uploaded-file.js","../src/http-server/client/uploaded-file/temporary-uploaded-file.js","../src/http-server/client/uploaded-file/uploaded-file.js","../src/http-server/worker-handler/in-process.js","../src/http-server/worker-handler/index.js","../src/http-server/worker-handler/worker-script.js","../src/http-server/worker-handler/worker-thread.js","../src/jobs/mail-delivery.js","../src/logger/base-logger.js","../src/logger/console-logger.js","../src/logger/file-logger.js","../src/logger/outputs/array-output.js","../src/logger/outputs/console-output.js","../src/logger/outputs/file-output.js","../src/logger/outputs/stdout-output.js","../src/mailer/base.js","../src/mailer/delivery.js","../src/mailer/index.js","../src/mailer/backends/smtp.js","../src/plugins/sqljs-wasm-route-controller.js","../src/plugins/sqljs-wasm-route.js","../src/routes/app-routes.js","../src/routes/base-route.js","../src/routes/basic-route.js","../src/routes/get-route.js","../src/routes/index.js","../src/routes/namespace-route.js","../src/routes/plugin-routes.js","../src/routes/post-route.js","../src/routes/resolver.js","../src/routes/resource-route.js","../src/routes/root-route.js","../src/routes/built-in/errors/controller.js","../src/routes/hooks/frontend-model-command-route-hook.js","../src/testing/base-expect.js","../src/testing/browser-test-app.js","../src/testing/expect-to-change.js","../src/testing/expect-utils.js","../src/testing/expect.js","../src/testing/request-client.js","../src/testing/test-files-finder.js","../src/testing/test-filter-parser.js","../src/testing/test-runner.js","../src/testing/test-suite-splitter.js","../src/testing/test.js","../src/types/external-modules.d.ts","../src/utils/backtrace-cleaner.js","../src/utils/ensure-error.js","../src/utils/event-emitter.js","../src/utils/file-exists.js","../src/utils/format-value.js","../src/utils/model-scope.js","../src/utils/nest-callbacks.js","../src/utils/ransack.js","../src/utils/rest-args-error.js","../src/utils/singularize-model-name.js","../src/utils/split-sql-statements.js","../src/utils/to-import-specifier.js","../src/utils/with-tracked-stack-async-hooks.js","../src/utils/with-tracked-stack.js"],"version":"6.0.3"}
|
|
1
|
+
{"root":["../index.js","../bin/velocious.js","../src/application.js","../src/configuration-resolver.js","../src/configuration-types.js","../src/configuration.js","../src/controller.js","../src/current.js","../src/error-logger.js","../src/frontend-model-controller.js","../src/initializer.js","../src/logger.js","../src/mailer.js","../src/velocious-error.js","../src/authorization/ability.js","../src/authorization/base-resource.js","../src/background-jobs/client.js","../src/background-jobs/cron-expression.js","../src/background-jobs/job-record.js","../src/background-jobs/job-registry.js","../src/background-jobs/job-runner.js","../src/background-jobs/job.js","../src/background-jobs/json-socket.js","../src/background-jobs/main.js","../src/background-jobs/scheduler.js","../src/background-jobs/status-reporter.js","../src/background-jobs/store.js","../src/background-jobs/types.js","../src/background-jobs/worker.js","../src/cli/base-command.js","../src/cli/browser-cli.js","../src/cli/index.js","../src/cli/use-browser-cli.js","../src/cli/commands/background-jobs-main.js","../src/cli/commands/background-jobs-runner.js","../src/cli/commands/background-jobs-worker.js","../src/cli/commands/console.js","../src/cli/commands/init.js","../src/cli/commands/routes.js","../src/cli/commands/run-script.js","../src/cli/commands/runner.js","../src/cli/commands/server.js","../src/cli/commands/test.js","../src/cli/commands/db/create.js","../src/cli/commands/db/drop.js","../src/cli/commands/db/migrate.js","../src/cli/commands/db/reset.js","../src/cli/commands/db/rollback.js","../src/cli/commands/db/seed.js","../src/cli/commands/db/schema/dump.js","../src/cli/commands/db/schema/load.js","../src/cli/commands/destroy/migration.js","../src/cli/commands/generate/base-models.js","../src/cli/commands/generate/frontend-models.js","../src/cli/commands/generate/migration.js","../src/cli/commands/generate/model.js","../src/database/handler.js","../src/database/initializer-from-require-context.js","../src/database/migrator.js","../src/database/use-database.js","../src/database/drivers/base-column.js","../src/database/drivers/base-columns-index.js","../src/database/drivers/base-foreign-key.js","../src/database/drivers/base-table.js","../src/database/drivers/base.js","../src/database/drivers/mssql/column.js","../src/database/drivers/mssql/columns-index.js","../src/database/drivers/mssql/connect-connection.js","../src/database/drivers/mssql/foreign-key.js","../src/database/drivers/mssql/index.js","../src/database/drivers/mssql/options.js","../src/database/drivers/mssql/query-parser.js","../src/database/drivers/mssql/structure-sql.js","../src/database/drivers/mssql/table.js","../src/database/drivers/mssql/sql/alter-table.js","../src/database/drivers/mssql/sql/create-database.js","../src/database/drivers/mssql/sql/create-index.js","../src/database/drivers/mssql/sql/create-table.js","../src/database/drivers/mssql/sql/delete.js","../src/database/drivers/mssql/sql/drop-database.js","../src/database/drivers/mssql/sql/drop-table.js","../src/database/drivers/mssql/sql/insert.js","../src/database/drivers/mssql/sql/update.js","../src/database/drivers/mssql/sql/upsert.js","../src/database/drivers/mysql/column.js","../src/database/drivers/mysql/columns-index.js","../src/database/drivers/mysql/foreign-key.js","../src/database/drivers/mysql/index.js","../src/database/drivers/mysql/options.js","../src/database/drivers/mysql/query-parser.js","../src/database/drivers/mysql/query.js","../src/database/drivers/mysql/structure-sql.js","../src/database/drivers/mysql/table.js","../src/database/drivers/mysql/sql/alter-table.js","../src/database/drivers/mysql/sql/create-database.js","../src/database/drivers/mysql/sql/create-index.js","../src/database/drivers/mysql/sql/create-table.js","../src/database/drivers/mysql/sql/delete.js","../src/database/drivers/mysql/sql/drop-database.js","../src/database/drivers/mysql/sql/drop-table.js","../src/database/drivers/mysql/sql/insert.js","../src/database/drivers/mysql/sql/update.js","../src/database/drivers/mysql/sql/upsert.js","../src/database/drivers/pgsql/column.js","../src/database/drivers/pgsql/columns-index.js","../src/database/drivers/pgsql/foreign-key.js","../src/database/drivers/pgsql/index.js","../src/database/drivers/pgsql/options.js","../src/database/drivers/pgsql/query-parser.js","../src/database/drivers/pgsql/structure-sql.js","../src/database/drivers/pgsql/table.js","../src/database/drivers/pgsql/sql/alter-table.js","../src/database/drivers/pgsql/sql/create-database.js","../src/database/drivers/pgsql/sql/create-index.js","../src/database/drivers/pgsql/sql/create-table.js","../src/database/drivers/pgsql/sql/delete.js","../src/database/drivers/pgsql/sql/drop-database.js","../src/database/drivers/pgsql/sql/drop-table.js","../src/database/drivers/pgsql/sql/insert.js","../src/database/drivers/pgsql/sql/update.js","../src/database/drivers/pgsql/sql/upsert.js","../src/database/drivers/sqlite/base.js","../src/database/drivers/sqlite/column.js","../src/database/drivers/sqlite/columns-index.js","../src/database/drivers/sqlite/connection-sql-js.js","../src/database/drivers/sqlite/foreign-key.js","../src/database/drivers/sqlite/index.js","../src/database/drivers/sqlite/index.native.js","../src/database/drivers/sqlite/index.web.js","../src/database/drivers/sqlite/options.js","../src/database/drivers/sqlite/query-parser.js","../src/database/drivers/sqlite/query.js","../src/database/drivers/sqlite/query.native.js","../src/database/drivers/sqlite/query.web.js","../src/database/drivers/sqlite/structure-sql.js","../src/database/drivers/sqlite/table-rebuilder.js","../src/database/drivers/sqlite/table.js","../src/database/drivers/sqlite/sql/alter-table.js","../src/database/drivers/sqlite/sql/create-index.js","../src/database/drivers/sqlite/sql/create-table.js","../src/database/drivers/sqlite/sql/delete.js","../src/database/drivers/sqlite/sql/drop-table.js","../src/database/drivers/sqlite/sql/insert.js","../src/database/drivers/sqlite/sql/update.js","../src/database/drivers/sqlite/sql/upsert.js","../src/database/drivers/structure-sql/utils.js","../src/database/migration/index.js","../src/database/migrator/files-finder.js","../src/database/migrator/types.js","../src/database/pool/async-tracked-multi-connection.js","../src/database/pool/base-methods-forward.js","../src/database/pool/base.js","../src/database/pool/single-multi-use.js","../src/database/query/alter-table-base.js","../src/database/query/base.js","../src/database/query/create-database-base.js","../src/database/query/create-index-base.js","../src/database/query/create-table-base.js","../src/database/query/delete-base.js","../src/database/query/drop-database-base.js","../src/database/query/drop-table-base.js","../src/database/query/from-base.js","../src/database/query/from-plain.js","../src/database/query/from-table.js","../src/database/query/index.js","../src/database/query/insert-base.js","../src/database/query/join-base.js","../src/database/query/join-object.js","../src/database/query/join-plain.js","../src/database/query/join-tracker.js","../src/database/query/model-class-query.js","../src/database/query/order-base.js","../src/database/query/order-plain.js","../src/database/query/preloader.js","../src/database/query/query-data.js","../src/database/query/select-base.js","../src/database/query/select-plain.js","../src/database/query/select-table-and-column.js","../src/database/query/update-base.js","../src/database/query/upsert-base.js","../src/database/query/where-base.js","../src/database/query/where-hash.js","../src/database/query/where-model-class-hash.js","../src/database/query/where-not.js","../src/database/query/where-plain.js","../src/database/query/with-count.js","../src/database/query/preloader/belongs-to.js","../src/database/query/preloader/has-many.js","../src/database/query/preloader/has-one.js","../src/database/query-parser/base-query-parser.js","../src/database/query-parser/from-parser.js","../src/database/query-parser/group-parser.js","../src/database/query-parser/joins-parser.js","../src/database/query-parser/limit-parser.js","../src/database/query-parser/options.js","../src/database/query-parser/order-parser.js","../src/database/query-parser/select-parser.js","../src/database/query-parser/where-parser.js","../src/database/record/index.js","../src/database/record/record-not-found-error.js","../src/database/record/state-machine.js","../src/database/record/user-module.js","../src/database/record/attachments/download.js","../src/database/record/attachments/handle.js","../src/database/record/attachments/normalize-input.js","../src/database/record/attachments/store.js","../src/database/record/attachments/storage-drivers/filesystem.js","../src/database/record/attachments/storage-drivers/native.js","../src/database/record/attachments/storage-drivers/s3.js","../src/database/record/instance-relationships/base.js","../src/database/record/instance-relationships/belongs-to.js","../src/database/record/instance-relationships/has-many.js","../src/database/record/instance-relationships/has-one.js","../src/database/record/relationships/base.js","../src/database/record/relationships/belongs-to.js","../src/database/record/relationships/has-many.js","../src/database/record/relationships/has-one.js","../src/database/record/validators/base.js","../src/database/record/validators/format.js","../src/database/record/validators/presence.js","../src/database/record/validators/uniqueness.js","../src/database/table-data/index.js","../src/database/table-data/table-column.js","../src/database/table-data/table-foreign-key.js","../src/database/table-data/table-index.js","../src/database/table-data/table-reference.js","../src/environment-handlers/base.js","../src/environment-handlers/browser.js","../src/environment-handlers/node.js","../src/environment-handlers/node/cli/commands/background-jobs-main.js","../src/environment-handlers/node/cli/commands/background-jobs-runner.js","../src/environment-handlers/node/cli/commands/background-jobs-worker.js","../src/environment-handlers/node/cli/commands/console.js","../src/environment-handlers/node/cli/commands/init.js","../src/environment-handlers/node/cli/commands/routes.js","../src/environment-handlers/node/cli/commands/run-script.js","../src/environment-handlers/node/cli/commands/runner.js","../src/environment-handlers/node/cli/commands/server.js","../src/environment-handlers/node/cli/commands/test.js","../src/environment-handlers/node/cli/commands/db/seed.js","../src/environment-handlers/node/cli/commands/db/schema/dump.js","../src/environment-handlers/node/cli/commands/db/schema/load.js","../src/environment-handlers/node/cli/commands/destroy/migration.js","../src/environment-handlers/node/cli/commands/generate/base-models.js","../src/environment-handlers/node/cli/commands/generate/frontend-models.js","../src/environment-handlers/node/cli/commands/generate/migration.js","../src/environment-handlers/node/cli/commands/generate/model.js","../src/frontend-model-resource/base-resource.js","../src/frontend-models/base.js","../src/frontend-models/model-registry.js","../src/frontend-models/outgoing-event-buffer.js","../src/frontend-models/query.js","../src/frontend-models/resource-config-validation.js","../src/frontend-models/resource-definition.js","../src/frontend-models/transport-serialization.js","../src/frontend-models/websocket-channel.js","../src/frontend-models/websocket-publishers.js","../src/http-client/header.js","../src/http-client/index.js","../src/http-client/request.js","../src/http-client/response.js","../src/http-client/websocket-channel.js","../src/http-client/websocket-client.js","../src/http-client/websocket-connection.js","../src/http-server/cookie.js","../src/http-server/development-reloader.js","../src/http-server/index.js","../src/http-server/server-client.js","../src/http-server/websocket-channel-subscribers.js","../src/http-server/websocket-channel.js","../src/http-server/websocket-connection.js","../src/http-server/websocket-event-log-store.js","../src/http-server/websocket-events-host.js","../src/http-server/websocket-events.js","../src/http-server/client/index.js","../src/http-server/client/params-to-object.js","../src/http-server/client/request-parser.js","../src/http-server/client/request-runner.js","../src/http-server/client/request.js","../src/http-server/client/response.js","../src/http-server/client/websocket-request.js","../src/http-server/client/websocket-session.js","../src/http-server/client/request-buffer/form-data-part.js","../src/http-server/client/request-buffer/header.js","../src/http-server/client/request-buffer/index.js","../src/http-server/client/uploaded-file/memory-uploaded-file.js","../src/http-server/client/uploaded-file/temporary-uploaded-file.js","../src/http-server/client/uploaded-file/uploaded-file.js","../src/http-server/worker-handler/in-process.js","../src/http-server/worker-handler/index.js","../src/http-server/worker-handler/worker-script.js","../src/http-server/worker-handler/worker-thread.js","../src/jobs/mail-delivery.js","../src/logger/base-logger.js","../src/logger/console-logger.js","../src/logger/file-logger.js","../src/logger/outputs/array-output.js","../src/logger/outputs/console-output.js","../src/logger/outputs/file-output.js","../src/logger/outputs/stdout-output.js","../src/mailer/base.js","../src/mailer/delivery.js","../src/mailer/index.js","../src/mailer/backends/smtp.js","../src/plugins/sqljs-wasm-route-controller.js","../src/plugins/sqljs-wasm-route.js","../src/routes/app-routes.js","../src/routes/base-route.js","../src/routes/basic-route.js","../src/routes/get-route.js","../src/routes/index.js","../src/routes/namespace-route.js","../src/routes/plugin-routes.js","../src/routes/post-route.js","../src/routes/resolver.js","../src/routes/resource-route.js","../src/routes/root-route.js","../src/routes/built-in/errors/controller.js","../src/routes/hooks/frontend-model-command-route-hook.js","../src/testing/base-expect.js","../src/testing/browser-test-app.js","../src/testing/expect-to-change.js","../src/testing/expect-utils.js","../src/testing/expect.js","../src/testing/request-client.js","../src/testing/test-files-finder.js","../src/testing/test-filter-parser.js","../src/testing/test-runner.js","../src/testing/test-suite-splitter.js","../src/testing/test.js","../src/types/external-modules.d.ts","../src/utils/backtrace-cleaner.js","../src/utils/ensure-error.js","../src/utils/event-emitter.js","../src/utils/file-exists.js","../src/utils/format-value.js","../src/utils/model-scope.js","../src/utils/nest-callbacks.js","../src/utils/ransack.js","../src/utils/rest-args-error.js","../src/utils/singularize-model-name.js","../src/utils/split-sql-statements.js","../src/utils/to-import-specifier.js","../src/utils/with-tracked-stack-async-hooks.js","../src/utils/with-tracked-stack.js"],"version":"6.0.3"}
|