Initial commit
This commit is contained in:
71
node_modules/drizzle-orm/mysql-core/utils.js
generated
vendored
Normal file
71
node_modules/drizzle-orm/mysql-core/utils.js
generated
vendored
Normal file
@ -0,0 +1,71 @@
|
||||
import { is } from "../entity.js";
|
||||
import { Table } from "../table.js";
|
||||
import { ViewBaseConfig } from "../view-common.js";
|
||||
import { CheckBuilder } from "./checks.js";
|
||||
import { ForeignKeyBuilder } from "./foreign-keys.js";
|
||||
import { IndexBuilder } from "./indexes.js";
|
||||
import { PrimaryKeyBuilder } from "./primary-keys.js";
|
||||
import { MySqlTable } from "./table.js";
|
||||
import { UniqueConstraintBuilder } from "./unique-constraint.js";
|
||||
import { MySqlViewConfig } from "./view-common.js";
|
||||
function getTableConfig(table) {
|
||||
const columns = Object.values(table[MySqlTable.Symbol.Columns]);
|
||||
const indexes = [];
|
||||
const checks = [];
|
||||
const primaryKeys = [];
|
||||
const uniqueConstraints = [];
|
||||
const foreignKeys = Object.values(table[MySqlTable.Symbol.InlineForeignKeys]);
|
||||
const name = table[Table.Symbol.Name];
|
||||
const schema = table[Table.Symbol.Schema];
|
||||
const baseName = table[Table.Symbol.BaseName];
|
||||
const extraConfigBuilder = table[MySqlTable.Symbol.ExtraConfigBuilder];
|
||||
if (extraConfigBuilder !== void 0) {
|
||||
const extraConfig = extraConfigBuilder(table[MySqlTable.Symbol.Columns]);
|
||||
const extraValues = Array.isArray(extraConfig) ? extraConfig.flat(1) : Object.values(extraConfig);
|
||||
for (const builder of Object.values(extraValues)) {
|
||||
if (is(builder, IndexBuilder)) {
|
||||
indexes.push(builder.build(table));
|
||||
} else if (is(builder, CheckBuilder)) {
|
||||
checks.push(builder.build(table));
|
||||
} else if (is(builder, UniqueConstraintBuilder)) {
|
||||
uniqueConstraints.push(builder.build(table));
|
||||
} else if (is(builder, PrimaryKeyBuilder)) {
|
||||
primaryKeys.push(builder.build(table));
|
||||
} else if (is(builder, ForeignKeyBuilder)) {
|
||||
foreignKeys.push(builder.build(table));
|
||||
}
|
||||
}
|
||||
}
|
||||
return {
|
||||
columns,
|
||||
indexes,
|
||||
foreignKeys,
|
||||
checks,
|
||||
primaryKeys,
|
||||
uniqueConstraints,
|
||||
name,
|
||||
schema,
|
||||
baseName
|
||||
};
|
||||
}
|
||||
function getViewConfig(view) {
|
||||
return {
|
||||
...view[ViewBaseConfig],
|
||||
...view[MySqlViewConfig]
|
||||
};
|
||||
}
|
||||
function convertIndexToString(indexes) {
|
||||
return indexes.map((idx) => {
|
||||
return typeof idx === "object" ? idx.config.name : idx;
|
||||
});
|
||||
}
|
||||
function toArray(value) {
|
||||
return Array.isArray(value) ? value : [value];
|
||||
}
|
||||
export {
|
||||
convertIndexToString,
|
||||
getTableConfig,
|
||||
getViewConfig,
|
||||
toArray
|
||||
};
|
||||
//# sourceMappingURL=utils.js.map
|
||||
Reference in New Issue
Block a user