| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- import { is } from "../entity.js";
- import { PgTable } from "./table.js";
- import { SQL } from "../sql/sql.js";
- import { Subquery } from "../subquery.js";
- import { Schema, 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 { PgPolicy } from "./policies.js";
- import { PrimaryKeyBuilder } from "./primary-keys.js";
- import { UniqueConstraintBuilder } from "./unique-constraint.js";
- import { PgViewConfig } from "./view-common.js";
- import { PgMaterializedViewConfig } from "./view.js";
- function getTableConfig(table) {
- const columns = Object.values(table[Table.Symbol.Columns]);
- const indexes = [];
- const checks = [];
- const primaryKeys = [];
- const foreignKeys = Object.values(table[PgTable.Symbol.InlineForeignKeys]);
- const uniqueConstraints = [];
- const name = table[Table.Symbol.Name];
- const schema = table[Table.Symbol.Schema];
- const policies = [];
- const enableRLS = table[PgTable.Symbol.EnableRLS];
- const extraConfigBuilder = table[PgTable.Symbol.ExtraConfigBuilder];
- if (extraConfigBuilder !== void 0) {
- const extraConfig = extraConfigBuilder(table[Table.Symbol.ExtraConfigColumns]);
- const extraValues = Array.isArray(extraConfig) ? extraConfig.flat(1) : Object.values(extraConfig);
- for (const builder of 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));
- } else if (is(builder, PgPolicy)) {
- policies.push(builder);
- }
- }
- }
- return {
- columns,
- indexes,
- foreignKeys,
- checks,
- primaryKeys,
- uniqueConstraints,
- name,
- schema,
- policies,
- enableRLS
- };
- }
- function extractUsedTable(table) {
- if (is(table, PgTable)) {
- return [table[Schema] ? `${table[Schema]}.${table[Table.Symbol.BaseName]}` : table[Table.Symbol.BaseName]];
- }
- if (is(table, Subquery)) {
- return table._.usedTables ?? [];
- }
- if (is(table, SQL)) {
- return table.usedTables ?? [];
- }
- return [];
- }
- function getViewConfig(view) {
- return {
- ...view[ViewBaseConfig],
- ...view[PgViewConfig]
- };
- }
- function getMaterializedViewConfig(view) {
- return {
- ...view[ViewBaseConfig],
- ...view[PgMaterializedViewConfig]
- };
- }
- export {
- extractUsedTable,
- getMaterializedViewConfig,
- getTableConfig,
- getViewConfig
- };
- //# sourceMappingURL=utils.js.map
|