@payloadcms/drizzle 3.0.0-beta.125 → 3.0.0-beta.127
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/exports/postgres.d.ts +1 -0
- package/dist/exports/postgres.d.ts.map +1 -1
- package/dist/exports/postgres.js +1 -0
- package/dist/exports/postgres.js.map +1 -1
- package/dist/find/traverseFields.d.ts.map +1 -1
- package/dist/find/traverseFields.js +29 -0
- package/dist/find/traverseFields.js.map +1 -1
- package/dist/migrate.d.ts.map +1 -1
- package/dist/migrate.js +3 -0
- package/dist/migrate.js.map +1 -1
- package/dist/migrateFresh.d.ts.map +1 -1
- package/dist/migrateFresh.js +3 -0
- package/dist/migrateFresh.js.map +1 -1
- package/dist/postgres/createDatabase.js +1 -1
- package/dist/postgres/createDatabase.js.map +1 -1
- package/dist/postgres/createExtensions.d.ts +3 -0
- package/dist/postgres/createExtensions.d.ts.map +1 -0
- package/dist/postgres/createExtensions.js +16 -0
- package/dist/postgres/createExtensions.js.map +1 -0
- package/dist/postgres/defaultSnapshot.d.ts.map +1 -1
- package/dist/postgres/defaultSnapshot.js +2 -0
- package/dist/postgres/defaultSnapshot.js.map +1 -1
- package/dist/postgres/schema/geometryColumn.d.ts +12 -0
- package/dist/postgres/schema/geometryColumn.d.ts.map +1 -0
- package/dist/postgres/schema/geometryColumn.js +18 -0
- package/dist/postgres/schema/geometryColumn.js.map +1 -0
- package/dist/postgres/schema/traverseFields.d.ts.map +1 -1
- package/dist/postgres/schema/traverseFields.js +6 -2
- package/dist/postgres/schema/traverseFields.js.map +1 -1
- package/dist/postgres/schema/withDefault.d.ts.map +1 -1
- package/dist/postgres/schema/withDefault.js +3 -0
- package/dist/postgres/schema/withDefault.js.map +1 -1
- package/dist/postgres/types.d.ts +3 -0
- package/dist/postgres/types.d.ts.map +1 -1
- package/dist/postgres/types.js.map +1 -1
- package/dist/queries/operatorMap.d.ts.map +1 -1
- package/dist/queries/operatorMap.js +0 -4
- package/dist/queries/operatorMap.js.map +1 -1
- package/dist/queries/parseParams.d.ts.map +1 -1
- package/dist/queries/parseParams.js +27 -0
- package/dist/queries/parseParams.js.map +1 -1
- package/dist/queries/sanitizeQueryValue.js +8 -2
- package/dist/queries/sanitizeQueryValue.js.map +1 -1
- package/dist/transform/write/traverseFields.d.ts.map +1 -1
- package/dist/transform/write/traverseFields.js +4 -0
- package/dist/transform/write/traverseFields.js.map +1 -1
- package/dist/types.d.ts +1 -1
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js.map +1 -1
- package/dist/utilities/pushDevSchema.d.ts.map +1 -1
- package/dist/utilities/pushDevSchema.js +5 -0
- package/dist/utilities/pushDevSchema.js.map +1 -1
- package/package.json +5 -5
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
export { countDistinct } from '../postgres/countDistinct.js';
|
|
2
2
|
export { createDatabase } from '../postgres/createDatabase.js';
|
|
3
|
+
export { createExtensions } from '../postgres/createExtensions.js';
|
|
3
4
|
export { convertPathToJSONTraversal } from '../postgres/createJSONQuery/convertPathToJSONTraversal.js';
|
|
4
5
|
export { createJSONQuery } from '../postgres/createJSONQuery/index.js';
|
|
5
6
|
export { createMigration } from '../postgres/createMigration.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"postgres.d.ts","sourceRoot":"","sources":["../../src/exports/postgres.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAA;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAA;AAC9D,OAAO,EAAE,0BAA0B,EAAE,MAAM,2DAA2D,CAAA;AACtG,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAA;AACtE,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAA;AAChE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAA;AACvE,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAA;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAC1D,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAA;AAC1E,OAAO,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAA;AAC1C,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAA;AAC9C,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAA;AACpE,cAAc,sBAAsB,CAAA"}
|
|
1
|
+
{"version":3,"file":"postgres.d.ts","sourceRoot":"","sources":["../../src/exports/postgres.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAA;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAA;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAA;AAClE,OAAO,EAAE,0BAA0B,EAAE,MAAM,2DAA2D,CAAA;AACtG,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAA;AACtE,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAA;AAChE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAA;AACvE,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAA;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAC1D,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAA;AAC1E,OAAO,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAA;AAC1C,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAA;AAC9C,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAA;AACpE,cAAc,sBAAsB,CAAA"}
|
package/dist/exports/postgres.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
export { countDistinct } from '../postgres/countDistinct.js';
|
|
2
2
|
export { createDatabase } from '../postgres/createDatabase.js';
|
|
3
|
+
export { createExtensions } from '../postgres/createExtensions.js';
|
|
3
4
|
export { convertPathToJSONTraversal } from '../postgres/createJSONQuery/convertPathToJSONTraversal.js';
|
|
4
5
|
export { createJSONQuery } from '../postgres/createJSONQuery/index.js';
|
|
5
6
|
export { createMigration } from '../postgres/createMigration.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/exports/postgres.ts"],"sourcesContent":["export { countDistinct } from '../postgres/countDistinct.js'\nexport { createDatabase } from '../postgres/createDatabase.js'\nexport { convertPathToJSONTraversal } from '../postgres/createJSONQuery/convertPathToJSONTraversal.js'\nexport { createJSONQuery } from '../postgres/createJSONQuery/index.js'\nexport { createMigration } from '../postgres/createMigration.js'\nexport { defaultDrizzleSnapshot } from '../postgres/defaultSnapshot.js'\nexport { deleteWhere } from '../postgres/deleteWhere.js'\nexport { dropDatabase } from '../postgres/dropDatabase.js'\nexport { execute } from '../postgres/execute.js'\nexport { getMigrationTemplate } from '../postgres/getMigrationTemplate.js'\nexport { init } from '../postgres/init.js'\nexport { insert } from '../postgres/insert.js'\nexport { requireDrizzleKit } from '../postgres/requireDrizzleKit.js'\nexport * from '../postgres/types.js'\n"],"names":["countDistinct","createDatabase","convertPathToJSONTraversal","createJSONQuery","createMigration","defaultDrizzleSnapshot","deleteWhere","dropDatabase","execute","getMigrationTemplate","init","insert","requireDrizzleKit"],"mappings":"AAAA,SAASA,aAAa,QAAQ,+BAA8B;AAC5D,SAASC,cAAc,QAAQ,gCAA+B;AAC9D,SAASC,0BAA0B,QAAQ,4DAA2D;AACtG,SAASC,eAAe,QAAQ,uCAAsC;AACtE,SAASC,eAAe,QAAQ,iCAAgC;AAChE,SAASC,sBAAsB,QAAQ,iCAAgC;AACvE,SAASC,WAAW,QAAQ,6BAA4B;AACxD,SAASC,YAAY,QAAQ,8BAA6B;AAC1D,SAASC,OAAO,QAAQ,yBAAwB;AAChD,SAASC,oBAAoB,QAAQ,sCAAqC;AAC1E,SAASC,IAAI,QAAQ,sBAAqB;AAC1C,SAASC,MAAM,QAAQ,wBAAuB;AAC9C,SAASC,iBAAiB,QAAQ,mCAAkC;AACpE,cAAc,uBAAsB"}
|
|
1
|
+
{"version":3,"sources":["../../src/exports/postgres.ts"],"sourcesContent":["export { countDistinct } from '../postgres/countDistinct.js'\nexport { createDatabase } from '../postgres/createDatabase.js'\nexport { createExtensions } from '../postgres/createExtensions.js'\nexport { convertPathToJSONTraversal } from '../postgres/createJSONQuery/convertPathToJSONTraversal.js'\nexport { createJSONQuery } from '../postgres/createJSONQuery/index.js'\nexport { createMigration } from '../postgres/createMigration.js'\nexport { defaultDrizzleSnapshot } from '../postgres/defaultSnapshot.js'\nexport { deleteWhere } from '../postgres/deleteWhere.js'\nexport { dropDatabase } from '../postgres/dropDatabase.js'\nexport { execute } from '../postgres/execute.js'\nexport { getMigrationTemplate } from '../postgres/getMigrationTemplate.js'\nexport { init } from '../postgres/init.js'\nexport { insert } from '../postgres/insert.js'\nexport { requireDrizzleKit } from '../postgres/requireDrizzleKit.js'\nexport * from '../postgres/types.js'\n"],"names":["countDistinct","createDatabase","createExtensions","convertPathToJSONTraversal","createJSONQuery","createMigration","defaultDrizzleSnapshot","deleteWhere","dropDatabase","execute","getMigrationTemplate","init","insert","requireDrizzleKit"],"mappings":"AAAA,SAASA,aAAa,QAAQ,+BAA8B;AAC5D,SAASC,cAAc,QAAQ,gCAA+B;AAC9D,SAASC,gBAAgB,QAAQ,kCAAiC;AAClE,SAASC,0BAA0B,QAAQ,4DAA2D;AACtG,SAASC,eAAe,QAAQ,uCAAsC;AACtE,SAASC,eAAe,QAAQ,iCAAgC;AAChE,SAASC,sBAAsB,QAAQ,iCAAgC;AACvE,SAASC,WAAW,QAAQ,6BAA4B;AACxD,SAASC,YAAY,QAAQ,8BAA6B;AAC1D,SAASC,OAAO,QAAQ,yBAAwB;AAChD,SAASC,oBAAoB,QAAQ,sCAAqC;AAC1E,SAASC,IAAI,QAAQ,sBAAqB;AAC1C,SAASC,MAAM,QAAQ,wBAAuB;AAC9C,SAASC,iBAAiB,QAAQ,mCAAkC;AACpE,cAAc,uBAAsB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../src/find/traverseFields.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAOnF,OAAO,KAAK,EAAE,qBAAqB,EAAkB,cAAc,EAAE,MAAM,aAAa,CAAA;AACxF,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAA;AAKpD,KAAK,iBAAiB,GAAG;IACvB,QAAQ,EAAE,MAAM,CAAA;IAChB,OAAO,EAAE,cAAc,CAAA;IACvB,WAAW,EAAE,MAAM,CAAA;IACnB,gBAAgB,EAAE,MAAM,CAAA;IACxB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,SAAS,EAAE,SAAS,CAAA;IACpB,KAAK,CAAC,EAAE,qBAAqB,CAAA;IAC7B,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,CAAC,EAAE,UAAU,CAAA;IACnB,uBAAuB,CAAC,EAAE,OAAO,CAAA;IACjC,UAAU,CAAC,EAAE,UAAU,CAAA;IACvB,SAAS,EAAE,MAAM,CAAA;IACjB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IACrC,iBAAiB,EAAE,MAAM,CAAA;IACzB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,oBAAoB,CAAC,EAAE,OAAO,CAAA;IAC9B,gBAAgB,EAAE;QAChB,OAAO,CAAC,EAAE,OAAO,CAAA;QACjB,IAAI,CAAC,EAAE,OAAO,CAAA;QACd,KAAK,CAAC,EAAE,OAAO,CAAA;KAChB,CAAA;CACF,CAAA;AAED,eAAO,MAAM,cAAc,oPAoBxB,iBAAiB,
|
|
1
|
+
{"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../src/find/traverseFields.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAOnF,OAAO,KAAK,EAAE,qBAAqB,EAAkB,cAAc,EAAE,MAAM,aAAa,CAAA;AACxF,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAA;AAKpD,KAAK,iBAAiB,GAAG;IACvB,QAAQ,EAAE,MAAM,CAAA;IAChB,OAAO,EAAE,cAAc,CAAA;IACvB,WAAW,EAAE,MAAM,CAAA;IACnB,gBAAgB,EAAE,MAAM,CAAA;IACxB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,SAAS,EAAE,SAAS,CAAA;IACpB,KAAK,CAAC,EAAE,qBAAqB,CAAA;IAC7B,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,CAAC,EAAE,UAAU,CAAA;IACnB,uBAAuB,CAAC,EAAE,OAAO,CAAA;IACjC,UAAU,CAAC,EAAE,UAAU,CAAA;IACvB,SAAS,EAAE,MAAM,CAAA;IACjB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IACrC,iBAAiB,EAAE,MAAM,CAAA;IACzB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,oBAAoB,CAAC,EAAE,OAAO,CAAA;IAC9B,gBAAgB,EAAE;QAChB,OAAO,CAAC,EAAE,OAAO,CAAA;QACjB,IAAI,CAAC,EAAE,OAAO,CAAA;QACd,KAAK,CAAC,EAAE,OAAO,CAAA;KAChB,CAAA;CACF,CAAA;AAED,eAAO,MAAM,cAAc,oPAoBxB,iBAAiB,4BA6lBnB,CAAA"}
|
|
@@ -261,6 +261,35 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
|
|
|
261
261
|
});
|
|
262
262
|
break;
|
|
263
263
|
}
|
|
264
|
+
case 'point':
|
|
265
|
+
{
|
|
266
|
+
if (adapter.name === 'sqlite') {
|
|
267
|
+
break;
|
|
268
|
+
}
|
|
269
|
+
const args = field.localized ? _locales : currentArgs;
|
|
270
|
+
if (!args.columns) {
|
|
271
|
+
args.columns = {};
|
|
272
|
+
}
|
|
273
|
+
if (!args.extras) {
|
|
274
|
+
args.extras = {};
|
|
275
|
+
}
|
|
276
|
+
const name = `${path}${field.name}`;
|
|
277
|
+
// Drizzle handles that poorly. See https://github.com/drizzle-team/drizzle-orm/issues/2526
|
|
278
|
+
// Additionally, this way we format the column value straight in the database using ST_AsGeoJSON
|
|
279
|
+
args.columns[name] = false;
|
|
280
|
+
let shouldSelect = false;
|
|
281
|
+
if (select || selectAllOnCurrentLevel) {
|
|
282
|
+
if (selectAllOnCurrentLevel || selectMode === 'include' && select[field.name] === true || selectMode === 'exclude' && typeof select[field.name] === 'undefined') {
|
|
283
|
+
shouldSelect = true;
|
|
284
|
+
}
|
|
285
|
+
} else {
|
|
286
|
+
shouldSelect = true;
|
|
287
|
+
}
|
|
288
|
+
if (shouldSelect) {
|
|
289
|
+
args.extras[name] = sql.raw(`ST_AsGeoJSON(${toSnakeCase(name)})::jsonb`).as(name);
|
|
290
|
+
}
|
|
291
|
+
break;
|
|
292
|
+
}
|
|
264
293
|
case 'join':
|
|
265
294
|
{
|
|
266
295
|
// when `joinsQuery` is false, do not join
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/find/traverseFields.ts"],"sourcesContent":["import type { LibSQLDatabase } from 'drizzle-orm/libsql'\nimport type { Field, JoinQuery, SelectMode, SelectType, TabAsField } from 'payload'\n\nimport { and, eq, sql } from 'drizzle-orm'\nimport { combineQueries } from 'payload'\nimport { fieldAffectsData, fieldIsVirtual, tabHasName } from 'payload/shared'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { BuildQueryJoinAliases, ChainedMethods, DrizzleAdapter } from '../types.js'\nimport type { Result } from './buildFindManyArgs.js'\n\nimport buildQuery from '../queries/buildQuery.js'\nimport { chainMethods } from './chainMethods.js'\n\ntype TraverseFieldArgs = {\n _locales: Result\n adapter: DrizzleAdapter\n currentArgs: Result\n currentTableName: string\n depth?: number\n fields: (Field | TabAsField)[]\n joinQuery: JoinQuery\n joins?: BuildQueryJoinAliases\n locale?: string\n path: string\n select?: SelectType\n selectAllOnCurrentLevel?: boolean\n selectMode?: SelectMode\n tablePath: string\n topLevelArgs: Record<string, unknown>\n topLevelTableName: string\n versions?: boolean\n withinLocalizedField?: boolean\n withTabledFields: {\n numbers?: boolean\n rels?: boolean\n texts?: boolean\n }\n}\n\nexport const traverseFields = ({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields,\n joinQuery = {},\n joins,\n locale,\n path,\n select,\n selectAllOnCurrentLevel = false,\n selectMode,\n tablePath,\n topLevelArgs,\n topLevelTableName,\n versions,\n withinLocalizedField = false,\n withTabledFields,\n}: TraverseFieldArgs) => {\n fields.forEach((field) => {\n if (fieldIsVirtual(field)) {\n return\n }\n\n // handle simple relationship\n if (\n depth > 0 &&\n (field.type === 'upload' || field.type === 'relationship') &&\n !field.hasMany &&\n typeof field.relationTo === 'string'\n ) {\n if (field.localized) {\n _locales.with[`${path}${field.name}`] = true\n } else {\n currentArgs.with[`${path}${field.name}`] = true\n }\n }\n\n if (\n field.type === 'collapsible' ||\n field.type === 'row' ||\n (field.type === 'tab' && !tabHasName(field))\n ) {\n traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: field.fields,\n joinQuery,\n joins,\n path,\n select,\n selectMode,\n tablePath,\n topLevelArgs,\n topLevelTableName,\n withTabledFields,\n })\n\n return\n }\n\n if (field.type === 'tabs') {\n traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n joinQuery,\n joins,\n path,\n select,\n selectAllOnCurrentLevel,\n selectMode,\n tablePath,\n topLevelArgs,\n topLevelTableName,\n versions,\n withTabledFields,\n })\n\n return\n }\n\n if (fieldAffectsData(field)) {\n switch (field.type) {\n case 'array': {\n const arraySelect = selectAllOnCurrentLevel ? true : select?.[field.name]\n\n if (select) {\n if (\n (selectMode === 'include' && typeof arraySelect === 'undefined') ||\n (selectMode === 'exclude' && arraySelect === false)\n ) {\n break\n }\n }\n\n const withArray: Result = {\n columns:\n typeof arraySelect === 'object'\n ? {\n id: true,\n _order: true,\n }\n : {\n _parentID: false,\n },\n orderBy: ({ _order }, { asc }) => [asc(_order)],\n with: {},\n }\n\n const arrayTableName = adapter.tableNameMap.get(\n `${currentTableName}_${tablePath}${toSnakeCase(field.name)}`,\n )\n\n if (typeof arraySelect === 'object') {\n if (adapter.tables[arrayTableName]._locale) {\n withArray.columns._locale = true\n }\n\n if (adapter.tables[arrayTableName]._uuid) {\n withArray.columns._uuid = true\n }\n }\n\n const arrayTableNameWithLocales = `${arrayTableName}${adapter.localesSuffix}`\n\n if (adapter.tables[arrayTableNameWithLocales]) {\n withArray.with._locales = {\n columns:\n typeof arraySelect === 'object'\n ? {\n _locale: true,\n }\n : {\n id: false,\n _parentID: false,\n },\n with: {},\n }\n }\n\n currentArgs.with[`${path}${field.name}`] = withArray\n\n traverseFields({\n _locales: withArray.with._locales,\n adapter,\n currentArgs: withArray,\n currentTableName: arrayTableName,\n depth,\n fields: field.fields,\n joinQuery,\n path: '',\n select: typeof arraySelect === 'object' ? arraySelect : undefined,\n selectMode,\n tablePath: '',\n topLevelArgs,\n topLevelTableName,\n withinLocalizedField: withinLocalizedField || field.localized,\n withTabledFields,\n })\n\n if (\n typeof arraySelect === 'object' &&\n withArray.with._locales &&\n Object.keys(withArray.with._locales).length === 1\n ) {\n delete withArray.with._locales\n }\n\n break\n }\n\n case 'select': {\n if (field.hasMany) {\n if (select) {\n if (\n (selectMode === 'include' && !select[field.name]) ||\n (selectMode === 'exclude' && select[field.name] === false)\n ) {\n break\n }\n }\n\n const withSelect: Result = {\n columns: {\n id: false,\n order: false,\n parent: false,\n },\n orderBy: ({ order }, { asc }) => [asc(order)],\n }\n\n currentArgs.with[`${path}${field.name}`] = withSelect\n }\n\n break\n }\n\n case 'blocks': {\n const blocksSelect = selectAllOnCurrentLevel ? true : select?.[field.name]\n\n if (select) {\n if (\n (selectMode === 'include' && !blocksSelect) ||\n (selectMode === 'exclude' && blocksSelect === false)\n ) {\n break\n }\n }\n\n field.blocks.forEach((block) => {\n const blockKey = `_blocks_${block.slug}`\n\n let blockSelect: boolean | SelectType | undefined\n\n let blockSelectMode = selectMode\n\n if (selectMode === 'include' && blocksSelect === true) {\n blockSelect = true\n }\n\n if (typeof blocksSelect === 'object') {\n if (typeof blocksSelect[block.slug] === 'object') {\n blockSelect = blocksSelect[block.slug]\n } else if (\n (selectMode === 'include' && typeof blocksSelect[block.slug] === 'undefined') ||\n (selectMode === 'exclude' && blocksSelect[block.slug] === false)\n ) {\n blockSelect = {}\n blockSelectMode = 'include'\n } else if (selectMode === 'include' && blocksSelect[block.slug] === true) {\n blockSelect = true\n }\n }\n\n if (!topLevelArgs[blockKey]) {\n const withBlock: Result = {\n columns:\n typeof blockSelect === 'object'\n ? {\n id: true,\n _order: true,\n _path: true,\n }\n : {\n _parentID: false,\n },\n orderBy: ({ _order }, { asc }) => [asc(_order)],\n with: {},\n }\n\n const tableName = adapter.tableNameMap.get(\n `${topLevelTableName}_blocks_${toSnakeCase(block.slug)}`,\n )\n\n if (typeof blockSelect === 'object') {\n if (adapter.tables[tableName]._locale) {\n withBlock.columns._locale = true\n }\n\n if (adapter.tables[tableName]._uuid) {\n withBlock.columns._uuid = true\n }\n }\n\n if (adapter.tables[`${tableName}${adapter.localesSuffix}`]) {\n withBlock.with._locales = {\n with: {},\n }\n\n if (typeof blockSelect === 'object') {\n withBlock.with._locales.columns = {\n _locale: true,\n }\n }\n }\n topLevelArgs.with[blockKey] = withBlock\n\n traverseFields({\n _locales: withBlock.with._locales,\n adapter,\n currentArgs: withBlock,\n currentTableName: tableName,\n depth,\n fields: block.fields,\n joinQuery,\n path: '',\n select: typeof blockSelect === 'object' ? blockSelect : undefined,\n selectMode: blockSelectMode,\n tablePath: '',\n topLevelArgs,\n topLevelTableName,\n withinLocalizedField: withinLocalizedField || field.localized,\n withTabledFields,\n })\n\n if (\n typeof blockSelect === 'object' &&\n withBlock.with._locales &&\n Object.keys(withBlock.with._locales.columns).length === 1\n ) {\n delete withBlock.with._locales\n }\n }\n })\n\n break\n }\n\n case 'group':\n case 'tab': {\n const fieldSelect = select?.[field.name]\n\n if (fieldSelect === false) {\n break\n }\n\n traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: field.fields,\n joinQuery,\n joins,\n path: `${path}${field.name}_`,\n select: typeof fieldSelect === 'object' ? fieldSelect : undefined,\n selectAllOnCurrentLevel:\n selectAllOnCurrentLevel ||\n fieldSelect === true ||\n (selectMode === 'exclude' && typeof fieldSelect === 'undefined'),\n selectMode,\n tablePath: `${tablePath}${toSnakeCase(field.name)}_`,\n topLevelArgs,\n topLevelTableName,\n versions,\n withinLocalizedField: withinLocalizedField || field.localized,\n withTabledFields,\n })\n\n break\n }\n\n case 'join': {\n // when `joinsQuery` is false, do not join\n if (joinQuery === false) {\n break\n }\n\n if (\n (select && selectMode === 'include' && !select[field.name]) ||\n (selectMode === 'exclude' && select[field.name] === false)\n ) {\n break\n }\n\n const joinSchemaPath = `${path.replaceAll('_', '.')}${field.name}`\n\n if (joinQuery[joinSchemaPath] === false) {\n break\n }\n\n const {\n limit: limitArg = field.defaultLimit ?? 10,\n sort = field.defaultSort,\n where,\n } = joinQuery[joinSchemaPath] || {}\n let limit = limitArg\n\n if (limit !== 0) {\n // get an additional document and slice it later to determine if there is a next page\n limit += 1\n }\n\n const fields = adapter.payload.collections[field.collection].config.fields\n\n const joinCollectionTableName = adapter.tableNameMap.get(toSnakeCase(field.collection))\n\n const joins: BuildQueryJoinAliases = []\n\n const buildQueryResult = buildQuery({\n adapter,\n fields,\n joins,\n locale,\n sort,\n tableName: joinCollectionTableName,\n where,\n })\n\n let subQueryWhere = buildQueryResult.where\n const orderBy = buildQueryResult.orderBy\n\n let joinLocalesCollectionTableName: string | undefined\n\n const currentIDColumn = versions\n ? adapter.tables[currentTableName].parent\n : adapter.tables[currentTableName].id\n\n // Handle hasMany _rels table\n if (field.hasMany) {\n const joinRelsCollectionTableName = `${joinCollectionTableName}${adapter.relationshipsSuffix}`\n\n if (field.localized) {\n joinLocalesCollectionTableName = joinRelsCollectionTableName\n }\n\n let columnReferenceToCurrentID: string\n\n if (versions) {\n columnReferenceToCurrentID = `${topLevelTableName\n .replace('_', '')\n .replace(new RegExp(`${adapter.versionsSuffix}$`), '')}_id`\n } else {\n columnReferenceToCurrentID = `${topLevelTableName}_id`\n }\n\n joins.push({\n type: 'innerJoin',\n condition: and(\n eq(\n adapter.tables[joinRelsCollectionTableName].parent,\n adapter.tables[joinCollectionTableName].id,\n ),\n eq(\n sql.raw(`\"${joinRelsCollectionTableName}\".\"${columnReferenceToCurrentID}\"`),\n currentIDColumn,\n ),\n eq(adapter.tables[joinRelsCollectionTableName].path, field.on),\n ),\n table: adapter.tables[joinRelsCollectionTableName],\n })\n } else {\n // Handle localized without hasMany\n\n const foreignColumn = field.on.replaceAll('.', '_')\n\n if (field.localized) {\n joinLocalesCollectionTableName = `${joinCollectionTableName}${adapter.localesSuffix}`\n\n joins.push({\n type: 'innerJoin',\n condition: and(\n eq(\n adapter.tables[joinLocalesCollectionTableName]._parentID,\n adapter.tables[joinCollectionTableName].id,\n ),\n eq(\n adapter.tables[joinLocalesCollectionTableName][foreignColumn],\n currentIDColumn,\n ),\n ),\n table: adapter.tables[joinLocalesCollectionTableName],\n })\n // Handle without localized and without hasMany, just a condition append to where. With localized the inner join handles eq.\n } else {\n const constraint = eq(\n adapter.tables[joinCollectionTableName][foreignColumn],\n currentIDColumn,\n )\n\n if (subQueryWhere) {\n subQueryWhere = and(subQueryWhere, constraint)\n } else {\n subQueryWhere = constraint\n }\n }\n }\n\n const chainedMethods: ChainedMethods = []\n\n joins.forEach(({ type, condition, table }) => {\n chainedMethods.push({\n args: [table, condition],\n method: type ?? 'leftJoin',\n })\n })\n\n if (limit !== 0) {\n chainedMethods.push({\n args: [limit],\n method: 'limit',\n })\n }\n\n const db = adapter.drizzle as LibSQLDatabase\n\n const subQuery = chainMethods({\n methods: chainedMethods,\n query: db\n .select({\n id: adapter.tables[joinCollectionTableName].id,\n ...(joinLocalesCollectionTableName && {\n locale:\n adapter.tables[joinLocalesCollectionTableName].locale ||\n adapter.tables[joinLocalesCollectionTableName]._locale,\n }),\n })\n .from(adapter.tables[joinCollectionTableName])\n .where(subQueryWhere)\n .orderBy(() => orderBy.map(({ column, order }) => order(column))),\n })\n\n const columnName = `${path.replaceAll('.', '_')}${field.name}`\n\n const jsonObjectSelect = field.localized\n ? sql.raw(\n `'_parentID', \"id\", '_locale', \"${adapter.tables[joinLocalesCollectionTableName].locale ? 'locale' : '_locale'}\"`,\n )\n : sql.raw(`'id', \"id\"`)\n\n if (adapter.name === 'sqlite') {\n currentArgs.extras[columnName] = sql`\n COALESCE((\n SELECT json_group_array(json_object(${jsonObjectSelect}))\n FROM (\n ${subQuery}\n ) AS ${sql.raw(`${columnName}_sub`)}\n ), '[]')\n `.as(columnName)\n } else {\n currentArgs.extras[columnName] = sql`\n COALESCE((\n SELECT json_agg(json_build_object(${jsonObjectSelect}))\n FROM (\n ${subQuery}\n ) AS ${sql.raw(`${columnName}_sub`)}\n ), '[]'::json)\n `.as(columnName)\n }\n\n break\n }\n\n default: {\n if (!select && !selectAllOnCurrentLevel) {\n break\n }\n\n if (\n selectAllOnCurrentLevel ||\n (selectMode === 'include' && select[field.name] === true) ||\n (selectMode === 'exclude' && typeof select[field.name] === 'undefined')\n ) {\n const fieldPath = `${path}${field.name}`\n\n if ((field.localized || withinLocalizedField) && _locales) {\n _locales.columns[fieldPath] = true\n } else if (adapter.tables[currentTableName]?.[fieldPath]) {\n currentArgs.columns[fieldPath] = true\n }\n\n if (\n !withTabledFields.rels &&\n field.type === 'relationship' &&\n (field.hasMany || Array.isArray(field.relationTo))\n ) {\n withTabledFields.rels = true\n }\n\n if (!withTabledFields.numbers && field.type === 'number' && field.hasMany) {\n withTabledFields.numbers = true\n }\n\n if (!withTabledFields.texts && field.type === 'text' && field.hasMany) {\n withTabledFields.texts = true\n }\n }\n\n break\n }\n }\n }\n })\n\n return topLevelArgs\n}\n"],"names":["and","eq","sql","fieldAffectsData","fieldIsVirtual","tabHasName","toSnakeCase","buildQuery","chainMethods","traverseFields","_locales","adapter","currentArgs","currentTableName","depth","fields","joinQuery","joins","locale","path","select","selectAllOnCurrentLevel","selectMode","tablePath","topLevelArgs","topLevelTableName","versions","withinLocalizedField","withTabledFields","forEach","field","type","hasMany","relationTo","localized","with","name","tabs","map","tab","arraySelect","withArray","columns","id","_order","_parentID","orderBy","asc","arrayTableName","tableNameMap","get","tables","_locale","_uuid","arrayTableNameWithLocales","localesSuffix","undefined","Object","keys","length","withSelect","order","parent","blocksSelect","blocks","block","blockKey","slug","blockSelect","blockSelectMode","withBlock","_path","tableName","fieldSelect","joinSchemaPath","replaceAll","limit","limitArg","defaultLimit","sort","defaultSort","where","payload","collections","collection","config","joinCollectionTableName","buildQueryResult","subQueryWhere","joinLocalesCollectionTableName","currentIDColumn","joinRelsCollectionTableName","relationshipsSuffix","columnReferenceToCurrentID","replace","RegExp","versionsSuffix","push","condition","raw","on","table","foreignColumn","constraint","chainedMethods","args","method","db","drizzle","subQuery","methods","query","from","column","columnName","jsonObjectSelect","extras","as","fieldPath","rels","Array","isArray","numbers","texts"],"mappings":"AAGA,SAASA,GAAG,EAAEC,EAAE,EAAEC,GAAG,QAAQ,cAAa;AAE1C,SAASC,gBAAgB,EAAEC,cAAc,EAAEC,UAAU,QAAQ,iBAAgB;AAC7E,OAAOC,iBAAiB,gBAAe;AAKvC,OAAOC,gBAAgB,2BAA0B;AACjD,SAASC,YAAY,QAAQ,oBAAmB;AA4BhD,OAAO,MAAMC,iBAAiB,CAAC,EAC7BC,QAAQ,EACRC,OAAO,EACPC,WAAW,EACXC,gBAAgB,EAChBC,KAAK,EACLC,MAAM,EACNC,YAAY,CAAC,CAAC,EACdC,KAAK,EACLC,MAAM,EACNC,IAAI,EACJC,MAAM,EACNC,0BAA0B,KAAK,EAC/BC,UAAU,EACVC,SAAS,EACTC,YAAY,EACZC,iBAAiB,EACjBC,QAAQ,EACRC,uBAAuB,KAAK,EAC5BC,gBAAgB,EACE;IAClBb,OAAOc,OAAO,CAAC,CAACC;QACd,IAAI1B,eAAe0B,QAAQ;YACzB;QACF;QAEA,6BAA6B;QAC7B,IACEhB,QAAQ,KACPgB,CAAAA,MAAMC,IAAI,KAAK,YAAYD,MAAMC,IAAI,KAAK,cAAa,KACxD,CAACD,MAAME,OAAO,IACd,OAAOF,MAAMG,UAAU,KAAK,UAC5B;YACA,IAAIH,MAAMI,SAAS,EAAE;gBACnBxB,SAASyB,IAAI,CAAC,CAAC,EAAEhB,KAAK,EAAEW,MAAMM,IAAI,CAAC,CAAC,CAAC,GAAG;YAC1C,OAAO;gBACLxB,YAAYuB,IAAI,CAAC,CAAC,EAAEhB,KAAK,EAAEW,MAAMM,IAAI,CAAC,CAAC,CAAC,GAAG;YAC7C;QACF;QAEA,IACEN,MAAMC,IAAI,KAAK,iBACfD,MAAMC,IAAI,KAAK,SACdD,MAAMC,IAAI,KAAK,SAAS,CAAC1B,WAAWyB,QACrC;YACArB,eAAe;gBACbC;gBACAC;gBACAC;gBACAC;gBACAC;gBACAC,QAAQe,MAAMf,MAAM;gBACpBC;gBACAC;gBACAE;gBACAC;gBACAE;gBACAC;gBACAC;gBACAC;gBACAG;YACF;YAEA;QACF;QAEA,IAAIE,MAAMC,IAAI,KAAK,QAAQ;YACzBtB,eAAe;gBACbC;gBACAC;gBACAC;gBACAC;gBACAC;gBACAC,QAAQe,MAAMO,IAAI,CAACC,GAAG,CAAC,CAACC,MAAS,CAAA;wBAAE,GAAGA,GAAG;wBAAER,MAAM;oBAAM,CAAA;gBACvDf;gBACAC;gBACAE;gBACAC;gBACAC;gBACAC;gBACAC;gBACAC;gBACAC;gBACAC;gBACAE;YACF;YAEA;QACF;QAEA,IAAIzB,iBAAiB2B,QAAQ;YAC3B,OAAQA,MAAMC,IAAI;gBAChB,KAAK;oBAAS;wBACZ,MAAMS,cAAcnB,0BAA0B,OAAOD,QAAQ,CAACU,MAAMM,IAAI,CAAC;wBAEzE,IAAIhB,QAAQ;4BACV,IACE,AAACE,eAAe,aAAa,OAAOkB,gBAAgB,eACnDlB,eAAe,aAAakB,gBAAgB,OAC7C;gCACA;4BACF;wBACF;wBAEA,MAAMC,YAAoB;4BACxBC,SACE,OAAOF,gBAAgB,WACnB;gCACEG,IAAI;gCACJC,QAAQ;4BACV,IACA;gCACEC,WAAW;4BACb;4BACNC,SAAS,CAAC,EAAEF,MAAM,EAAE,EAAE,EAAEG,GAAG,EAAE,GAAK;oCAACA,IAAIH;iCAAQ;4BAC/CT,MAAM,CAAC;wBACT;wBAEA,MAAMa,iBAAiBrC,QAAQsC,YAAY,CAACC,GAAG,CAC7C,CAAC,EAAErC,iBAAiB,CAAC,EAAEU,UAAU,EAAEjB,YAAYwB,MAAMM,IAAI,EAAE,CAAC;wBAG9D,IAAI,OAAOI,gBAAgB,UAAU;4BACnC,IAAI7B,QAAQwC,MAAM,CAACH,eAAe,CAACI,OAAO,EAAE;gCAC1CX,UAAUC,OAAO,CAACU,OAAO,GAAG;4BAC9B;4BAEA,IAAIzC,QAAQwC,MAAM,CAACH,eAAe,CAACK,KAAK,EAAE;gCACxCZ,UAAUC,OAAO,CAACW,KAAK,GAAG;4BAC5B;wBACF;wBAEA,MAAMC,4BAA4B,CAAC,EAAEN,eAAe,EAAErC,QAAQ4C,aAAa,CAAC,CAAC;wBAE7E,IAAI5C,QAAQwC,MAAM,CAACG,0BAA0B,EAAE;4BAC7Cb,UAAUN,IAAI,CAACzB,QAAQ,GAAG;gCACxBgC,SACE,OAAOF,gBAAgB,WACnB;oCACEY,SAAS;gCACX,IACA;oCACET,IAAI;oCACJE,WAAW;gCACb;gCACNV,MAAM,CAAC;4BACT;wBACF;wBAEAvB,YAAYuB,IAAI,CAAC,CAAC,EAAEhB,KAAK,EAAEW,MAAMM,IAAI,CAAC,CAAC,CAAC,GAAGK;wBAE3ChC,eAAe;4BACbC,UAAU+B,UAAUN,IAAI,CAACzB,QAAQ;4BACjCC;4BACAC,aAAa6B;4BACb5B,kBAAkBmC;4BAClBlC;4BACAC,QAAQe,MAAMf,MAAM;4BACpBC;4BACAG,MAAM;4BACNC,QAAQ,OAAOoB,gBAAgB,WAAWA,cAAcgB;4BACxDlC;4BACAC,WAAW;4BACXC;4BACAC;4BACAE,sBAAsBA,wBAAwBG,MAAMI,SAAS;4BAC7DN;wBACF;wBAEA,IACE,OAAOY,gBAAgB,YACvBC,UAAUN,IAAI,CAACzB,QAAQ,IACvB+C,OAAOC,IAAI,CAACjB,UAAUN,IAAI,CAACzB,QAAQ,EAAEiD,MAAM,KAAK,GAChD;4BACA,OAAOlB,UAAUN,IAAI,CAACzB,QAAQ;wBAChC;wBAEA;oBACF;gBAEA,KAAK;oBAAU;wBACb,IAAIoB,MAAME,OAAO,EAAE;4BACjB,IAAIZ,QAAQ;gCACV,IACE,AAACE,eAAe,aAAa,CAACF,MAAM,CAACU,MAAMM,IAAI,CAAC,IAC/Cd,eAAe,aAAaF,MAAM,CAACU,MAAMM,IAAI,CAAC,KAAK,OACpD;oCACA;gCACF;4BACF;4BAEA,MAAMwB,aAAqB;gCACzBlB,SAAS;oCACPC,IAAI;oCACJkB,OAAO;oCACPC,QAAQ;gCACV;gCACAhB,SAAS,CAAC,EAAEe,KAAK,EAAE,EAAE,EAAEd,GAAG,EAAE,GAAK;wCAACA,IAAIc;qCAAO;4BAC/C;4BAEAjD,YAAYuB,IAAI,CAAC,CAAC,EAAEhB,KAAK,EAAEW,MAAMM,IAAI,CAAC,CAAC,CAAC,GAAGwB;wBAC7C;wBAEA;oBACF;gBAEA,KAAK;oBAAU;wBACb,MAAMG,eAAe1C,0BAA0B,OAAOD,QAAQ,CAACU,MAAMM,IAAI,CAAC;wBAE1E,IAAIhB,QAAQ;4BACV,IACE,AAACE,eAAe,aAAa,CAACyC,gBAC7BzC,eAAe,aAAayC,iBAAiB,OAC9C;gCACA;4BACF;wBACF;wBAEAjC,MAAMkC,MAAM,CAACnC,OAAO,CAAC,CAACoC;4BACpB,MAAMC,WAAW,CAAC,QAAQ,EAAED,MAAME,IAAI,CAAC,CAAC;4BAExC,IAAIC;4BAEJ,IAAIC,kBAAkB/C;4BAEtB,IAAIA,eAAe,aAAayC,iBAAiB,MAAM;gCACrDK,cAAc;4BAChB;4BAEA,IAAI,OAAOL,iBAAiB,UAAU;gCACpC,IAAI,OAAOA,YAAY,CAACE,MAAME,IAAI,CAAC,KAAK,UAAU;oCAChDC,cAAcL,YAAY,CAACE,MAAME,IAAI,CAAC;gCACxC,OAAO,IACL,AAAC7C,eAAe,aAAa,OAAOyC,YAAY,CAACE,MAAME,IAAI,CAAC,KAAK,eAChE7C,eAAe,aAAayC,YAAY,CAACE,MAAME,IAAI,CAAC,KAAK,OAC1D;oCACAC,cAAc,CAAC;oCACfC,kBAAkB;gCACpB,OAAO,IAAI/C,eAAe,aAAayC,YAAY,CAACE,MAAME,IAAI,CAAC,KAAK,MAAM;oCACxEC,cAAc;gCAChB;4BACF;4BAEA,IAAI,CAAC5C,YAAY,CAAC0C,SAAS,EAAE;gCAC3B,MAAMI,YAAoB;oCACxB5B,SACE,OAAO0B,gBAAgB,WACnB;wCACEzB,IAAI;wCACJC,QAAQ;wCACR2B,OAAO;oCACT,IACA;wCACE1B,WAAW;oCACb;oCACNC,SAAS,CAAC,EAAEF,MAAM,EAAE,EAAE,EAAEG,GAAG,EAAE,GAAK;4CAACA,IAAIH;yCAAQ;oCAC/CT,MAAM,CAAC;gCACT;gCAEA,MAAMqC,YAAY7D,QAAQsC,YAAY,CAACC,GAAG,CACxC,CAAC,EAAEzB,kBAAkB,QAAQ,EAAEnB,YAAY2D,MAAME,IAAI,EAAE,CAAC;gCAG1D,IAAI,OAAOC,gBAAgB,UAAU;oCACnC,IAAIzD,QAAQwC,MAAM,CAACqB,UAAU,CAACpB,OAAO,EAAE;wCACrCkB,UAAU5B,OAAO,CAACU,OAAO,GAAG;oCAC9B;oCAEA,IAAIzC,QAAQwC,MAAM,CAACqB,UAAU,CAACnB,KAAK,EAAE;wCACnCiB,UAAU5B,OAAO,CAACW,KAAK,GAAG;oCAC5B;gCACF;gCAEA,IAAI1C,QAAQwC,MAAM,CAAC,CAAC,EAAEqB,UAAU,EAAE7D,QAAQ4C,aAAa,CAAC,CAAC,CAAC,EAAE;oCAC1De,UAAUnC,IAAI,CAACzB,QAAQ,GAAG;wCACxByB,MAAM,CAAC;oCACT;oCAEA,IAAI,OAAOiC,gBAAgB,UAAU;wCACnCE,UAAUnC,IAAI,CAACzB,QAAQ,CAACgC,OAAO,GAAG;4CAChCU,SAAS;wCACX;oCACF;gCACF;gCACA5B,aAAaW,IAAI,CAAC+B,SAAS,GAAGI;gCAE9B7D,eAAe;oCACbC,UAAU4D,UAAUnC,IAAI,CAACzB,QAAQ;oCACjCC;oCACAC,aAAa0D;oCACbzD,kBAAkB2D;oCAClB1D;oCACAC,QAAQkD,MAAMlD,MAAM;oCACpBC;oCACAG,MAAM;oCACNC,QAAQ,OAAOgD,gBAAgB,WAAWA,cAAcZ;oCACxDlC,YAAY+C;oCACZ9C,WAAW;oCACXC;oCACAC;oCACAE,sBAAsBA,wBAAwBG,MAAMI,SAAS;oCAC7DN;gCACF;gCAEA,IACE,OAAOwC,gBAAgB,YACvBE,UAAUnC,IAAI,CAACzB,QAAQ,IACvB+C,OAAOC,IAAI,CAACY,UAAUnC,IAAI,CAACzB,QAAQ,CAACgC,OAAO,EAAEiB,MAAM,KAAK,GACxD;oCACA,OAAOW,UAAUnC,IAAI,CAACzB,QAAQ;gCAChC;4BACF;wBACF;wBAEA;oBACF;gBAEA,KAAK;gBACL,KAAK;oBAAO;wBACV,MAAM+D,cAAcrD,QAAQ,CAACU,MAAMM,IAAI,CAAC;wBAExC,IAAIqC,gBAAgB,OAAO;4BACzB;wBACF;wBAEAhE,eAAe;4BACbC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC,QAAQe,MAAMf,MAAM;4BACpBC;4BACAC;4BACAE,MAAM,CAAC,EAAEA,KAAK,EAAEW,MAAMM,IAAI,CAAC,CAAC,CAAC;4BAC7BhB,QAAQ,OAAOqD,gBAAgB,WAAWA,cAAcjB;4BACxDnC,yBACEA,2BACAoD,gBAAgB,QACfnD,eAAe,aAAa,OAAOmD,gBAAgB;4BACtDnD;4BACAC,WAAW,CAAC,EAAEA,UAAU,EAAEjB,YAAYwB,MAAMM,IAAI,EAAE,CAAC,CAAC;4BACpDZ;4BACAC;4BACAC;4BACAC,sBAAsBA,wBAAwBG,MAAMI,SAAS;4BAC7DN;wBACF;wBAEA;oBACF;gBAEA,KAAK;oBAAQ;wBACX,0CAA0C;wBAC1C,IAAIZ,cAAc,OAAO;4BACvB;wBACF;wBAEA,IACE,AAACI,UAAUE,eAAe,aAAa,CAACF,MAAM,CAACU,MAAMM,IAAI,CAAC,IACzDd,eAAe,aAAaF,MAAM,CAACU,MAAMM,IAAI,CAAC,KAAK,OACpD;4BACA;wBACF;wBAEA,MAAMsC,iBAAiB,CAAC,EAAEvD,KAAKwD,UAAU,CAAC,KAAK,KAAK,EAAE7C,MAAMM,IAAI,CAAC,CAAC;wBAElE,IAAIpB,SAAS,CAAC0D,eAAe,KAAK,OAAO;4BACvC;wBACF;wBAEA,MAAM,EACJE,OAAOC,WAAW/C,MAAMgD,YAAY,IAAI,EAAE,EAC1CC,OAAOjD,MAAMkD,WAAW,EACxBC,KAAK,EACN,GAAGjE,SAAS,CAAC0D,eAAe,IAAI,CAAC;wBAClC,IAAIE,QAAQC;wBAEZ,IAAID,UAAU,GAAG;4BACf,qFAAqF;4BACrFA,SAAS;wBACX;wBAEA,MAAM7D,SAASJ,QAAQuE,OAAO,CAACC,WAAW,CAACrD,MAAMsD,UAAU,CAAC,CAACC,MAAM,CAACtE,MAAM;wBAE1E,MAAMuE,0BAA0B3E,QAAQsC,YAAY,CAACC,GAAG,CAAC5C,YAAYwB,MAAMsD,UAAU;wBAErF,MAAMnE,QAA+B,EAAE;wBAEvC,MAAMsE,mBAAmBhF,WAAW;4BAClCI;4BACAI;4BACAE;4BACAC;4BACA6D;4BACAP,WAAWc;4BACXL;wBACF;wBAEA,IAAIO,gBAAgBD,iBAAiBN,KAAK;wBAC1C,MAAMnC,UAAUyC,iBAAiBzC,OAAO;wBAExC,IAAI2C;wBAEJ,MAAMC,kBAAkBhE,WACpBf,QAAQwC,MAAM,CAACtC,iBAAiB,CAACiD,MAAM,GACvCnD,QAAQwC,MAAM,CAACtC,iBAAiB,CAAC8B,EAAE;wBAEvC,6BAA6B;wBAC7B,IAAIb,MAAME,OAAO,EAAE;4BACjB,MAAM2D,8BAA8B,CAAC,EAAEL,wBAAwB,EAAE3E,QAAQiF,mBAAmB,CAAC,CAAC;4BAE9F,IAAI9D,MAAMI,SAAS,EAAE;gCACnBuD,iCAAiCE;4BACnC;4BAEA,IAAIE;4BAEJ,IAAInE,UAAU;gCACZmE,6BAA6B,CAAC,EAAEpE,kBAC7BqE,OAAO,CAAC,KAAK,IACbA,OAAO,CAAC,IAAIC,OAAO,CAAC,EAAEpF,QAAQqF,cAAc,CAAC,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC;4BAC/D,OAAO;gCACLH,6BAA6B,CAAC,EAAEpE,kBAAkB,GAAG,CAAC;4BACxD;4BAEAR,MAAMgF,IAAI,CAAC;gCACTlE,MAAM;gCACNmE,WAAWlG,IACTC,GACEU,QAAQwC,MAAM,CAACwC,4BAA4B,CAAC7B,MAAM,EAClDnD,QAAQwC,MAAM,CAACmC,wBAAwB,CAAC3C,EAAE,GAE5C1C,GACEC,IAAIiG,GAAG,CAAC,CAAC,CAAC,EAAER,4BAA4B,GAAG,EAAEE,2BAA2B,CAAC,CAAC,GAC1EH,kBAEFzF,GAAGU,QAAQwC,MAAM,CAACwC,4BAA4B,CAACxE,IAAI,EAAEW,MAAMsE,EAAE;gCAE/DC,OAAO1F,QAAQwC,MAAM,CAACwC,4BAA4B;4BACpD;wBACF,OAAO;4BACL,mCAAmC;4BAEnC,MAAMW,gBAAgBxE,MAAMsE,EAAE,CAACzB,UAAU,CAAC,KAAK;4BAE/C,IAAI7C,MAAMI,SAAS,EAAE;gCACnBuD,iCAAiC,CAAC,EAAEH,wBAAwB,EAAE3E,QAAQ4C,aAAa,CAAC,CAAC;gCAErFtC,MAAMgF,IAAI,CAAC;oCACTlE,MAAM;oCACNmE,WAAWlG,IACTC,GACEU,QAAQwC,MAAM,CAACsC,+BAA+B,CAAC5C,SAAS,EACxDlC,QAAQwC,MAAM,CAACmC,wBAAwB,CAAC3C,EAAE,GAE5C1C,GACEU,QAAQwC,MAAM,CAACsC,+BAA+B,CAACa,cAAc,EAC7DZ;oCAGJW,OAAO1F,QAAQwC,MAAM,CAACsC,+BAA+B;gCACvD;4BACA,4HAA4H;4BAC9H,OAAO;gCACL,MAAMc,aAAatG,GACjBU,QAAQwC,MAAM,CAACmC,wBAAwB,CAACgB,cAAc,EACtDZ;gCAGF,IAAIF,eAAe;oCACjBA,gBAAgBxF,IAAIwF,eAAee;gCACrC,OAAO;oCACLf,gBAAgBe;gCAClB;4BACF;wBACF;wBAEA,MAAMC,iBAAiC,EAAE;wBAEzCvF,MAAMY,OAAO,CAAC,CAAC,EAAEE,IAAI,EAAEmE,SAAS,EAAEG,KAAK,EAAE;4BACvCG,eAAeP,IAAI,CAAC;gCAClBQ,MAAM;oCAACJ;oCAAOH;iCAAU;gCACxBQ,QAAQ3E,QAAQ;4BAClB;wBACF;wBAEA,IAAI6C,UAAU,GAAG;4BACf4B,eAAeP,IAAI,CAAC;gCAClBQ,MAAM;oCAAC7B;iCAAM;gCACb8B,QAAQ;4BACV;wBACF;wBAEA,MAAMC,KAAKhG,QAAQiG,OAAO;wBAE1B,MAAMC,WAAWrG,aAAa;4BAC5BsG,SAASN;4BACTO,OAAOJ,GACJvF,MAAM,CAAC;gCACNuB,IAAIhC,QAAQwC,MAAM,CAACmC,wBAAwB,CAAC3C,EAAE;gCAC9C,GAAI8C,kCAAkC;oCACpCvE,QACEP,QAAQwC,MAAM,CAACsC,+BAA+B,CAACvE,MAAM,IACrDP,QAAQwC,MAAM,CAACsC,+BAA+B,CAACrC,OAAO;gCAC1D,CAAC;4BACH,GACC4D,IAAI,CAACrG,QAAQwC,MAAM,CAACmC,wBAAwB,EAC5CL,KAAK,CAACO,eACN1C,OAAO,CAAC,IAAMA,QAAQR,GAAG,CAAC,CAAC,EAAE2E,MAAM,EAAEpD,KAAK,EAAE,GAAKA,MAAMoD;wBAC5D;wBAEA,MAAMC,aAAa,CAAC,EAAE/F,KAAKwD,UAAU,CAAC,KAAK,KAAK,EAAE7C,MAAMM,IAAI,CAAC,CAAC;wBAE9D,MAAM+E,mBAAmBrF,MAAMI,SAAS,GACpChC,IAAIiG,GAAG,CACL,CAAC,+BAA+B,EAAExF,QAAQwC,MAAM,CAACsC,+BAA+B,CAACvE,MAAM,GAAG,WAAW,UAAU,CAAC,CAAC,IAEnHhB,IAAIiG,GAAG,CAAC,CAAC,UAAU,CAAC;wBAExB,IAAIxF,QAAQyB,IAAI,KAAK,UAAU;4BAC7BxB,YAAYwG,MAAM,CAACF,WAAW,GAAGhH,GAAG,CAAC;;oDAEG,EAAEiH,iBAAiB;;kBAErD,EAAEN,SAAS;qBACR,EAAE3G,IAAIiG,GAAG,CAAC,CAAC,EAAEe,WAAW,IAAI,CAAC,EAAE;;YAExC,CAAC,CAACG,EAAE,CAACH;wBACP,OAAO;4BACLtG,YAAYwG,MAAM,CAACF,WAAW,GAAGhH,GAAG,CAAC;;kDAEC,EAAEiH,iBAAiB;;kBAEnD,EAAEN,SAAS;qBACR,EAAE3G,IAAIiG,GAAG,CAAC,CAAC,EAAEe,WAAW,IAAI,CAAC,EAAE;;YAExC,CAAC,CAACG,EAAE,CAACH;wBACP;wBAEA;oBACF;gBAEA;oBAAS;wBACP,IAAI,CAAC9F,UAAU,CAACC,yBAAyB;4BACvC;wBACF;wBAEA,IACEA,2BACCC,eAAe,aAAaF,MAAM,CAACU,MAAMM,IAAI,CAAC,KAAK,QACnDd,eAAe,aAAa,OAAOF,MAAM,CAACU,MAAMM,IAAI,CAAC,KAAK,aAC3D;4BACA,MAAMkF,YAAY,CAAC,EAAEnG,KAAK,EAAEW,MAAMM,IAAI,CAAC,CAAC;4BAExC,IAAI,AAACN,CAAAA,MAAMI,SAAS,IAAIP,oBAAmB,KAAMjB,UAAU;gCACzDA,SAASgC,OAAO,CAAC4E,UAAU,GAAG;4BAChC,OAAO,IAAI3G,QAAQwC,MAAM,CAACtC,iBAAiB,EAAE,CAACyG,UAAU,EAAE;gCACxD1G,YAAY8B,OAAO,CAAC4E,UAAU,GAAG;4BACnC;4BAEA,IACE,CAAC1F,iBAAiB2F,IAAI,IACtBzF,MAAMC,IAAI,KAAK,kBACdD,CAAAA,MAAME,OAAO,IAAIwF,MAAMC,OAAO,CAAC3F,MAAMG,UAAU,CAAA,GAChD;gCACAL,iBAAiB2F,IAAI,GAAG;4BAC1B;4BAEA,IAAI,CAAC3F,iBAAiB8F,OAAO,IAAI5F,MAAMC,IAAI,KAAK,YAAYD,MAAME,OAAO,EAAE;gCACzEJ,iBAAiB8F,OAAO,GAAG;4BAC7B;4BAEA,IAAI,CAAC9F,iBAAiB+F,KAAK,IAAI7F,MAAMC,IAAI,KAAK,UAAUD,MAAME,OAAO,EAAE;gCACrEJ,iBAAiB+F,KAAK,GAAG;4BAC3B;wBACF;wBAEA;oBACF;YACF;QACF;IACF;IAEA,OAAOnG;AACT,EAAC"}
|
|
1
|
+
{"version":3,"sources":["../../src/find/traverseFields.ts"],"sourcesContent":["import type { LibSQLDatabase } from 'drizzle-orm/libsql'\nimport type { Field, JoinQuery, SelectMode, SelectType, TabAsField } from 'payload'\n\nimport { and, eq, sql } from 'drizzle-orm'\nimport { combineQueries } from 'payload'\nimport { fieldAffectsData, fieldIsVirtual, tabHasName } from 'payload/shared'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { BuildQueryJoinAliases, ChainedMethods, DrizzleAdapter } from '../types.js'\nimport type { Result } from './buildFindManyArgs.js'\n\nimport buildQuery from '../queries/buildQuery.js'\nimport { chainMethods } from './chainMethods.js'\n\ntype TraverseFieldArgs = {\n _locales: Result\n adapter: DrizzleAdapter\n currentArgs: Result\n currentTableName: string\n depth?: number\n fields: (Field | TabAsField)[]\n joinQuery: JoinQuery\n joins?: BuildQueryJoinAliases\n locale?: string\n path: string\n select?: SelectType\n selectAllOnCurrentLevel?: boolean\n selectMode?: SelectMode\n tablePath: string\n topLevelArgs: Record<string, unknown>\n topLevelTableName: string\n versions?: boolean\n withinLocalizedField?: boolean\n withTabledFields: {\n numbers?: boolean\n rels?: boolean\n texts?: boolean\n }\n}\n\nexport const traverseFields = ({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields,\n joinQuery = {},\n joins,\n locale,\n path,\n select,\n selectAllOnCurrentLevel = false,\n selectMode,\n tablePath,\n topLevelArgs,\n topLevelTableName,\n versions,\n withinLocalizedField = false,\n withTabledFields,\n}: TraverseFieldArgs) => {\n fields.forEach((field) => {\n if (fieldIsVirtual(field)) {\n return\n }\n\n // handle simple relationship\n if (\n depth > 0 &&\n (field.type === 'upload' || field.type === 'relationship') &&\n !field.hasMany &&\n typeof field.relationTo === 'string'\n ) {\n if (field.localized) {\n _locales.with[`${path}${field.name}`] = true\n } else {\n currentArgs.with[`${path}${field.name}`] = true\n }\n }\n\n if (\n field.type === 'collapsible' ||\n field.type === 'row' ||\n (field.type === 'tab' && !tabHasName(field))\n ) {\n traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: field.fields,\n joinQuery,\n joins,\n path,\n select,\n selectMode,\n tablePath,\n topLevelArgs,\n topLevelTableName,\n withTabledFields,\n })\n\n return\n }\n\n if (field.type === 'tabs') {\n traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n joinQuery,\n joins,\n path,\n select,\n selectAllOnCurrentLevel,\n selectMode,\n tablePath,\n topLevelArgs,\n topLevelTableName,\n versions,\n withTabledFields,\n })\n\n return\n }\n\n if (fieldAffectsData(field)) {\n switch (field.type) {\n case 'array': {\n const arraySelect = selectAllOnCurrentLevel ? true : select?.[field.name]\n\n if (select) {\n if (\n (selectMode === 'include' && typeof arraySelect === 'undefined') ||\n (selectMode === 'exclude' && arraySelect === false)\n ) {\n break\n }\n }\n\n const withArray: Result = {\n columns:\n typeof arraySelect === 'object'\n ? {\n id: true,\n _order: true,\n }\n : {\n _parentID: false,\n },\n orderBy: ({ _order }, { asc }) => [asc(_order)],\n with: {},\n }\n\n const arrayTableName = adapter.tableNameMap.get(\n `${currentTableName}_${tablePath}${toSnakeCase(field.name)}`,\n )\n\n if (typeof arraySelect === 'object') {\n if (adapter.tables[arrayTableName]._locale) {\n withArray.columns._locale = true\n }\n\n if (adapter.tables[arrayTableName]._uuid) {\n withArray.columns._uuid = true\n }\n }\n\n const arrayTableNameWithLocales = `${arrayTableName}${adapter.localesSuffix}`\n\n if (adapter.tables[arrayTableNameWithLocales]) {\n withArray.with._locales = {\n columns:\n typeof arraySelect === 'object'\n ? {\n _locale: true,\n }\n : {\n id: false,\n _parentID: false,\n },\n with: {},\n }\n }\n\n currentArgs.with[`${path}${field.name}`] = withArray\n\n traverseFields({\n _locales: withArray.with._locales,\n adapter,\n currentArgs: withArray,\n currentTableName: arrayTableName,\n depth,\n fields: field.fields,\n joinQuery,\n path: '',\n select: typeof arraySelect === 'object' ? arraySelect : undefined,\n selectMode,\n tablePath: '',\n topLevelArgs,\n topLevelTableName,\n withinLocalizedField: withinLocalizedField || field.localized,\n withTabledFields,\n })\n\n if (\n typeof arraySelect === 'object' &&\n withArray.with._locales &&\n Object.keys(withArray.with._locales).length === 1\n ) {\n delete withArray.with._locales\n }\n\n break\n }\n\n case 'select': {\n if (field.hasMany) {\n if (select) {\n if (\n (selectMode === 'include' && !select[field.name]) ||\n (selectMode === 'exclude' && select[field.name] === false)\n ) {\n break\n }\n }\n\n const withSelect: Result = {\n columns: {\n id: false,\n order: false,\n parent: false,\n },\n orderBy: ({ order }, { asc }) => [asc(order)],\n }\n\n currentArgs.with[`${path}${field.name}`] = withSelect\n }\n\n break\n }\n\n case 'blocks': {\n const blocksSelect = selectAllOnCurrentLevel ? true : select?.[field.name]\n\n if (select) {\n if (\n (selectMode === 'include' && !blocksSelect) ||\n (selectMode === 'exclude' && blocksSelect === false)\n ) {\n break\n }\n }\n\n field.blocks.forEach((block) => {\n const blockKey = `_blocks_${block.slug}`\n\n let blockSelect: boolean | SelectType | undefined\n\n let blockSelectMode = selectMode\n\n if (selectMode === 'include' && blocksSelect === true) {\n blockSelect = true\n }\n\n if (typeof blocksSelect === 'object') {\n if (typeof blocksSelect[block.slug] === 'object') {\n blockSelect = blocksSelect[block.slug]\n } else if (\n (selectMode === 'include' && typeof blocksSelect[block.slug] === 'undefined') ||\n (selectMode === 'exclude' && blocksSelect[block.slug] === false)\n ) {\n blockSelect = {}\n blockSelectMode = 'include'\n } else if (selectMode === 'include' && blocksSelect[block.slug] === true) {\n blockSelect = true\n }\n }\n\n if (!topLevelArgs[blockKey]) {\n const withBlock: Result = {\n columns:\n typeof blockSelect === 'object'\n ? {\n id: true,\n _order: true,\n _path: true,\n }\n : {\n _parentID: false,\n },\n orderBy: ({ _order }, { asc }) => [asc(_order)],\n with: {},\n }\n\n const tableName = adapter.tableNameMap.get(\n `${topLevelTableName}_blocks_${toSnakeCase(block.slug)}`,\n )\n\n if (typeof blockSelect === 'object') {\n if (adapter.tables[tableName]._locale) {\n withBlock.columns._locale = true\n }\n\n if (adapter.tables[tableName]._uuid) {\n withBlock.columns._uuid = true\n }\n }\n\n if (adapter.tables[`${tableName}${adapter.localesSuffix}`]) {\n withBlock.with._locales = {\n with: {},\n }\n\n if (typeof blockSelect === 'object') {\n withBlock.with._locales.columns = {\n _locale: true,\n }\n }\n }\n topLevelArgs.with[blockKey] = withBlock\n\n traverseFields({\n _locales: withBlock.with._locales,\n adapter,\n currentArgs: withBlock,\n currentTableName: tableName,\n depth,\n fields: block.fields,\n joinQuery,\n path: '',\n select: typeof blockSelect === 'object' ? blockSelect : undefined,\n selectMode: blockSelectMode,\n tablePath: '',\n topLevelArgs,\n topLevelTableName,\n withinLocalizedField: withinLocalizedField || field.localized,\n withTabledFields,\n })\n\n if (\n typeof blockSelect === 'object' &&\n withBlock.with._locales &&\n Object.keys(withBlock.with._locales.columns).length === 1\n ) {\n delete withBlock.with._locales\n }\n }\n })\n\n break\n }\n\n case 'group':\n case 'tab': {\n const fieldSelect = select?.[field.name]\n\n if (fieldSelect === false) {\n break\n }\n\n traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: field.fields,\n joinQuery,\n joins,\n path: `${path}${field.name}_`,\n select: typeof fieldSelect === 'object' ? fieldSelect : undefined,\n selectAllOnCurrentLevel:\n selectAllOnCurrentLevel ||\n fieldSelect === true ||\n (selectMode === 'exclude' && typeof fieldSelect === 'undefined'),\n selectMode,\n tablePath: `${tablePath}${toSnakeCase(field.name)}_`,\n topLevelArgs,\n topLevelTableName,\n versions,\n withinLocalizedField: withinLocalizedField || field.localized,\n withTabledFields,\n })\n\n break\n }\n\n case 'point': {\n if (adapter.name === 'sqlite') {\n break\n }\n\n const args = field.localized ? _locales : currentArgs\n if (!args.columns) {\n args.columns = {}\n }\n\n if (!args.extras) {\n args.extras = {}\n }\n\n const name = `${path}${field.name}`\n\n // Drizzle handles that poorly. See https://github.com/drizzle-team/drizzle-orm/issues/2526\n // Additionally, this way we format the column value straight in the database using ST_AsGeoJSON\n args.columns[name] = false\n\n let shouldSelect = false\n\n if (select || selectAllOnCurrentLevel) {\n if (\n selectAllOnCurrentLevel ||\n (selectMode === 'include' && select[field.name] === true) ||\n (selectMode === 'exclude' && typeof select[field.name] === 'undefined')\n ) {\n shouldSelect = true\n }\n } else {\n shouldSelect = true\n }\n\n if (shouldSelect) {\n args.extras[name] = sql.raw(`ST_AsGeoJSON(${toSnakeCase(name)})::jsonb`).as(name)\n }\n break\n }\n\n case 'join': {\n // when `joinsQuery` is false, do not join\n if (joinQuery === false) {\n break\n }\n\n if (\n (select && selectMode === 'include' && !select[field.name]) ||\n (selectMode === 'exclude' && select[field.name] === false)\n ) {\n break\n }\n\n const joinSchemaPath = `${path.replaceAll('_', '.')}${field.name}`\n\n if (joinQuery[joinSchemaPath] === false) {\n break\n }\n\n const {\n limit: limitArg = field.defaultLimit ?? 10,\n sort = field.defaultSort,\n where,\n } = joinQuery[joinSchemaPath] || {}\n let limit = limitArg\n\n if (limit !== 0) {\n // get an additional document and slice it later to determine if there is a next page\n limit += 1\n }\n\n const fields = adapter.payload.collections[field.collection].config.fields\n\n const joinCollectionTableName = adapter.tableNameMap.get(toSnakeCase(field.collection))\n\n const joins: BuildQueryJoinAliases = []\n\n const buildQueryResult = buildQuery({\n adapter,\n fields,\n joins,\n locale,\n sort,\n tableName: joinCollectionTableName,\n where,\n })\n\n let subQueryWhere = buildQueryResult.where\n const orderBy = buildQueryResult.orderBy\n\n let joinLocalesCollectionTableName: string | undefined\n\n const currentIDColumn = versions\n ? adapter.tables[currentTableName].parent\n : adapter.tables[currentTableName].id\n\n // Handle hasMany _rels table\n if (field.hasMany) {\n const joinRelsCollectionTableName = `${joinCollectionTableName}${adapter.relationshipsSuffix}`\n\n if (field.localized) {\n joinLocalesCollectionTableName = joinRelsCollectionTableName\n }\n\n let columnReferenceToCurrentID: string\n\n if (versions) {\n columnReferenceToCurrentID = `${topLevelTableName\n .replace('_', '')\n .replace(new RegExp(`${adapter.versionsSuffix}$`), '')}_id`\n } else {\n columnReferenceToCurrentID = `${topLevelTableName}_id`\n }\n\n joins.push({\n type: 'innerJoin',\n condition: and(\n eq(\n adapter.tables[joinRelsCollectionTableName].parent,\n adapter.tables[joinCollectionTableName].id,\n ),\n eq(\n sql.raw(`\"${joinRelsCollectionTableName}\".\"${columnReferenceToCurrentID}\"`),\n currentIDColumn,\n ),\n eq(adapter.tables[joinRelsCollectionTableName].path, field.on),\n ),\n table: adapter.tables[joinRelsCollectionTableName],\n })\n } else {\n // Handle localized without hasMany\n\n const foreignColumn = field.on.replaceAll('.', '_')\n\n if (field.localized) {\n joinLocalesCollectionTableName = `${joinCollectionTableName}${adapter.localesSuffix}`\n\n joins.push({\n type: 'innerJoin',\n condition: and(\n eq(\n adapter.tables[joinLocalesCollectionTableName]._parentID,\n adapter.tables[joinCollectionTableName].id,\n ),\n eq(\n adapter.tables[joinLocalesCollectionTableName][foreignColumn],\n currentIDColumn,\n ),\n ),\n table: adapter.tables[joinLocalesCollectionTableName],\n })\n // Handle without localized and without hasMany, just a condition append to where. With localized the inner join handles eq.\n } else {\n const constraint = eq(\n adapter.tables[joinCollectionTableName][foreignColumn],\n currentIDColumn,\n )\n\n if (subQueryWhere) {\n subQueryWhere = and(subQueryWhere, constraint)\n } else {\n subQueryWhere = constraint\n }\n }\n }\n\n const chainedMethods: ChainedMethods = []\n\n joins.forEach(({ type, condition, table }) => {\n chainedMethods.push({\n args: [table, condition],\n method: type ?? 'leftJoin',\n })\n })\n\n if (limit !== 0) {\n chainedMethods.push({\n args: [limit],\n method: 'limit',\n })\n }\n\n const db = adapter.drizzle as LibSQLDatabase\n\n const subQuery = chainMethods({\n methods: chainedMethods,\n query: db\n .select({\n id: adapter.tables[joinCollectionTableName].id,\n ...(joinLocalesCollectionTableName && {\n locale:\n adapter.tables[joinLocalesCollectionTableName].locale ||\n adapter.tables[joinLocalesCollectionTableName]._locale,\n }),\n })\n .from(adapter.tables[joinCollectionTableName])\n .where(subQueryWhere)\n .orderBy(() => orderBy.map(({ column, order }) => order(column))),\n })\n\n const columnName = `${path.replaceAll('.', '_')}${field.name}`\n\n const jsonObjectSelect = field.localized\n ? sql.raw(\n `'_parentID', \"id\", '_locale', \"${adapter.tables[joinLocalesCollectionTableName].locale ? 'locale' : '_locale'}\"`,\n )\n : sql.raw(`'id', \"id\"`)\n\n if (adapter.name === 'sqlite') {\n currentArgs.extras[columnName] = sql`\n COALESCE((\n SELECT json_group_array(json_object(${jsonObjectSelect}))\n FROM (\n ${subQuery}\n ) AS ${sql.raw(`${columnName}_sub`)}\n ), '[]')\n `.as(columnName)\n } else {\n currentArgs.extras[columnName] = sql`\n COALESCE((\n SELECT json_agg(json_build_object(${jsonObjectSelect}))\n FROM (\n ${subQuery}\n ) AS ${sql.raw(`${columnName}_sub`)}\n ), '[]'::json)\n `.as(columnName)\n }\n\n break\n }\n\n default: {\n if (!select && !selectAllOnCurrentLevel) {\n break\n }\n\n if (\n selectAllOnCurrentLevel ||\n (selectMode === 'include' && select[field.name] === true) ||\n (selectMode === 'exclude' && typeof select[field.name] === 'undefined')\n ) {\n const fieldPath = `${path}${field.name}`\n\n if ((field.localized || withinLocalizedField) && _locales) {\n _locales.columns[fieldPath] = true\n } else if (adapter.tables[currentTableName]?.[fieldPath]) {\n currentArgs.columns[fieldPath] = true\n }\n\n if (\n !withTabledFields.rels &&\n field.type === 'relationship' &&\n (field.hasMany || Array.isArray(field.relationTo))\n ) {\n withTabledFields.rels = true\n }\n\n if (!withTabledFields.numbers && field.type === 'number' && field.hasMany) {\n withTabledFields.numbers = true\n }\n\n if (!withTabledFields.texts && field.type === 'text' && field.hasMany) {\n withTabledFields.texts = true\n }\n }\n\n break\n }\n }\n }\n })\n\n return topLevelArgs\n}\n"],"names":["and","eq","sql","fieldAffectsData","fieldIsVirtual","tabHasName","toSnakeCase","buildQuery","chainMethods","traverseFields","_locales","adapter","currentArgs","currentTableName","depth","fields","joinQuery","joins","locale","path","select","selectAllOnCurrentLevel","selectMode","tablePath","topLevelArgs","topLevelTableName","versions","withinLocalizedField","withTabledFields","forEach","field","type","hasMany","relationTo","localized","with","name","tabs","map","tab","arraySelect","withArray","columns","id","_order","_parentID","orderBy","asc","arrayTableName","tableNameMap","get","tables","_locale","_uuid","arrayTableNameWithLocales","localesSuffix","undefined","Object","keys","length","withSelect","order","parent","blocksSelect","blocks","block","blockKey","slug","blockSelect","blockSelectMode","withBlock","_path","tableName","fieldSelect","args","extras","shouldSelect","raw","as","joinSchemaPath","replaceAll","limit","limitArg","defaultLimit","sort","defaultSort","where","payload","collections","collection","config","joinCollectionTableName","buildQueryResult","subQueryWhere","joinLocalesCollectionTableName","currentIDColumn","joinRelsCollectionTableName","relationshipsSuffix","columnReferenceToCurrentID","replace","RegExp","versionsSuffix","push","condition","on","table","foreignColumn","constraint","chainedMethods","method","db","drizzle","subQuery","methods","query","from","column","columnName","jsonObjectSelect","fieldPath","rels","Array","isArray","numbers","texts"],"mappings":"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"}
|
package/dist/migrate.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrate.d.ts","sourceRoot":"","sources":["../src/migrate.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,cAAc,EAAa,MAAM,YAAY,CAAA;AAK3D,eAAO,MAAM,OAAO,EAAE,cAAc,CAAC,SAAS,
|
|
1
|
+
{"version":3,"file":"migrate.d.ts","sourceRoot":"","sources":["../src/migrate.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,cAAc,EAAa,MAAM,YAAY,CAAA;AAK3D,eAAO,MAAM,OAAO,EAAE,cAAc,CAAC,SAAS,CAmE7C,CAAA"}
|
package/dist/migrate.js
CHANGED
|
@@ -13,6 +13,9 @@ export const migrate = async function migrate(args) {
|
|
|
13
13
|
});
|
|
14
14
|
return;
|
|
15
15
|
}
|
|
16
|
+
if ('createExtensions' in this && typeof this.createExtensions === 'function') {
|
|
17
|
+
await this.createExtensions();
|
|
18
|
+
}
|
|
16
19
|
let latestBatch = 0;
|
|
17
20
|
let migrationsInDB = [];
|
|
18
21
|
const hasMigrationTable = await migrationTableExists(this);
|
package/dist/migrate.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/migrate.ts"],"sourcesContent":["import type { Payload, PayloadRequest } from 'payload'\n\nimport { commitTransaction, initTransaction, killTransaction, readMigrationFiles } from 'payload'\nimport prompts from 'prompts'\n\nimport type { DrizzleAdapter, Migration } from './types.js'\n\nimport { migrationTableExists } from './utilities/migrationTableExists.js'\nimport { parseError } from './utilities/parseError.js'\n\nexport const migrate: DrizzleAdapter['migrate'] = async function migrate(\n this: DrizzleAdapter,\n args,\n): Promise<void> {\n const { payload } = this\n const migrationFiles = args?.migrations || (await readMigrationFiles({ payload }))\n\n if (!migrationFiles.length) {\n payload.logger.info({ msg: 'No migrations to run.' })\n return\n }\n\n let latestBatch = 0\n let migrationsInDB = []\n\n const hasMigrationTable = await migrationTableExists(this)\n\n if (hasMigrationTable) {\n ;({ docs: migrationsInDB } = await payload.find({\n collection: 'payload-migrations',\n limit: 0,\n sort: '-name',\n }))\n if (Number(migrationsInDB?.[0]?.batch) > 0) {\n latestBatch = Number(migrationsInDB[0]?.batch)\n }\n }\n\n if (migrationsInDB.find((m) => m.batch === -1)) {\n const { confirm: runMigrations } = await prompts(\n {\n name: 'confirm',\n type: 'confirm',\n initial: false,\n message:\n \"It looks like you've run Payload in dev mode, meaning you've dynamically pushed changes to your database.\\n\\n\" +\n \"If you'd like to run migrations, data loss will occur. Would you like to proceed?\",\n },\n {\n onCancel: () => {\n process.exit(0)\n },\n },\n )\n\n if (!runMigrations) {\n process.exit(0)\n }\n }\n\n const newBatch = latestBatch + 1\n\n // Execute 'up' function for each migration sequentially\n for (const migration of migrationFiles) {\n const alreadyRan = migrationsInDB.find((existing) => existing.name === migration.name)\n\n // If already ran, skip\n if (alreadyRan) {\n continue\n }\n\n await runMigrationFile(payload, migration, newBatch)\n }\n}\n\nasync function runMigrationFile(payload: Payload, migration: Migration, batch: number) {\n const start = Date.now()\n const req = { payload } as PayloadRequest\n const adapter = payload.db as DrizzleAdapter\n\n payload.logger.info({ msg: `Migrating: ${migration.name}` })\n\n try {\n await initTransaction(req)\n const db = adapter?.sessions[await req.transactionID]?.db || adapter.drizzle\n await migration.up({ db, payload, req })\n payload.logger.info({ msg: `Migrated: ${migration.name} (${Date.now() - start}ms)` })\n await payload.create({\n collection: 'payload-migrations',\n data: {\n name: migration.name,\n batch,\n },\n req,\n })\n await commitTransaction(req)\n } catch (err: unknown) {\n await killTransaction(req)\n payload.logger.error({\n err,\n msg: parseError(err, `Error running migration ${migration.name}`),\n })\n process.exit(1)\n }\n}\n"],"names":["commitTransaction","initTransaction","killTransaction","readMigrationFiles","prompts","migrationTableExists","parseError","migrate","args","payload","migrationFiles","migrations","length","logger","info","msg","latestBatch","migrationsInDB","hasMigrationTable","docs","find","collection","limit","sort","Number","batch","m","confirm","runMigrations","name","type","initial","message","onCancel","process","exit","newBatch","migration","alreadyRan","existing","runMigrationFile","start","Date","now","req","adapter","db","sessions","transactionID","drizzle","up","create","data","err","error"],"mappings":"AAEA,SAASA,iBAAiB,EAAEC,eAAe,EAAEC,eAAe,EAAEC,kBAAkB,QAAQ,UAAS;AACjG,OAAOC,aAAa,UAAS;AAI7B,SAASC,oBAAoB,QAAQ,sCAAqC;AAC1E,SAASC,UAAU,QAAQ,4BAA2B;AAEtD,OAAO,MAAMC,UAAqC,eAAeA,QAE/DC,IAAI;IAEJ,MAAM,EAAEC,OAAO,EAAE,GAAG,IAAI;IACxB,MAAMC,iBAAiBF,MAAMG,cAAe,MAAMR,mBAAmB;QAAEM;IAAQ;IAE/E,IAAI,CAACC,eAAeE,MAAM,EAAE;QAC1BH,QAAQI,MAAM,CAACC,IAAI,CAAC;YAAEC,KAAK;QAAwB;QACnD;IACF;IAEA,IAAIC,cAAc;IAClB,IAAIC,iBAAiB,EAAE;IAEvB,MAAMC,oBAAoB,
|
|
1
|
+
{"version":3,"sources":["../src/migrate.ts"],"sourcesContent":["import type { Payload, PayloadRequest } from 'payload'\n\nimport { commitTransaction, initTransaction, killTransaction, readMigrationFiles } from 'payload'\nimport prompts from 'prompts'\n\nimport type { DrizzleAdapter, Migration } from './types.js'\n\nimport { migrationTableExists } from './utilities/migrationTableExists.js'\nimport { parseError } from './utilities/parseError.js'\n\nexport const migrate: DrizzleAdapter['migrate'] = async function migrate(\n this: DrizzleAdapter,\n args,\n): Promise<void> {\n const { payload } = this\n const migrationFiles = args?.migrations || (await readMigrationFiles({ payload }))\n\n if (!migrationFiles.length) {\n payload.logger.info({ msg: 'No migrations to run.' })\n return\n }\n\n if ('createExtensions' in this && typeof this.createExtensions === 'function') {\n await this.createExtensions()\n }\n\n let latestBatch = 0\n let migrationsInDB = []\n\n const hasMigrationTable = await migrationTableExists(this)\n\n if (hasMigrationTable) {\n ;({ docs: migrationsInDB } = await payload.find({\n collection: 'payload-migrations',\n limit: 0,\n sort: '-name',\n }))\n if (Number(migrationsInDB?.[0]?.batch) > 0) {\n latestBatch = Number(migrationsInDB[0]?.batch)\n }\n }\n\n if (migrationsInDB.find((m) => m.batch === -1)) {\n const { confirm: runMigrations } = await prompts(\n {\n name: 'confirm',\n type: 'confirm',\n initial: false,\n message:\n \"It looks like you've run Payload in dev mode, meaning you've dynamically pushed changes to your database.\\n\\n\" +\n \"If you'd like to run migrations, data loss will occur. Would you like to proceed?\",\n },\n {\n onCancel: () => {\n process.exit(0)\n },\n },\n )\n\n if (!runMigrations) {\n process.exit(0)\n }\n }\n\n const newBatch = latestBatch + 1\n\n // Execute 'up' function for each migration sequentially\n for (const migration of migrationFiles) {\n const alreadyRan = migrationsInDB.find((existing) => existing.name === migration.name)\n\n // If already ran, skip\n if (alreadyRan) {\n continue\n }\n\n await runMigrationFile(payload, migration, newBatch)\n }\n}\n\nasync function runMigrationFile(payload: Payload, migration: Migration, batch: number) {\n const start = Date.now()\n const req = { payload } as PayloadRequest\n const adapter = payload.db as DrizzleAdapter\n\n payload.logger.info({ msg: `Migrating: ${migration.name}` })\n\n try {\n await initTransaction(req)\n const db = adapter?.sessions[await req.transactionID]?.db || adapter.drizzle\n await migration.up({ db, payload, req })\n payload.logger.info({ msg: `Migrated: ${migration.name} (${Date.now() - start}ms)` })\n await payload.create({\n collection: 'payload-migrations',\n data: {\n name: migration.name,\n batch,\n },\n req,\n })\n await commitTransaction(req)\n } catch (err: unknown) {\n await killTransaction(req)\n payload.logger.error({\n err,\n msg: parseError(err, `Error running migration ${migration.name}`),\n })\n process.exit(1)\n }\n}\n"],"names":["commitTransaction","initTransaction","killTransaction","readMigrationFiles","prompts","migrationTableExists","parseError","migrate","args","payload","migrationFiles","migrations","length","logger","info","msg","createExtensions","latestBatch","migrationsInDB","hasMigrationTable","docs","find","collection","limit","sort","Number","batch","m","confirm","runMigrations","name","type","initial","message","onCancel","process","exit","newBatch","migration","alreadyRan","existing","runMigrationFile","start","Date","now","req","adapter","db","sessions","transactionID","drizzle","up","create","data","err","error"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrateFresh.d.ts","sourceRoot":"","sources":["../src/migrateFresh.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,cAAc,
|
|
1
|
+
{"version":3,"file":"migrateFresh.d.ts","sourceRoot":"","sources":["../src/migrateFresh.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;AAIhD;;GAEG;AACH,wBAAsB,YAAY,CAChC,IAAI,EAAE,cAAc,EACpB,EAAE,kBAA0B,EAAE;;CAAA,GAC7B,OAAO,CAAC,IAAI,CAAC,CAqEf"}
|
package/dist/migrateFresh.js
CHANGED
|
@@ -35,6 +35,9 @@ import { parseError } from './utilities/parseError.js';
|
|
|
35
35
|
const req = {
|
|
36
36
|
payload
|
|
37
37
|
};
|
|
38
|
+
if ('createExtensions' in this && typeof this.createExtensions === 'function') {
|
|
39
|
+
await this.createExtensions();
|
|
40
|
+
}
|
|
38
41
|
// Run all migrate up
|
|
39
42
|
for (const migration of migrationFiles){
|
|
40
43
|
payload.logger.info({
|
package/dist/migrateFresh.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/migrateFresh.ts"],"sourcesContent":["import type { PayloadRequest } from 'payload'\n\nimport { commitTransaction, initTransaction, killTransaction, readMigrationFiles } from 'payload'\nimport prompts from 'prompts'\n\nimport type { DrizzleAdapter
|
|
1
|
+
{"version":3,"sources":["../src/migrateFresh.ts"],"sourcesContent":["import type { PayloadRequest } from 'payload'\n\nimport { commitTransaction, initTransaction, killTransaction, readMigrationFiles } from 'payload'\nimport prompts from 'prompts'\n\nimport type { DrizzleAdapter } from './types.js'\n\nimport { parseError } from './utilities/parseError.js'\n\n/**\n * Drop the current database and run all migrate up functions\n */\nexport async function migrateFresh(\n this: DrizzleAdapter,\n { forceAcceptWarning = false },\n): Promise<void> {\n const { payload } = this\n\n if (forceAcceptWarning === false) {\n const { confirm: acceptWarning } = await prompts(\n {\n name: 'confirm',\n type: 'confirm',\n initial: false,\n message: `WARNING: This will drop your database and run all migrations. Are you sure you want to proceed?`,\n },\n {\n onCancel: () => {\n process.exit(0)\n },\n },\n )\n\n if (!acceptWarning) {\n process.exit(0)\n }\n }\n\n payload.logger.info({\n msg: `Dropping database.`,\n })\n\n await this.dropDatabase({ adapter: this })\n\n const migrationFiles = await readMigrationFiles({ payload })\n payload.logger.debug({\n msg: `Found ${migrationFiles.length} migration files.`,\n })\n\n const req = { payload } as PayloadRequest\n\n if ('createExtensions' in this && typeof this.createExtensions === 'function') {\n await this.createExtensions()\n }\n\n // Run all migrate up\n for (const migration of migrationFiles) {\n payload.logger.info({ msg: `Migrating: ${migration.name}` })\n try {\n const start = Date.now()\n await initTransaction(req)\n const adapter = payload.db as DrizzleAdapter\n const db = adapter?.sessions[await req.transactionID]?.db || adapter.drizzle\n await migration.up({ db, payload, req })\n await payload.create({\n collection: 'payload-migrations',\n data: {\n name: migration.name,\n batch: 1,\n },\n req,\n })\n await commitTransaction(req)\n\n payload.logger.info({ msg: `Migrated: ${migration.name} (${Date.now() - start}ms)` })\n } catch (err: unknown) {\n await killTransaction(req)\n payload.logger.error({\n err,\n msg: parseError(err, `Error running migration ${migration.name}. Rolling back`),\n })\n process.exit(1)\n }\n }\n}\n"],"names":["commitTransaction","initTransaction","killTransaction","readMigrationFiles","prompts","parseError","migrateFresh","forceAcceptWarning","payload","confirm","acceptWarning","name","type","initial","message","onCancel","process","exit","logger","info","msg","dropDatabase","adapter","migrationFiles","debug","length","req","createExtensions","migration","start","Date","now","db","sessions","transactionID","drizzle","up","create","collection","data","batch","err","error"],"mappings":"AAEA,SAASA,iBAAiB,EAAEC,eAAe,EAAEC,eAAe,EAAEC,kBAAkB,QAAQ,UAAS;AACjG,OAAOC,aAAa,UAAS;AAI7B,SAASC,UAAU,QAAQ,4BAA2B;AAEtD;;CAEC,GACD,OAAO,eAAeC,aAEpB,EAAEC,qBAAqB,KAAK,EAAE;IAE9B,MAAM,EAAEC,OAAO,EAAE,GAAG,IAAI;IAExB,IAAID,uBAAuB,OAAO;QAChC,MAAM,EAAEE,SAASC,aAAa,EAAE,GAAG,MAAMN,QACvC;YACEO,MAAM;YACNC,MAAM;YACNC,SAAS;YACTC,SAAS,CAAC,+FAA+F,CAAC;QAC5G,GACA;YACEC,UAAU;gBACRC,QAAQC,IAAI,CAAC;YACf;QACF;QAGF,IAAI,CAACP,eAAe;YAClBM,QAAQC,IAAI,CAAC;QACf;IACF;IAEAT,QAAQU,MAAM,CAACC,IAAI,CAAC;QAClBC,KAAK,CAAC,kBAAkB,CAAC;IAC3B;IAEA,MAAM,IAAI,CAACC,YAAY,CAAC;QAAEC,SAAS,IAAI;IAAC;IAExC,MAAMC,iBAAiB,MAAMpB,mBAAmB;QAAEK;IAAQ;IAC1DA,QAAQU,MAAM,CAACM,KAAK,CAAC;QACnBJ,KAAK,CAAC,MAAM,EAAEG,eAAeE,MAAM,CAAC,iBAAiB,CAAC;IACxD;IAEA,MAAMC,MAAM;QAAElB;IAAQ;IAEtB,IAAI,sBAAsB,IAAI,IAAI,OAAO,IAAI,CAACmB,gBAAgB,KAAK,YAAY;QAC7E,MAAM,IAAI,CAACA,gBAAgB;IAC7B;IAEA,qBAAqB;IACrB,KAAK,MAAMC,aAAaL,eAAgB;QACtCf,QAAQU,MAAM,CAACC,IAAI,CAAC;YAAEC,KAAK,CAAC,WAAW,EAAEQ,UAAUjB,IAAI,CAAC,CAAC;QAAC;QAC1D,IAAI;YACF,MAAMkB,QAAQC,KAAKC,GAAG;YACtB,MAAM9B,gBAAgByB;YACtB,MAAMJ,UAAUd,QAAQwB,EAAE;YAC1B,MAAMA,KAAKV,SAASW,QAAQ,CAAC,MAAMP,IAAIQ,aAAa,CAAC,EAAEF,MAAMV,QAAQa,OAAO;YAC5E,MAAMP,UAAUQ,EAAE,CAAC;gBAAEJ;gBAAIxB;gBAASkB;YAAI;YACtC,MAAMlB,QAAQ6B,MAAM,CAAC;gBACnBC,YAAY;gBACZC,MAAM;oBACJ5B,MAAMiB,UAAUjB,IAAI;oBACpB6B,OAAO;gBACT;gBACAd;YACF;YACA,MAAM1B,kBAAkB0B;YAExBlB,QAAQU,MAAM,CAACC,IAAI,CAAC;gBAAEC,KAAK,CAAC,WAAW,EAAEQ,UAAUjB,IAAI,CAAC,EAAE,EAAEmB,KAAKC,GAAG,KAAKF,MAAM,GAAG,CAAC;YAAC;QACtF,EAAE,OAAOY,KAAc;YACrB,MAAMvC,gBAAgBwB;YACtBlB,QAAQU,MAAM,CAACwB,KAAK,CAAC;gBACnBD;gBACArB,KAAKf,WAAWoC,KAAK,CAAC,wBAAwB,EAAEb,UAAUjB,IAAI,CAAC,cAAc,CAAC;YAChF;YACAK,QAAQC,IAAI,CAAC;QACf;IACF;AACF"}
|
|
@@ -32,7 +32,7 @@ export const createDatabase = async function(args = {}) {
|
|
|
32
32
|
const managementClient = new pg.Client(managementClientConfig);
|
|
33
33
|
try {
|
|
34
34
|
await managementClient.connect();
|
|
35
|
-
await managementClient.query(`CREATE DATABASE ${dbName}`);
|
|
35
|
+
await managementClient.query(`CREATE DATABASE "${dbName}"`);
|
|
36
36
|
this.payload.logger.info(`Created database "${dbName}"`);
|
|
37
37
|
if (schemaName !== 'public') {
|
|
38
38
|
let createdDatabaseConfig = {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/postgres/createDatabase.ts"],"sourcesContent":["import type { ClientConfig } from 'pg'\n\nimport type { BasePostgresAdapter } from './types.js'\n\nconst setConnectionStringDatabase = ({\n connectionString,\n database,\n}: {\n connectionString: string\n database: string\n}): string => {\n const connectionURL = new URL(connectionString)\n const newConnectionURL = new URL(connectionURL)\n newConnectionURL.pathname = `/${database}`\n\n return newConnectionURL.toString()\n}\n\ntype Args = {\n /**\n * Name of a database, defaults to the current one\n */\n name?: string\n /**\n * Schema to create in addition to 'public'. Defaults to adapter.schemaName if exists.\n */\n schemaName?: string\n}\nexport const createDatabase = async function (this: BasePostgresAdapter, args: Args = {}) {\n // POSTGRES_URL - default Vercel env\n const connectionString =\n this.poolOptions?.connectionString ?? process.env.POSTGRES_URL ?? process.env.DATABASE_URL\n let managementClientConfig: ClientConfig = {}\n let dbName = args.name\n const schemaName = this.schemaName || 'public'\n\n if (connectionString) {\n if (!dbName) {\n dbName = new URL(connectionString).pathname.slice(1)\n }\n\n managementClientConfig.connectionString = setConnectionStringDatabase({\n connectionString,\n database: 'postgres',\n })\n } else {\n if (!dbName) {\n dbName = this.poolOptions.database\n }\n\n managementClientConfig = {\n ...this.poolOptions,\n database: 'postgres',\n }\n }\n\n // import pg only when createDatabase is used\n const pg = await import('pg').then((mod) => mod.default)\n\n const managementClient = new pg.Client(managementClientConfig)\n\n try {\n await managementClient.connect()\n await managementClient.query(`CREATE DATABASE ${dbName}`)\n\n this.payload.logger.info(`Created database \"${dbName}\"`)\n\n if (schemaName !== 'public') {\n let createdDatabaseConfig: ClientConfig = {}\n\n if (connectionString) {\n createdDatabaseConfig.connectionString = setConnectionStringDatabase({\n connectionString,\n database: dbName,\n })\n } else {\n createdDatabaseConfig = {\n ...this.poolOptions,\n database: dbName,\n }\n }\n\n const createdDatabaseClient = new pg.Client(createdDatabaseConfig)\n\n try {\n await createdDatabaseClient.connect()\n\n await createdDatabaseClient.query(`CREATE SCHEMA ${schemaName}`)\n this.payload.logger.info(`Created schema \"${dbName}.${schemaName}\"`)\n } catch (err) {\n this.payload.logger.error({\n err,\n msg: `Error: failed to create schema \"${dbName}.${schemaName}\". Details: ${err.message}`,\n })\n } finally {\n await createdDatabaseClient.end()\n }\n }\n\n return true\n } catch (err) {\n this.payload.logger.error({\n err,\n msg: `Error: failed to create database ${dbName}. Details: ${err.message}`,\n })\n\n return false\n } finally {\n await managementClient.end()\n }\n}\n"],"names":["setConnectionStringDatabase","connectionString","database","connectionURL","URL","newConnectionURL","pathname","toString","createDatabase","args","poolOptions","process","env","POSTGRES_URL","DATABASE_URL","managementClientConfig","dbName","name","schemaName","slice","pg","then","mod","default","managementClient","Client","connect","query","payload","logger","info","createdDatabaseConfig","createdDatabaseClient","err","error","msg","message","end"],"mappings":"AAIA,MAAMA,8BAA8B,CAAC,EACnCC,gBAAgB,EAChBC,QAAQ,EAIT;IACC,MAAMC,gBAAgB,IAAIC,IAAIH;IAC9B,MAAMI,mBAAmB,IAAID,IAAID;IACjCE,iBAAiBC,QAAQ,GAAG,CAAC,CAAC,EAAEJ,SAAS,CAAC;IAE1C,OAAOG,iBAAiBE,QAAQ;AAClC;AAYA,OAAO,MAAMC,iBAAiB,eAA2CC,OAAa,CAAC,CAAC;IACtF,oCAAoC;IACpC,MAAMR,mBACJ,IAAI,CAACS,WAAW,EAAET,oBAAoBU,QAAQC,GAAG,CAACC,YAAY,IAAIF,QAAQC,GAAG,CAACE,YAAY;IAC5F,IAAIC,yBAAuC,CAAC;IAC5C,IAAIC,SAASP,KAAKQ,IAAI;IACtB,MAAMC,aAAa,IAAI,CAACA,UAAU,IAAI;IAEtC,IAAIjB,kBAAkB;QACpB,IAAI,CAACe,QAAQ;YACXA,SAAS,IAAIZ,IAAIH,kBAAkBK,QAAQ,CAACa,KAAK,CAAC;QACpD;QAEAJ,uBAAuBd,gBAAgB,GAAGD,4BAA4B;YACpEC;YACAC,UAAU;QACZ;IACF,OAAO;QACL,IAAI,CAACc,QAAQ;YACXA,SAAS,IAAI,CAACN,WAAW,CAACR,QAAQ;QACpC;QAEAa,yBAAyB;YACvB,GAAG,IAAI,CAACL,WAAW;YACnBR,UAAU;QACZ;IACF;IAEA,6CAA6C;IAC7C,MAAMkB,KAAK,MAAM,MAAM,CAAC,MAAMC,IAAI,CAAC,CAACC,MAAQA,IAAIC,OAAO;IAEvD,MAAMC,mBAAmB,IAAIJ,GAAGK,MAAM,CAACV;IAEvC,IAAI;QACF,MAAMS,iBAAiBE,OAAO;QAC9B,MAAMF,iBAAiBG,KAAK,CAAC,CAAC,
|
|
1
|
+
{"version":3,"sources":["../../src/postgres/createDatabase.ts"],"sourcesContent":["import type { ClientConfig } from 'pg'\n\nimport type { BasePostgresAdapter } from './types.js'\n\nconst setConnectionStringDatabase = ({\n connectionString,\n database,\n}: {\n connectionString: string\n database: string\n}): string => {\n const connectionURL = new URL(connectionString)\n const newConnectionURL = new URL(connectionURL)\n newConnectionURL.pathname = `/${database}`\n\n return newConnectionURL.toString()\n}\n\ntype Args = {\n /**\n * Name of a database, defaults to the current one\n */\n name?: string\n /**\n * Schema to create in addition to 'public'. Defaults to adapter.schemaName if exists.\n */\n schemaName?: string\n}\nexport const createDatabase = async function (this: BasePostgresAdapter, args: Args = {}) {\n // POSTGRES_URL - default Vercel env\n const connectionString =\n this.poolOptions?.connectionString ?? process.env.POSTGRES_URL ?? process.env.DATABASE_URL\n let managementClientConfig: ClientConfig = {}\n let dbName = args.name\n const schemaName = this.schemaName || 'public'\n\n if (connectionString) {\n if (!dbName) {\n dbName = new URL(connectionString).pathname.slice(1)\n }\n\n managementClientConfig.connectionString = setConnectionStringDatabase({\n connectionString,\n database: 'postgres',\n })\n } else {\n if (!dbName) {\n dbName = this.poolOptions.database\n }\n\n managementClientConfig = {\n ...this.poolOptions,\n database: 'postgres',\n }\n }\n\n // import pg only when createDatabase is used\n const pg = await import('pg').then((mod) => mod.default)\n\n const managementClient = new pg.Client(managementClientConfig)\n\n try {\n await managementClient.connect()\n await managementClient.query(`CREATE DATABASE \"${dbName}\"`)\n\n this.payload.logger.info(`Created database \"${dbName}\"`)\n\n if (schemaName !== 'public') {\n let createdDatabaseConfig: ClientConfig = {}\n\n if (connectionString) {\n createdDatabaseConfig.connectionString = setConnectionStringDatabase({\n connectionString,\n database: dbName,\n })\n } else {\n createdDatabaseConfig = {\n ...this.poolOptions,\n database: dbName,\n }\n }\n\n const createdDatabaseClient = new pg.Client(createdDatabaseConfig)\n\n try {\n await createdDatabaseClient.connect()\n\n await createdDatabaseClient.query(`CREATE SCHEMA ${schemaName}`)\n this.payload.logger.info(`Created schema \"${dbName}.${schemaName}\"`)\n } catch (err) {\n this.payload.logger.error({\n err,\n msg: `Error: failed to create schema \"${dbName}.${schemaName}\". Details: ${err.message}`,\n })\n } finally {\n await createdDatabaseClient.end()\n }\n }\n\n return true\n } catch (err) {\n this.payload.logger.error({\n err,\n msg: `Error: failed to create database ${dbName}. Details: ${err.message}`,\n })\n\n return false\n } finally {\n await managementClient.end()\n }\n}\n"],"names":["setConnectionStringDatabase","connectionString","database","connectionURL","URL","newConnectionURL","pathname","toString","createDatabase","args","poolOptions","process","env","POSTGRES_URL","DATABASE_URL","managementClientConfig","dbName","name","schemaName","slice","pg","then","mod","default","managementClient","Client","connect","query","payload","logger","info","createdDatabaseConfig","createdDatabaseClient","err","error","msg","message","end"],"mappings":"AAIA,MAAMA,8BAA8B,CAAC,EACnCC,gBAAgB,EAChBC,QAAQ,EAIT;IACC,MAAMC,gBAAgB,IAAIC,IAAIH;IAC9B,MAAMI,mBAAmB,IAAID,IAAID;IACjCE,iBAAiBC,QAAQ,GAAG,CAAC,CAAC,EAAEJ,SAAS,CAAC;IAE1C,OAAOG,iBAAiBE,QAAQ;AAClC;AAYA,OAAO,MAAMC,iBAAiB,eAA2CC,OAAa,CAAC,CAAC;IACtF,oCAAoC;IACpC,MAAMR,mBACJ,IAAI,CAACS,WAAW,EAAET,oBAAoBU,QAAQC,GAAG,CAACC,YAAY,IAAIF,QAAQC,GAAG,CAACE,YAAY;IAC5F,IAAIC,yBAAuC,CAAC;IAC5C,IAAIC,SAASP,KAAKQ,IAAI;IACtB,MAAMC,aAAa,IAAI,CAACA,UAAU,IAAI;IAEtC,IAAIjB,kBAAkB;QACpB,IAAI,CAACe,QAAQ;YACXA,SAAS,IAAIZ,IAAIH,kBAAkBK,QAAQ,CAACa,KAAK,CAAC;QACpD;QAEAJ,uBAAuBd,gBAAgB,GAAGD,4BAA4B;YACpEC;YACAC,UAAU;QACZ;IACF,OAAO;QACL,IAAI,CAACc,QAAQ;YACXA,SAAS,IAAI,CAACN,WAAW,CAACR,QAAQ;QACpC;QAEAa,yBAAyB;YACvB,GAAG,IAAI,CAACL,WAAW;YACnBR,UAAU;QACZ;IACF;IAEA,6CAA6C;IAC7C,MAAMkB,KAAK,MAAM,MAAM,CAAC,MAAMC,IAAI,CAAC,CAACC,MAAQA,IAAIC,OAAO;IAEvD,MAAMC,mBAAmB,IAAIJ,GAAGK,MAAM,CAACV;IAEvC,IAAI;QACF,MAAMS,iBAAiBE,OAAO;QAC9B,MAAMF,iBAAiBG,KAAK,CAAC,CAAC,iBAAiB,EAAEX,OAAO,CAAC,CAAC;QAE1D,IAAI,CAACY,OAAO,CAACC,MAAM,CAACC,IAAI,CAAC,CAAC,kBAAkB,EAAEd,OAAO,CAAC,CAAC;QAEvD,IAAIE,eAAe,UAAU;YAC3B,IAAIa,wBAAsC,CAAC;YAE3C,IAAI9B,kBAAkB;gBACpB8B,sBAAsB9B,gBAAgB,GAAGD,4BAA4B;oBACnEC;oBACAC,UAAUc;gBACZ;YACF,OAAO;gBACLe,wBAAwB;oBACtB,GAAG,IAAI,CAACrB,WAAW;oBACnBR,UAAUc;gBACZ;YACF;YAEA,MAAMgB,wBAAwB,IAAIZ,GAAGK,MAAM,CAACM;YAE5C,IAAI;gBACF,MAAMC,sBAAsBN,OAAO;gBAEnC,MAAMM,sBAAsBL,KAAK,CAAC,CAAC,cAAc,EAAET,WAAW,CAAC;gBAC/D,IAAI,CAACU,OAAO,CAACC,MAAM,CAACC,IAAI,CAAC,CAAC,gBAAgB,EAAEd,OAAO,CAAC,EAAEE,WAAW,CAAC,CAAC;YACrE,EAAE,OAAOe,KAAK;gBACZ,IAAI,CAACL,OAAO,CAACC,MAAM,CAACK,KAAK,CAAC;oBACxBD;oBACAE,KAAK,CAAC,gCAAgC,EAAEnB,OAAO,CAAC,EAAEE,WAAW,YAAY,EAAEe,IAAIG,OAAO,CAAC,CAAC;gBAC1F;YACF,SAAU;gBACR,MAAMJ,sBAAsBK,GAAG;YACjC;QACF;QAEA,OAAO;IACT,EAAE,OAAOJ,KAAK;QACZ,IAAI,CAACL,OAAO,CAACC,MAAM,CAACK,KAAK,CAAC;YACxBD;YACAE,KAAK,CAAC,iCAAiC,EAAEnB,OAAO,WAAW,EAAEiB,IAAIG,OAAO,CAAC,CAAC;QAC5E;QAEA,OAAO;IACT,SAAU;QACR,MAAMZ,iBAAiBa,GAAG;IAC5B;AACF,EAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createExtensions.d.ts","sourceRoot":"","sources":["../../src/postgres/createExtensions.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAA;AAErD,eAAO,MAAM,gBAAgB,SAAyB,mBAAmB,KAAG,OAAO,CAAC,IAAI,CAUvF,CAAA"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export const createExtensions = async function() {
|
|
2
|
+
for(const extension in this.extensions){
|
|
3
|
+
if (this.extensions[extension]) {
|
|
4
|
+
try {
|
|
5
|
+
await this.drizzle.execute(`CREATE EXTENSION IF NOT EXISTS "${extension}"`);
|
|
6
|
+
} catch (err) {
|
|
7
|
+
this.payload.logger.error({
|
|
8
|
+
err,
|
|
9
|
+
msg: `Failed to create extension ${extension}`
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
//# sourceMappingURL=createExtensions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/postgres/createExtensions.ts"],"sourcesContent":["import type { BasePostgresAdapter } from './types.js'\n\nexport const createExtensions = async function (this: BasePostgresAdapter): Promise<void> {\n for (const extension in this.extensions) {\n if (this.extensions[extension]) {\n try {\n await this.drizzle.execute(`CREATE EXTENSION IF NOT EXISTS \"${extension}\"`)\n } catch (err) {\n this.payload.logger.error({ err, msg: `Failed to create extension ${extension}` })\n }\n }\n }\n}\n"],"names":["createExtensions","extension","extensions","drizzle","execute","err","payload","logger","error","msg"],"mappings":"AAEA,OAAO,MAAMA,mBAAmB;IAC9B,IAAK,MAAMC,aAAa,IAAI,CAACC,UAAU,CAAE;QACvC,IAAI,IAAI,CAACA,UAAU,CAACD,UAAU,EAAE;YAC9B,IAAI;gBACF,MAAM,IAAI,CAACE,OAAO,CAACC,OAAO,CAAC,CAAC,gCAAgC,EAAEH,UAAU,CAAC,CAAC;YAC5E,EAAE,OAAOI,KAAK;gBACZ,IAAI,CAACC,OAAO,CAACC,MAAM,CAACC,KAAK,CAAC;oBAAEH;oBAAKI,KAAK,CAAC,2BAA2B,EAAER,UAAU,CAAC;gBAAC;YAClF;QACF;IACF;AACF,EAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"defaultSnapshot.d.ts","sourceRoot":"","sources":["../../src/postgres/defaultSnapshot.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAA;AAE1D,eAAO,MAAM,sBAAsB,EAAE,
|
|
1
|
+
{"version":3,"file":"defaultSnapshot.d.ts","sourceRoot":"","sources":["../../src/postgres/defaultSnapshot.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAA;AAE1D,eAAO,MAAM,sBAAsB,EAAE,mBAiBpC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/postgres/defaultSnapshot.ts"],"sourcesContent":["import type { DrizzleSnapshotJSON } from 'drizzle-kit/api'\n\nexport const defaultDrizzleSnapshot: DrizzleSnapshotJSON = {\n id: '00000000-0000-0000-0000-000000000000',\n _meta: {\n columns: {},\n schemas: {},\n tables: {},\n },\n dialect: 'postgresql',\n enums: {},\n prevId: '00000000-0000-0000-0000-00000000000',\n schemas: {},\n sequences: {},\n tables: {},\n version: '7',\n views: {},\n}\n"],"names":["defaultDrizzleSnapshot","id","_meta","columns","schemas","tables","dialect","enums","prevId","sequences","version","views"],"mappings":"AAEA,OAAO,MAAMA,yBAA8C;IACzDC,IAAI;IACJC,OAAO;QACLC,SAAS,CAAC;QACVC,SAAS,CAAC;QACVC,QAAQ,CAAC;IACX;IACAC,SAAS;IACTC,OAAO,CAAC;IACRC,QAAQ;
|
|
1
|
+
{"version":3,"sources":["../../src/postgres/defaultSnapshot.ts"],"sourcesContent":["import type { DrizzleSnapshotJSON } from 'drizzle-kit/api'\n\nexport const defaultDrizzleSnapshot: DrizzleSnapshotJSON = {\n id: '00000000-0000-0000-0000-000000000000',\n _meta: {\n columns: {},\n schemas: {},\n tables: {},\n },\n dialect: 'postgresql',\n enums: {},\n policies: {},\n prevId: '00000000-0000-0000-0000-00000000000',\n roles: {},\n schemas: {},\n sequences: {},\n tables: {},\n version: '7',\n views: {},\n}\n"],"names":["defaultDrizzleSnapshot","id","_meta","columns","schemas","tables","dialect","enums","policies","prevId","roles","sequences","version","views"],"mappings":"AAEA,OAAO,MAAMA,yBAA8C;IACzDC,IAAI;IACJC,OAAO;QACLC,SAAS,CAAC;QACVC,SAAS,CAAC;QACVC,QAAQ,CAAC;IACX;IACAC,SAAS;IACTC,OAAO,CAAC;IACRC,UAAU,CAAC;IACXC,QAAQ;IACRC,OAAO,CAAC;IACRN,SAAS,CAAC;IACVO,WAAW,CAAC;IACZN,QAAQ,CAAC;IACTO,SAAS;IACTC,OAAO,CAAC;AACV,EAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
type Point = [number, number];
|
|
2
|
+
export declare const geometryColumn: (name: string) => import("drizzle-orm/pg-core").PgCustomColumnBuilder<{
|
|
3
|
+
name: string;
|
|
4
|
+
dataType: "custom";
|
|
5
|
+
columnType: "PgCustomColumn";
|
|
6
|
+
data: Point;
|
|
7
|
+
driverParam: string;
|
|
8
|
+
enumValues: undefined;
|
|
9
|
+
generated: undefined;
|
|
10
|
+
}>;
|
|
11
|
+
export {};
|
|
12
|
+
//# sourceMappingURL=geometryColumn.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"geometryColumn.d.ts","sourceRoot":"","sources":["../../../src/postgres/schema/geometryColumn.ts"],"names":[],"mappings":"AAMA,KAAK,KAAK,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;AAE7B,eAAO,MAAM,cAAc,SAAU,MAAM;;;;;;;;EAWjC,CAAA"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
// Uses custom one instead of geometry() from drizzle-orm/pg-core because it's broken on pushDevSchema
|
|
2
|
+
// Why?
|
|
3
|
+
// It tries to give us a prompt "you're about to change.. from geometry(Point) to geometry(point)"
|
|
4
|
+
import { customType } from 'drizzle-orm/pg-core';
|
|
5
|
+
import { parseEWKB } from 'drizzle-orm/pg-core/columns/postgis_extension/utils';
|
|
6
|
+
export const geometryColumn = (name)=>customType({
|
|
7
|
+
dataType () {
|
|
8
|
+
return `geometry(Point)`;
|
|
9
|
+
},
|
|
10
|
+
fromDriver (value) {
|
|
11
|
+
return parseEWKB(value);
|
|
12
|
+
},
|
|
13
|
+
toDriver (value) {
|
|
14
|
+
return `SRID=4326;point(${value[0]} ${value[1]})`;
|
|
15
|
+
}
|
|
16
|
+
})(name);
|
|
17
|
+
|
|
18
|
+
//# sourceMappingURL=geometryColumn.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/postgres/schema/geometryColumn.ts"],"sourcesContent":["// Uses custom one instead of geometry() from drizzle-orm/pg-core because it's broken on pushDevSchema\n// Why?\n// It tries to give us a prompt \"you're about to change.. from geometry(Point) to geometry(point)\"\nimport { customType } from 'drizzle-orm/pg-core'\nimport { parseEWKB } from 'drizzle-orm/pg-core/columns/postgis_extension/utils'\n\ntype Point = [number, number]\n\nexport const geometryColumn = (name: string) =>\n customType<{ data: Point; driverData: string }>({\n dataType() {\n return `geometry(Point)`\n },\n fromDriver(value: string) {\n return parseEWKB(value)\n },\n toDriver(value: Point) {\n return `SRID=4326;point(${value[0]} ${value[1]})`\n },\n })(name)\n"],"names":["customType","parseEWKB","geometryColumn","name","dataType","fromDriver","value","toDriver"],"mappings":"AAAA,sGAAsG;AACtG,OAAO;AACP,kGAAkG;AAClG,SAASA,UAAU,QAAQ,sBAAqB;AAChD,SAASC,SAAS,QAAQ,sDAAqD;AAI/E,OAAO,MAAMC,iBAAiB,CAACC,OAC7BH,WAAgD;QAC9CI;YACE,OAAO,CAAC,eAAe,CAAC;QAC1B;QACAC,YAAWC,KAAa;YACtB,OAAOL,UAAUK;QACnB;QACAC,UAASD,KAAY;YACnB,OAAO,CAAC,gBAAgB,EAAEA,KAAK,CAAC,EAAE,CAAC,CAAC,EAAEA,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;QACnD;IACF,GAAGH,MAAK"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../../src/postgres/schema/traverseFields.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACxE,OAAO,KAAK,EAAE,KAAK,EAAkB,UAAU,EAAE,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../../src/postgres/schema/traverseFields.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACxE,OAAO,KAAK,EAAE,KAAK,EAAkB,UAAU,EAAE,MAAM,SAAS,CAAA;AAsBhE,OAAO,KAAK,EAEV,mBAAmB,EACnB,cAAc,EAEd,WAAW,EACZ,MAAM,aAAa,CAAA;AAapB,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,mBAAmB,CAAA;IAC5B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IACxC,cAAc,EAAE,OAAO,CAAA;IACvB,sBAAsB,CAAC,EAAE,OAAO,CAAA;IAChC,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IAC/D,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC/C,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IACtE,YAAY,EAAE,MAAM,CAAA;IACpB,eAAe,EAAE,MAAM,CAAA;IACvB,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1B,gBAAgB,EAAE,WAAW,CAAA;IAC7B,oBAAoB,CAAC,EAAE,WAAW,CAAA;IAClC,kBAAkB,EAAE,MAAM,CAAA;IAC1B,aAAa,EAAE,MAAM,CAAA;IACrB,mBAAmB,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAChC,QAAQ,EAAE,OAAO,CAAA;IACjB;;;OAGG;IACH,2BAA2B,CAAC,EAAE,OAAO,CAAA;CACtC,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,iBAAiB,EAAE,OAAO,CAAA;IAC1B,2BAA2B,EAAE,OAAO,CAAA;IACpC,yBAAyB,EAAE,OAAO,CAAA;IAClC,6BAA6B,EAAE,OAAO,CAAA;IACtC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;CACpC,CAAA;AAED,eAAO,MAAM,cAAc,kWAuBxB,IAAI,KAAG,MA21BT,CAAA"}
|
|
@@ -9,6 +9,7 @@ import { hasLocalesTable } from '../../utilities/hasLocalesTable.js';
|
|
|
9
9
|
import { validateExistingBlockIsIdentical } from '../../utilities/validateExistingBlockIsIdentical.js';
|
|
10
10
|
import { buildTable } from './build.js';
|
|
11
11
|
import { createIndex } from './createIndex.js';
|
|
12
|
+
import { geometryColumn } from './geometryColumn.js';
|
|
12
13
|
import { idToUUID } from './idToUUID.js';
|
|
13
14
|
import { parentIDColumnMap } from './parentIDColumnMap.js';
|
|
14
15
|
import { withDefault } from './withDefault.js';
|
|
@@ -57,8 +58,7 @@ export const traverseFields = ({ adapter, columnPrefix, columns, disableNotNull,
|
|
|
57
58
|
].includes(field.type)) && ![
|
|
58
59
|
'array',
|
|
59
60
|
'blocks',
|
|
60
|
-
'group'
|
|
61
|
-
'point'
|
|
61
|
+
'group'
|
|
62
62
|
].includes(field.type) && !('hasMany' in field && field.hasMany === true) && !('relationTo' in field && Array.isArray(field.relationTo))) {
|
|
63
63
|
const unique = disableUnique !== true && field.unique;
|
|
64
64
|
if (unique) {
|
|
@@ -147,6 +147,10 @@ export const traverseFields = ({ adapter, columnPrefix, columns, disableNotNull,
|
|
|
147
147
|
}
|
|
148
148
|
case 'point':
|
|
149
149
|
{
|
|
150
|
+
targetTable[fieldName] = withDefault(geometryColumn(columnName), field);
|
|
151
|
+
if (!adapter.extensions.postgis) {
|
|
152
|
+
adapter.extensions.postgis = true;
|
|
153
|
+
}
|
|
150
154
|
break;
|
|
151
155
|
}
|
|
152
156
|
case 'radio':
|