@payloadcms/db-postgres 3.0.0-alpha.53 → 3.0.0-alpha.55
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/create.d.ts.map +1 -1
- package/dist/create.js +5 -2
- package/dist/create.js.map +1 -1
- package/dist/createGlobal.d.ts.map +1 -1
- package/dist/createGlobal.js +5 -2
- package/dist/createGlobal.js.map +1 -1
- package/dist/createGlobalVersion.d.ts.map +1 -1
- package/dist/createGlobalVersion.js +6 -3
- package/dist/createGlobalVersion.js.map +1 -1
- package/dist/createVersion.d.ts.map +1 -1
- package/dist/createVersion.js +12 -4
- package/dist/createVersion.js.map +1 -1
- package/dist/deleteMany.js +5 -2
- package/dist/deleteMany.js.map +1 -1
- package/dist/deleteOne.d.ts.map +1 -1
- package/dist/deleteOne.js +5 -2
- package/dist/deleteOne.js.map +1 -1
- package/dist/deleteVersions.d.ts.map +1 -1
- package/dist/deleteVersions.js +6 -2
- package/dist/deleteVersions.js.map +1 -1
- package/dist/find/traverseFields.d.ts.map +1 -1
- package/dist/find/traverseFields.js +24 -5
- package/dist/find/traverseFields.js.map +1 -1
- package/dist/find.d.ts.map +1 -1
- package/dist/find.js +9 -5
- package/dist/find.js.map +1 -1
- package/dist/findGlobal.d.ts.map +1 -1
- package/dist/findGlobal.js +5 -2
- package/dist/findGlobal.js.map +1 -1
- package/dist/findGlobalVersions.d.ts.map +1 -1
- package/dist/findGlobalVersions.js +6 -2
- package/dist/findGlobalVersions.js.map +1 -1
- package/dist/findOne.d.ts +1 -1
- package/dist/findOne.d.ts.map +1 -1
- package/dist/findOne.js +8 -4
- package/dist/findOne.js.map +1 -1
- package/dist/findVersions.d.ts.map +1 -1
- package/dist/findVersions.js +6 -2
- package/dist/findVersions.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -1
- package/dist/init.d.ts.map +1 -1
- package/dist/init.js +27 -9
- package/dist/init.js.map +1 -1
- package/dist/migrate.js.map +1 -1
- package/dist/queries/getTableColumnFromPath.d.ts.map +1 -1
- package/dist/queries/getTableColumnFromPath.js +57 -13
- package/dist/queries/getTableColumnFromPath.js.map +1 -1
- package/dist/queryDrafts.d.ts.map +1 -1
- package/dist/queryDrafts.js +6 -2
- package/dist/queryDrafts.js.map +1 -1
- package/dist/schema/build.d.ts +2 -1
- package/dist/schema/build.d.ts.map +1 -1
- package/dist/schema/build.js +18 -8
- package/dist/schema/build.js.map +1 -1
- package/dist/schema/getTableName.d.ts +32 -0
- package/dist/schema/getTableName.d.ts.map +1 -0
- package/dist/schema/getTableName.js +31 -0
- package/dist/schema/getTableName.js.map +1 -0
- package/dist/schema/traverseFields.d.ts +2 -1
- package/dist/schema/traverseFields.d.ts.map +1 -1
- package/dist/schema/traverseFields.js +52 -15
- package/dist/schema/traverseFields.js.map +1 -1
- package/dist/types.d.ts +13 -0
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js.map +1 -1
- package/dist/update.d.ts.map +1 -1
- package/dist/update.js +6 -3
- package/dist/update.js.map +1 -1
- package/dist/updateGlobal.d.ts.map +1 -1
- package/dist/updateGlobal.js +5 -2
- package/dist/updateGlobal.js.map +1 -1
- package/dist/updateGlobalVersion.d.ts.map +1 -1
- package/dist/updateGlobalVersion.js +6 -2
- package/dist/updateGlobalVersion.js.map +1 -1
- package/dist/updateVersion.d.ts.map +1 -1
- package/dist/updateVersion.js +6 -2
- package/dist/updateVersion.js.map +1 -1
- package/package.json +3 -3
- package/src/index.ts +6 -1
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../src/schema/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type { IndexBuilder, PgColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/pg-core'\nimport type { Field, TabAsField } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n PgNumericBuilder,\n PgUUIDBuilder,\n PgVarcharBuilder,\n boolean,\n index,\n integer,\n jsonb,\n numeric,\n pgEnum,\n text,\n timestamp,\n varchar,\n} from 'drizzle-orm/pg-core'\nimport { InvalidConfiguration } from 'payload/errors'\nimport { fieldAffectsData, optionIsObject } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, IDType, PostgresAdapter } from '../types.js'\n\nimport { hasLocalesTable } from '../utilities/hasLocalesTable.js'\nimport { buildTable } from './build.js'\nimport { createIndex } from './createIndex.js'\nimport { idToUUID } from './idToUUID.js'\nimport { parentIDColumnMap } from './parentIDColumnMap.js'\nimport { validateExistingBlockIsIdentical } from './validateExistingBlockIsIdentical.js'\n\ntype Args = {\n adapter: PostgresAdapter\n buildNumbers: boolean\n buildRelationships: boolean\n buildTexts: boolean\n columnPrefix?: string\n columns: Record<string, PgColumnBuilder>\n disableNotNull: boolean\n disableUnique?: boolean\n fieldPrefix?: string\n fields: (Field | TabAsField)[]\n forceLocalized?: boolean\n indexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n localesColumns: Record<string, PgColumnBuilder>\n localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n newTableName: string\n parentTableName: string\n relationsToBuild: Map<string, string>\n relationships: Set<string>\n rootRelationsToBuild?: Map<string, string>\n rootTableIDColType: string\n rootTableName: string\n}\n\ntype Result = {\n hasLocalizedField: boolean\n hasLocalizedManyNumberField: boolean\n hasLocalizedManyTextField: boolean\n hasLocalizedRelationshipField: boolean\n hasManyNumberField: 'index' | boolean\n hasManyTextField: 'index' | boolean\n}\n\nexport const traverseFields = ({\n adapter,\n buildNumbers,\n buildRelationships,\n buildTexts,\n columnPrefix,\n columns,\n disableNotNull,\n disableUnique = false,\n fieldPrefix,\n fields,\n forceLocalized,\n indexes,\n localesColumns,\n localesIndexes,\n newTableName,\n parentTableName,\n relationsToBuild,\n relationships,\n rootRelationsToBuild,\n rootTableIDColType,\n rootTableName,\n}: Args): Result => {\n let hasLocalizedField = false\n let hasLocalizedRelationshipField = false\n let hasManyTextField: 'index' | boolean = false\n let hasLocalizedManyTextField = false\n let hasManyNumberField: 'index' | boolean = false\n let hasLocalizedManyNumberField = false\n\n let parentIDColType: IDType = 'integer'\n if (columns.id instanceof PgUUIDBuilder) parentIDColType = 'uuid'\n if (columns.id instanceof PgNumericBuilder) parentIDColType = 'numeric'\n if (columns.id instanceof PgVarcharBuilder) parentIDColType = 'varchar'\n\n fields.forEach((field) => {\n if ('name' in field && field.name === 'id') return\n let columnName: string\n let fieldName: string\n\n let targetTable = columns\n let targetIndexes = indexes\n\n if (fieldAffectsData(field)) {\n columnName = `${columnPrefix || ''}${field.name[0] === '_' ? '_' : ''}${toSnakeCase(\n field.name,\n )}`\n fieldName = `${fieldPrefix?.replace('.', '_') || ''}${field.name}`\n\n // If field is localized,\n // add the column to the locale table instead of main table\n if (adapter.payload.config.localization && (field.localized || forceLocalized)) {\n hasLocalizedField = true\n targetTable = localesColumns\n targetIndexes = localesIndexes\n }\n\n if (\n (field.unique || field.index) &&\n !['array', 'blocks', 'group', 'point', 'relationship', 'upload'].includes(field.type) &&\n !('hasMany' in field && field.hasMany === true)\n ) {\n const unique = disableUnique !== true && field.unique\n if (unique) {\n const constraintValue = `${fieldPrefix || ''}${field.name}`\n if (!adapter.fieldConstraints?.[rootTableName]) {\n adapter.fieldConstraints[rootTableName] = {}\n }\n adapter.fieldConstraints[rootTableName][`${columnName}_idx`] = constraintValue\n }\n targetIndexes[`${newTableName}_${field.name}Idx`] = createIndex({\n name: fieldName,\n columnName,\n tableName: newTableName,\n unique,\n })\n }\n }\n\n switch (field.type) {\n case 'text': {\n if (field.hasMany) {\n if (field.localized) {\n hasLocalizedManyTextField = true\n }\n\n if (field.index) {\n hasManyTextField = 'index'\n } else if (!hasManyTextField) {\n hasManyTextField = true\n }\n\n if (field.unique) {\n throw new InvalidConfiguration(\n 'Unique is not supported in Postgres for hasMany text fields.',\n )\n }\n } else {\n targetTable[fieldName] = varchar(columnName)\n }\n break\n }\n case 'email':\n case 'code':\n case 'textarea': {\n targetTable[fieldName] = varchar(columnName)\n break\n }\n\n case 'number': {\n if (field.hasMany) {\n if (field.localized) {\n hasLocalizedManyNumberField = true\n }\n\n if (field.index) {\n hasManyNumberField = 'index'\n } else if (!hasManyNumberField) {\n hasManyNumberField = true\n }\n\n if (field.unique) {\n throw new InvalidConfiguration(\n 'Unique is not supported in Postgres for hasMany number fields.',\n )\n }\n } else {\n targetTable[fieldName] = numeric(columnName)\n }\n break\n }\n\n case 'richText':\n case 'json': {\n targetTable[fieldName] = jsonb(columnName)\n break\n }\n\n case 'date': {\n targetTable[fieldName] = timestamp(columnName, {\n mode: 'string',\n precision: 3,\n withTimezone: true,\n })\n break\n }\n\n case 'point': {\n break\n }\n\n case 'radio':\n case 'select': {\n const enumName = `enum_${newTableName}_${toSnakeCase(field.name)}`\n\n adapter.enums[enumName] = pgEnum(\n enumName,\n field.options.map((option) => {\n if (optionIsObject(option)) {\n return option.value\n }\n\n return option\n }) as [string, ...string[]],\n )\n\n if (field.type === 'select' && field.hasMany) {\n const selectTableName = `${newTableName}_${toSnakeCase(field.name)}`\n const baseColumns: Record<string, PgColumnBuilder> = {\n order: integer('order').notNull(),\n parent: parentIDColumnMap[parentIDColType]('parent_id')\n .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n .notNull(),\n value: adapter.enums[enumName]('value'),\n }\n\n const baseExtraConfig: Record<\n string,\n (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n > = {\n orderIdx: (cols) => index(`${selectTableName}_order_idx`).on(cols.order),\n parentIdx: (cols) => index(`${selectTableName}_parent_idx`).on(cols.parent),\n }\n\n if (field.localized) {\n baseColumns.locale = adapter.enums.enum__locales('locale').notNull()\n baseExtraConfig.localeIdx = (cols) =>\n index(`${selectTableName}_locale_idx`).on(cols.locale)\n }\n\n if (field.index) {\n baseExtraConfig.value = (cols) => index(`${selectTableName}_value_idx`).on(cols.value)\n }\n\n buildTable({\n adapter,\n baseColumns,\n baseExtraConfig,\n disableNotNull,\n disableUnique,\n fields: [],\n tableName: selectTableName,\n })\n\n relationsToBuild.set(fieldName, selectTableName)\n\n const selectTableRelations = relations(adapter.tables[selectTableName], ({ one }) => {\n const result: Record<string, Relation<string>> = {\n parent: one(adapter.tables[parentTableName], {\n fields: [adapter.tables[selectTableName].parent],\n references: [adapter.tables[parentTableName].id],\n }),\n }\n\n return result\n })\n\n adapter.relations[`relation_${selectTableName}`] = selectTableRelations\n } else {\n targetTable[fieldName] = adapter.enums[enumName](fieldName)\n }\n break\n }\n\n case 'checkbox': {\n targetTable[fieldName] = boolean(columnName)\n break\n }\n\n case 'array': {\n const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n const arrayTableName = `${newTableName}_${toSnakeCase(field.name)}`\n const baseColumns: Record<string, PgColumnBuilder> = {\n _order: integer('_order').notNull(),\n _parentID: parentIDColumnMap[parentIDColType]('_parent_id')\n .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n .notNull(),\n }\n\n const baseExtraConfig: Record<\n string,\n (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n > = {\n _orderIdx: (cols) => index(`${arrayTableName}_order_idx`).on(cols._order),\n _parentIDIdx: (cols) => index(`${arrayTableName}_parent_id_idx`).on(cols._parentID),\n }\n\n if (field.localized && adapter.payload.config.localization) {\n baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n baseExtraConfig._localeIdx = (cols) =>\n index(`${arrayTableName}_locale_idx`).on(cols._locale)\n }\n\n const {\n hasManyNumberField: subHasManyNumberField,\n hasManyTextField: subHasManyTextField,\n relationsToBuild: subRelationsToBuild,\n } = buildTable({\n adapter,\n baseColumns,\n baseExtraConfig,\n disableNotNull: disableNotNullFromHere,\n disableUnique,\n fields: disableUnique ? idToUUID(field.fields) : field.fields,\n rootRelationsToBuild,\n rootRelationships: relationships,\n rootTableIDColType,\n rootTableName,\n tableName: arrayTableName,\n })\n\n if (subHasManyTextField) {\n if (!hasManyTextField || subHasManyTextField === 'index')\n hasManyTextField = subHasManyTextField\n }\n if (subHasManyNumberField) {\n if (!hasManyNumberField || subHasManyNumberField === 'index')\n hasManyNumberField = subHasManyNumberField\n }\n\n relationsToBuild.set(fieldName, arrayTableName)\n\n const arrayTableRelations = relations(adapter.tables[arrayTableName], ({ many, one }) => {\n const result: Record<string, Relation<string>> = {\n _parentID: one(adapter.tables[parentTableName], {\n fields: [adapter.tables[arrayTableName]._parentID],\n references: [adapter.tables[parentTableName].id],\n }),\n }\n\n if (hasLocalesTable(field.fields)) {\n result._locales = many(adapter.tables[`${arrayTableName}_locales`])\n }\n\n subRelationsToBuild.forEach((val, key) => {\n result[key] = many(adapter.tables[val])\n })\n\n return result\n })\n\n adapter.relations[`relations_${arrayTableName}`] = arrayTableRelations\n\n break\n }\n\n case 'blocks': {\n const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n field.blocks.forEach((block) => {\n const blockTableName = `${rootTableName}_blocks_${toSnakeCase(block.slug)}`\n if (!adapter.tables[blockTableName]) {\n const baseColumns: Record<string, PgColumnBuilder> = {\n _order: integer('_order').notNull(),\n _parentID: parentIDColumnMap[rootTableIDColType]('_parent_id')\n .references(() => adapter.tables[rootTableName].id, { onDelete: 'cascade' })\n .notNull(),\n _path: text('_path').notNull(),\n }\n\n const baseExtraConfig: Record<\n string,\n (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n > = {\n _orderIdx: (cols) => index(`${blockTableName}_order_idx`).on(cols._order),\n _parentIDIdx: (cols) => index(`${blockTableName}_parent_id_idx`).on(cols._parentID),\n _pathIdx: (cols) => index(`${blockTableName}_path_idx`).on(cols._path),\n }\n\n if (field.localized && adapter.payload.config.localization) {\n baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n baseExtraConfig._localeIdx = (cols) =>\n index(`${blockTableName}_locale_idx`).on(cols._locale)\n }\n\n const {\n hasManyNumberField: subHasManyNumberField,\n hasManyTextField: subHasManyTextField,\n relationsToBuild: subRelationsToBuild,\n } = buildTable({\n adapter,\n baseColumns,\n baseExtraConfig,\n disableNotNull: disableNotNullFromHere,\n disableUnique,\n fields: disableUnique ? idToUUID(block.fields) : block.fields,\n rootRelationsToBuild,\n rootRelationships: relationships,\n rootTableIDColType,\n rootTableName,\n tableName: blockTableName,\n })\n\n if (subHasManyTextField) {\n if (!hasManyTextField || subHasManyTextField === 'index')\n hasManyTextField = subHasManyTextField\n }\n\n if (subHasManyNumberField) {\n if (!hasManyNumberField || subHasManyNumberField === 'index')\n hasManyNumberField = subHasManyNumberField\n }\n\n const blockTableRelations = relations(\n adapter.tables[blockTableName],\n ({ many, one }) => {\n const result: Record<string, Relation<string>> = {\n _parentID: one(adapter.tables[rootTableName], {\n fields: [adapter.tables[blockTableName]._parentID],\n references: [adapter.tables[rootTableName].id],\n }),\n }\n\n if (hasLocalesTable(block.fields)) {\n result._locales = many(adapter.tables[`${blockTableName}_locales`])\n }\n\n subRelationsToBuild.forEach((val, key) => {\n result[key] = many(adapter.tables[val])\n })\n\n return result\n },\n )\n\n adapter.relations[`relations_${blockTableName}`] = blockTableRelations\n } else if (process.env.NODE_ENV !== 'production') {\n validateExistingBlockIsIdentical({\n block,\n localized: field.localized,\n rootTableName,\n table: adapter.tables[blockTableName],\n })\n }\n\n rootRelationsToBuild.set(`_blocks_${block.slug}`, blockTableName)\n })\n\n break\n }\n\n case 'tab':\n case 'group': {\n if (!('name' in field)) {\n const {\n hasLocalizedField: groupHasLocalizedField,\n hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n hasLocalizedManyTextField: groupHasLocalizedManyTextField,\n hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n hasManyNumberField: groupHasManyNumberField,\n hasManyTextField: groupHasManyTextField,\n } = traverseFields({\n adapter,\n buildNumbers,\n buildRelationships,\n buildTexts,\n columnPrefix,\n columns,\n disableNotNull,\n disableUnique,\n fieldPrefix,\n fields: field.fields,\n forceLocalized,\n indexes,\n localesColumns,\n localesIndexes,\n newTableName,\n parentTableName,\n relationsToBuild,\n relationships,\n rootRelationsToBuild,\n rootTableIDColType,\n rootTableName,\n })\n\n if (groupHasLocalizedField) hasLocalizedField = true\n if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n if (groupHasManyTextField) hasManyTextField = true\n if (groupHasLocalizedManyTextField) hasLocalizedManyTextField = true\n if (groupHasManyNumberField) hasManyNumberField = true\n if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n break\n }\n\n const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n const {\n hasLocalizedField: groupHasLocalizedField,\n hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n hasLocalizedManyTextField: groupHasLocalizedManyTextField,\n hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n hasManyNumberField: groupHasManyNumberField,\n hasManyTextField: groupHasManyTextField,\n } = traverseFields({\n adapter,\n buildNumbers,\n buildRelationships,\n buildTexts,\n columnPrefix: `${columnName}_`,\n columns,\n disableNotNull: disableNotNullFromHere,\n disableUnique,\n fieldPrefix: `${fieldName}.`,\n fields: field.fields,\n forceLocalized: field.localized,\n indexes,\n localesColumns,\n localesIndexes,\n newTableName: `${parentTableName}_${columnName}`,\n parentTableName,\n relationsToBuild,\n relationships,\n rootRelationsToBuild,\n rootTableIDColType,\n rootTableName,\n })\n\n if (groupHasLocalizedField) hasLocalizedField = true\n if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n if (groupHasManyTextField) hasManyTextField = true\n if (groupHasLocalizedManyTextField) hasLocalizedManyTextField = true\n if (groupHasManyNumberField) hasManyNumberField = true\n if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n break\n }\n\n case 'tabs': {\n const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n const {\n hasLocalizedField: tabHasLocalizedField,\n hasLocalizedManyNumberField: tabHasLocalizedManyNumberField,\n hasLocalizedManyTextField: tabHasLocalizedManyTextField,\n hasLocalizedRelationshipField: tabHasLocalizedRelationshipField,\n hasManyNumberField: tabHasManyNumberField,\n hasManyTextField: tabHasManyTextField,\n } = traverseFields({\n adapter,\n buildNumbers,\n buildRelationships,\n buildTexts,\n columnPrefix,\n columns,\n disableNotNull: disableNotNullFromHere,\n disableUnique,\n fieldPrefix,\n fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n forceLocalized,\n indexes,\n localesColumns,\n localesIndexes,\n newTableName,\n parentTableName,\n relationsToBuild,\n relationships,\n rootRelationsToBuild,\n rootTableIDColType,\n rootTableName,\n })\n\n if (tabHasLocalizedField) hasLocalizedField = true\n if (tabHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n if (tabHasManyTextField) hasManyTextField = true\n if (tabHasLocalizedManyTextField) hasLocalizedManyTextField = true\n if (tabHasManyNumberField) hasManyNumberField = true\n if (tabHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n break\n }\n\n case 'row':\n case 'collapsible': {\n const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n const {\n hasLocalizedField: rowHasLocalizedField,\n hasLocalizedManyNumberField: rowHasLocalizedManyNumberField,\n hasLocalizedManyTextField: rowHasLocalizedManyTextField,\n hasLocalizedRelationshipField: rowHasLocalizedRelationshipField,\n hasManyNumberField: rowHasManyNumberField,\n hasManyTextField: rowHasManyTextField,\n } = traverseFields({\n adapter,\n buildNumbers,\n buildRelationships,\n buildTexts,\n columnPrefix,\n columns,\n disableNotNull: disableNotNullFromHere,\n disableUnique,\n fieldPrefix,\n fields: field.fields,\n forceLocalized,\n indexes,\n localesColumns,\n localesIndexes,\n newTableName: parentTableName,\n parentTableName,\n relationsToBuild,\n relationships,\n rootRelationsToBuild,\n rootTableIDColType,\n rootTableName,\n })\n\n if (rowHasLocalizedField) hasLocalizedField = true\n if (rowHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n if (rowHasManyTextField) hasManyTextField = true\n if (rowHasLocalizedManyTextField) hasLocalizedManyTextField = true\n if (rowHasManyNumberField) hasManyNumberField = true\n if (rowHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n break\n }\n\n case 'relationship':\n case 'upload':\n if (Array.isArray(field.relationTo)) {\n field.relationTo.forEach((relation) => relationships.add(relation))\n } else {\n relationships.add(field.relationTo)\n }\n\n if (field.localized && adapter.payload.config.localization) {\n hasLocalizedRelationshipField = true\n }\n break\n\n default:\n break\n }\n\n const condition = field.admin && field.admin.condition\n\n if (\n !disableNotNull &&\n targetTable[fieldName] &&\n 'required' in field &&\n field.required &&\n !condition\n ) {\n targetTable[fieldName].notNull()\n }\n })\n\n return {\n hasLocalizedField,\n hasLocalizedManyNumberField,\n hasLocalizedManyTextField,\n hasLocalizedRelationshipField,\n hasManyNumberField,\n hasManyTextField,\n }\n}\n"],"names":["relations","PgNumericBuilder","PgUUIDBuilder","PgVarcharBuilder","boolean","index","integer","jsonb","numeric","pgEnum","text","timestamp","varchar","InvalidConfiguration","fieldAffectsData","optionIsObject","toSnakeCase","hasLocalesTable","buildTable","createIndex","idToUUID","parentIDColumnMap","validateExistingBlockIsIdentical","traverseFields","adapter","buildNumbers","buildRelationships","buildTexts","columnPrefix","columns","disableNotNull","disableUnique","fieldPrefix","fields","forceLocalized","indexes","localesColumns","localesIndexes","newTableName","parentTableName","relationsToBuild","relationships","rootRelationsToBuild","rootTableIDColType","rootTableName","hasLocalizedField","hasLocalizedRelationshipField","hasManyTextField","hasLocalizedManyTextField","hasManyNumberField","hasLocalizedManyNumberField","parentIDColType","id","forEach","field","name","columnName","fieldName","targetTable","targetIndexes","replace","payload","config","localization","localized","unique","includes","type","hasMany","constraintValue","fieldConstraints","tableName","mode","precision","withTimezone","enumName","enums","options","map","option","value","selectTableName","baseColumns","order","notNull","parent","references","tables","onDelete","baseExtraConfig","orderIdx","cols","on","parentIdx","locale","enum__locales","localeIdx","set","selectTableRelations","one","result","disableNotNullFromHere","Boolean","admin","condition","arrayTableName","_order","_parentID","_orderIdx","_parentIDIdx","_locale","_localeIdx","subHasManyNumberField","subHasManyTextField","subRelationsToBuild","rootRelationships","arrayTableRelations","many","_locales","val","key","blocks","block","blockTableName","slug","_path","_pathIdx","blockTableRelations","process","env","NODE_ENV","table","groupHasLocalizedField","groupHasLocalizedManyNumberField","groupHasLocalizedManyTextField","groupHasLocalizedRelationshipField","groupHasManyNumberField","groupHasManyTextField","tabHasLocalizedField","tabHasLocalizedManyNumberField","tabHasLocalizedManyTextField","tabHasLocalizedRelationshipField","tabHasManyNumberField","tabHasManyTextField","tabs","tab","rowHasLocalizedField","rowHasLocalizedManyNumberField","rowHasLocalizedManyTextField","rowHasLocalizedRelationshipField","rowHasManyNumberField","rowHasManyTextField","Array","isArray","relationTo","relation","add","required"],"mappings":"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"}
|
1
|
+
{"version":3,"sources":["../../src/schema/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type { IndexBuilder, PgColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/pg-core'\nimport type { Field, TabAsField } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n PgNumericBuilder,\n PgUUIDBuilder,\n PgVarcharBuilder,\n boolean,\n index,\n integer,\n jsonb,\n numeric,\n pgEnum,\n text,\n timestamp,\n varchar,\n} from 'drizzle-orm/pg-core'\nimport { InvalidConfiguration } from 'payload/errors'\nimport { fieldAffectsData, optionIsObject } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, IDType, PostgresAdapter } from '../types.js'\n\nimport { hasLocalesTable } from '../utilities/hasLocalesTable.js'\nimport { buildTable } from './build.js'\nimport { createIndex } from './createIndex.js'\nimport { getTableName } from './getTableName.js'\nimport { idToUUID } from './idToUUID.js'\nimport { parentIDColumnMap } from './parentIDColumnMap.js'\nimport { validateExistingBlockIsIdentical } from './validateExistingBlockIsIdentical.js'\n\ntype Args = {\n adapter: PostgresAdapter\n buildNumbers: boolean\n buildRelationships: boolean\n buildTexts: boolean\n columnPrefix?: string\n columns: Record<string, PgColumnBuilder>\n disableNotNull: boolean\n disableUnique?: boolean\n fieldPrefix?: string\n fields: (Field | TabAsField)[]\n forceLocalized?: boolean\n indexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n localesColumns: Record<string, PgColumnBuilder>\n localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n newTableName: string\n parentTableName: string\n relationsToBuild: Map<string, string>\n relationships: Set<string>\n rootRelationsToBuild?: Map<string, string>\n rootTableIDColType: string\n rootTableName: string\n versions: boolean\n}\n\ntype Result = {\n hasLocalizedField: boolean\n hasLocalizedManyNumberField: boolean\n hasLocalizedManyTextField: boolean\n hasLocalizedRelationshipField: boolean\n hasManyNumberField: 'index' | boolean\n hasManyTextField: 'index' | boolean\n}\n\nexport const traverseFields = ({\n adapter,\n buildNumbers,\n buildRelationships,\n buildTexts,\n columnPrefix,\n columns,\n disableNotNull,\n disableUnique = false,\n fieldPrefix,\n fields,\n forceLocalized,\n indexes,\n localesColumns,\n localesIndexes,\n newTableName,\n parentTableName,\n relationsToBuild,\n relationships,\n rootRelationsToBuild,\n rootTableIDColType,\n rootTableName,\n versions,\n}: Args): Result => {\n const throwValidationError = true\n let hasLocalizedField = false\n let hasLocalizedRelationshipField = false\n let hasManyTextField: 'index' | boolean = false\n let hasLocalizedManyTextField = false\n let hasManyNumberField: 'index' | boolean = false\n let hasLocalizedManyNumberField = false\n\n let parentIDColType: IDType = 'integer'\n if (columns.id instanceof PgUUIDBuilder) parentIDColType = 'uuid'\n if (columns.id instanceof PgNumericBuilder) parentIDColType = 'numeric'\n if (columns.id instanceof PgVarcharBuilder) parentIDColType = 'varchar'\n\n fields.forEach((field) => {\n if ('name' in field && field.name === 'id') return\n let columnName: string\n let fieldName: string\n\n let targetTable = columns\n let targetIndexes = indexes\n\n if (fieldAffectsData(field)) {\n columnName = `${columnPrefix || ''}${field.name[0] === '_' ? '_' : ''}${toSnakeCase(\n field.name,\n )}`\n fieldName = `${fieldPrefix?.replace('.', '_') || ''}${field.name}`\n\n // If field is localized,\n // add the column to the locale table instead of main table\n if (adapter.payload.config.localization && (field.localized || forceLocalized)) {\n hasLocalizedField = true\n targetTable = localesColumns\n targetIndexes = localesIndexes\n }\n\n if (\n (field.unique || field.index) &&\n !['array', 'blocks', 'group', 'point', 'relationship', 'upload'].includes(field.type) &&\n !('hasMany' in field && field.hasMany === true)\n ) {\n const unique = disableUnique !== true && field.unique\n if (unique) {\n const constraintValue = `${fieldPrefix || ''}${field.name}`\n if (!adapter.fieldConstraints?.[rootTableName]) {\n adapter.fieldConstraints[rootTableName] = {}\n }\n adapter.fieldConstraints[rootTableName][`${columnName}_idx`] = constraintValue\n }\n targetIndexes[`${newTableName}_${field.name}Idx`] = createIndex({\n name: fieldName,\n columnName,\n tableName: newTableName,\n unique,\n })\n }\n }\n\n switch (field.type) {\n case 'text': {\n if (field.hasMany) {\n if (field.localized) {\n hasLocalizedManyTextField = true\n }\n\n if (field.index) {\n hasManyTextField = 'index'\n } else if (!hasManyTextField) {\n hasManyTextField = true\n }\n\n if (field.unique) {\n throw new InvalidConfiguration(\n 'Unique is not supported in Postgres for hasMany text fields.',\n )\n }\n } else {\n targetTable[fieldName] = varchar(columnName)\n }\n break\n }\n case 'email':\n case 'code':\n case 'textarea': {\n targetTable[fieldName] = varchar(columnName)\n break\n }\n\n case 'number': {\n if (field.hasMany) {\n if (field.localized) {\n hasLocalizedManyNumberField = true\n }\n\n if (field.index) {\n hasManyNumberField = 'index'\n } else if (!hasManyNumberField) {\n hasManyNumberField = true\n }\n\n if (field.unique) {\n throw new InvalidConfiguration(\n 'Unique is not supported in Postgres for hasMany number fields.',\n )\n }\n } else {\n targetTable[fieldName] = numeric(columnName)\n }\n break\n }\n\n case 'richText':\n case 'json': {\n targetTable[fieldName] = jsonb(columnName)\n break\n }\n\n case 'date': {\n targetTable[fieldName] = timestamp(columnName, {\n mode: 'string',\n precision: 3,\n withTimezone: true,\n })\n break\n }\n\n case 'point': {\n break\n }\n\n case 'radio':\n case 'select': {\n const enumName = getTableName({\n adapter,\n config: field,\n parentTableName: newTableName,\n prefix: `enum_${newTableName}_`,\n target: 'enumName',\n throwValidationError,\n versions,\n })\n\n adapter.enums[enumName] = pgEnum(\n enumName,\n field.options.map((option) => {\n if (optionIsObject(option)) {\n return option.value\n }\n\n return option\n }) as [string, ...string[]],\n )\n\n if (field.type === 'select' && field.hasMany) {\n const selectTableName = getTableName({\n adapter,\n config: field,\n parentTableName: newTableName,\n prefix: `${newTableName}_`,\n throwValidationError,\n versions,\n })\n const baseColumns: Record<string, PgColumnBuilder> = {\n order: integer('order').notNull(),\n parent: parentIDColumnMap[parentIDColType]('parent_id')\n .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n .notNull(),\n value: adapter.enums[enumName]('value'),\n }\n\n const baseExtraConfig: Record<\n string,\n (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n > = {\n orderIdx: (cols) => index(`${selectTableName}_order_idx`).on(cols.order),\n parentIdx: (cols) => index(`${selectTableName}_parent_idx`).on(cols.parent),\n }\n\n if (field.localized) {\n baseColumns.locale = adapter.enums.enum__locales('locale').notNull()\n baseExtraConfig.localeIdx = (cols) =>\n index(`${selectTableName}_locale_idx`).on(cols.locale)\n }\n\n if (field.index) {\n baseExtraConfig.value = (cols) => index(`${selectTableName}_value_idx`).on(cols.value)\n }\n\n buildTable({\n adapter,\n baseColumns,\n baseExtraConfig,\n disableNotNull,\n disableUnique,\n fields: [],\n tableName: selectTableName,\n versions,\n })\n\n relationsToBuild.set(fieldName, selectTableName)\n\n const selectTableRelations = relations(adapter.tables[selectTableName], ({ one }) => {\n const result: Record<string, Relation<string>> = {\n parent: one(adapter.tables[parentTableName], {\n fields: [adapter.tables[selectTableName].parent],\n references: [adapter.tables[parentTableName].id],\n }),\n }\n\n return result\n })\n\n adapter.relations[`relation_${selectTableName}`] = selectTableRelations\n } else {\n targetTable[fieldName] = adapter.enums[enumName](fieldName)\n }\n break\n }\n\n case 'checkbox': {\n targetTable[fieldName] = boolean(columnName)\n break\n }\n\n case 'array': {\n const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n const arrayTableName = getTableName({\n adapter,\n config: field,\n parentTableName: newTableName,\n prefix: `${newTableName}_`,\n throwValidationError,\n })\n const baseColumns: Record<string, PgColumnBuilder> = {\n _order: integer('_order').notNull(),\n _parentID: parentIDColumnMap[parentIDColType]('_parent_id')\n .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n .notNull(),\n }\n\n const baseExtraConfig: Record<\n string,\n (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n > = {\n _orderIdx: (cols) => index(`${arrayTableName}_order_idx`).on(cols._order),\n _parentIDIdx: (cols) => index(`${arrayTableName}_parent_id_idx`).on(cols._parentID),\n }\n\n if (field.localized && adapter.payload.config.localization) {\n baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n baseExtraConfig._localeIdx = (cols) =>\n index(`${arrayTableName}_locale_idx`).on(cols._locale)\n }\n\n const {\n hasManyNumberField: subHasManyNumberField,\n hasManyTextField: subHasManyTextField,\n relationsToBuild: subRelationsToBuild,\n } = buildTable({\n adapter,\n baseColumns,\n baseExtraConfig,\n disableNotNull: disableNotNullFromHere,\n disableUnique,\n fields: disableUnique ? idToUUID(field.fields) : field.fields,\n rootRelationsToBuild,\n rootRelationships: relationships,\n rootTableIDColType,\n rootTableName,\n tableName: arrayTableName,\n versions,\n })\n\n if (subHasManyTextField) {\n if (!hasManyTextField || subHasManyTextField === 'index')\n hasManyTextField = subHasManyTextField\n }\n if (subHasManyNumberField) {\n if (!hasManyNumberField || subHasManyNumberField === 'index')\n hasManyNumberField = subHasManyNumberField\n }\n\n relationsToBuild.set(fieldName, arrayTableName)\n\n const arrayTableRelations = relations(adapter.tables[arrayTableName], ({ many, one }) => {\n const result: Record<string, Relation<string>> = {\n _parentID: one(adapter.tables[parentTableName], {\n fields: [adapter.tables[arrayTableName]._parentID],\n references: [adapter.tables[parentTableName].id],\n }),\n }\n\n if (hasLocalesTable(field.fields)) {\n result._locales = many(adapter.tables[`${arrayTableName}${adapter.localesSuffix}`])\n }\n\n subRelationsToBuild.forEach((val, key) => {\n result[key] = many(adapter.tables[val])\n })\n\n return result\n })\n\n adapter.relations[`relations_${arrayTableName}`] = arrayTableRelations\n\n break\n }\n\n case 'blocks': {\n const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n field.blocks.forEach((block) => {\n const blockTableName = getTableName({\n adapter,\n config: block,\n parentTableName: rootTableName,\n prefix: `${rootTableName}_blocks_`,\n throwValidationError,\n })\n if (!adapter.tables[blockTableName]) {\n const baseColumns: Record<string, PgColumnBuilder> = {\n _order: integer('_order').notNull(),\n _parentID: parentIDColumnMap[rootTableIDColType]('_parent_id')\n .references(() => adapter.tables[rootTableName].id, { onDelete: 'cascade' })\n .notNull(),\n _path: text('_path').notNull(),\n }\n\n const baseExtraConfig: Record<\n string,\n (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n > = {\n _orderIdx: (cols) => index(`${blockTableName}_order_idx`).on(cols._order),\n _parentIDIdx: (cols) => index(`${blockTableName}_parent_id_idx`).on(cols._parentID),\n _pathIdx: (cols) => index(`${blockTableName}_path_idx`).on(cols._path),\n }\n\n if (field.localized && adapter.payload.config.localization) {\n baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n baseExtraConfig._localeIdx = (cols) =>\n index(`${blockTableName}_locale_idx`).on(cols._locale)\n }\n\n const {\n hasManyNumberField: subHasManyNumberField,\n hasManyTextField: subHasManyTextField,\n relationsToBuild: subRelationsToBuild,\n } = buildTable({\n adapter,\n baseColumns,\n baseExtraConfig,\n disableNotNull: disableNotNullFromHere,\n disableUnique,\n fields: disableUnique ? idToUUID(block.fields) : block.fields,\n rootRelationsToBuild,\n rootRelationships: relationships,\n rootTableIDColType,\n rootTableName,\n tableName: blockTableName,\n versions,\n })\n\n if (subHasManyTextField) {\n if (!hasManyTextField || subHasManyTextField === 'index')\n hasManyTextField = subHasManyTextField\n }\n\n if (subHasManyNumberField) {\n if (!hasManyNumberField || subHasManyNumberField === 'index')\n hasManyNumberField = subHasManyNumberField\n }\n\n const blockTableRelations = relations(\n adapter.tables[blockTableName],\n ({ many, one }) => {\n const result: Record<string, Relation<string>> = {\n _parentID: one(adapter.tables[rootTableName], {\n fields: [adapter.tables[blockTableName]._parentID],\n references: [adapter.tables[rootTableName].id],\n }),\n }\n\n if (hasLocalesTable(block.fields)) {\n result._locales = many(\n adapter.tables[`${blockTableName}${adapter.localesSuffix}`],\n )\n }\n\n subRelationsToBuild.forEach((val, key) => {\n result[key] = many(adapter.tables[val])\n })\n\n return result\n },\n )\n\n adapter.relations[`relations_${blockTableName}`] = blockTableRelations\n } else if (process.env.NODE_ENV !== 'production' && !versions) {\n validateExistingBlockIsIdentical({\n block,\n localized: field.localized,\n rootTableName,\n table: adapter.tables[blockTableName],\n })\n }\n adapter.blockTableNames[`${rootTableName}.${toSnakeCase(block.slug)}`] = blockTableName\n rootRelationsToBuild.set(`_blocks_${block.slug}`, blockTableName)\n })\n\n break\n }\n\n case 'tab':\n case 'group': {\n if (!('name' in field)) {\n const {\n hasLocalizedField: groupHasLocalizedField,\n hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n hasLocalizedManyTextField: groupHasLocalizedManyTextField,\n hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n hasManyNumberField: groupHasManyNumberField,\n hasManyTextField: groupHasManyTextField,\n } = traverseFields({\n adapter,\n buildNumbers,\n buildRelationships,\n buildTexts,\n columnPrefix,\n columns,\n disableNotNull,\n disableUnique,\n fieldPrefix,\n fields: field.fields,\n forceLocalized,\n indexes,\n localesColumns,\n localesIndexes,\n newTableName,\n parentTableName,\n relationsToBuild,\n relationships,\n rootRelationsToBuild,\n rootTableIDColType,\n rootTableName,\n versions,\n })\n\n if (groupHasLocalizedField) hasLocalizedField = true\n if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n if (groupHasManyTextField) hasManyTextField = true\n if (groupHasLocalizedManyTextField) hasLocalizedManyTextField = true\n if (groupHasManyNumberField) hasManyNumberField = true\n if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n break\n }\n\n const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n const {\n hasLocalizedField: groupHasLocalizedField,\n hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n hasLocalizedManyTextField: groupHasLocalizedManyTextField,\n hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n hasManyNumberField: groupHasManyNumberField,\n hasManyTextField: groupHasManyTextField,\n } = traverseFields({\n adapter,\n buildNumbers,\n buildRelationships,\n buildTexts,\n columnPrefix: `${columnName}_`,\n columns,\n disableNotNull: disableNotNullFromHere,\n disableUnique,\n fieldPrefix: `${fieldName}.`,\n fields: field.fields,\n forceLocalized: field.localized,\n indexes,\n localesColumns,\n localesIndexes,\n newTableName: `${parentTableName}_${columnName}`,\n parentTableName,\n relationsToBuild,\n relationships,\n rootRelationsToBuild,\n rootTableIDColType,\n rootTableName,\n versions,\n })\n\n if (groupHasLocalizedField) hasLocalizedField = true\n if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n if (groupHasManyTextField) hasManyTextField = true\n if (groupHasLocalizedManyTextField) hasLocalizedManyTextField = true\n if (groupHasManyNumberField) hasManyNumberField = true\n if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n break\n }\n\n case 'tabs': {\n const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n const {\n hasLocalizedField: tabHasLocalizedField,\n hasLocalizedManyNumberField: tabHasLocalizedManyNumberField,\n hasLocalizedManyTextField: tabHasLocalizedManyTextField,\n hasLocalizedRelationshipField: tabHasLocalizedRelationshipField,\n hasManyNumberField: tabHasManyNumberField,\n hasManyTextField: tabHasManyTextField,\n } = traverseFields({\n adapter,\n buildNumbers,\n buildRelationships,\n buildTexts,\n columnPrefix,\n columns,\n disableNotNull: disableNotNullFromHere,\n disableUnique,\n fieldPrefix,\n fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n forceLocalized,\n indexes,\n localesColumns,\n localesIndexes,\n newTableName,\n parentTableName,\n relationsToBuild,\n relationships,\n rootRelationsToBuild,\n rootTableIDColType,\n rootTableName,\n versions,\n })\n\n if (tabHasLocalizedField) hasLocalizedField = true\n if (tabHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n if (tabHasManyTextField) hasManyTextField = true\n if (tabHasLocalizedManyTextField) hasLocalizedManyTextField = true\n if (tabHasManyNumberField) hasManyNumberField = true\n if (tabHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n break\n }\n\n case 'row':\n case 'collapsible': {\n const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n const {\n hasLocalizedField: rowHasLocalizedField,\n hasLocalizedManyNumberField: rowHasLocalizedManyNumberField,\n hasLocalizedManyTextField: rowHasLocalizedManyTextField,\n hasLocalizedRelationshipField: rowHasLocalizedRelationshipField,\n hasManyNumberField: rowHasManyNumberField,\n hasManyTextField: rowHasManyTextField,\n } = traverseFields({\n adapter,\n buildNumbers,\n buildRelationships,\n buildTexts,\n columnPrefix,\n columns,\n disableNotNull: disableNotNullFromHere,\n disableUnique,\n fieldPrefix,\n fields: field.fields,\n forceLocalized,\n indexes,\n localesColumns,\n localesIndexes,\n newTableName: parentTableName,\n parentTableName,\n relationsToBuild,\n relationships,\n rootRelationsToBuild,\n rootTableIDColType,\n rootTableName,\n versions,\n })\n\n if (rowHasLocalizedField) hasLocalizedField = true\n if (rowHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n if (rowHasManyTextField) hasManyTextField = true\n if (rowHasLocalizedManyTextField) hasLocalizedManyTextField = true\n if (rowHasManyNumberField) hasManyNumberField = true\n if (rowHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n break\n }\n\n case 'relationship':\n case 'upload':\n if (Array.isArray(field.relationTo)) {\n field.relationTo.forEach((relation) => relationships.add(relation))\n } else {\n relationships.add(field.relationTo)\n }\n\n if (field.localized && adapter.payload.config.localization) {\n hasLocalizedRelationshipField = true\n }\n break\n\n default:\n break\n }\n\n const condition = field.admin && field.admin.condition\n\n if (\n !disableNotNull &&\n targetTable[fieldName] &&\n 'required' in field &&\n field.required &&\n !condition\n ) {\n targetTable[fieldName].notNull()\n }\n })\n\n return {\n hasLocalizedField,\n hasLocalizedManyNumberField,\n hasLocalizedManyTextField,\n hasLocalizedRelationshipField,\n hasManyNumberField,\n hasManyTextField,\n }\n}\n"],"names":["relations","PgNumericBuilder","PgUUIDBuilder","PgVarcharBuilder","boolean","index","integer","jsonb","numeric","pgEnum","text","timestamp","varchar","InvalidConfiguration","fieldAffectsData","optionIsObject","toSnakeCase","hasLocalesTable","buildTable","createIndex","getTableName","idToUUID","parentIDColumnMap","validateExistingBlockIsIdentical","traverseFields","adapter","buildNumbers","buildRelationships","buildTexts","columnPrefix","columns","disableNotNull","disableUnique","fieldPrefix","fields","forceLocalized","indexes","localesColumns","localesIndexes","newTableName","parentTableName","relationsToBuild","relationships","rootRelationsToBuild","rootTableIDColType","rootTableName","versions","throwValidationError","hasLocalizedField","hasLocalizedRelationshipField","hasManyTextField","hasLocalizedManyTextField","hasManyNumberField","hasLocalizedManyNumberField","parentIDColType","id","forEach","field","name","columnName","fieldName","targetTable","targetIndexes","replace","payload","config","localization","localized","unique","includes","type","hasMany","constraintValue","fieldConstraints","tableName","mode","precision","withTimezone","enumName","prefix","target","enums","options","map","option","value","selectTableName","baseColumns","order","notNull","parent","references","tables","onDelete","baseExtraConfig","orderIdx","cols","on","parentIdx","locale","enum__locales","localeIdx","set","selectTableRelations","one","result","disableNotNullFromHere","Boolean","admin","condition","arrayTableName","_order","_parentID","_orderIdx","_parentIDIdx","_locale","_localeIdx","subHasManyNumberField","subHasManyTextField","subRelationsToBuild","rootRelationships","arrayTableRelations","many","_locales","localesSuffix","val","key","blocks","block","blockTableName","_path","_pathIdx","blockTableRelations","process","env","NODE_ENV","table","blockTableNames","slug","groupHasLocalizedField","groupHasLocalizedManyNumberField","groupHasLocalizedManyTextField","groupHasLocalizedRelationshipField","groupHasManyNumberField","groupHasManyTextField","tabHasLocalizedField","tabHasLocalizedManyNumberField","tabHasLocalizedManyTextField","tabHasLocalizedRelationshipField","tabHasManyNumberField","tabHasManyTextField","tabs","tab","rowHasLocalizedField","rowHasLocalizedManyNumberField","rowHasLocalizedManyTextField","rowHasLocalizedRelationshipField","rowHasManyNumberField","rowHasManyTextField","Array","isArray","relationTo","relation","add","required"],"mappings":"AAAA,oCAAoC,GAKpC,SAASA,SAAS,QAAQ,cAAa;AACvC,SACEC,gBAAgB,EAChBC,aAAa,EACbC,gBAAgB,EAChBC,OAAO,EACPC,KAAK,EACLC,OAAO,EACPC,KAAK,EACLC,OAAO,EACPC,MAAM,EACNC,IAAI,EACJC,SAAS,EACTC,OAAO,QACF,sBAAqB;AAC5B,SAASC,oBAAoB,QAAQ,iBAAgB;AACrD,SAASC,gBAAgB,EAAEC,cAAc,QAAQ,gBAAe;AAChE,OAAOC,iBAAiB,gBAAe;AAIvC,SAASC,eAAe,QAAQ,kCAAiC;AACjE,SAASC,UAAU,QAAQ,aAAY;AACvC,SAASC,WAAW,QAAQ,mBAAkB;AAC9C,SAASC,YAAY,QAAQ,oBAAmB;AAChD,SAASC,QAAQ,QAAQ,gBAAe;AACxC,SAASC,iBAAiB,QAAQ,yBAAwB;AAC1D,SAASC,gCAAgC,QAAQ,wCAAuC;AAoCxF,OAAO,MAAMC,iBAAiB,CAAC,EAC7BC,OAAO,EACPC,YAAY,EACZC,kBAAkB,EAClBC,UAAU,EACVC,YAAY,EACZC,OAAO,EACPC,cAAc,EACdC,gBAAgB,KAAK,EACrBC,WAAW,EACXC,MAAM,EACNC,cAAc,EACdC,OAAO,EACPC,cAAc,EACdC,cAAc,EACdC,YAAY,EACZC,eAAe,EACfC,gBAAgB,EAChBC,aAAa,EACbC,oBAAoB,EACpBC,kBAAkB,EAClBC,aAAa,EACbC,QAAQ,EACH;IACL,MAAMC,uBAAuB;IAC7B,IAAIC,oBAAoB;IACxB,IAAIC,gCAAgC;IACpC,IAAIC,mBAAsC;IAC1C,IAAIC,4BAA4B;IAChC,IAAIC,qBAAwC;IAC5C,IAAIC,8BAA8B;IAElC,IAAIC,kBAA0B;IAC9B,IAAIxB,QAAQyB,EAAE,YAAYrD,eAAeoD,kBAAkB;IAC3D,IAAIxB,QAAQyB,EAAE,YAAYtD,kBAAkBqD,kBAAkB;IAC9D,IAAIxB,QAAQyB,EAAE,YAAYpD,kBAAkBmD,kBAAkB;IAE9DpB,OAAOsB,OAAO,CAAC,CAACC;QACd,IAAI,UAAUA,SAASA,MAAMC,IAAI,KAAK,MAAM;QAC5C,IAAIC;QACJ,IAAIC;QAEJ,IAAIC,cAAc/B;QAClB,IAAIgC,gBAAgB1B;QAEpB,IAAItB,iBAAiB2C,QAAQ;YAC3BE,aAAa,CAAC,EAAE9B,gBAAgB,GAAG,EAAE4B,MAAMC,IAAI,CAAC,EAAE,KAAK,MAAM,MAAM,GAAG,EAAE1C,YACtEyC,MAAMC,IAAI,EACV,CAAC;YACHE,YAAY,CAAC,EAAE3B,aAAa8B,QAAQ,KAAK,QAAQ,GAAG,EAAEN,MAAMC,IAAI,CAAC,CAAC;YAElE,yBAAyB;YACzB,2DAA2D;YAC3D,IAAIjC,QAAQuC,OAAO,CAACC,MAAM,CAACC,YAAY,IAAKT,CAAAA,MAAMU,SAAS,IAAIhC,cAAa,GAAI;gBAC9Ea,oBAAoB;gBACpBa,cAAcxB;gBACdyB,gBAAgBxB;YAClB;YAEA,IACE,AAACmB,CAAAA,MAAMW,MAAM,IAAIX,MAAMpD,KAAK,AAAD,KAC3B,CAAC;gBAAC;gBAAS;gBAAU;gBAAS;gBAAS;gBAAgB;aAAS,CAACgE,QAAQ,CAACZ,MAAMa,IAAI,KACpF,CAAE,CAAA,aAAab,SAASA,MAAMc,OAAO,KAAK,IAAG,GAC7C;gBACA,MAAMH,SAASpC,kBAAkB,QAAQyB,MAAMW,MAAM;gBACrD,IAAIA,QAAQ;oBACV,MAAMI,kBAAkB,CAAC,EAAEvC,eAAe,GAAG,EAAEwB,MAAMC,IAAI,CAAC,CAAC;oBAC3D,IAAI,CAACjC,QAAQgD,gBAAgB,EAAE,CAAC5B,cAAc,EAAE;wBAC9CpB,QAAQgD,gBAAgB,CAAC5B,cAAc,GAAG,CAAC;oBAC7C;oBACApB,QAAQgD,gBAAgB,CAAC5B,cAAc,CAAC,CAAC,EAAEc,WAAW,IAAI,CAAC,CAAC,GAAGa;gBACjE;gBACAV,aAAa,CAAC,CAAC,EAAEvB,aAAa,CAAC,EAAEkB,MAAMC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAGvC,YAAY;oBAC9DuC,MAAME;oBACND;oBACAe,WAAWnC;oBACX6B;gBACF;YACF;QACF;QAEA,OAAQX,MAAMa,IAAI;YAChB,KAAK;gBAAQ;oBACX,IAAIb,MAAMc,OAAO,EAAE;wBACjB,IAAId,MAAMU,SAAS,EAAE;4BACnBhB,4BAA4B;wBAC9B;wBAEA,IAAIM,MAAMpD,KAAK,EAAE;4BACf6C,mBAAmB;wBACrB,OAAO,IAAI,CAACA,kBAAkB;4BAC5BA,mBAAmB;wBACrB;wBAEA,IAAIO,MAAMW,MAAM,EAAE;4BAChB,MAAM,IAAIvD,qBACR;wBAEJ;oBACF,OAAO;wBACLgD,WAAW,CAACD,UAAU,GAAGhD,QAAQ+C;oBACnC;oBACA;gBACF;YACA,KAAK;YACL,KAAK;YACL,KAAK;gBAAY;oBACfE,WAAW,CAACD,UAAU,GAAGhD,QAAQ+C;oBACjC;gBACF;YAEA,KAAK;gBAAU;oBACb,IAAIF,MAAMc,OAAO,EAAE;wBACjB,IAAId,MAAMU,SAAS,EAAE;4BACnBd,8BAA8B;wBAChC;wBAEA,IAAII,MAAMpD,KAAK,EAAE;4BACf+C,qBAAqB;wBACvB,OAAO,IAAI,CAACA,oBAAoB;4BAC9BA,qBAAqB;wBACvB;wBAEA,IAAIK,MAAMW,MAAM,EAAE;4BAChB,MAAM,IAAIvD,qBACR;wBAEJ;oBACF,OAAO;wBACLgD,WAAW,CAACD,UAAU,GAAGpD,QAAQmD;oBACnC;oBACA;gBACF;YAEA,KAAK;YACL,KAAK;gBAAQ;oBACXE,WAAW,CAACD,UAAU,GAAGrD,MAAMoD;oBAC/B;gBACF;YAEA,KAAK;gBAAQ;oBACXE,WAAW,CAACD,UAAU,GAAGjD,UAAUgD,YAAY;wBAC7CgB,MAAM;wBACNC,WAAW;wBACXC,cAAc;oBAChB;oBACA;gBACF;YAEA,KAAK;gBAAS;oBACZ;gBACF;YAEA,KAAK;YACL,KAAK;gBAAU;oBACb,MAAMC,WAAW1D,aAAa;wBAC5BK;wBACAwC,QAAQR;wBACRjB,iBAAiBD;wBACjBwC,QAAQ,CAAC,KAAK,EAAExC,aAAa,CAAC,CAAC;wBAC/ByC,QAAQ;wBACRjC;wBACAD;oBACF;oBAEArB,QAAQwD,KAAK,CAACH,SAAS,GAAGrE,OACxBqE,UACArB,MAAMyB,OAAO,CAACC,GAAG,CAAC,CAACC;wBACjB,IAAIrE,eAAeqE,SAAS;4BAC1B,OAAOA,OAAOC,KAAK;wBACrB;wBAEA,OAAOD;oBACT;oBAGF,IAAI3B,MAAMa,IAAI,KAAK,YAAYb,MAAMc,OAAO,EAAE;wBAC5C,MAAMe,kBAAkBlE,aAAa;4BACnCK;4BACAwC,QAAQR;4BACRjB,iBAAiBD;4BACjBwC,QAAQ,CAAC,EAAExC,aAAa,CAAC,CAAC;4BAC1BQ;4BACAD;wBACF;wBACA,MAAMyC,cAA+C;4BACnDC,OAAOlF,QAAQ,SAASmF,OAAO;4BAC/BC,QAAQpE,iBAAiB,CAACgC,gBAAgB,CAAC,aACxCqC,UAAU,CAAC,IAAMlE,QAAQmE,MAAM,CAACpD,gBAAgB,CAACe,EAAE,EAAE;gCAAEsC,UAAU;4BAAU,GAC3EJ,OAAO;4BACVJ,OAAO5D,QAAQwD,KAAK,CAACH,SAAS,CAAC;wBACjC;wBAEA,MAAMgB,kBAGF;4BACFC,UAAU,CAACC,OAAS3F,MAAM,CAAC,EAAEiF,gBAAgB,UAAU,CAAC,EAAEW,EAAE,CAACD,KAAKR,KAAK;4BACvEU,WAAW,CAACF,OAAS3F,MAAM,CAAC,EAAEiF,gBAAgB,WAAW,CAAC,EAAEW,EAAE,CAACD,KAAKN,MAAM;wBAC5E;wBAEA,IAAIjC,MAAMU,SAAS,EAAE;4BACnBoB,YAAYY,MAAM,GAAG1E,QAAQwD,KAAK,CAACmB,aAAa,CAAC,UAAUX,OAAO;4BAClEK,gBAAgBO,SAAS,GAAG,CAACL,OAC3B3F,MAAM,CAAC,EAAEiF,gBAAgB,WAAW,CAAC,EAAEW,EAAE,CAACD,KAAKG,MAAM;wBACzD;wBAEA,IAAI1C,MAAMpD,KAAK,EAAE;4BACfyF,gBAAgBT,KAAK,GAAG,CAACW,OAAS3F,MAAM,CAAC,EAAEiF,gBAAgB,UAAU,CAAC,EAAEW,EAAE,CAACD,KAAKX,KAAK;wBACvF;wBAEAnE,WAAW;4BACTO;4BACA8D;4BACAO;4BACA/D;4BACAC;4BACAE,QAAQ,EAAE;4BACVwC,WAAWY;4BACXxC;wBACF;wBAEAL,iBAAiB6D,GAAG,CAAC1C,WAAW0B;wBAEhC,MAAMiB,uBAAuBvG,UAAUyB,QAAQmE,MAAM,CAACN,gBAAgB,EAAE,CAAC,EAAEkB,GAAG,EAAE;4BAC9E,MAAMC,SAA2C;gCAC/Cf,QAAQc,IAAI/E,QAAQmE,MAAM,CAACpD,gBAAgB,EAAE;oCAC3CN,QAAQ;wCAACT,QAAQmE,MAAM,CAACN,gBAAgB,CAACI,MAAM;qCAAC;oCAChDC,YAAY;wCAAClE,QAAQmE,MAAM,CAACpD,gBAAgB,CAACe,EAAE;qCAAC;gCAClD;4BACF;4BAEA,OAAOkD;wBACT;wBAEAhF,QAAQzB,SAAS,CAAC,CAAC,SAAS,EAAEsF,gBAAgB,CAAC,CAAC,GAAGiB;oBACrD,OAAO;wBACL1C,WAAW,CAACD,UAAU,GAAGnC,QAAQwD,KAAK,CAACH,SAAS,CAAClB;oBACnD;oBACA;gBACF;YAEA,KAAK;gBAAY;oBACfC,WAAW,CAACD,UAAU,GAAGxD,QAAQuD;oBACjC;gBACF;YAEA,KAAK;gBAAS;oBACZ,MAAM+C,yBAAyBC,QAAQlD,MAAMmD,KAAK,EAAEC,cAAc9E;oBAElE,MAAM+E,iBAAiB1F,aAAa;wBAClCK;wBACAwC,QAAQR;wBACRjB,iBAAiBD;wBACjBwC,QAAQ,CAAC,EAAExC,aAAa,CAAC,CAAC;wBAC1BQ;oBACF;oBACA,MAAMwC,cAA+C;wBACnDwB,QAAQzG,QAAQ,UAAUmF,OAAO;wBACjCuB,WAAW1F,iBAAiB,CAACgC,gBAAgB,CAAC,cAC3CqC,UAAU,CAAC,IAAMlE,QAAQmE,MAAM,CAACpD,gBAAgB,CAACe,EAAE,EAAE;4BAAEsC,UAAU;wBAAU,GAC3EJ,OAAO;oBACZ;oBAEA,MAAMK,kBAGF;wBACFmB,WAAW,CAACjB,OAAS3F,MAAM,CAAC,EAAEyG,eAAe,UAAU,CAAC,EAAEb,EAAE,CAACD,KAAKe,MAAM;wBACxEG,cAAc,CAAClB,OAAS3F,MAAM,CAAC,EAAEyG,eAAe,cAAc,CAAC,EAAEb,EAAE,CAACD,KAAKgB,SAAS;oBACpF;oBAEA,IAAIvD,MAAMU,SAAS,IAAI1C,QAAQuC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;wBAC1DqB,YAAY4B,OAAO,GAAG1F,QAAQwD,KAAK,CAACmB,aAAa,CAAC,WAAWX,OAAO;wBACpEK,gBAAgBsB,UAAU,GAAG,CAACpB,OAC5B3F,MAAM,CAAC,EAAEyG,eAAe,WAAW,CAAC,EAAEb,EAAE,CAACD,KAAKmB,OAAO;oBACzD;oBAEA,MAAM,EACJ/D,oBAAoBiE,qBAAqB,EACzCnE,kBAAkBoE,mBAAmB,EACrC7E,kBAAkB8E,mBAAmB,EACtC,GAAGrG,WAAW;wBACbO;wBACA8D;wBACAO;wBACA/D,gBAAgB2E;wBAChB1E;wBACAE,QAAQF,gBAAgBX,SAASoC,MAAMvB,MAAM,IAAIuB,MAAMvB,MAAM;wBAC7DS;wBACA6E,mBAAmB9E;wBACnBE;wBACAC;wBACA6B,WAAWoC;wBACXhE;oBACF;oBAEA,IAAIwE,qBAAqB;wBACvB,IAAI,CAACpE,oBAAoBoE,wBAAwB,SAC/CpE,mBAAmBoE;oBACvB;oBACA,IAAID,uBAAuB;wBACzB,IAAI,CAACjE,sBAAsBiE,0BAA0B,SACnDjE,qBAAqBiE;oBACzB;oBAEA5E,iBAAiB6D,GAAG,CAAC1C,WAAWkD;oBAEhC,MAAMW,sBAAsBzH,UAAUyB,QAAQmE,MAAM,CAACkB,eAAe,EAAE,CAAC,EAAEY,IAAI,EAAElB,GAAG,EAAE;wBAClF,MAAMC,SAA2C;4BAC/CO,WAAWR,IAAI/E,QAAQmE,MAAM,CAACpD,gBAAgB,EAAE;gCAC9CN,QAAQ;oCAACT,QAAQmE,MAAM,CAACkB,eAAe,CAACE,SAAS;iCAAC;gCAClDrB,YAAY;oCAAClE,QAAQmE,MAAM,CAACpD,gBAAgB,CAACe,EAAE;iCAAC;4BAClD;wBACF;wBAEA,IAAItC,gBAAgBwC,MAAMvB,MAAM,GAAG;4BACjCuE,OAAOkB,QAAQ,GAAGD,KAAKjG,QAAQmE,MAAM,CAAC,CAAC,EAAEkB,eAAe,EAAErF,QAAQmG,aAAa,CAAC,CAAC,CAAC;wBACpF;wBAEAL,oBAAoB/D,OAAO,CAAC,CAACqE,KAAKC;4BAChCrB,MAAM,CAACqB,IAAI,GAAGJ,KAAKjG,QAAQmE,MAAM,CAACiC,IAAI;wBACxC;wBAEA,OAAOpB;oBACT;oBAEAhF,QAAQzB,SAAS,CAAC,CAAC,UAAU,EAAE8G,eAAe,CAAC,CAAC,GAAGW;oBAEnD;gBACF;YAEA,KAAK;gBAAU;oBACb,MAAMf,yBAAyBC,QAAQlD,MAAMmD,KAAK,EAAEC,cAAc9E;oBAElE0B,MAAMsE,MAAM,CAACvE,OAAO,CAAC,CAACwE;wBACpB,MAAMC,iBAAiB7G,aAAa;4BAClCK;4BACAwC,QAAQ+D;4BACRxF,iBAAiBK;4BACjBkC,QAAQ,CAAC,EAAElC,cAAc,QAAQ,CAAC;4BAClCE;wBACF;wBACA,IAAI,CAACtB,QAAQmE,MAAM,CAACqC,eAAe,EAAE;4BACnC,MAAM1C,cAA+C;gCACnDwB,QAAQzG,QAAQ,UAAUmF,OAAO;gCACjCuB,WAAW1F,iBAAiB,CAACsB,mBAAmB,CAAC,cAC9C+C,UAAU,CAAC,IAAMlE,QAAQmE,MAAM,CAAC/C,cAAc,CAACU,EAAE,EAAE;oCAAEsC,UAAU;gCAAU,GACzEJ,OAAO;gCACVyC,OAAOxH,KAAK,SAAS+E,OAAO;4BAC9B;4BAEA,MAAMK,kBAGF;gCACFmB,WAAW,CAACjB,OAAS3F,MAAM,CAAC,EAAE4H,eAAe,UAAU,CAAC,EAAEhC,EAAE,CAACD,KAAKe,MAAM;gCACxEG,cAAc,CAAClB,OAAS3F,MAAM,CAAC,EAAE4H,eAAe,cAAc,CAAC,EAAEhC,EAAE,CAACD,KAAKgB,SAAS;gCAClFmB,UAAU,CAACnC,OAAS3F,MAAM,CAAC,EAAE4H,eAAe,SAAS,CAAC,EAAEhC,EAAE,CAACD,KAAKkC,KAAK;4BACvE;4BAEA,IAAIzE,MAAMU,SAAS,IAAI1C,QAAQuC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;gCAC1DqB,YAAY4B,OAAO,GAAG1F,QAAQwD,KAAK,CAACmB,aAAa,CAAC,WAAWX,OAAO;gCACpEK,gBAAgBsB,UAAU,GAAG,CAACpB,OAC5B3F,MAAM,CAAC,EAAE4H,eAAe,WAAW,CAAC,EAAEhC,EAAE,CAACD,KAAKmB,OAAO;4BACzD;4BAEA,MAAM,EACJ/D,oBAAoBiE,qBAAqB,EACzCnE,kBAAkBoE,mBAAmB,EACrC7E,kBAAkB8E,mBAAmB,EACtC,GAAGrG,WAAW;gCACbO;gCACA8D;gCACAO;gCACA/D,gBAAgB2E;gCAChB1E;gCACAE,QAAQF,gBAAgBX,SAAS2G,MAAM9F,MAAM,IAAI8F,MAAM9F,MAAM;gCAC7DS;gCACA6E,mBAAmB9E;gCACnBE;gCACAC;gCACA6B,WAAWuD;gCACXnF;4BACF;4BAEA,IAAIwE,qBAAqB;gCACvB,IAAI,CAACpE,oBAAoBoE,wBAAwB,SAC/CpE,mBAAmBoE;4BACvB;4BAEA,IAAID,uBAAuB;gCACzB,IAAI,CAACjE,sBAAsBiE,0BAA0B,SACnDjE,qBAAqBiE;4BACzB;4BAEA,MAAMe,sBAAsBpI,UAC1ByB,QAAQmE,MAAM,CAACqC,eAAe,EAC9B,CAAC,EAAEP,IAAI,EAAElB,GAAG,EAAE;gCACZ,MAAMC,SAA2C;oCAC/CO,WAAWR,IAAI/E,QAAQmE,MAAM,CAAC/C,cAAc,EAAE;wCAC5CX,QAAQ;4CAACT,QAAQmE,MAAM,CAACqC,eAAe,CAACjB,SAAS;yCAAC;wCAClDrB,YAAY;4CAAClE,QAAQmE,MAAM,CAAC/C,cAAc,CAACU,EAAE;yCAAC;oCAChD;gCACF;gCAEA,IAAItC,gBAAgB+G,MAAM9F,MAAM,GAAG;oCACjCuE,OAAOkB,QAAQ,GAAGD,KAChBjG,QAAQmE,MAAM,CAAC,CAAC,EAAEqC,eAAe,EAAExG,QAAQmG,aAAa,CAAC,CAAC,CAAC;gCAE/D;gCAEAL,oBAAoB/D,OAAO,CAAC,CAACqE,KAAKC;oCAChCrB,MAAM,CAACqB,IAAI,GAAGJ,KAAKjG,QAAQmE,MAAM,CAACiC,IAAI;gCACxC;gCAEA,OAAOpB;4BACT;4BAGFhF,QAAQzB,SAAS,CAAC,CAAC,UAAU,EAAEiI,eAAe,CAAC,CAAC,GAAGG;wBACrD,OAAO,IAAIC,QAAQC,GAAG,CAACC,QAAQ,KAAK,gBAAgB,CAACzF,UAAU;4BAC7DvB,iCAAiC;gCAC/ByG;gCACA7D,WAAWV,MAAMU,SAAS;gCAC1BtB;gCACA2F,OAAO/G,QAAQmE,MAAM,CAACqC,eAAe;4BACvC;wBACF;wBACAxG,QAAQgH,eAAe,CAAC,CAAC,EAAE5F,cAAc,CAAC,EAAE7B,YAAYgH,MAAMU,IAAI,EAAE,CAAC,CAAC,GAAGT;wBACzEtF,qBAAqB2D,GAAG,CAAC,CAAC,QAAQ,EAAE0B,MAAMU,IAAI,CAAC,CAAC,EAAET;oBACpD;oBAEA;gBACF;YAEA,KAAK;YACL,KAAK;gBAAS;oBACZ,IAAI,CAAE,CAAA,UAAUxE,KAAI,GAAI;wBACtB,MAAM,EACJT,mBAAmB2F,sBAAsB,EACzCtF,6BAA6BuF,gCAAgC,EAC7DzF,2BAA2B0F,8BAA8B,EACzD5F,+BAA+B6F,kCAAkC,EACjE1F,oBAAoB2F,uBAAuB,EAC3C7F,kBAAkB8F,qBAAqB,EACxC,GAAGxH,eAAe;4BACjBC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC,QAAQuB,MAAMvB,MAAM;4BACpBC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;wBACF;wBAEA,IAAI6F,wBAAwB3F,oBAAoB;wBAChD,IAAI8F,oCAAoC7F,gCAAgC;wBACxE,IAAI+F,uBAAuB9F,mBAAmB;wBAC9C,IAAI2F,gCAAgC1F,4BAA4B;wBAChE,IAAI4F,yBAAyB3F,qBAAqB;wBAClD,IAAIwF,kCAAkCvF,8BAA8B;wBACpE;oBACF;oBAEA,MAAMqD,yBAAyBC,QAAQlD,MAAMmD,KAAK,EAAEC,cAAc9E;oBAElE,MAAM,EACJiB,mBAAmB2F,sBAAsB,EACzCtF,6BAA6BuF,gCAAgC,EAC7DzF,2BAA2B0F,8BAA8B,EACzD5F,+BAA+B6F,kCAAkC,EACjE1F,oBAAoB2F,uBAAuB,EAC3C7F,kBAAkB8F,qBAAqB,EACxC,GAAGxH,eAAe;wBACjBC;wBACAC;wBACAC;wBACAC;wBACAC,cAAc,CAAC,EAAE8B,WAAW,CAAC,CAAC;wBAC9B7B;wBACAC,gBAAgB2E;wBAChB1E;wBACAC,aAAa,CAAC,EAAE2B,UAAU,CAAC,CAAC;wBAC5B1B,QAAQuB,MAAMvB,MAAM;wBACpBC,gBAAgBsB,MAAMU,SAAS;wBAC/B/B;wBACAC;wBACAC;wBACAC,cAAc,CAAC,EAAEC,gBAAgB,CAAC,EAAEmB,WAAW,CAAC;wBAChDnB;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;oBACF;oBAEA,IAAI6F,wBAAwB3F,oBAAoB;oBAChD,IAAI8F,oCAAoC7F,gCAAgC;oBACxE,IAAI+F,uBAAuB9F,mBAAmB;oBAC9C,IAAI2F,gCAAgC1F,4BAA4B;oBAChE,IAAI4F,yBAAyB3F,qBAAqB;oBAClD,IAAIwF,kCAAkCvF,8BAA8B;oBACpE;gBACF;YAEA,KAAK;gBAAQ;oBACX,MAAMqD,yBAAyBC,QAAQlD,MAAMmD,KAAK,EAAEC,cAAc9E;oBAElE,MAAM,EACJiB,mBAAmBiG,oBAAoB,EACvC5F,6BAA6B6F,8BAA8B,EAC3D/F,2BAA2BgG,4BAA4B,EACvDlG,+BAA+BmG,gCAAgC,EAC/DhG,oBAAoBiG,qBAAqB,EACzCnG,kBAAkBoG,mBAAmB,EACtC,GAAG9H,eAAe;wBACjBC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC,gBAAgB2E;wBAChB1E;wBACAC;wBACAC,QAAQuB,MAAM8F,IAAI,CAACpE,GAAG,CAAC,CAACqE,MAAS,CAAA;gCAAE,GAAGA,GAAG;gCAAElF,MAAM;4BAAM,CAAA;wBACvDnC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;oBACF;oBAEA,IAAImG,sBAAsBjG,oBAAoB;oBAC9C,IAAIoG,kCAAkCnG,gCAAgC;oBACtE,IAAIqG,qBAAqBpG,mBAAmB;oBAC5C,IAAIiG,8BAA8BhG,4BAA4B;oBAC9D,IAAIkG,uBAAuBjG,qBAAqB;oBAChD,IAAI8F,gCAAgC7F,8BAA8B;oBAClE;gBACF;YAEA,KAAK;YACL,KAAK;gBAAe;oBAClB,MAAMqD,yBAAyBC,QAAQlD,MAAMmD,KAAK,EAAEC,cAAc9E;oBAClE,MAAM,EACJiB,mBAAmByG,oBAAoB,EACvCpG,6BAA6BqG,8BAA8B,EAC3DvG,2BAA2BwG,4BAA4B,EACvD1G,+BAA+B2G,gCAAgC,EAC/DxG,oBAAoByG,qBAAqB,EACzC3G,kBAAkB4G,mBAAmB,EACtC,GAAGtI,eAAe;wBACjBC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC,gBAAgB2E;wBAChB1E;wBACAC;wBACAC,QAAQuB,MAAMvB,MAAM;wBACpBC;wBACAC;wBACAC;wBACAC;wBACAC,cAAcC;wBACdA;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;oBACF;oBAEA,IAAI2G,sBAAsBzG,oBAAoB;oBAC9C,IAAI4G,kCAAkC3G,gCAAgC;oBACtE,IAAI6G,qBAAqB5G,mBAAmB;oBAC5C,IAAIyG,8BAA8BxG,4BAA4B;oBAC9D,IAAI0G,uBAAuBzG,qBAAqB;oBAChD,IAAIsG,gCAAgCrG,8BAA8B;oBAClE;gBACF;YAEA,KAAK;YACL,KAAK;gBACH,IAAI0G,MAAMC,OAAO,CAACvG,MAAMwG,UAAU,GAAG;oBACnCxG,MAAMwG,UAAU,CAACzG,OAAO,CAAC,CAAC0G,WAAaxH,cAAcyH,GAAG,CAACD;gBAC3D,OAAO;oBACLxH,cAAcyH,GAAG,CAAC1G,MAAMwG,UAAU;gBACpC;gBAEA,IAAIxG,MAAMU,SAAS,IAAI1C,QAAQuC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;oBAC1DjB,gCAAgC;gBAClC;gBACA;YAEF;gBACE;QACJ;QAEA,MAAM4D,YAAYpD,MAAMmD,KAAK,IAAInD,MAAMmD,KAAK,CAACC,SAAS;QAEtD,IACE,CAAC9E,kBACD8B,WAAW,CAACD,UAAU,IACtB,cAAcH,SACdA,MAAM2G,QAAQ,IACd,CAACvD,WACD;YACAhD,WAAW,CAACD,UAAU,CAAC6B,OAAO;QAChC;IACF;IAEA,OAAO;QACLzC;QACAK;QACAF;QACAF;QACAG;QACAF;IACF;AACF,EAAC"}
|
package/dist/types.d.ts
CHANGED
@@ -9,11 +9,14 @@ import type { Pool, PoolConfig } from 'pg';
|
|
9
9
|
export type DrizzleDB = NodePgDatabase<Record<string, unknown>>;
|
10
10
|
export type Args = {
|
11
11
|
idType?: 'serial' | 'uuid';
|
12
|
+
localesSuffix?: string;
|
12
13
|
logger?: DrizzleConfig['logger'];
|
13
14
|
migrationDir?: string;
|
14
15
|
pool: PoolConfig;
|
15
16
|
push?: boolean;
|
17
|
+
relationshipsSuffix?: string;
|
16
18
|
schemaName?: string;
|
19
|
+
versionsSuffix?: string;
|
17
20
|
};
|
18
21
|
export type GenericColumn = PgColumn<ColumnBaseConfig<ColumnDataType, string>, Record<string, unknown>>;
|
19
22
|
export type GenericColumns = {
|
@@ -29,6 +32,10 @@ export type GenericEnum = PgEnum<[string, ...string[]]>;
|
|
29
32
|
export type GenericRelation = Relations<string, Record<string, Relation<string>>>;
|
30
33
|
export type DrizzleTransaction = PgTransaction<NodePgQueryResultHKT, Record<string, unknown>, ExtractTablesWithRelations<Record<string, unknown>>>;
|
31
34
|
export type PostgresAdapter = BaseDatabaseAdapter & {
|
35
|
+
/**
|
36
|
+
* Used internally to map the block name to the table name
|
37
|
+
*/
|
38
|
+
blockTableNames: Record<string, string>;
|
32
39
|
drizzle: DrizzleDB;
|
33
40
|
enums: Record<string, GenericEnum>;
|
34
41
|
/**
|
@@ -37,6 +44,7 @@ export type PostgresAdapter = BaseDatabaseAdapter & {
|
|
37
44
|
*/
|
38
45
|
fieldConstraints: Record<string, Record<string, string>>;
|
39
46
|
idType: Args['idType'];
|
47
|
+
localesSuffix?: string;
|
40
48
|
logger: DrizzleConfig['logger'];
|
41
49
|
pgSchema?: {
|
42
50
|
table: PgTableFn;
|
@@ -45,6 +53,7 @@ export type PostgresAdapter = BaseDatabaseAdapter & {
|
|
45
53
|
poolOptions: Args['pool'];
|
46
54
|
push: boolean;
|
47
55
|
relations: Record<string, GenericRelation>;
|
56
|
+
relationshipsSuffix?: string;
|
48
57
|
schema: Record<string, GenericEnum | GenericRelation | GenericTable>;
|
49
58
|
schemaName?: Args['schemaName'];
|
50
59
|
sessions: {
|
@@ -55,6 +64,7 @@ export type PostgresAdapter = BaseDatabaseAdapter & {
|
|
55
64
|
};
|
56
65
|
};
|
57
66
|
tables: Record<string, GenericTable | PgTableWithColumns<any>>;
|
67
|
+
versionsSuffix?: string;
|
58
68
|
};
|
59
69
|
export type IDType = 'integer' | 'numeric' | 'uuid' | 'varchar';
|
60
70
|
export type PostgresAdapterResult = (args: {
|
@@ -73,9 +83,11 @@ declare module 'payload' {
|
|
73
83
|
drizzle: DrizzleDB;
|
74
84
|
enums: Record<string, GenericEnum>;
|
75
85
|
fieldConstraints: Record<string, Record<string, string>>;
|
86
|
+
localeSuffix?: string;
|
76
87
|
pool: Pool;
|
77
88
|
push: boolean;
|
78
89
|
relations: Record<string, GenericRelation>;
|
90
|
+
relationshipsSuffix?: string;
|
79
91
|
schema: Record<string, GenericEnum | GenericRelation | GenericTable>;
|
80
92
|
sessions: {
|
81
93
|
[id: string]: {
|
@@ -85,6 +97,7 @@ declare module 'payload' {
|
|
85
97
|
};
|
86
98
|
};
|
87
99
|
tables: Record<string, GenericTable>;
|
100
|
+
versionsSuffix?: string;
|
88
101
|
}
|
89
102
|
}
|
90
103
|
//# sourceMappingURL=types.d.ts.map
|
package/dist/types.d.ts.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,gBAAgB,EAChB,cAAc,EACd,aAAa,EACb,0BAA0B,EAC1B,QAAQ,EACR,SAAS,EACV,MAAM,aAAa,CAAA;AACpB,OAAO,KAAK,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAA;AACrF,OAAO,KAAK,EACV,QAAQ,EACR,MAAM,EACN,QAAQ,EACR,kBAAkB,EAClB,aAAa,EACd,MAAM,qBAAqB,CAAA;AAC5B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAA;AAC1D,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AACtC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAA;AAC3D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AACnD,OAAO,KAAK,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,IAAI,CAAA;AAE1C,MAAM,MAAM,SAAS,GAAG,cAAc,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAA;AAE/D,MAAM,MAAM,IAAI,GAAG;IACjB,MAAM,CAAC,EAAE,QAAQ,GAAG,MAAM,CAAA;IAC1B,MAAM,CAAC,EAAE,aAAa,CAAC,QAAQ,CAAC,CAAA;IAChC,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,IAAI,EAAE,UAAU,CAAA;IAChB,IAAI,CAAC,EAAE,OAAO,CAAA;IACd,UAAU,CAAC,EAAE,MAAM,CAAA;
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
|
package/dist/types.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../src/types.ts"],"sourcesContent":["import type {\n ColumnBaseConfig,\n ColumnDataType,\n DrizzleConfig,\n ExtractTablesWithRelations,\n Relation,\n Relations,\n} from 'drizzle-orm'\nimport type { NodePgDatabase, NodePgQueryResultHKT } from 'drizzle-orm/node-postgres'\nimport type {\n PgColumn,\n PgEnum,\n PgSchema,\n PgTableWithColumns,\n PgTransaction,\n} from 'drizzle-orm/pg-core'\nimport type { PgTableFn } from 'drizzle-orm/pg-core/table'\nimport type { Payload } from 'payload'\nimport type { BaseDatabaseAdapter } from 'payload/database'\nimport type { PayloadRequest } from 'payload/types'\nimport type { Pool, PoolConfig } from 'pg'\n\nexport type DrizzleDB = NodePgDatabase<Record<string, unknown>>\n\nexport type Args = {\n idType?: 'serial' | 'uuid'\n logger?: DrizzleConfig['logger']\n migrationDir?: string\n pool: PoolConfig\n push?: boolean\n schemaName?: string\n}\n\nexport type GenericColumn = PgColumn<\n ColumnBaseConfig<ColumnDataType, string>,\n Record<string, unknown>\n>\n\nexport type GenericColumns = {\n [x: string]: GenericColumn\n}\n\nexport type GenericTable = PgTableWithColumns<{\n columns: GenericColumns\n dialect: string\n name: string\n schema: undefined\n}>\n\nexport type GenericEnum = PgEnum<[string, ...string[]]>\n\nexport type GenericRelation = Relations<string, Record<string, Relation<string>>>\n\nexport type DrizzleTransaction = PgTransaction<\n NodePgQueryResultHKT,\n Record<string, unknown>,\n ExtractTablesWithRelations<Record<string, unknown>>\n>\n\nexport type PostgresAdapter = BaseDatabaseAdapter & {\n drizzle: DrizzleDB\n enums: Record<string, GenericEnum>\n /**\n * An object keyed on each table, with a key value pair where the constraint name is the key, followed by the dot-notation field name\n * Used for returning properly formed errors from unique fields\n */\n fieldConstraints: Record<string, Record<string, string>>\n idType: Args['idType']\n logger: DrizzleConfig['logger']\n pgSchema?: { table: PgTableFn } | PgSchema\n pool: Pool\n poolOptions: Args['pool']\n push: boolean\n relations: Record<string, GenericRelation>\n schema: Record<string, GenericEnum | GenericRelation | GenericTable>\n schemaName?: Args['schemaName']\n sessions: {\n [id: string]: {\n db: DrizzleTransaction\n reject: () => Promise<void>\n resolve: () => Promise<void>\n }\n }\n tables: Record<string, GenericTable | PgTableWithColumns<any>>\n}\n\nexport type IDType = 'integer' | 'numeric' | 'uuid' | 'varchar'\n\nexport type PostgresAdapterResult = (args: { payload: Payload }) => PostgresAdapter\n\nexport type MigrateUpArgs = { payload: Payload; req?: Partial<PayloadRequest> }\nexport type MigrateDownArgs = { payload: Payload; req?: Partial<PayloadRequest> }\n\ndeclare module 'payload' {\n export interface DatabaseAdapter\n extends Omit<Args, 'migrationDir' | 'pool'>,\n BaseDatabaseAdapter {\n drizzle: DrizzleDB\n enums: Record<string, GenericEnum>\n fieldConstraints: Record<string, Record<string, string>>\n pool: Pool\n push: boolean\n relations: Record<string, GenericRelation>\n schema: Record<string, GenericEnum | GenericRelation | GenericTable>\n sessions: {\n [id: string]: {\n db: DrizzleTransaction\n reject: () => Promise<void>\n resolve: () => Promise<void>\n }\n }\n tables: Record<string, GenericTable>\n }\n}\n"],"names":[],"mappings":"
|
1
|
+
{"version":3,"sources":["../src/types.ts"],"sourcesContent":["import type {\n ColumnBaseConfig,\n ColumnDataType,\n DrizzleConfig,\n ExtractTablesWithRelations,\n Relation,\n Relations,\n} from 'drizzle-orm'\nimport type { NodePgDatabase, NodePgQueryResultHKT } from 'drizzle-orm/node-postgres'\nimport type {\n PgColumn,\n PgEnum,\n PgSchema,\n PgTableWithColumns,\n PgTransaction,\n} from 'drizzle-orm/pg-core'\nimport type { PgTableFn } from 'drizzle-orm/pg-core/table'\nimport type { Payload } from 'payload'\nimport type { BaseDatabaseAdapter } from 'payload/database'\nimport type { PayloadRequest } from 'payload/types'\nimport type { Pool, PoolConfig } from 'pg'\n\nexport type DrizzleDB = NodePgDatabase<Record<string, unknown>>\n\nexport type Args = {\n idType?: 'serial' | 'uuid'\n localesSuffix?: string\n logger?: DrizzleConfig['logger']\n migrationDir?: string\n pool: PoolConfig\n push?: boolean\n relationshipsSuffix?: string\n schemaName?: string\n versionsSuffix?: string\n}\n\nexport type GenericColumn = PgColumn<\n ColumnBaseConfig<ColumnDataType, string>,\n Record<string, unknown>\n>\n\nexport type GenericColumns = {\n [x: string]: GenericColumn\n}\n\nexport type GenericTable = PgTableWithColumns<{\n columns: GenericColumns\n dialect: string\n name: string\n schema: undefined\n}>\n\nexport type GenericEnum = PgEnum<[string, ...string[]]>\n\nexport type GenericRelation = Relations<string, Record<string, Relation<string>>>\n\nexport type DrizzleTransaction = PgTransaction<\n NodePgQueryResultHKT,\n Record<string, unknown>,\n ExtractTablesWithRelations<Record<string, unknown>>\n>\n\nexport type PostgresAdapter = BaseDatabaseAdapter & {\n /**\n * Used internally to map the block name to the table name\n */\n blockTableNames: Record<string, string>\n drizzle: DrizzleDB\n enums: Record<string, GenericEnum>\n /**\n * An object keyed on each table, with a key value pair where the constraint name is the key, followed by the dot-notation field name\n * Used for returning properly formed errors from unique fields\n */\n fieldConstraints: Record<string, Record<string, string>>\n idType: Args['idType']\n localesSuffix?: string\n logger: DrizzleConfig['logger']\n pgSchema?: { table: PgTableFn } | PgSchema\n pool: Pool\n poolOptions: Args['pool']\n push: boolean\n relations: Record<string, GenericRelation>\n relationshipsSuffix?: string\n schema: Record<string, GenericEnum | GenericRelation | GenericTable>\n schemaName?: Args['schemaName']\n sessions: {\n [id: string]: {\n db: DrizzleTransaction\n reject: () => Promise<void>\n resolve: () => Promise<void>\n }\n }\n tables: Record<string, GenericTable | PgTableWithColumns<any>>\n versionsSuffix?: string\n}\n\nexport type IDType = 'integer' | 'numeric' | 'uuid' | 'varchar'\n\nexport type PostgresAdapterResult = (args: { payload: Payload }) => PostgresAdapter\n\nexport type MigrateUpArgs = { payload: Payload; req?: Partial<PayloadRequest> }\nexport type MigrateDownArgs = { payload: Payload; req?: Partial<PayloadRequest> }\n\ndeclare module 'payload' {\n export interface DatabaseAdapter\n extends Omit<Args, 'migrationDir' | 'pool'>,\n BaseDatabaseAdapter {\n drizzle: DrizzleDB\n enums: Record<string, GenericEnum>\n fieldConstraints: Record<string, Record<string, string>>\n localeSuffix?: string\n pool: Pool\n push: boolean\n relations: Record<string, GenericRelation>\n relationshipsSuffix?: string\n schema: Record<string, GenericEnum | GenericRelation | GenericTable>\n sessions: {\n [id: string]: {\n db: DrizzleTransaction\n reject: () => Promise<void>\n resolve: () => Promise<void>\n }\n }\n tables: Record<string, GenericTable>\n versionsSuffix?: string\n }\n}\n"],"names":[],"mappings":"AAqGA,WAAiF"}
|
package/dist/update.d.ts.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"update.d.ts","sourceRoot":"","sources":["../src/update.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;
|
1
|
+
{"version":3,"file":"update.d.ts","sourceRoot":"","sources":["../src/update.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AASjD,eAAO,MAAM,SAAS,EAAE,SAgDvB,CAAA"}
|
package/dist/update.js
CHANGED
@@ -1,11 +1,14 @@
|
|
1
|
-
import toSnakeCase from 'to-snake-case';
|
2
1
|
import buildQuery from './queries/buildQuery.js';
|
3
2
|
import { selectDistinct } from './queries/selectDistinct.js';
|
3
|
+
import { getTableName } from './schema/getTableName.js';
|
4
4
|
import { upsertRow } from './upsertRow/index.js';
|
5
5
|
export const updateOne = async function updateOne({ id, collection: collectionSlug, data, draft, locale, req, where: whereArg }) {
|
6
6
|
const db = this.sessions[req.transactionID]?.db || this.drizzle;
|
7
7
|
const collection = this.payload.collections[collectionSlug].config;
|
8
|
-
const tableName =
|
8
|
+
const tableName = getTableName({
|
9
|
+
adapter: this,
|
10
|
+
config: collection
|
11
|
+
});
|
9
12
|
const whereToUse = whereArg || {
|
10
13
|
id: {
|
11
14
|
equals: id
|
@@ -47,7 +50,7 @@ export const updateOne = async function updateOne({ id, collection: collectionSl
|
|
47
50
|
fields: collection.fields,
|
48
51
|
operation: 'update',
|
49
52
|
req,
|
50
|
-
tableName
|
53
|
+
tableName
|
51
54
|
});
|
52
55
|
return result;
|
53
56
|
};
|
package/dist/update.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../src/update.ts"],"sourcesContent":["import type { UpdateOne } from 'payload/database'\n\nimport
|
1
|
+
{"version":3,"sources":["../src/update.ts"],"sourcesContent":["import type { UpdateOne } from 'payload/database'\n\nimport type { PostgresAdapter } from './types.js'\n\nimport buildQuery from './queries/buildQuery.js'\nimport { selectDistinct } from './queries/selectDistinct.js'\nimport { getTableName } from './schema/getTableName.js'\nimport { upsertRow } from './upsertRow/index.js'\n\nexport const updateOne: UpdateOne = async function updateOne(\n this: PostgresAdapter,\n { id, collection: collectionSlug, data, draft, locale, req, where: whereArg },\n) {\n const db = this.sessions[req.transactionID]?.db || this.drizzle\n const collection = this.payload.collections[collectionSlug].config\n const tableName = getTableName({\n adapter: this,\n config: collection,\n })\n const whereToUse = whereArg || { id: { equals: id } }\n let idToUpdate = id\n\n const { joinAliases, joins, selectFields, where } = await buildQuery({\n adapter: this,\n fields: collection.fields,\n locale,\n tableName,\n where: whereToUse,\n })\n\n const selectDistinctResult = await selectDistinct({\n adapter: this,\n chainedMethods: [{ args: [1], method: 'limit' }],\n db,\n joinAliases,\n joins,\n selectFields,\n tableName,\n where,\n })\n\n if (selectDistinctResult?.[0]?.id) {\n idToUpdate = selectDistinctResult?.[0]?.id\n }\n\n const result = await upsertRow({\n id: idToUpdate,\n adapter: this,\n data,\n db,\n fields: collection.fields,\n operation: 'update',\n req,\n tableName,\n })\n\n return result\n}\n"],"names":["buildQuery","selectDistinct","getTableName","upsertRow","updateOne","id","collection","collectionSlug","data","draft","locale","req","where","whereArg","db","sessions","transactionID","drizzle","payload","collections","config","tableName","adapter","whereToUse","equals","idToUpdate","joinAliases","joins","selectFields","fields","selectDistinctResult","chainedMethods","args","method","result","operation"],"mappings":"AAIA,OAAOA,gBAAgB,0BAAyB;AAChD,SAASC,cAAc,QAAQ,8BAA6B;AAC5D,SAASC,YAAY,QAAQ,2BAA0B;AACvD,SAASC,SAAS,QAAQ,uBAAsB;AAEhD,OAAO,MAAMC,YAAuB,eAAeA,UAEjD,EAAEC,EAAE,EAAEC,YAAYC,cAAc,EAAEC,IAAI,EAAEC,KAAK,EAAEC,MAAM,EAAEC,GAAG,EAAEC,OAAOC,QAAQ,EAAE;IAE7E,MAAMC,KAAK,IAAI,CAACC,QAAQ,CAACJ,IAAIK,aAAa,CAAC,EAAEF,MAAM,IAAI,CAACG,OAAO;IAC/D,MAAMX,aAAa,IAAI,CAACY,OAAO,CAACC,WAAW,CAACZ,eAAe,CAACa,MAAM;IAClE,MAAMC,YAAYnB,aAAa;QAC7BoB,SAAS,IAAI;QACbF,QAAQd;IACV;IACA,MAAMiB,aAAaV,YAAY;QAAER,IAAI;YAAEmB,QAAQnB;QAAG;IAAE;IACpD,IAAIoB,aAAapB;IAEjB,MAAM,EAAEqB,WAAW,EAAEC,KAAK,EAAEC,YAAY,EAAEhB,KAAK,EAAE,GAAG,MAAMZ,WAAW;QACnEsB,SAAS,IAAI;QACbO,QAAQvB,WAAWuB,MAAM;QACzBnB;QACAW;QACAT,OAAOW;IACT;IAEA,MAAMO,uBAAuB,MAAM7B,eAAe;QAChDqB,SAAS,IAAI;QACbS,gBAAgB;YAAC;gBAAEC,MAAM;oBAAC;iBAAE;gBAAEC,QAAQ;YAAQ;SAAE;QAChDnB;QACAY;QACAC;QACAC;QACAP;QACAT;IACF;IAEA,IAAIkB,sBAAsB,CAAC,EAAE,EAAEzB,IAAI;QACjCoB,aAAaK,sBAAsB,CAAC,EAAE,EAAEzB;IAC1C;IAEA,MAAM6B,SAAS,MAAM/B,UAAU;QAC7BE,IAAIoB;QACJH,SAAS,IAAI;QACbd;QACAM;QACAe,QAAQvB,WAAWuB,MAAM;QACzBM,WAAW;QACXxB;QACAU;IACF;IAEA,OAAOa;AACT,EAAC"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"updateGlobal.d.ts","sourceRoot":"","sources":["../src/updateGlobal.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAA;AACxD,OAAO,KAAK,EAAkB,UAAU,EAAE,MAAM,eAAe,CAAA;
|
1
|
+
{"version":3,"file":"updateGlobal.d.ts","sourceRoot":"","sources":["../src/updateGlobal.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAA;AACxD,OAAO,KAAK,EAAkB,UAAU,EAAE,MAAM,eAAe,CAAA;AAE/D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAKjD,wBAAsB,YAAY,CAAC,CAAC,SAAS,UAAU,EACrD,IAAI,EAAE,eAAe,EACrB,EAAE,IAAI,EAAE,IAAI,EAAE,GAA0B,EAAE,EAAE,gBAAgB,GAC3D,OAAO,CAAC,CAAC,CAAC,CAqBZ"}
|
package/dist/updateGlobal.js
CHANGED
@@ -1,9 +1,12 @@
|
|
1
|
-
import
|
1
|
+
import { getTableName } from './schema/getTableName.js';
|
2
2
|
import { upsertRow } from './upsertRow/index.js';
|
3
3
|
export async function updateGlobal({ slug, data, req = {} }) {
|
4
4
|
const db = this.sessions[req.transactionID]?.db || this.drizzle;
|
5
5
|
const globalConfig = this.payload.globals.config.find((config)=>config.slug === slug);
|
6
|
-
const tableName =
|
6
|
+
const tableName = getTableName({
|
7
|
+
adapter: this,
|
8
|
+
config: globalConfig
|
9
|
+
});
|
7
10
|
const existingGlobal = await db.query[tableName].findFirst({});
|
8
11
|
const result = await upsertRow({
|
9
12
|
...existingGlobal ? {
|
package/dist/updateGlobal.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../src/updateGlobal.ts"],"sourcesContent":["import type { UpdateGlobalArgs } from 'payload/database'\nimport type { PayloadRequest, TypeWithID } from 'payload/types'\n\nimport
|
1
|
+
{"version":3,"sources":["../src/updateGlobal.ts"],"sourcesContent":["import type { UpdateGlobalArgs } from 'payload/database'\nimport type { PayloadRequest, TypeWithID } from 'payload/types'\n\nimport type { PostgresAdapter } from './types.js'\n\nimport { getTableName } from './schema/getTableName.js'\nimport { upsertRow } from './upsertRow/index.js'\n\nexport async function updateGlobal<T extends TypeWithID>(\n this: PostgresAdapter,\n { slug, data, req = {} as PayloadRequest }: UpdateGlobalArgs,\n): Promise<T> {\n const db = this.sessions[req.transactionID]?.db || this.drizzle\n const globalConfig = this.payload.globals.config.find((config) => config.slug === slug)\n const tableName = getTableName({\n adapter: this,\n config: globalConfig,\n })\n\n const existingGlobal = await db.query[tableName].findFirst({})\n\n const result = await upsertRow<T>({\n ...(existingGlobal ? { id: existingGlobal.id, operation: 'update' } : { operation: 'create' }),\n adapter: this,\n data,\n db,\n fields: globalConfig.fields,\n req,\n tableName,\n })\n\n return result\n}\n"],"names":["getTableName","upsertRow","updateGlobal","slug","data","req","db","sessions","transactionID","drizzle","globalConfig","payload","globals","config","find","tableName","adapter","existingGlobal","query","findFirst","result","id","operation","fields"],"mappings":"AAKA,SAASA,YAAY,QAAQ,2BAA0B;AACvD,SAASC,SAAS,QAAQ,uBAAsB;AAEhD,OAAO,eAAeC,aAEpB,EAAEC,IAAI,EAAEC,IAAI,EAAEC,MAAM,CAAC,CAAmB,EAAoB;IAE5D,MAAMC,KAAK,IAAI,CAACC,QAAQ,CAACF,IAAIG,aAAa,CAAC,EAAEF,MAAM,IAAI,CAACG,OAAO;IAC/D,MAAMC,eAAe,IAAI,CAACC,OAAO,CAACC,OAAO,CAACC,MAAM,CAACC,IAAI,CAAC,CAACD,SAAWA,OAAOV,IAAI,KAAKA;IAClF,MAAMY,YAAYf,aAAa;QAC7BgB,SAAS,IAAI;QACbH,QAAQH;IACV;IAEA,MAAMO,iBAAiB,MAAMX,GAAGY,KAAK,CAACH,UAAU,CAACI,SAAS,CAAC,CAAC;IAE5D,MAAMC,SAAS,MAAMnB,UAAa;QAChC,GAAIgB,iBAAiB;YAAEI,IAAIJ,eAAeI,EAAE;YAAEC,WAAW;QAAS,IAAI;YAAEA,WAAW;QAAS,CAAC;QAC7FN,SAAS,IAAI;QACbZ;QACAE;QACAiB,QAAQb,aAAaa,MAAM;QAC3BlB;QACAU;IACF;IAEA,OAAOK;AACT"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"updateGlobalVersion.d.ts","sourceRoot":"","sources":["../src/updateGlobalVersion.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,uBAAuB,EAAE,MAAM,kBAAkB,CAAA;AAChF,OAAO,KAAK,EAAyC,UAAU,EAAE,MAAM,eAAe,CAAA;
|
1
|
+
{"version":3,"file":"updateGlobalVersion.d.ts","sourceRoot":"","sources":["../src/updateGlobalVersion.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,uBAAuB,EAAE,MAAM,kBAAkB,CAAA;AAChF,OAAO,KAAK,EAAyC,UAAU,EAAE,MAAM,eAAe,CAAA;AAItF,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAMjD,wBAAsB,mBAAmB,CAAC,CAAC,SAAS,UAAU,EAC5D,IAAI,EAAE,eAAe,EACrB,EACE,EAAE,EACF,MAAM,EACN,MAAM,EACN,GAA0B,EAC1B,WAAW,EACX,KAAK,EAAE,QAAQ,GAChB,EAAE,uBAAuB,CAAC,CAAC,CAAC,+BAmC9B"}
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { buildVersionGlobalFields } from 'payload/versions';
|
2
|
-
import toSnakeCase from 'to-snake-case';
|
3
2
|
import buildQuery from './queries/buildQuery.js';
|
3
|
+
import { getTableName } from './schema/getTableName.js';
|
4
4
|
import { upsertRow } from './upsertRow/index.js';
|
5
5
|
export async function updateGlobalVersion({ id, global, locale, req = {}, versionData, where: whereArg }) {
|
6
6
|
const db = this.sessions[req.transactionID]?.db || this.drizzle;
|
@@ -10,7 +10,11 @@ export async function updateGlobalVersion({ id, global, locale, req = {}, versio
|
|
10
10
|
equals: id
|
11
11
|
}
|
12
12
|
};
|
13
|
-
const tableName =
|
13
|
+
const tableName = getTableName({
|
14
|
+
adapter: this,
|
15
|
+
config: globalConfig,
|
16
|
+
versions: true
|
17
|
+
});
|
14
18
|
const fields = buildVersionGlobalFields(globalConfig);
|
15
19
|
const { where } = await buildQuery({
|
16
20
|
adapter: this,
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../src/updateGlobalVersion.ts"],"sourcesContent":["import type { TypeWithVersion, UpdateGlobalVersionArgs } from 'payload/database'\nimport type { PayloadRequest, SanitizedGlobalConfig, TypeWithID } from 'payload/types'\n\nimport { buildVersionGlobalFields } from 'payload/versions'\
|
1
|
+
{"version":3,"sources":["../src/updateGlobalVersion.ts"],"sourcesContent":["import type { TypeWithVersion, UpdateGlobalVersionArgs } from 'payload/database'\nimport type { PayloadRequest, SanitizedGlobalConfig, TypeWithID } from 'payload/types'\n\nimport { buildVersionGlobalFields } from 'payload/versions'\n\nimport type { PostgresAdapter } from './types.js'\n\nimport buildQuery from './queries/buildQuery.js'\nimport { getTableName } from './schema/getTableName.js'\nimport { upsertRow } from './upsertRow/index.js'\n\nexport async function updateGlobalVersion<T extends TypeWithID>(\n this: PostgresAdapter,\n {\n id,\n global,\n locale,\n req = {} as PayloadRequest,\n versionData,\n where: whereArg,\n }: UpdateGlobalVersionArgs<T>,\n) {\n const db = this.sessions[req.transactionID]?.db || this.drizzle\n const globalConfig: SanitizedGlobalConfig = this.payload.globals.config.find(\n ({ slug }) => slug === global,\n )\n const whereToUse = whereArg || { id: { equals: id } }\n const tableName = getTableName({\n adapter: this,\n config: globalConfig,\n versions: true,\n })\n const fields = buildVersionGlobalFields(globalConfig)\n\n const { where } = await buildQuery({\n adapter: this,\n fields,\n locale,\n tableName,\n where: whereToUse,\n })\n\n const result = await upsertRow<TypeWithVersion<T>>({\n id,\n adapter: this,\n data: versionData,\n db,\n fields,\n operation: 'update',\n req,\n tableName,\n where,\n })\n\n return result\n}\n"],"names":["buildVersionGlobalFields","buildQuery","getTableName","upsertRow","updateGlobalVersion","id","global","locale","req","versionData","where","whereArg","db","sessions","transactionID","drizzle","globalConfig","payload","globals","config","find","slug","whereToUse","equals","tableName","adapter","versions","fields","result","data","operation"],"mappings":"AAGA,SAASA,wBAAwB,QAAQ,mBAAkB;AAI3D,OAAOC,gBAAgB,0BAAyB;AAChD,SAASC,YAAY,QAAQ,2BAA0B;AACvD,SAASC,SAAS,QAAQ,uBAAsB;AAEhD,OAAO,eAAeC,oBAEpB,EACEC,EAAE,EACFC,MAAM,EACNC,MAAM,EACNC,MAAM,CAAC,CAAmB,EAC1BC,WAAW,EACXC,OAAOC,QAAQ,EACY;IAE7B,MAAMC,KAAK,IAAI,CAACC,QAAQ,CAACL,IAAIM,aAAa,CAAC,EAAEF,MAAM,IAAI,CAACG,OAAO;IAC/D,MAAMC,eAAsC,IAAI,CAACC,OAAO,CAACC,OAAO,CAACC,MAAM,CAACC,IAAI,CAC1E,CAAC,EAAEC,IAAI,EAAE,GAAKA,SAASf;IAEzB,MAAMgB,aAAaX,YAAY;QAAEN,IAAI;YAAEkB,QAAQlB;QAAG;IAAE;IACpD,MAAMmB,YAAYtB,aAAa;QAC7BuB,SAAS,IAAI;QACbN,QAAQH;QACRU,UAAU;IACZ;IACA,MAAMC,SAAS3B,yBAAyBgB;IAExC,MAAM,EAAEN,KAAK,EAAE,GAAG,MAAMT,WAAW;QACjCwB,SAAS,IAAI;QACbE;QACApB;QACAiB;QACAd,OAAOY;IACT;IAEA,MAAMM,SAAS,MAAMzB,UAA8B;QACjDE;QACAoB,SAAS,IAAI;QACbI,MAAMpB;QACNG;QACAe;QACAG,WAAW;QACXtB;QACAgB;QACAd;IACF;IAEA,OAAOkB;AACT"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"updateVersion.d.ts","sourceRoot":"","sources":["../src/updateVersion.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAC1E,OAAO,KAAK,EAA6C,UAAU,EAAE,MAAM,eAAe,CAAA;
|
1
|
+
{"version":3,"file":"updateVersion.d.ts","sourceRoot":"","sources":["../src/updateVersion.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAC1E,OAAO,KAAK,EAA6C,UAAU,EAAE,MAAM,eAAe,CAAA;AAI1F,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAMjD,wBAAsB,aAAa,CAAC,CAAC,SAAS,UAAU,EACtD,IAAI,EAAE,eAAe,EACrB,EACE,EAAE,EACF,UAAU,EACV,MAAM,EACN,GAA0B,EAC1B,WAAW,EACX,KAAK,EAAE,QAAQ,GAChB,EAAE,iBAAiB,CAAC,CAAC,CAAC,+BAiCxB"}
|
package/dist/updateVersion.js
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
import { buildVersionCollectionFields } from 'payload/versions';
|
2
|
-
import toSnakeCase from 'to-snake-case';
|
3
2
|
import buildQuery from './queries/buildQuery.js';
|
3
|
+
import { getTableName } from './schema/getTableName.js';
|
4
4
|
import { upsertRow } from './upsertRow/index.js';
|
5
5
|
export async function updateVersion({ id, collection, locale, req = {}, versionData, where: whereArg }) {
|
6
6
|
const db = this.sessions[req.transactionID]?.db || this.drizzle;
|
@@ -10,7 +10,11 @@ export async function updateVersion({ id, collection, locale, req = {}, versionD
|
|
10
10
|
equals: id
|
11
11
|
}
|
12
12
|
};
|
13
|
-
const tableName =
|
13
|
+
const tableName = getTableName({
|
14
|
+
adapter: this,
|
15
|
+
config: collectionConfig,
|
16
|
+
versions: true
|
17
|
+
});
|
14
18
|
const fields = buildVersionCollectionFields(collectionConfig);
|
15
19
|
const { where } = await buildQuery({
|
16
20
|
adapter: this,
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../src/updateVersion.ts"],"sourcesContent":["import type { TypeWithVersion, UpdateVersionArgs } from 'payload/database'\nimport type { PayloadRequest, SanitizedCollectionConfig, TypeWithID } from 'payload/types'\n\nimport { buildVersionCollectionFields } from 'payload/versions'\
|
1
|
+
{"version":3,"sources":["../src/updateVersion.ts"],"sourcesContent":["import type { TypeWithVersion, UpdateVersionArgs } from 'payload/database'\nimport type { PayloadRequest, SanitizedCollectionConfig, TypeWithID } from 'payload/types'\n\nimport { buildVersionCollectionFields } from 'payload/versions'\n\nimport type { PostgresAdapter } from './types.js'\n\nimport buildQuery from './queries/buildQuery.js'\nimport { getTableName } from './schema/getTableName.js'\nimport { upsertRow } from './upsertRow/index.js'\n\nexport async function updateVersion<T extends TypeWithID>(\n this: PostgresAdapter,\n {\n id,\n collection,\n locale,\n req = {} as PayloadRequest,\n versionData,\n where: whereArg,\n }: UpdateVersionArgs<T>,\n) {\n const db = this.sessions[req.transactionID]?.db || this.drizzle\n const collectionConfig: SanitizedCollectionConfig = this.payload.collections[collection].config\n const whereToUse = whereArg || { id: { equals: id } }\n const tableName = getTableName({\n adapter: this,\n config: collectionConfig,\n versions: true,\n })\n const fields = buildVersionCollectionFields(collectionConfig)\n\n const { where } = await buildQuery({\n adapter: this,\n fields,\n locale,\n tableName,\n where: whereToUse,\n })\n\n const result = await upsertRow<TypeWithVersion<T>>({\n id,\n adapter: this,\n data: versionData,\n db,\n fields,\n operation: 'update',\n req,\n tableName,\n where,\n })\n\n return result\n}\n"],"names":["buildVersionCollectionFields","buildQuery","getTableName","upsertRow","updateVersion","id","collection","locale","req","versionData","where","whereArg","db","sessions","transactionID","drizzle","collectionConfig","payload","collections","config","whereToUse","equals","tableName","adapter","versions","fields","result","data","operation"],"mappings":"AAGA,SAASA,4BAA4B,QAAQ,mBAAkB;AAI/D,OAAOC,gBAAgB,0BAAyB;AAChD,SAASC,YAAY,QAAQ,2BAA0B;AACvD,SAASC,SAAS,QAAQ,uBAAsB;AAEhD,OAAO,eAAeC,cAEpB,EACEC,EAAE,EACFC,UAAU,EACVC,MAAM,EACNC,MAAM,CAAC,CAAmB,EAC1BC,WAAW,EACXC,OAAOC,QAAQ,EACM;IAEvB,MAAMC,KAAK,IAAI,CAACC,QAAQ,CAACL,IAAIM,aAAa,CAAC,EAAEF,MAAM,IAAI,CAACG,OAAO;IAC/D,MAAMC,mBAA8C,IAAI,CAACC,OAAO,CAACC,WAAW,CAACZ,WAAW,CAACa,MAAM;IAC/F,MAAMC,aAAaT,YAAY;QAAEN,IAAI;YAAEgB,QAAQhB;QAAG;IAAE;IACpD,MAAMiB,YAAYpB,aAAa;QAC7BqB,SAAS,IAAI;QACbJ,QAAQH;QACRQ,UAAU;IACZ;IACA,MAAMC,SAASzB,6BAA6BgB;IAE5C,MAAM,EAAEN,KAAK,EAAE,GAAG,MAAMT,WAAW;QACjCsB,SAAS,IAAI;QACbE;QACAlB;QACAe;QACAZ,OAAOU;IACT;IAEA,MAAMM,SAAS,MAAMvB,UAA8B;QACjDE;QACAkB,SAAS,IAAI;QACbI,MAAMlB;QACNG;QACAa;QACAG,WAAW;QACXpB;QACAc;QACAZ;IACF;IAEA,OAAOgB;AACT"}
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@payloadcms/db-postgres",
|
3
|
-
"version": "3.0.0-alpha.
|
3
|
+
"version": "3.0.0-alpha.55",
|
4
4
|
"description": "The officially supported Postgres database adapter for Payload",
|
5
5
|
"repository": {
|
6
6
|
"type": "git",
|
@@ -31,10 +31,10 @@
|
|
31
31
|
"@types/pg": "8.10.2",
|
32
32
|
"@types/to-snake-case": "1.0.0",
|
33
33
|
"@payloadcms/eslint-config": "1.1.1",
|
34
|
-
"payload": "3.0.0-alpha.
|
34
|
+
"payload": "3.0.0-alpha.55"
|
35
35
|
},
|
36
36
|
"peerDependencies": {
|
37
|
-
"payload": "3.0.0-alpha.
|
37
|
+
"payload": "3.0.0-alpha.55"
|
38
38
|
},
|
39
39
|
"exports": {
|
40
40
|
".": {
|
package/src/index.ts
CHANGED
@@ -1,6 +1,5 @@
|
|
1
1
|
import type { Payload } from 'payload'
|
2
2
|
import type { DatabaseAdapterObj } from 'payload/database'
|
3
|
-
export type { MigrateDownArgs, MigrateUpArgs } from './types.js'
|
4
3
|
|
5
4
|
import fs from 'fs'
|
6
5
|
import path from 'path'
|
@@ -39,6 +38,8 @@ import { updateGlobal } from './updateGlobal.js'
|
|
39
38
|
import { updateGlobalVersion } from './updateGlobalVersion.js'
|
40
39
|
import { updateVersion } from './updateVersion.js'
|
41
40
|
|
41
|
+
export type { MigrateDownArgs, MigrateUpArgs } from './types.js'
|
42
|
+
|
42
43
|
export { sql } from 'drizzle-orm'
|
43
44
|
|
44
45
|
export function postgresAdapter(args: Args): DatabaseAdapterObj<PostgresAdapter> {
|
@@ -50,20 +51,24 @@ export function postgresAdapter(args: Args): DatabaseAdapterObj<PostgresAdapter>
|
|
50
51
|
name: 'postgres',
|
51
52
|
|
52
53
|
// Postgres-specific
|
54
|
+
blockTableNames: {},
|
53
55
|
drizzle: undefined,
|
54
56
|
enums: {},
|
55
57
|
fieldConstraints: {},
|
56
58
|
idType,
|
59
|
+
localesSuffix: args.localesSuffix || '_locales',
|
57
60
|
logger: args.logger,
|
58
61
|
pgSchema: undefined,
|
59
62
|
pool: undefined,
|
60
63
|
poolOptions: args.pool,
|
61
64
|
push: args.push,
|
62
65
|
relations: {},
|
66
|
+
relationshipsSuffix: args.relationshipsSuffix || '_rels',
|
63
67
|
schema: {},
|
64
68
|
schemaName: args.schemaName,
|
65
69
|
sessions: {},
|
66
70
|
tables: {},
|
71
|
+
versionsSuffix: args.versionsSuffix || '_v',
|
67
72
|
|
68
73
|
// DatabaseAdapter
|
69
74
|
beginTransaction,
|