@payloadcms/drizzle 3.81.0-internal-debug.1a0f4d0 → 3.81.0-internal.181753b
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/find/buildFindManyArgs.d.ts +28 -3
- package/dist/find/buildFindManyArgs.d.ts.map +1 -1
- package/dist/find/buildFindManyArgs.js +4 -1
- package/dist/find/buildFindManyArgs.js.map +1 -1
- package/dist/find/findMany.d.ts.map +1 -1
- package/dist/find/findMany.js +61 -1
- package/dist/find/findMany.js.map +1 -1
- package/dist/find/traverseFields.d.ts.map +1 -1
- package/dist/find/traverseFields.js +53 -27
- package/dist/find/traverseFields.js.map +1 -1
- package/dist/queries/getTableColumnFromPath.js +1 -1
- package/dist/queries/getTableColumnFromPath.js.map +1 -1
- package/package.json +3 -3
|
@@ -1,6 +1,23 @@
|
|
|
1
|
-
import type { DBQueryConfig } from 'drizzle-orm';
|
|
2
|
-
import type { FlattenedField, JoinQuery, SelectType } from 'payload';
|
|
1
|
+
import type { DBQueryConfig, SQL } from 'drizzle-orm';
|
|
2
|
+
import type { FlattenedField, JoinQuery, SelectType, Where } from 'payload';
|
|
3
3
|
import type { BuildQueryJoinAliases, DrizzleAdapter } from '../types.js';
|
|
4
|
+
/**
|
|
5
|
+
* Metadata captured by traverseFields for each polymorphic join field when
|
|
6
|
+
* batch loading is enabled. findMany.ts uses this to execute a single batch
|
|
7
|
+
* query per join field after the main parent query, avoiding N+1 correlated
|
|
8
|
+
* subqueries.
|
|
9
|
+
*/
|
|
10
|
+
export type PolymorphicJoinInfo = {
|
|
11
|
+
columnName: string;
|
|
12
|
+
countColumnName?: string;
|
|
13
|
+
currentQuery: any;
|
|
14
|
+
limit: number;
|
|
15
|
+
onPath: string;
|
|
16
|
+
page?: number;
|
|
17
|
+
sortDir: 'ASC' | 'DESC';
|
|
18
|
+
sqlWhere?: SQL;
|
|
19
|
+
where?: Where;
|
|
20
|
+
};
|
|
4
21
|
type BuildFindQueryArgs = {
|
|
5
22
|
adapter: DrizzleAdapter;
|
|
6
23
|
collectionSlug?: string;
|
|
@@ -15,13 +32,21 @@ type BuildFindQueryArgs = {
|
|
|
15
32
|
locale?: string;
|
|
16
33
|
select?: SelectType;
|
|
17
34
|
tableName: string;
|
|
35
|
+
/**
|
|
36
|
+
* When true, polymorphic join fields are deferred for batch loading by findMany.ts
|
|
37
|
+
* instead of using per-row correlated subqueries. Only valid for PostgreSQL.
|
|
38
|
+
* Populated into _polymorphicJoins on the returned Result.
|
|
39
|
+
*/
|
|
40
|
+
useBatchPolymorphicJoins?: boolean;
|
|
18
41
|
versions?: boolean;
|
|
19
42
|
};
|
|
20
43
|
export type Result = {
|
|
44
|
+
/** Populated only when useBatchPolymorphicJoins=true; processed by findMany.ts */
|
|
45
|
+
_polymorphicJoins?: PolymorphicJoinInfo[];
|
|
21
46
|
with?: {
|
|
22
47
|
_locales?: DBQueryConfig<'many', true, any, any>;
|
|
23
48
|
} & DBQueryConfig<'many', true, any, any>;
|
|
24
49
|
} & DBQueryConfig<'many', true, any, any>;
|
|
25
|
-
export declare const buildFindManyArgs: ({ adapter, collectionSlug, depth, draftsEnabled, fields, joinQuery, joins, locale, select, tableName, versions, }: BuildFindQueryArgs) => Result;
|
|
50
|
+
export declare const buildFindManyArgs: ({ adapter, collectionSlug, depth, draftsEnabled, fields, joinQuery, joins, locale, select, tableName, useBatchPolymorphicJoins, versions, }: BuildFindQueryArgs) => Result;
|
|
26
51
|
export {};
|
|
27
52
|
//# sourceMappingURL=buildFindManyArgs.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"buildFindManyArgs.d.ts","sourceRoot":"","sources":["../../src/find/buildFindManyArgs.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;
|
|
1
|
+
{"version":3,"file":"buildFindManyArgs.d.ts","sourceRoot":"","sources":["../../src/find/buildFindManyArgs.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AACrD,OAAO,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,SAAS,CAAA;AAI3E,OAAO,KAAK,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,aAAa,CAAA;AAIxE;;;;;GAKG;AACH,MAAM,MAAM,mBAAmB,GAAG;IAChC,UAAU,EAAE,MAAM,CAAA;IAClB,eAAe,CAAC,EAAE,MAAM,CAAA;IAExB,YAAY,EAAE,GAAG,CAAA;IACjB,KAAK,EAAE,MAAM,CAAA;IACb,MAAM,EAAE,MAAM,CAAA;IACd,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,OAAO,EAAE,KAAK,GAAG,MAAM,CAAA;IAEvB,QAAQ,CAAC,EAAE,GAAG,CAAA;IACd,KAAK,CAAC,EAAE,KAAK,CAAA;CACd,CAAA;AAED,KAAK,kBAAkB,GAAG;IACxB,OAAO,EAAE,cAAc,CAAA;IACvB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,KAAK,EAAE,MAAM,CAAA;IACb,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,MAAM,EAAE,cAAc,EAAE,CAAA;IACxB,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB;;OAEG;IACH,KAAK,CAAC,EAAE,qBAAqB,CAAA;IAC7B,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,MAAM,CAAC,EAAE,UAAU,CAAA;IACnB,SAAS,EAAE,MAAM,CAAA;IACjB;;;;OAIG;IACH,wBAAwB,CAAC,EAAE,OAAO,CAAA;IAClC,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,MAAM,MAAM,MAAM,GAAG;IACnB,kFAAkF;IAClF,iBAAiB,CAAC,EAAE,mBAAmB,EAAE,CAAA;IACzC,IAAI,CAAC,EAAE;QACL,QAAQ,CAAC,EAAE,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,CAAA;KACjD,GAAG,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,CAAA;CAC1C,GAAG,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,CAAA;AAIzC,eAAO,MAAM,iBAAiB,gJAa3B,kBAAkB,KAAG,MAsGvB,CAAA"}
|
|
@@ -2,11 +2,14 @@ import { getSelectMode } from 'payload/shared';
|
|
|
2
2
|
import { traverseFields } from './traverseFields.js';
|
|
3
3
|
// Generate the Drizzle query for findMany based on
|
|
4
4
|
// a collection field structure
|
|
5
|
-
export const buildFindManyArgs = ({ adapter, collectionSlug, depth, draftsEnabled, fields, joinQuery, joins = [], locale, select, tableName, versions })=>{
|
|
5
|
+
export const buildFindManyArgs = ({ adapter, collectionSlug, depth, draftsEnabled, fields, joinQuery, joins = [], locale, select, tableName, useBatchPolymorphicJoins, versions })=>{
|
|
6
6
|
const result = {
|
|
7
7
|
extras: {},
|
|
8
8
|
with: {}
|
|
9
9
|
};
|
|
10
|
+
if (useBatchPolymorphicJoins && adapter.name === 'postgres') {
|
|
11
|
+
result._polymorphicJoins = [];
|
|
12
|
+
}
|
|
10
13
|
if (select) {
|
|
11
14
|
result.columns = {
|
|
12
15
|
id: true
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/find/buildFindManyArgs.ts"],"sourcesContent":["import type { DBQueryConfig } from 'drizzle-orm'\nimport type { FlattenedField, JoinQuery, SelectType } from 'payload'\n\nimport { getSelectMode } from 'payload/shared'\n\nimport type { BuildQueryJoinAliases, DrizzleAdapter } from '../types.js'\n\nimport { traverseFields } from './traverseFields.js'\n\ntype BuildFindQueryArgs = {\n adapter: DrizzleAdapter\n collectionSlug?: string\n depth: number\n draftsEnabled?: boolean\n fields: FlattenedField[]\n joinQuery?: JoinQuery\n /**\n * The joins array will be mutated by pushing any joins needed for the where queries of join field joins\n */\n joins?: BuildQueryJoinAliases\n locale?: string\n select?: SelectType\n tableName: string\n versions?: boolean\n}\n\nexport type Result = {\n with?: {\n _locales?: DBQueryConfig<'many', true, any, any>\n } & DBQueryConfig<'many', true, any, any>\n} & DBQueryConfig<'many', true, any, any>\n\n// Generate the Drizzle query for findMany based on\n// a collection field structure\nexport const buildFindManyArgs = ({\n adapter,\n collectionSlug,\n depth,\n draftsEnabled,\n fields,\n joinQuery,\n joins = [],\n locale,\n select,\n tableName,\n versions,\n}: BuildFindQueryArgs): Result => {\n const result: Result = {\n extras: {},\n with: {},\n }\n\n if (select) {\n result.columns = {\n id: true,\n }\n }\n\n const _locales: Result = {\n columns: select\n ? { _locale: true }\n : {\n id: false,\n _parentID: false,\n },\n extras: {},\n with: {},\n }\n\n const withTabledFields = select\n ? {}\n : {\n numbers: true,\n rels: true,\n texts: true,\n }\n\n traverseFields({\n _locales,\n adapter,\n collectionSlug,\n currentArgs: result,\n currentTableName: tableName,\n depth,\n draftsEnabled,\n fields,\n joinQuery,\n joins,\n locale,\n path: '',\n select,\n selectMode: select ? getSelectMode(select) : undefined,\n tablePath: '',\n topLevelArgs: result,\n topLevelTableName: tableName,\n versions,\n withTabledFields,\n })\n\n if (adapter.tables[`${tableName}_texts`] && withTabledFields.texts) {\n result.with._texts = {\n columns: {\n id: false,\n parent: false,\n },\n orderBy: ({ order }, { asc: ASC }) => [ASC(order)],\n }\n }\n\n if (adapter.tables[`${tableName}_numbers`] && withTabledFields.numbers) {\n result.with._numbers = {\n columns: {\n id: false,\n parent: false,\n },\n orderBy: ({ order }, { asc: ASC }) => [ASC(order)],\n }\n }\n\n if (adapter.tables[`${tableName}${adapter.relationshipsSuffix}`] && withTabledFields.rels) {\n result.with._rels = {\n columns: {\n id: false,\n parent: false,\n },\n orderBy: ({ order }, { asc: ASC }) => [ASC(order)],\n }\n }\n\n if (\n adapter.tables[`${tableName}${adapter.localesSuffix}`] &&\n (!select || Object.keys(_locales.columns).length > 1)\n ) {\n result.with._locales = _locales\n }\n\n // Delete properties that are empty\n for (const key of Object.keys(result)) {\n if (!Object.keys(result[key]).length) {\n delete result[key]\n }\n }\n\n return result\n}\n"],"names":["getSelectMode","traverseFields","buildFindManyArgs","adapter","collectionSlug","depth","draftsEnabled","fields","joinQuery","joins","locale","select","tableName","versions","result","extras","with","columns","id","_locales","_locale","_parentID","withTabledFields","numbers","rels","texts","currentArgs","currentTableName","path","selectMode","undefined","tablePath","topLevelArgs","topLevelTableName","tables","_texts","parent","orderBy","order","asc","ASC","_numbers","relationshipsSuffix","_rels","localesSuffix","Object","keys","length","key"],"mappings":"AAGA,SAASA,aAAa,QAAQ,iBAAgB;AAI9C,SAASC,cAAc,QAAQ,sBAAqB;
|
|
1
|
+
{"version":3,"sources":["../../src/find/buildFindManyArgs.ts"],"sourcesContent":["import type { DBQueryConfig, SQL } from 'drizzle-orm'\nimport type { FlattenedField, JoinQuery, SelectType, Where } from 'payload'\n\nimport { getSelectMode } from 'payload/shared'\n\nimport type { BuildQueryJoinAliases, DrizzleAdapter } from '../types.js'\n\nimport { traverseFields } from './traverseFields.js'\n\n/**\n * Metadata captured by traverseFields for each polymorphic join field when\n * batch loading is enabled. findMany.ts uses this to execute a single batch\n * query per join field after the main parent query, avoiding N+1 correlated\n * subqueries.\n */\nexport type PolymorphicJoinInfo = {\n columnName: string\n countColumnName?: string\n // The unsorted UNION SQLSelect built from all child collection tables\n currentQuery: any\n limit: number\n onPath: string\n page?: number\n sortDir: 'ASC' | 'DESC'\n // Pre-built SQL condition for the join's where clause (alias: ${columnName}_pre)\n sqlWhere?: SQL\n where?: Where\n}\n\ntype BuildFindQueryArgs = {\n adapter: DrizzleAdapter\n collectionSlug?: string\n depth: number\n draftsEnabled?: boolean\n fields: FlattenedField[]\n joinQuery?: JoinQuery\n /**\n * The joins array will be mutated by pushing any joins needed for the where queries of join field joins\n */\n joins?: BuildQueryJoinAliases\n locale?: string\n select?: SelectType\n tableName: string\n /**\n * When true, polymorphic join fields are deferred for batch loading by findMany.ts\n * instead of using per-row correlated subqueries. Only valid for PostgreSQL.\n * Populated into _polymorphicJoins on the returned Result.\n */\n useBatchPolymorphicJoins?: boolean\n versions?: boolean\n}\n\nexport type Result = {\n /** Populated only when useBatchPolymorphicJoins=true; processed by findMany.ts */\n _polymorphicJoins?: PolymorphicJoinInfo[]\n with?: {\n _locales?: DBQueryConfig<'many', true, any, any>\n } & DBQueryConfig<'many', true, any, any>\n} & DBQueryConfig<'many', true, any, any>\n\n// Generate the Drizzle query for findMany based on\n// a collection field structure\nexport const buildFindManyArgs = ({\n adapter,\n collectionSlug,\n depth,\n draftsEnabled,\n fields,\n joinQuery,\n joins = [],\n locale,\n select,\n tableName,\n useBatchPolymorphicJoins,\n versions,\n}: BuildFindQueryArgs): Result => {\n const result: Result = {\n extras: {},\n with: {},\n }\n\n if (useBatchPolymorphicJoins && adapter.name === 'postgres') {\n result._polymorphicJoins = []\n }\n\n if (select) {\n result.columns = {\n id: true,\n }\n }\n\n const _locales: Result = {\n columns: select\n ? { _locale: true }\n : {\n id: false,\n _parentID: false,\n },\n extras: {},\n with: {},\n }\n\n const withTabledFields = select\n ? {}\n : {\n numbers: true,\n rels: true,\n texts: true,\n }\n\n traverseFields({\n _locales,\n adapter,\n collectionSlug,\n currentArgs: result,\n currentTableName: tableName,\n depth,\n draftsEnabled,\n fields,\n joinQuery,\n joins,\n locale,\n path: '',\n select,\n selectMode: select ? getSelectMode(select) : undefined,\n tablePath: '',\n topLevelArgs: result,\n topLevelTableName: tableName,\n versions,\n withTabledFields,\n })\n\n if (adapter.tables[`${tableName}_texts`] && withTabledFields.texts) {\n result.with._texts = {\n columns: {\n id: false,\n parent: false,\n },\n orderBy: ({ order }, { asc: ASC }) => [ASC(order)],\n }\n }\n\n if (adapter.tables[`${tableName}_numbers`] && withTabledFields.numbers) {\n result.with._numbers = {\n columns: {\n id: false,\n parent: false,\n },\n orderBy: ({ order }, { asc: ASC }) => [ASC(order)],\n }\n }\n\n if (adapter.tables[`${tableName}${adapter.relationshipsSuffix}`] && withTabledFields.rels) {\n result.with._rels = {\n columns: {\n id: false,\n parent: false,\n },\n orderBy: ({ order }, { asc: ASC }) => [ASC(order)],\n }\n }\n\n if (\n adapter.tables[`${tableName}${adapter.localesSuffix}`] &&\n (!select || Object.keys(_locales.columns).length > 1)\n ) {\n result.with._locales = _locales\n }\n\n // Delete properties that are empty\n for (const key of Object.keys(result)) {\n if (!Object.keys(result[key]).length) {\n delete result[key]\n }\n }\n\n return result\n}\n"],"names":["getSelectMode","traverseFields","buildFindManyArgs","adapter","collectionSlug","depth","draftsEnabled","fields","joinQuery","joins","locale","select","tableName","useBatchPolymorphicJoins","versions","result","extras","with","name","_polymorphicJoins","columns","id","_locales","_locale","_parentID","withTabledFields","numbers","rels","texts","currentArgs","currentTableName","path","selectMode","undefined","tablePath","topLevelArgs","topLevelTableName","tables","_texts","parent","orderBy","order","asc","ASC","_numbers","relationshipsSuffix","_rels","localesSuffix","Object","keys","length","key"],"mappings":"AAGA,SAASA,aAAa,QAAQ,iBAAgB;AAI9C,SAASC,cAAc,QAAQ,sBAAqB;AAqDpD,mDAAmD;AACnD,+BAA+B;AAC/B,OAAO,MAAMC,oBAAoB,CAAC,EAChCC,OAAO,EACPC,cAAc,EACdC,KAAK,EACLC,aAAa,EACbC,MAAM,EACNC,SAAS,EACTC,QAAQ,EAAE,EACVC,MAAM,EACNC,MAAM,EACNC,SAAS,EACTC,wBAAwB,EACxBC,QAAQ,EACW;IACnB,MAAMC,SAAiB;QACrBC,QAAQ,CAAC;QACTC,MAAM,CAAC;IACT;IAEA,IAAIJ,4BAA4BV,QAAQe,IAAI,KAAK,YAAY;QAC3DH,OAAOI,iBAAiB,GAAG,EAAE;IAC/B;IAEA,IAAIR,QAAQ;QACVI,OAAOK,OAAO,GAAG;YACfC,IAAI;QACN;IACF;IAEA,MAAMC,WAAmB;QACvBF,SAAST,SACL;YAAEY,SAAS;QAAK,IAChB;YACEF,IAAI;YACJG,WAAW;QACb;QACJR,QAAQ,CAAC;QACTC,MAAM,CAAC;IACT;IAEA,MAAMQ,mBAAmBd,SACrB,CAAC,IACD;QACEe,SAAS;QACTC,MAAM;QACNC,OAAO;IACT;IAEJ3B,eAAe;QACbqB;QACAnB;QACAC;QACAyB,aAAad;QACbe,kBAAkBlB;QAClBP;QACAC;QACAC;QACAC;QACAC;QACAC;QACAqB,MAAM;QACNpB;QACAqB,YAAYrB,SAASX,cAAcW,UAAUsB;QAC7CC,WAAW;QACXC,cAAcpB;QACdqB,mBAAmBxB;QACnBE;QACAW;IACF;IAEA,IAAItB,QAAQkC,MAAM,CAAC,GAAGzB,UAAU,MAAM,CAAC,CAAC,IAAIa,iBAAiBG,KAAK,EAAE;QAClEb,OAAOE,IAAI,CAACqB,MAAM,GAAG;YACnBlB,SAAS;gBACPC,IAAI;gBACJkB,QAAQ;YACV;YACAC,SAAS,CAAC,EAAEC,KAAK,EAAE,EAAE,EAAEC,KAAKC,GAAG,EAAE,GAAK;oBAACA,IAAIF;iBAAO;QACpD;IACF;IAEA,IAAItC,QAAQkC,MAAM,CAAC,GAAGzB,UAAU,QAAQ,CAAC,CAAC,IAAIa,iBAAiBC,OAAO,EAAE;QACtEX,OAAOE,IAAI,CAAC2B,QAAQ,GAAG;YACrBxB,SAAS;gBACPC,IAAI;gBACJkB,QAAQ;YACV;YACAC,SAAS,CAAC,EAAEC,KAAK,EAAE,EAAE,EAAEC,KAAKC,GAAG,EAAE,GAAK;oBAACA,IAAIF;iBAAO;QACpD;IACF;IAEA,IAAItC,QAAQkC,MAAM,CAAC,GAAGzB,YAAYT,QAAQ0C,mBAAmB,EAAE,CAAC,IAAIpB,iBAAiBE,IAAI,EAAE;QACzFZ,OAAOE,IAAI,CAAC6B,KAAK,GAAG;YAClB1B,SAAS;gBACPC,IAAI;gBACJkB,QAAQ;YACV;YACAC,SAAS,CAAC,EAAEC,KAAK,EAAE,EAAE,EAAEC,KAAKC,GAAG,EAAE,GAAK;oBAACA,IAAIF;iBAAO;QACpD;IACF;IAEA,IACEtC,QAAQkC,MAAM,CAAC,GAAGzB,YAAYT,QAAQ4C,aAAa,EAAE,CAAC,IACrD,CAAA,CAACpC,UAAUqC,OAAOC,IAAI,CAAC3B,SAASF,OAAO,EAAE8B,MAAM,GAAG,CAAA,GACnD;QACAnC,OAAOE,IAAI,CAACK,QAAQ,GAAGA;IACzB;IAEA,mCAAmC;IACnC,KAAK,MAAM6B,OAAOH,OAAOC,IAAI,CAAClC,QAAS;QACrC,IAAI,CAACiC,OAAOC,IAAI,CAAClC,MAAM,CAACoC,IAAI,EAAED,MAAM,EAAE;YACpC,OAAOnC,MAAM,CAACoC,IAAI;QACpB;IACF;IAEA,OAAOpC;AACT,EAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"findMany.d.ts","sourceRoot":"","sources":["../../src/find/findMany.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAc,MAAM,SAAS,CAAA;AAInE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,aAAa,CAAA;
|
|
1
|
+
{"version":3,"file":"findMany.d.ts","sourceRoot":"","sources":["../../src/find/findMany.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAc,MAAM,SAAS,CAAA;AAInE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,aAAa,CAAA;AAUjD,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,cAAc,CAAA;IACvB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,MAAM,EAAE,cAAc,EAAE,CAAA;IACxB,SAAS,EAAE,MAAM,CAAA;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,GAAG,IAAI,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;AAEhC,eAAO,MAAM,QAAQ,8KAgBlB,IAAI;;;;;;;;;;;EA6QN,CAAA"}
|
package/dist/find/findMany.js
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { asc, desc, inArray, max, min } from 'drizzle-orm';
|
|
1
|
+
import { asc, desc, inArray, max, min, sql } from 'drizzle-orm';
|
|
2
2
|
import { buildQuery } from '../queries/buildQuery.js';
|
|
3
3
|
import { selectDistinct } from '../queries/selectDistinct.js';
|
|
4
4
|
import { transform } from '../transform/read/index.js';
|
|
5
5
|
import { getNameFromDrizzleTable } from '../utilities/getNameFromDrizzleTable.js';
|
|
6
6
|
import { getTransaction } from '../utilities/getTransaction.js';
|
|
7
|
+
import { jsonAggBuildObject } from '../utilities/json.js';
|
|
7
8
|
import { buildFindManyArgs } from './buildFindManyArgs.js';
|
|
8
9
|
export const findMany = async function find({ adapter, collectionSlug, draftsEnabled, fields, joins: joinQuery, limit: limitArg, locale, page = 1, pagination, req, select, sort, tableName, versions, where: whereArg }) {
|
|
9
10
|
let limit = limitArg;
|
|
@@ -38,6 +39,7 @@ export const findMany = async function find({ adapter, collectionSlug, draftsEna
|
|
|
38
39
|
locale,
|
|
39
40
|
select,
|
|
40
41
|
tableName,
|
|
42
|
+
useBatchPolymorphicJoins: true,
|
|
41
43
|
versions
|
|
42
44
|
});
|
|
43
45
|
if (orderBy) {
|
|
@@ -139,6 +141,64 @@ export const findMany = async function find({ adapter, collectionSlug, draftsEna
|
|
|
139
141
|
if (Object.keys(orderedIDMap).length > 0) {
|
|
140
142
|
rawDocs.sort((a, b)=>orderedIDMap[a.id] - orderedIDMap[b.id]);
|
|
141
143
|
}
|
|
144
|
+
// Batch-load polymorphic join fields: execute one query per join field for all
|
|
145
|
+
// fetched parents, replacing the N+1 correlated subquery pattern with 2 queries total.
|
|
146
|
+
if (findManyArgs._polymorphicJoins?.length && rawDocs.length > 0) {
|
|
147
|
+
const parentIds = rawDocs.map((doc)=>doc.id).filter(Boolean);
|
|
148
|
+
for (const join of findManyArgs._polymorphicJoins){
|
|
149
|
+
const { columnName, countColumnName, currentQuery, limit, onPath, page, sortDir, sqlWhere } = join;
|
|
150
|
+
const rankedAlias = `${columnName}_ranked`;
|
|
151
|
+
const preAlias = `${columnName}_pre`;
|
|
152
|
+
// Compute ROW_NUMBER range from page/limit
|
|
153
|
+
const rnOffset = page && limit !== 0 ? (page - 1) * limit : 0;
|
|
154
|
+
const rnStart = rnOffset + 1;
|
|
155
|
+
const rnEndSQL = limit !== 0 ? sql` AND "_rn" <= ${rnOffset + limit}` : sql``;
|
|
156
|
+
// Use IN (...) rather than = ANY(ARRAY[...]) so PostgreSQL can coerce bind
|
|
157
|
+
// parameter types to match the column type without an explicit cast.
|
|
158
|
+
const parentIdsSql = sql.join(parentIds.map((id)=>sql`${id}`), sql`, `);
|
|
159
|
+
// Apply the join's where filter alongside the parent-ID filter.
|
|
160
|
+
const rankSourceSQL = sql`(
|
|
161
|
+
SELECT * FROM ${sql`${currentQuery.as(preAlias)}`}
|
|
162
|
+
WHERE ${sql.raw(`"${onPath}"`)} IN (${parentIdsSql})${sqlWhere ? sql` AND ${sqlWhere}` : sql``}
|
|
163
|
+
) AS ${sql.raw(`"${preAlias}_src"`)}`;
|
|
164
|
+
// Single query: rank all children for all fetched parents, aggregate per parent.
|
|
165
|
+
// COUNT(*) OVER is placed in the inner (ranking) query so it reflects the total
|
|
166
|
+
// number of matching children per parent — not just the current page's rows.
|
|
167
|
+
const batchResult = await db.execute(sql`
|
|
168
|
+
SELECT
|
|
169
|
+
${sql.raw(`"${rankedAlias}"."${onPath}"`)} AS "_parent_id",
|
|
170
|
+
${jsonAggBuildObject(adapter, {
|
|
171
|
+
id: sql.raw(`"${rankedAlias}"."id"`),
|
|
172
|
+
relationTo: sql.raw(`"${rankedAlias}"."relationTo"`)
|
|
173
|
+
})} AS "_result"
|
|
174
|
+
${countColumnName ? sql`, MAX(${sql.raw(`"${rankedAlias}"."_total_count"`)}) AS "_total_count"` : sql``}
|
|
175
|
+
FROM (
|
|
176
|
+
SELECT *,
|
|
177
|
+
ROW_NUMBER() OVER (
|
|
178
|
+
PARTITION BY ${sql.raw(`"${onPath}"`)}
|
|
179
|
+
ORDER BY "sortPath" ${sql.raw(sortDir)}
|
|
180
|
+
) AS "_rn"
|
|
181
|
+
${countColumnName ? sql`, COUNT(*) OVER (PARTITION BY ${sql.raw(`"${onPath}"`)}) AS "_total_count"` : sql``}
|
|
182
|
+
FROM ${rankSourceSQL}
|
|
183
|
+
) AS ${sql.raw(`"${rankedAlias}"`)}
|
|
184
|
+
WHERE "_rn" >= ${rnStart}${rnEndSQL}
|
|
185
|
+
GROUP BY ${sql.raw(`"${rankedAlias}"."${onPath}"`)}
|
|
186
|
+
`);
|
|
187
|
+
const rows = batchResult.rows ?? batchResult;
|
|
188
|
+
const childMap = new Map(rows.map((r)=>[
|
|
189
|
+
String(r._parent_id),
|
|
190
|
+
r
|
|
191
|
+
]));
|
|
192
|
+
for (const doc of rawDocs){
|
|
193
|
+
const row = childMap.get(String(doc.id));
|
|
194
|
+
doc[columnName] = row?._result ?? null;
|
|
195
|
+
if (countColumnName) {
|
|
196
|
+
;
|
|
197
|
+
doc[countColumnName] = row?._total_count ?? 0;
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
}
|
|
142
202
|
if (pagination === false || !totalDocs) {
|
|
143
203
|
totalDocs = rawDocs.length;
|
|
144
204
|
totalPages = 1;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/find/findMany.ts"],"sourcesContent":["import type { FindArgs, FlattenedField, TypeWithID } from 'payload'\n\nimport { asc, desc, inArray, max, min } from 'drizzle-orm'\n\nimport type { DrizzleAdapter } from '../types.js'\n\nimport { buildQuery } from '../queries/buildQuery.js'\nimport { selectDistinct } from '../queries/selectDistinct.js'\nimport { transform } from '../transform/read/index.js'\nimport { getNameFromDrizzleTable } from '../utilities/getNameFromDrizzleTable.js'\nimport { getTransaction } from '../utilities/getTransaction.js'\nimport { buildFindManyArgs } from './buildFindManyArgs.js'\n\ntype Args = {\n adapter: DrizzleAdapter\n collectionSlug?: string\n fields: FlattenedField[]\n tableName: string\n versions?: boolean\n} & Omit<FindArgs, 'collection'>\n\nexport const findMany = async function find({\n adapter,\n collectionSlug,\n draftsEnabled,\n fields,\n joins: joinQuery,\n limit: limitArg,\n locale,\n page = 1,\n pagination,\n req,\n select,\n sort,\n tableName,\n versions,\n where: whereArg,\n}: Args) {\n let limit = limitArg\n let totalDocs: number\n let totalPages: number\n let hasPrevPage: boolean\n let hasNextPage: boolean\n let pagingCounter: number\n const offset = (page - 1) * limit\n\n if (limit === 0) {\n pagination = false\n limit = undefined\n }\n\n const { joins, orderBy, selectFields, where } = buildQuery({\n adapter,\n fields,\n locale,\n sort,\n tableName,\n where: whereArg,\n })\n\n const orderedIDMap: Record<number | string, number> = {}\n let orderedIDs: (number | string)[]\n\n const findManyArgs = buildFindManyArgs({\n adapter,\n collectionSlug,\n depth: 0,\n draftsEnabled,\n fields,\n joinQuery,\n joins,\n locale,\n select,\n tableName,\n versions,\n })\n\n if (orderBy) {\n for (const key in selectFields) {\n const column = selectFields[key]\n if (!column || column.primary) {\n continue\n }\n\n if (\n !orderBy.some(\n (col) =>\n col.column.name === column.name &&\n getNameFromDrizzleTable(col.column.table) === getNameFromDrizzleTable(column.table),\n )\n ) {\n delete selectFields[key]\n }\n }\n }\n\n const db = await getTransaction(adapter, req)\n\n const oneToManyJoinedTableNames = new Set(\n joins.filter((j) => j.isOneToMany).map((j) => getNameFromDrizzleTable(j.table)),\n )\n\n const hasSortOnOneToMany =\n oneToManyJoinedTableNames.size > 0 &&\n orderBy?.some(({ column }) =>\n oneToManyJoinedTableNames.has(getNameFromDrizzleTable(column.table)),\n )\n\n let selectDistinctResult: { id: number | string }[] | undefined\n\n // avoid duplicate results by using a group query instead of select distinct when there is a sort on a one-to-many joined table\n if (hasSortOnOneToMany) {\n const mainTable = adapter.tables[tableName]\n let groupQuery = (db as any).select({ id: mainTable.id }).from(mainTable).$dynamic()\n\n if (where) {\n groupQuery = groupQuery.where(where)\n }\n\n joins.forEach(({ type, condition, table }) => {\n groupQuery = groupQuery[type ?? 'leftJoin'](table, condition)\n })\n\n groupQuery = groupQuery.groupBy(mainTable.id)\n\n groupQuery = groupQuery.orderBy(() =>\n orderBy.map(({ column, order }) => {\n if (oneToManyJoinedTableNames.has(getNameFromDrizzleTable(column.table))) {\n return order === asc ? asc(min(column)) : desc(max(column))\n }\n return order(column)\n }),\n )\n\n selectDistinctResult = await groupQuery.offset(offset).limit(limit)\n } else {\n selectDistinctResult = await selectDistinct({\n adapter,\n db,\n joins,\n query: ({ query }) => {\n if (orderBy) {\n query = query.orderBy(() => orderBy.map(({ column, order }) => order(column)))\n }\n return query.offset(offset).limit(limit)\n },\n selectFields,\n tableName,\n where,\n })\n }\n\n if (selectDistinctResult) {\n if (selectDistinctResult.length === 0) {\n return {\n docs: [],\n hasNextPage: false,\n hasPrevPage: false,\n limit,\n nextPage: null,\n page: 1,\n pagingCounter: 0,\n prevPage: null,\n totalDocs: 0,\n totalPages: 0,\n }\n } else {\n // set the id in an object for sorting later\n selectDistinctResult.forEach(({ id }, i) => {\n orderedIDMap[id] = i\n })\n orderedIDs = Object.keys(orderedIDMap)\n findManyArgs.where = inArray(adapter.tables[tableName].id, orderedIDs)\n }\n } else {\n findManyArgs.limit = limit\n findManyArgs.offset = offset\n findManyArgs.orderBy = () => orderBy.map(({ column, order }) => order(column))\n\n if (where) {\n findManyArgs.where = where\n }\n }\n\n const findPromise = db.query[tableName].findMany(findManyArgs)\n\n if (pagination !== false && (orderedIDs ? orderedIDs?.length <= limit : true)) {\n totalDocs = await adapter.countDistinct({\n db,\n joins,\n tableName,\n where,\n })\n\n totalPages = typeof limit === 'number' && limit !== 0 ? Math.ceil(totalDocs / limit) : 1\n hasPrevPage = page > 1\n hasNextPage = totalPages > page\n pagingCounter = (page - 1) * limit + 1\n }\n\n const rawDocs = await findPromise\n // sort rawDocs from selectQuery\n if (Object.keys(orderedIDMap).length > 0) {\n rawDocs.sort((a, b) => orderedIDMap[a.id] - orderedIDMap[b.id])\n }\n\n if (pagination === false || !totalDocs) {\n totalDocs = rawDocs.length\n totalPages = 1\n pagingCounter = 1\n hasPrevPage = false\n hasNextPage = false\n }\n\n const docs = rawDocs.map((data: TypeWithID) => {\n return transform({\n adapter,\n config: adapter.payload.config,\n data,\n fields,\n joinQuery,\n tableName,\n })\n })\n\n return {\n docs,\n hasNextPage,\n hasPrevPage,\n limit: limitArg,\n nextPage: hasNextPage ? page + 1 : null,\n page,\n pagingCounter,\n prevPage: hasPrevPage ? page - 1 : null,\n totalDocs,\n totalPages,\n }\n}\n"],"names":["asc","desc","inArray","max","min","buildQuery","selectDistinct","transform","getNameFromDrizzleTable","getTransaction","buildFindManyArgs","findMany","find","adapter","collectionSlug","draftsEnabled","fields","joins","joinQuery","limit","limitArg","locale","page","pagination","req","select","sort","tableName","versions","where","whereArg","totalDocs","totalPages","hasPrevPage","hasNextPage","pagingCounter","offset","undefined","orderBy","selectFields","orderedIDMap","orderedIDs","findManyArgs","depth","key","column","primary","some","col","name","table","db","oneToManyJoinedTableNames","Set","filter","j","isOneToMany","map","hasSortOnOneToMany","size","has","selectDistinctResult","mainTable","tables","groupQuery","id","from","$dynamic","forEach","type","condition","groupBy","order","query","length","docs","nextPage","prevPage","i","Object","keys","findPromise","countDistinct","Math","ceil","rawDocs","a","b","data","config","payload"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../src/find/findMany.ts"],"sourcesContent":["import type { FindArgs, FlattenedField, TypeWithID } from 'payload'\n\nimport { asc, desc, inArray, max, min, sql } from 'drizzle-orm'\n\nimport type { DrizzleAdapter } from '../types.js'\n\nimport { buildQuery } from '../queries/buildQuery.js'\nimport { selectDistinct } from '../queries/selectDistinct.js'\nimport { transform } from '../transform/read/index.js'\nimport { getNameFromDrizzleTable } from '../utilities/getNameFromDrizzleTable.js'\nimport { getTransaction } from '../utilities/getTransaction.js'\nimport { jsonAggBuildObject } from '../utilities/json.js'\nimport { buildFindManyArgs } from './buildFindManyArgs.js'\n\ntype Args = {\n adapter: DrizzleAdapter\n collectionSlug?: string\n fields: FlattenedField[]\n tableName: string\n versions?: boolean\n} & Omit<FindArgs, 'collection'>\n\nexport const findMany = async function find({\n adapter,\n collectionSlug,\n draftsEnabled,\n fields,\n joins: joinQuery,\n limit: limitArg,\n locale,\n page = 1,\n pagination,\n req,\n select,\n sort,\n tableName,\n versions,\n where: whereArg,\n}: Args) {\n let limit = limitArg\n let totalDocs: number\n let totalPages: number\n let hasPrevPage: boolean\n let hasNextPage: boolean\n let pagingCounter: number\n const offset = (page - 1) * limit\n\n if (limit === 0) {\n pagination = false\n limit = undefined\n }\n\n const { joins, orderBy, selectFields, where } = buildQuery({\n adapter,\n fields,\n locale,\n sort,\n tableName,\n where: whereArg,\n })\n\n const orderedIDMap: Record<number | string, number> = {}\n let orderedIDs: (number | string)[]\n\n const findManyArgs = buildFindManyArgs({\n adapter,\n collectionSlug,\n depth: 0,\n draftsEnabled,\n fields,\n joinQuery,\n joins,\n locale,\n select,\n tableName,\n useBatchPolymorphicJoins: true,\n versions,\n })\n\n if (orderBy) {\n for (const key in selectFields) {\n const column = selectFields[key]\n if (!column || column.primary) {\n continue\n }\n\n if (\n !orderBy.some(\n (col) =>\n col.column.name === column.name &&\n getNameFromDrizzleTable(col.column.table) === getNameFromDrizzleTable(column.table),\n )\n ) {\n delete selectFields[key]\n }\n }\n }\n\n const db = await getTransaction(adapter, req)\n\n const oneToManyJoinedTableNames = new Set(\n joins.filter((j) => j.isOneToMany).map((j) => getNameFromDrizzleTable(j.table)),\n )\n\n const hasSortOnOneToMany =\n oneToManyJoinedTableNames.size > 0 &&\n orderBy?.some(({ column }) =>\n oneToManyJoinedTableNames.has(getNameFromDrizzleTable(column.table)),\n )\n\n let selectDistinctResult: { id: number | string }[] | undefined\n\n // avoid duplicate results by using a group query instead of select distinct when there is a sort on a one-to-many joined table\n if (hasSortOnOneToMany) {\n const mainTable = adapter.tables[tableName]\n let groupQuery = (db as any).select({ id: mainTable.id }).from(mainTable).$dynamic()\n\n if (where) {\n groupQuery = groupQuery.where(where)\n }\n\n joins.forEach(({ type, condition, table }) => {\n groupQuery = groupQuery[type ?? 'leftJoin'](table, condition)\n })\n\n groupQuery = groupQuery.groupBy(mainTable.id)\n\n groupQuery = groupQuery.orderBy(() =>\n orderBy.map(({ column, order }) => {\n if (oneToManyJoinedTableNames.has(getNameFromDrizzleTable(column.table))) {\n return order === asc ? asc(min(column)) : desc(max(column))\n }\n return order(column)\n }),\n )\n\n selectDistinctResult = await groupQuery.offset(offset).limit(limit)\n } else {\n selectDistinctResult = await selectDistinct({\n adapter,\n db,\n joins,\n query: ({ query }) => {\n if (orderBy) {\n query = query.orderBy(() => orderBy.map(({ column, order }) => order(column)))\n }\n return query.offset(offset).limit(limit)\n },\n selectFields,\n tableName,\n where,\n })\n }\n\n if (selectDistinctResult) {\n if (selectDistinctResult.length === 0) {\n return {\n docs: [],\n hasNextPage: false,\n hasPrevPage: false,\n limit,\n nextPage: null,\n page: 1,\n pagingCounter: 0,\n prevPage: null,\n totalDocs: 0,\n totalPages: 0,\n }\n } else {\n // set the id in an object for sorting later\n selectDistinctResult.forEach(({ id }, i) => {\n orderedIDMap[id] = i\n })\n orderedIDs = Object.keys(orderedIDMap)\n findManyArgs.where = inArray(adapter.tables[tableName].id, orderedIDs)\n }\n } else {\n findManyArgs.limit = limit\n findManyArgs.offset = offset\n findManyArgs.orderBy = () => orderBy.map(({ column, order }) => order(column))\n\n if (where) {\n findManyArgs.where = where\n }\n }\n\n const findPromise = db.query[tableName].findMany(findManyArgs)\n\n if (pagination !== false && (orderedIDs ? orderedIDs?.length <= limit : true)) {\n totalDocs = await adapter.countDistinct({\n db,\n joins,\n tableName,\n where,\n })\n\n totalPages = typeof limit === 'number' && limit !== 0 ? Math.ceil(totalDocs / limit) : 1\n hasPrevPage = page > 1\n hasNextPage = totalPages > page\n pagingCounter = (page - 1) * limit + 1\n }\n\n const rawDocs = await findPromise\n // sort rawDocs from selectQuery\n if (Object.keys(orderedIDMap).length > 0) {\n rawDocs.sort((a, b) => orderedIDMap[a.id] - orderedIDMap[b.id])\n }\n\n // Batch-load polymorphic join fields: execute one query per join field for all\n // fetched parents, replacing the N+1 correlated subquery pattern with 2 queries total.\n if (findManyArgs._polymorphicJoins?.length && rawDocs.length > 0) {\n const parentIds = rawDocs.map((doc) => doc.id).filter(Boolean)\n\n for (const join of findManyArgs._polymorphicJoins) {\n const { columnName, countColumnName, currentQuery, limit, onPath, page, sortDir, sqlWhere } =\n join\n\n const rankedAlias = `${columnName}_ranked`\n const preAlias = `${columnName}_pre`\n\n // Compute ROW_NUMBER range from page/limit\n const rnOffset = page && limit !== 0 ? (page - 1) * limit : 0\n const rnStart = rnOffset + 1\n const rnEndSQL = limit !== 0 ? sql` AND \"_rn\" <= ${rnOffset + limit}` : sql``\n\n // Use IN (...) rather than = ANY(ARRAY[...]) so PostgreSQL can coerce bind\n // parameter types to match the column type without an explicit cast.\n const parentIdsSql = sql.join(\n parentIds.map((id) => sql`${id}`),\n sql`, `,\n )\n\n // Apply the join's where filter alongside the parent-ID filter.\n const rankSourceSQL = sql`(\n SELECT * FROM ${sql`${currentQuery.as(preAlias)}`}\n WHERE ${sql.raw(`\"${onPath}\"`)} IN (${parentIdsSql})${sqlWhere ? sql` AND ${sqlWhere}` : sql``}\n ) AS ${sql.raw(`\"${preAlias}_src\"`)}`\n\n // Single query: rank all children for all fetched parents, aggregate per parent.\n // COUNT(*) OVER is placed in the inner (ranking) query so it reflects the total\n // number of matching children per parent — not just the current page's rows.\n const batchResult = await (db as any).execute(sql`\n SELECT\n ${sql.raw(`\"${rankedAlias}\".\"${onPath}\"`)} AS \"_parent_id\",\n ${jsonAggBuildObject(adapter, {\n id: sql.raw(`\"${rankedAlias}\".\"id\"`),\n relationTo: sql.raw(`\"${rankedAlias}\".\"relationTo\"`),\n })} AS \"_result\"\n ${countColumnName ? sql`, MAX(${sql.raw(`\"${rankedAlias}\".\"_total_count\"`)}) AS \"_total_count\"` : sql``}\n FROM (\n SELECT *,\n ROW_NUMBER() OVER (\n PARTITION BY ${sql.raw(`\"${onPath}\"`)}\n ORDER BY \"sortPath\" ${sql.raw(sortDir)}\n ) AS \"_rn\"\n ${countColumnName ? sql`, COUNT(*) OVER (PARTITION BY ${sql.raw(`\"${onPath}\"`)}) AS \"_total_count\"` : sql``}\n FROM ${rankSourceSQL}\n ) AS ${sql.raw(`\"${rankedAlias}\"`)}\n WHERE \"_rn\" >= ${rnStart}${rnEndSQL}\n GROUP BY ${sql.raw(`\"${rankedAlias}\".\"${onPath}\"`)}\n `)\n\n const rows: Array<{ _parent_id: unknown; _result: unknown; _total_count?: number }> =\n batchResult.rows ?? batchResult\n const childMap = new Map(rows.map((r) => [String(r._parent_id), r]))\n\n for (const doc of rawDocs) {\n const row = childMap.get(String((doc as any).id))\n ;(doc as any)[columnName] = row?._result ?? null\n if (countColumnName) {\n ;(doc as any)[countColumnName] = row?._total_count ?? 0\n }\n }\n }\n }\n\n if (pagination === false || !totalDocs) {\n totalDocs = rawDocs.length\n totalPages = 1\n pagingCounter = 1\n hasPrevPage = false\n hasNextPage = false\n }\n\n const docs = rawDocs.map((data: TypeWithID) => {\n return transform({\n adapter,\n config: adapter.payload.config,\n data,\n fields,\n joinQuery,\n tableName,\n })\n })\n\n return {\n docs,\n hasNextPage,\n hasPrevPage,\n limit: limitArg,\n nextPage: hasNextPage ? page + 1 : null,\n page,\n pagingCounter,\n prevPage: hasPrevPage ? page - 1 : null,\n totalDocs,\n totalPages,\n }\n}\n"],"names":["asc","desc","inArray","max","min","sql","buildQuery","selectDistinct","transform","getNameFromDrizzleTable","getTransaction","jsonAggBuildObject","buildFindManyArgs","findMany","find","adapter","collectionSlug","draftsEnabled","fields","joins","joinQuery","limit","limitArg","locale","page","pagination","req","select","sort","tableName","versions","where","whereArg","totalDocs","totalPages","hasPrevPage","hasNextPage","pagingCounter","offset","undefined","orderBy","selectFields","orderedIDMap","orderedIDs","findManyArgs","depth","useBatchPolymorphicJoins","key","column","primary","some","col","name","table","db","oneToManyJoinedTableNames","Set","filter","j","isOneToMany","map","hasSortOnOneToMany","size","has","selectDistinctResult","mainTable","tables","groupQuery","id","from","$dynamic","forEach","type","condition","groupBy","order","query","length","docs","nextPage","prevPage","i","Object","keys","findPromise","countDistinct","Math","ceil","rawDocs","a","b","_polymorphicJoins","parentIds","doc","Boolean","join","columnName","countColumnName","currentQuery","onPath","sortDir","sqlWhere","rankedAlias","preAlias","rnOffset","rnStart","rnEndSQL","parentIdsSql","rankSourceSQL","as","raw","batchResult","execute","relationTo","rows","childMap","Map","r","String","_parent_id","row","get","_result","_total_count","data","config","payload"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../src/find/traverseFields.ts"],"names":[],"mappings":"AAIA,OAAO,EAIL,KAAK,cAAc,EAGnB,KAAK,SAAS,EACd,KAAK,UAAU,EACf,KAAK,UAAU,EAEhB,MAAM,SAAS,CAAA;AAIhB,OAAO,KAAK,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,aAAa,CAAA;AACxE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAA;AA6EpD,KAAK,iBAAiB,GAAG;IACvB,QAAQ,EAAE,MAAM,CAAA;IAChB,OAAO,EAAE,cAAc,CAAA;IACvB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,WAAW,EAAE,MAAM,CAAA;IACnB,gBAAgB,EAAE,MAAM,CAAA;IACxB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,MAAM,EAAE,cAAc,EAAE,CAAA;IACxB,eAAe,CAAC,EAAE,OAAO,CAAA;IACzB,SAAS,EAAE,SAAS,CAAA;IACpB,KAAK,CAAC,EAAE,qBAAqB,CAAA;IAC7B,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,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,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,iSAuBxB,iBAAiB,
|
|
1
|
+
{"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../src/find/traverseFields.ts"],"names":[],"mappings":"AAIA,OAAO,EAIL,KAAK,cAAc,EAGnB,KAAK,SAAS,EACd,KAAK,UAAU,EACf,KAAK,UAAU,EAEhB,MAAM,SAAS,CAAA;AAIhB,OAAO,KAAK,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,aAAa,CAAA;AACxE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAA;AA6EpD,KAAK,iBAAiB,GAAG;IACvB,QAAQ,EAAE,MAAM,CAAA;IAChB,OAAO,EAAE,cAAc,CAAA;IACvB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,WAAW,EAAE,MAAM,CAAA;IACnB,gBAAgB,EAAE,MAAM,CAAA;IACxB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,MAAM,EAAE,cAAc,EAAE,CAAA;IACxB,eAAe,CAAC,EAAE,OAAO,CAAA;IACzB,SAAS,EAAE,SAAS,CAAA;IACpB,KAAK,CAAC,EAAE,qBAAqB,CAAA;IAC7B,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,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,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,iSAuBxB,iBAAiB,4BAk0BnB,CAAA"}
|
|
@@ -411,36 +411,62 @@ export const traverseFields = ({ _locales, adapter, collectionSlug, currentArgs,
|
|
|
411
411
|
count: count()
|
|
412
412
|
}).from(sql`${currentQuery.as(subQueryAlias)}`).where(sqlWhere)}`.as(`${columnName}_count`);
|
|
413
413
|
}
|
|
414
|
-
|
|
414
|
+
// Sort direction for the batch / window-function query.
|
|
415
|
+
// NOTE: sanitizedSort has already had its '-' stripped by this point (line ~503),
|
|
416
|
+
// so we derive direction from sortOrder (computed before the strip) instead.
|
|
417
|
+
const sortDir = sortOrder === desc ? 'DESC' : 'ASC';
|
|
415
418
|
const sortedUnionAlias = `${columnName}_sorted`;
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
419
|
+
if (currentArgs._polymorphicJoins) {
|
|
420
|
+
// Batch mode (enabled by findMany.ts): defer loading to a single
|
|
421
|
+
// post-query batch instead of executing a correlated subquery per parent row.
|
|
422
|
+
// Pre-build the WHERE SQL using the alias that findMany.ts will use for the
|
|
423
|
+
// UNION subquery (${columnName}_pre), so it can be applied without re-importing
|
|
424
|
+
// buildSQLWhere.
|
|
425
|
+
const sqlWhere = where && Object.keys(where).length > 0 ? buildSQLWhere(where, `${columnName}_pre`) : undefined;
|
|
426
|
+
currentArgs._polymorphicJoins.push({
|
|
427
|
+
columnName,
|
|
428
|
+
countColumnName: shouldCount ? `${columnName}_count` : undefined,
|
|
429
|
+
currentQuery,
|
|
430
|
+
limit,
|
|
431
|
+
onPath,
|
|
432
|
+
page,
|
|
433
|
+
sortDir,
|
|
434
|
+
sqlWhere,
|
|
435
|
+
where
|
|
436
|
+
});
|
|
437
|
+
} else {
|
|
438
|
+
// Fallback: correlated subquery per parent row.
|
|
439
|
+
// Used for single-doc reads (upsertRow / deleteOne) where N=1 and N+1 is negligible.
|
|
440
|
+
let limitOffsetSQL = sql.empty();
|
|
441
|
+
if (limit) {
|
|
442
|
+
limitOffsetSQL = sql` LIMIT ${limit}`;
|
|
424
443
|
}
|
|
444
|
+
if (page && limit !== 0) {
|
|
445
|
+
const offset = (page - 1) * limit;
|
|
446
|
+
if (offset > 0) {
|
|
447
|
+
limitOffsetSQL = sql`${limitOffsetSQL} OFFSET ${offset}`;
|
|
448
|
+
}
|
|
449
|
+
}
|
|
450
|
+
currentQuery = currentQuery.orderBy(sortOrder(sql`"sortPath"`));
|
|
451
|
+
let innerWhere = sql.raw(`"${sortedUnionAlias}"."${onPath}" = "${currentTableName}"."id"`);
|
|
452
|
+
if (where && Object.keys(where).length > 0) {
|
|
453
|
+
const additionalWhere = buildSQLWhere(where, sortedUnionAlias);
|
|
454
|
+
innerWhere = sql`${innerWhere} AND ${additionalWhere}`;
|
|
455
|
+
}
|
|
456
|
+
// IMPORTANT: For polymorphic joins, LIMIT must be applied AFTER correlating
|
|
457
|
+
// to the parent row. Otherwise, the limit applies globally across ALL parents,
|
|
458
|
+
// not per-parent.
|
|
459
|
+
currentArgs.extras[columnName] = sql`(
|
|
460
|
+
SELECT ${jsonAggBuildObject(adapter, {
|
|
461
|
+
id: sql.raw(`"${columnName}_subquery"."id"`),
|
|
462
|
+
relationTo: sql.raw(`"${columnName}_subquery"."relationTo"`)
|
|
463
|
+
})}
|
|
464
|
+
FROM (
|
|
465
|
+
SELECT * FROM ${sql`${currentQuery.as(sortedUnionAlias)}`}
|
|
466
|
+
WHERE ${innerWhere}${limitOffsetSQL}
|
|
467
|
+
) AS ${sql.raw(`"${columnName}_subquery"`)}
|
|
468
|
+
)`.as(columnName);
|
|
425
469
|
}
|
|
426
|
-
// Correlate to parent row + apply any join where filters
|
|
427
|
-
let innerWhere = sql.raw(`"${sortedUnionAlias}"."${onPath}" = "${currentTableName}"."id"`);
|
|
428
|
-
if (where && Object.keys(where).length > 0) {
|
|
429
|
-
const additionalWhere = buildSQLWhere(where, sortedUnionAlias);
|
|
430
|
-
innerWhere = sql`${innerWhere} AND ${additionalWhere}`;
|
|
431
|
-
}
|
|
432
|
-
// IMPORTANT: For polymorphic joins, LIMIT must be applied AFTER correlating to the parent row.
|
|
433
|
-
// Otherwise, the limit applies globally across ALL parents, not per-parent.
|
|
434
|
-
currentArgs.extras[columnName] = sql`(
|
|
435
|
-
SELECT ${jsonAggBuildObject(adapter, {
|
|
436
|
-
id: sql.raw(`"${subQueryAlias}"."id"`),
|
|
437
|
-
relationTo: sql.raw(`"${subQueryAlias}"."relationTo"`)
|
|
438
|
-
})}
|
|
439
|
-
FROM (
|
|
440
|
-
SELECT * FROM ${sql`${currentQuery.as(sortedUnionAlias)}`}
|
|
441
|
-
WHERE ${innerWhere}${limitOffsetSQL}
|
|
442
|
-
) AS ${sql.raw(`"${subQueryAlias}"`)}
|
|
443
|
-
)`.as(columnName);
|
|
444
470
|
} else {
|
|
445
471
|
const useDrafts = (versions || draftsEnabled) && hasDraftsEnabled(adapter.payload.collections[field.collection].config);
|
|
446
472
|
const fields = useDrafts ? buildVersionCollectionFields(adapter.payload.config, adapter.payload.collections[field.collection].config, true) : adapter.payload.collections[field.collection].config.flattenedFields;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/find/traverseFields.ts"],"sourcesContent":["import type { LibSQLDatabase } from 'drizzle-orm/libsql'\nimport type { SQLiteSelect, SQLiteSelectBase } from 'drizzle-orm/sqlite-core'\n\nimport { and, asc, count, desc, eq, getTableName, or, sql } from 'drizzle-orm'\nimport {\n appendVersionToQueryKey,\n buildVersionCollectionFields,\n combineQueries,\n type FlattenedField,\n getFieldByPath,\n getQueryDraftsSort,\n type JoinQuery,\n type SelectMode,\n type SelectType,\n type Where,\n} from 'payload'\nimport { fieldIsVirtual, fieldShouldBeLocalized, hasDraftsEnabled } from 'payload/shared'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { BuildQueryJoinAliases, DrizzleAdapter } from '../types.js'\nimport type { Result } from './buildFindManyArgs.js'\n\nimport { buildQuery } from '../queries/buildQuery.js'\nimport { getTableAlias } from '../queries/getTableAlias.js'\nimport { operatorMap } from '../queries/operatorMap.js'\nimport { getArrayRelationName } from '../utilities/getArrayRelationName.js'\nimport { getNameFromDrizzleTable } from '../utilities/getNameFromDrizzleTable.js'\nimport { jsonAggBuildObject } from '../utilities/json.js'\nimport { rawConstraint } from '../utilities/rawConstraint.js'\nimport { sanitizePathSegment } from '../utilities/sanitizePathSegment.js'\nimport {\n InternalBlockTableNameIndex,\n resolveBlockTableName,\n} from '../utilities/validateExistingBlockIsIdentical.js'\n\nconst flattenAllWherePaths = (where: Where, paths: { path: string; ref: any }[]) => {\n for (const k in where) {\n if (['AND', 'OR'].includes(k.toUpperCase())) {\n if (Array.isArray(where[k])) {\n for (const whereField of where[k]) {\n flattenAllWherePaths(whereField, paths)\n }\n }\n } else {\n // TODO: explore how to support arrays/relationship querying.\n paths.push({ path: k.split('.').join('_'), ref: where })\n }\n }\n}\n\nconst buildSQLWhere = (where: Where, alias: string) => {\n for (const k in where) {\n if (['AND', 'OR'].includes(k.toUpperCase())) {\n if (Array.isArray(where[k])) {\n const op = 'AND' === k.toUpperCase() ? and : or\n const accumulated = []\n for (const whereField of where[k]) {\n accumulated.push(buildSQLWhere(whereField, alias))\n }\n return op(...accumulated)\n }\n } else {\n let payloadOperator = Object.keys(where[k])[0]\n\n const value = where[k][payloadOperator]\n if (payloadOperator === '$raw') {\n if (typeof value !== 'string') {\n return undefined\n }\n return sql.raw(value)\n }\n\n // Handle exists: false -> use isNull instead of isNotNull\n\n // This logic is duplicated from sanitizeQueryValue.ts because buildSQLWhere\n // is a simplified WHERE builder for polymorphic joins that doesn't have access\n // to field definitions needed by sanitizeQueryValue\n if (payloadOperator === 'exists' && value === false) {\n payloadOperator = 'isNull'\n }\n\n if (!(payloadOperator in operatorMap)) {\n return undefined\n }\n\n const sanitizedColumnName = k\n .split('.')\n .map((s) => sanitizePathSegment(s))\n .join('_')\n\n return operatorMap[payloadOperator](sql.raw(`\"${alias}\".\"${sanitizedColumnName}\"`), value)\n }\n }\n}\n\ntype SQLSelect = SQLiteSelectBase<any, any, any, any>\n\ntype TraverseFieldArgs = {\n _locales: Result\n adapter: DrizzleAdapter\n collectionSlug?: string\n currentArgs: Result\n currentTableName: string\n depth?: number\n draftsEnabled?: boolean\n fields: FlattenedField[]\n forceWithFields?: boolean\n joinQuery: JoinQuery\n joins?: BuildQueryJoinAliases\n locale?: string\n parentIsLocalized?: boolean\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 withTabledFields: {\n numbers?: boolean\n rels?: boolean\n texts?: boolean\n }\n}\n\nexport const traverseFields = ({\n _locales,\n adapter,\n collectionSlug,\n currentArgs,\n currentTableName,\n depth,\n draftsEnabled,\n fields,\n forceWithFields,\n joinQuery = {},\n joins,\n locale,\n parentIsLocalized = false,\n path,\n select,\n selectAllOnCurrentLevel = false,\n selectMode,\n tablePath,\n topLevelArgs,\n topLevelTableName,\n versions,\n withTabledFields,\n}: TraverseFieldArgs) => {\n fields.forEach((field) => {\n if (fieldIsVirtual(field)) {\n return\n }\n\n const isFieldLocalized = fieldShouldBeLocalized({\n field,\n parentIsLocalized,\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 (isFieldLocalized) {\n _locales.with[`${path}${field.name}`] = true\n } else {\n currentArgs.with[`${path}${field.name}`] = true\n }\n }\n\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 const relationName = getArrayRelationName({\n field,\n path: `${path}${field.name}`,\n tableName: arrayTableName,\n })\n\n currentArgs.with[relationName] = withArray\n\n traverseFields({\n _locales: withArray.with._locales,\n adapter,\n currentArgs: withArray,\n currentTableName: arrayTableName,\n depth,\n draftsEnabled,\n fields: field.flattenedFields,\n forceWithFields,\n joinQuery,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n path: '',\n select: typeof arraySelect === 'object' ? arraySelect : undefined,\n selectMode,\n tablePath: '',\n topLevelArgs,\n topLevelTableName,\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 '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 if (adapter.blocksAsJSON) {\n if (select || selectAllOnCurrentLevel) {\n const fieldPath = `${path}${field.name}`\n\n if ((isFieldLocalized || parentIsLocalized) && _locales) {\n _locales.columns[fieldPath] = true\n } else if (adapter.tables[currentTableName]?.[fieldPath]) {\n currentArgs.columns[fieldPath] = true\n }\n }\n\n break\n }\n\n ;(field.blockReferences ?? field.blocks).forEach((_block) => {\n const block = typeof _block === 'string' ? adapter.payload.blocks[_block] : _block\n const blockKey = `_blocks_${block.slug}${!block[InternalBlockTableNameIndex] ? '' : `_${block[InternalBlockTableNameIndex]}`}`\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' && Boolean(blocksSelect[block.slug])) {\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 = resolveBlockTableName(\n block,\n adapter.tableNameMap.get(`${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 draftsEnabled,\n fields: block.flattenedFields,\n forceWithFields: blockSelect === true,\n joinQuery,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n path: '',\n select: typeof blockSelect === 'object' ? blockSelect : undefined,\n selectMode: blockSelectMode,\n tablePath: '',\n topLevelArgs,\n topLevelTableName,\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 collectionSlug,\n currentArgs,\n currentTableName,\n depth,\n draftsEnabled,\n fields: field.flattenedFields,\n forceWithFields,\n joinQuery,\n joins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\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 withTabledFields,\n })\n\n break\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 count: shouldCount = false,\n limit: limitArg = field.defaultLimit ?? 10,\n page,\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 columnName = `${path.replaceAll('.', '_')}${field.name}`\n\n const db = adapter.drizzle as LibSQLDatabase\n\n if (Array.isArray(field.collection)) {\n let currentQuery: null | SQLSelect = null\n const onPath = field.on.split('.').join('_')\n\n if (Array.isArray(sort)) {\n throw new Error('Not implemented')\n }\n\n let sanitizedSort = sort\n\n if (!sanitizedSort) {\n if (\n field.collection.some((collection) =>\n adapter.payload.collections[collection].config.fields.some(\n (f) => f.type === 'date' && f.name === 'createdAt',\n ),\n )\n ) {\n sanitizedSort = '-createdAt'\n } else {\n sanitizedSort = 'id'\n }\n }\n\n const sortOrder = sanitizedSort.startsWith('-') ? desc : asc\n sanitizedSort = sanitizedSort.replace('-', '')\n\n const sortPath = sanitizedSort.split('.').join('_')\n\n const wherePaths: { path: string; ref: any }[] = []\n\n if (where) {\n flattenAllWherePaths(where, wherePaths)\n }\n\n for (const collection of field.collection) {\n const joinCollectionTableName = adapter.tableNameMap.get(toSnakeCase(collection))\n\n const table = adapter.tables[joinCollectionTableName]\n\n const sortColumn = table[sortPath]\n\n const selectFields = {\n id: adapter.tables[joinCollectionTableName].id,\n parent: sql`${adapter.tables[joinCollectionTableName][onPath]}`.as(onPath),\n relationTo: sql`${collection}`.as('relationTo'),\n sortPath: sql`${sortColumn ? sortColumn : null}`.as('sortPath'),\n }\n\n const collectionQueryWhere: any[] = []\n // Select for WHERE and Fallback NULL\n for (const { path, ref } of wherePaths) {\n const collectioConfig = adapter.payload.collections[collection].config\n const field = getFieldByPath({ fields: collectioConfig.flattenedFields, path })\n\n if (field && field.field.type === 'select' && field.field.hasMany) {\n let tableName = adapter.tableNameMap.get(\n `${toSnakeCase(collection)}_${toSnakeCase(path)}`,\n )\n let parentTable = getTableName(table)\n\n if (adapter.schemaName) {\n tableName = `\"${adapter.schemaName}\".\"${tableName}\"`\n parentTable = `\"${adapter.schemaName}\".\"${parentTable}\"`\n }\n\n if (adapter.name === 'postgres') {\n selectFields[path] = sql\n .raw(\n `(select jsonb_agg(${tableName}.value) from ${tableName} where ${tableName}.parent_id = ${parentTable}.id)`,\n )\n .as(path)\n } else {\n selectFields[path] = sql\n .raw(\n `(select json_group_array(${tableName}.value) from ${tableName} where ${tableName}.parent_id = ${parentTable}.id)`,\n )\n .as(path)\n }\n\n const constraint = ref[path]\n const operator = Object.keys(constraint)[0]\n const value: any = Object.values(constraint)[0]\n\n const query = adapter.createJSONQuery({\n column: `\"${path}\"`,\n operator,\n pathSegments: [field.field.name],\n table: parentTable,\n value,\n })\n ref[path] = { $raw: query }\n } else if (adapter.tables[joinCollectionTableName][path]) {\n selectFields[path] = sql`${adapter.tables[joinCollectionTableName][path]}`.as(path)\n // Allow to filter by collectionSlug\n } else if (path !== 'relationTo') {\n // For timestamp fields like deletedAt, we need to cast to timestamp in Postgres\n // SQLite doesn't require explicit type casting for UNION queries\n if (path === 'deletedAt' && adapter.name === 'postgres') {\n selectFields[path] = sql`null::timestamp with time zone`.as(path)\n } else {\n selectFields[path] = sql`null`.as(path)\n }\n }\n }\n\n let query: any = db.select(selectFields).from(adapter.tables[joinCollectionTableName])\n if (collectionQueryWhere.length) {\n query = query.where(and(...collectionQueryWhere))\n }\n if (currentQuery === null) {\n currentQuery = query as unknown as SQLSelect\n } else {\n currentQuery = currentQuery.unionAll(query) as SQLSelect\n }\n }\n\n const subQueryAlias = `${columnName}_subquery`\n\n let sqlWhere = eq(\n sql.raw(`\"${currentTableName}\".\"id\"`),\n sql.raw(`\"${subQueryAlias}\".\"${onPath}\"`),\n )\n\n if (where && Object.keys(where).length > 0) {\n sqlWhere = and(sqlWhere, buildSQLWhere(where, subQueryAlias))\n }\n\n if (shouldCount) {\n currentArgs.extras[`${columnName}_count`] = sql`${db\n .select({ count: count() })\n .from(sql`${currentQuery.as(subQueryAlias)}`)\n .where(sqlWhere)}`.as(`${columnName}_count`)\n }\n\n currentQuery = currentQuery.orderBy(sortOrder(sql`\"sortPath\"`)) as SQLSelect\n\n const sortedUnionAlias = `${columnName}_sorted`\n\n let limitOffsetSQL = sql.empty()\n if (limit) {\n limitOffsetSQL = sql` LIMIT ${limit}`\n }\n if (page && limit !== 0) {\n const offset = (page - 1) * limit\n if (offset > 0) {\n limitOffsetSQL = sql`${limitOffsetSQL} OFFSET ${offset}`\n }\n }\n\n // Correlate to parent row + apply any join where filters\n let innerWhere = sql.raw(`\"${sortedUnionAlias}\".\"${onPath}\" = \"${currentTableName}\".\"id\"`)\n if (where && Object.keys(where).length > 0) {\n const additionalWhere = buildSQLWhere(where, sortedUnionAlias)\n innerWhere = sql`${innerWhere} AND ${additionalWhere}`\n }\n\n // IMPORTANT: For polymorphic joins, LIMIT must be applied AFTER correlating to the parent row.\n // Otherwise, the limit applies globally across ALL parents, not per-parent.\n currentArgs.extras[columnName] = sql`(\n SELECT ${jsonAggBuildObject(adapter, {\n id: sql.raw(`\"${subQueryAlias}\".\"id\"`),\n relationTo: sql.raw(`\"${subQueryAlias}\".\"relationTo\"`),\n })}\n FROM (\n SELECT * FROM ${sql`${currentQuery.as(sortedUnionAlias)}`}\n WHERE ${innerWhere}${limitOffsetSQL}\n ) AS ${sql.raw(`\"${subQueryAlias}\"`)}\n )`.as(columnName)\n } else {\n const useDrafts =\n (versions || draftsEnabled) &&\n hasDraftsEnabled(adapter.payload.collections[field.collection].config)\n\n const fields = useDrafts\n ? buildVersionCollectionFields(\n adapter.payload.config,\n adapter.payload.collections[field.collection].config,\n true,\n )\n : adapter.payload.collections[field.collection].config.flattenedFields\n\n const joinCollectionTableName = adapter.tableNameMap.get(\n useDrafts\n ? `_${toSnakeCase(field.collection)}${adapter.versionsSuffix}`\n : toSnakeCase(field.collection),\n )\n\n const joins: BuildQueryJoinAliases = []\n\n const currentIDColumn = versions\n ? adapter.tables[currentTableName].parent\n : adapter.tables[currentTableName].id\n\n let joinQueryWhere: Where\n\n const currentIDRaw = sql.raw(\n `\"${getNameFromDrizzleTable(currentIDColumn.table)}\".\"${currentIDColumn.name}\"`,\n )\n\n if (Array.isArray(field.targetField.relationTo)) {\n joinQueryWhere = {\n [field.on]: {\n equals: {\n relationTo: collectionSlug,\n value: rawConstraint(currentIDRaw),\n },\n },\n }\n } else {\n joinQueryWhere = {\n [field.on]: {\n equals: rawConstraint(currentIDRaw),\n },\n }\n }\n\n if (where && Object.keys(where).length) {\n joinQueryWhere = {\n and: [joinQueryWhere, where],\n }\n }\n\n if (useDrafts) {\n joinQueryWhere = combineQueries(appendVersionToQueryKey(joinQueryWhere), {\n latest: { equals: true },\n })\n }\n\n const columnName = `${path.replaceAll('.', '_')}${field.name}`\n\n const subQueryAlias = `${columnName}_alias`\n\n const { newAliasTable } = getTableAlias({\n adapter,\n tableName: joinCollectionTableName,\n })\n\n const {\n orderBy,\n selectFields,\n where: subQueryWhere,\n } = buildQuery({\n adapter,\n aliasTable: newAliasTable,\n fields,\n joins,\n locale,\n parentIsLocalized,\n selectLocale: true,\n sort: useDrafts\n ? getQueryDraftsSort({\n collectionConfig: adapter.payload.collections[field.collection].config,\n sort,\n })\n : sort,\n tableName: joinCollectionTableName,\n where: joinQueryWhere,\n })\n\n for (let key in selectFields) {\n const val = selectFields[key]\n\n if (val.table && getNameFromDrizzleTable(val.table) === joinCollectionTableName) {\n delete selectFields[key]\n key = key.split('.').pop()\n selectFields[key] = newAliasTable[key]\n }\n }\n\n if (useDrafts) {\n selectFields.parent = newAliasTable.parent\n }\n\n let query: SQLiteSelect = db\n .select(selectFields as any)\n .from(newAliasTable)\n .where(subQueryWhere)\n .orderBy(() => orderBy.map(({ column, order }) => order(column)))\n .$dynamic()\n\n joins.forEach(({ type, condition, table }) => {\n query = query[type ?? 'leftJoin'](table, condition)\n })\n\n if (page && limit !== 0) {\n const offset = (page - 1) * limit - 1\n if (offset > 0) {\n query = query.offset(offset)\n }\n }\n\n if (limit !== 0) {\n query = query.limit(limit)\n }\n\n const subQuery = query.as(subQueryAlias)\n\n if (shouldCount) {\n let countSubquery: SQLiteSelect = db\n .select(selectFields as any)\n\n .from(newAliasTable)\n .where(subQueryWhere)\n .$dynamic()\n\n joins.forEach(({ type, condition, table }) => {\n countSubquery = countSubquery[type ?? 'leftJoin'](table, condition)\n })\n\n currentArgs.extras[`${columnName}_count`] = sql`${db\n .select({\n count: count(),\n })\n .from(sql`${countSubquery.as(`${subQueryAlias}_count_subquery`)}`)}`.as(\n `${subQueryAlias}_count`,\n )\n }\n\n currentArgs.extras[columnName] = sql`${db\n .select({\n result: jsonAggBuildObject(adapter, {\n id: sql.raw(`\"${subQueryAlias}\".${useDrafts ? 'parent_id' : 'id'}`),\n ...(selectFields._locale && {\n locale: sql.raw(`\"${subQueryAlias}\".${selectFields._locale.name}`),\n }),\n }),\n })\n .from(sql`${subQuery}`)}`.as(subQueryAlias)\n }\n\n break\n }\n\n case 'point': {\n if (adapter.name === 'sqlite') {\n break\n }\n\n const args = isFieldLocalized ? _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' && Boolean(select[field.name])) ||\n (selectMode === 'exclude' && typeof select[field.name] === 'undefined')\n ) {\n shouldSelect = true\n }\n } else {\n shouldSelect = true\n }\n const tableName = fieldShouldBeLocalized({ field, parentIsLocalized })\n ? `${currentTableName}${adapter.localesSuffix}`\n : currentTableName\n\n if (shouldSelect) {\n args.extras[name] = sql\n .raw(`ST_AsGeoJSON(\"${adapter.tables[tableName][name].name}\")::jsonb`)\n .as(name)\n }\n break\n }\n\n case 'select': {\n if (select && !selectAllOnCurrentLevel) {\n if (\n (selectMode === 'include' && !select[field.name]) ||\n (selectMode === 'exclude' && select[field.name] === false)\n ) {\n break\n }\n }\n\n if (field.hasMany) {\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 break\n }\n\n if (select || selectAllOnCurrentLevel) {\n const fieldPath = `${path}${field.name}`\n\n if ((isFieldLocalized || parentIsLocalized) && _locales) {\n _locales.columns[fieldPath] = true\n } else if (adapter.tables[currentTableName]?.[fieldPath]) {\n currentArgs.columns[fieldPath] = true\n }\n }\n\n break\n }\n\n default: {\n if (forceWithFields) {\n if (\n (field.type === 'relationship' || field.type === 'upload') &&\n (field.hasMany || Array.isArray(field.relationTo))\n ) {\n withTabledFields.rels = true\n }\n\n if (field.type === 'number' && field.hasMany) {\n withTabledFields.numbers = true\n }\n\n if (field.type === 'text' && field.hasMany) {\n withTabledFields.texts = true\n }\n }\n\n if (!select && !selectAllOnCurrentLevel) {\n break\n }\n\n if (\n selectAllOnCurrentLevel ||\n (selectMode === 'include' && Boolean(select[field.name])) ||\n (selectMode === 'exclude' && typeof select[field.name] === 'undefined')\n ) {\n const fieldPath = `${path}${field.name}`\n\n if ((isFieldLocalized || parentIsLocalized) && _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' || field.type === 'upload') &&\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 return topLevelArgs\n}\n"],"names":["and","asc","count","desc","eq","getTableName","or","sql","appendVersionToQueryKey","buildVersionCollectionFields","combineQueries","getFieldByPath","getQueryDraftsSort","fieldIsVirtual","fieldShouldBeLocalized","hasDraftsEnabled","toSnakeCase","buildQuery","getTableAlias","operatorMap","getArrayRelationName","getNameFromDrizzleTable","jsonAggBuildObject","rawConstraint","sanitizePathSegment","InternalBlockTableNameIndex","resolveBlockTableName","flattenAllWherePaths","where","paths","k","includes","toUpperCase","Array","isArray","whereField","push","path","split","join","ref","buildSQLWhere","alias","op","accumulated","payloadOperator","Object","keys","value","undefined","raw","sanitizedColumnName","map","s","traverseFields","_locales","adapter","collectionSlug","currentArgs","currentTableName","depth","draftsEnabled","fields","forceWithFields","joinQuery","joins","locale","parentIsLocalized","select","selectAllOnCurrentLevel","selectMode","tablePath","topLevelArgs","topLevelTableName","versions","withTabledFields","forEach","field","isFieldLocalized","type","hasMany","relationTo","with","name","arraySelect","withArray","columns","id","_order","_parentID","orderBy","arrayTableName","tableNameMap","get","tables","_locale","_uuid","arrayTableNameWithLocales","localesSuffix","relationName","tableName","flattenedFields","localized","length","blocksSelect","blocksAsJSON","fieldPath","blockReferences","blocks","_block","block","payload","blockKey","slug","blockSelect","blockSelectMode","Boolean","withBlock","_path","fieldSelect","joinSchemaPath","replaceAll","shouldCount","limit","limitArg","defaultLimit","page","sort","defaultSort","columnName","db","drizzle","collection","currentQuery","onPath","on","Error","sanitizedSort","some","collections","config","f","sortOrder","startsWith","replace","sortPath","wherePaths","joinCollectionTableName","table","sortColumn","selectFields","parent","as","collectionQueryWhere","collectioConfig","parentTable","schemaName","constraint","operator","values","query","createJSONQuery","column","pathSegments","$raw","from","unionAll","subQueryAlias","sqlWhere","extras","sortedUnionAlias","limitOffsetSQL","empty","offset","innerWhere","additionalWhere","useDrafts","versionsSuffix","currentIDColumn","joinQueryWhere","currentIDRaw","targetField","equals","latest","newAliasTable","subQueryWhere","aliasTable","selectLocale","collectionConfig","key","val","pop","order","$dynamic","condition","subQuery","countSubquery","result","args","shouldSelect","withSelect","rels","numbers","texts"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../src/find/traverseFields.ts"],"sourcesContent":["import type { LibSQLDatabase } from 'drizzle-orm/libsql'\nimport type { SQLiteSelect, SQLiteSelectBase } from 'drizzle-orm/sqlite-core'\n\nimport { and, asc, count, desc, eq, getTableName, or, sql } from 'drizzle-orm'\nimport {\n appendVersionToQueryKey,\n buildVersionCollectionFields,\n combineQueries,\n type FlattenedField,\n getFieldByPath,\n getQueryDraftsSort,\n type JoinQuery,\n type SelectMode,\n type SelectType,\n type Where,\n} from 'payload'\nimport { fieldIsVirtual, fieldShouldBeLocalized, hasDraftsEnabled } from 'payload/shared'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { BuildQueryJoinAliases, DrizzleAdapter } from '../types.js'\nimport type { Result } from './buildFindManyArgs.js'\n\nimport { buildQuery } from '../queries/buildQuery.js'\nimport { getTableAlias } from '../queries/getTableAlias.js'\nimport { operatorMap } from '../queries/operatorMap.js'\nimport { getArrayRelationName } from '../utilities/getArrayRelationName.js'\nimport { getNameFromDrizzleTable } from '../utilities/getNameFromDrizzleTable.js'\nimport { jsonAggBuildObject } from '../utilities/json.js'\nimport { rawConstraint } from '../utilities/rawConstraint.js'\nimport { sanitizePathSegment } from '../utilities/sanitizePathSegment.js'\nimport {\n InternalBlockTableNameIndex,\n resolveBlockTableName,\n} from '../utilities/validateExistingBlockIsIdentical.js'\n\nconst flattenAllWherePaths = (where: Where, paths: { path: string; ref: any }[]) => {\n for (const k in where) {\n if (['AND', 'OR'].includes(k.toUpperCase())) {\n if (Array.isArray(where[k])) {\n for (const whereField of where[k]) {\n flattenAllWherePaths(whereField, paths)\n }\n }\n } else {\n // TODO: explore how to support arrays/relationship querying.\n paths.push({ path: k.split('.').join('_'), ref: where })\n }\n }\n}\n\nconst buildSQLWhere = (where: Where, alias: string) => {\n for (const k in where) {\n if (['AND', 'OR'].includes(k.toUpperCase())) {\n if (Array.isArray(where[k])) {\n const op = 'AND' === k.toUpperCase() ? and : or\n const accumulated = []\n for (const whereField of where[k]) {\n accumulated.push(buildSQLWhere(whereField, alias))\n }\n return op(...accumulated)\n }\n } else {\n let payloadOperator = Object.keys(where[k])[0]\n\n const value = where[k][payloadOperator]\n if (payloadOperator === '$raw') {\n if (typeof value !== 'string') {\n return undefined\n }\n return sql.raw(value)\n }\n\n // Handle exists: false -> use isNull instead of isNotNull\n\n // This logic is duplicated from sanitizeQueryValue.ts because buildSQLWhere\n // is a simplified WHERE builder for polymorphic joins that doesn't have access\n // to field definitions needed by sanitizeQueryValue\n if (payloadOperator === 'exists' && value === false) {\n payloadOperator = 'isNull'\n }\n\n if (!(payloadOperator in operatorMap)) {\n return undefined\n }\n\n const sanitizedColumnName = k\n .split('.')\n .map((s) => sanitizePathSegment(s))\n .join('_')\n\n return operatorMap[payloadOperator](sql.raw(`\"${alias}\".\"${sanitizedColumnName}\"`), value)\n }\n }\n}\n\ntype SQLSelect = SQLiteSelectBase<any, any, any, any>\n\ntype TraverseFieldArgs = {\n _locales: Result\n adapter: DrizzleAdapter\n collectionSlug?: string\n currentArgs: Result\n currentTableName: string\n depth?: number\n draftsEnabled?: boolean\n fields: FlattenedField[]\n forceWithFields?: boolean\n joinQuery: JoinQuery\n joins?: BuildQueryJoinAliases\n locale?: string\n parentIsLocalized?: boolean\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 withTabledFields: {\n numbers?: boolean\n rels?: boolean\n texts?: boolean\n }\n}\n\nexport const traverseFields = ({\n _locales,\n adapter,\n collectionSlug,\n currentArgs,\n currentTableName,\n depth,\n draftsEnabled,\n fields,\n forceWithFields,\n joinQuery = {},\n joins,\n locale,\n parentIsLocalized = false,\n path,\n select,\n selectAllOnCurrentLevel = false,\n selectMode,\n tablePath,\n topLevelArgs,\n topLevelTableName,\n versions,\n withTabledFields,\n}: TraverseFieldArgs) => {\n fields.forEach((field) => {\n if (fieldIsVirtual(field)) {\n return\n }\n\n const isFieldLocalized = fieldShouldBeLocalized({\n field,\n parentIsLocalized,\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 (isFieldLocalized) {\n _locales.with[`${path}${field.name}`] = true\n } else {\n currentArgs.with[`${path}${field.name}`] = true\n }\n }\n\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 const relationName = getArrayRelationName({\n field,\n path: `${path}${field.name}`,\n tableName: arrayTableName,\n })\n\n currentArgs.with[relationName] = withArray\n\n traverseFields({\n _locales: withArray.with._locales,\n adapter,\n currentArgs: withArray,\n currentTableName: arrayTableName,\n depth,\n draftsEnabled,\n fields: field.flattenedFields,\n forceWithFields,\n joinQuery,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n path: '',\n select: typeof arraySelect === 'object' ? arraySelect : undefined,\n selectMode,\n tablePath: '',\n topLevelArgs,\n topLevelTableName,\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 '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 if (adapter.blocksAsJSON) {\n if (select || selectAllOnCurrentLevel) {\n const fieldPath = `${path}${field.name}`\n\n if ((isFieldLocalized || parentIsLocalized) && _locales) {\n _locales.columns[fieldPath] = true\n } else if (adapter.tables[currentTableName]?.[fieldPath]) {\n currentArgs.columns[fieldPath] = true\n }\n }\n\n break\n }\n\n ;(field.blockReferences ?? field.blocks).forEach((_block) => {\n const block = typeof _block === 'string' ? adapter.payload.blocks[_block] : _block\n const blockKey = `_blocks_${block.slug}${!block[InternalBlockTableNameIndex] ? '' : `_${block[InternalBlockTableNameIndex]}`}`\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' && Boolean(blocksSelect[block.slug])) {\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 = resolveBlockTableName(\n block,\n adapter.tableNameMap.get(`${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 draftsEnabled,\n fields: block.flattenedFields,\n forceWithFields: blockSelect === true,\n joinQuery,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n path: '',\n select: typeof blockSelect === 'object' ? blockSelect : undefined,\n selectMode: blockSelectMode,\n tablePath: '',\n topLevelArgs,\n topLevelTableName,\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 collectionSlug,\n currentArgs,\n currentTableName,\n depth,\n draftsEnabled,\n fields: field.flattenedFields,\n forceWithFields,\n joinQuery,\n joins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\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 withTabledFields,\n })\n\n break\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 count: shouldCount = false,\n limit: limitArg = field.defaultLimit ?? 10,\n page,\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 columnName = `${path.replaceAll('.', '_')}${field.name}`\n\n const db = adapter.drizzle as LibSQLDatabase\n\n if (Array.isArray(field.collection)) {\n let currentQuery: null | SQLSelect = null\n const onPath = field.on.split('.').join('_')\n\n if (Array.isArray(sort)) {\n throw new Error('Not implemented')\n }\n\n let sanitizedSort = sort\n\n if (!sanitizedSort) {\n if (\n field.collection.some((collection) =>\n adapter.payload.collections[collection].config.fields.some(\n (f) => f.type === 'date' && f.name === 'createdAt',\n ),\n )\n ) {\n sanitizedSort = '-createdAt'\n } else {\n sanitizedSort = 'id'\n }\n }\n\n const sortOrder = sanitizedSort.startsWith('-') ? desc : asc\n sanitizedSort = sanitizedSort.replace('-', '')\n\n const sortPath = sanitizedSort.split('.').join('_')\n\n const wherePaths: { path: string; ref: any }[] = []\n\n if (where) {\n flattenAllWherePaths(where, wherePaths)\n }\n\n for (const collection of field.collection) {\n const joinCollectionTableName = adapter.tableNameMap.get(toSnakeCase(collection))\n\n const table = adapter.tables[joinCollectionTableName]\n\n const sortColumn = table[sortPath]\n\n const selectFields = {\n id: adapter.tables[joinCollectionTableName].id,\n parent: sql`${adapter.tables[joinCollectionTableName][onPath]}`.as(onPath),\n relationTo: sql`${collection}`.as('relationTo'),\n sortPath: sql`${sortColumn ? sortColumn : null}`.as('sortPath'),\n }\n\n const collectionQueryWhere: any[] = []\n // Select for WHERE and Fallback NULL\n for (const { path, ref } of wherePaths) {\n const collectioConfig = adapter.payload.collections[collection].config\n const field = getFieldByPath({ fields: collectioConfig.flattenedFields, path })\n\n if (field && field.field.type === 'select' && field.field.hasMany) {\n let tableName = adapter.tableNameMap.get(\n `${toSnakeCase(collection)}_${toSnakeCase(path)}`,\n )\n let parentTable = getTableName(table)\n\n if (adapter.schemaName) {\n tableName = `\"${adapter.schemaName}\".\"${tableName}\"`\n parentTable = `\"${adapter.schemaName}\".\"${parentTable}\"`\n }\n\n if (adapter.name === 'postgres') {\n selectFields[path] = sql\n .raw(\n `(select jsonb_agg(${tableName}.value) from ${tableName} where ${tableName}.parent_id = ${parentTable}.id)`,\n )\n .as(path)\n } else {\n selectFields[path] = sql\n .raw(\n `(select json_group_array(${tableName}.value) from ${tableName} where ${tableName}.parent_id = ${parentTable}.id)`,\n )\n .as(path)\n }\n\n const constraint = ref[path]\n const operator = Object.keys(constraint)[0]\n const value: any = Object.values(constraint)[0]\n\n const query = adapter.createJSONQuery({\n column: `\"${path}\"`,\n operator,\n pathSegments: [field.field.name],\n table: parentTable,\n value,\n })\n ref[path] = { $raw: query }\n } else if (adapter.tables[joinCollectionTableName][path]) {\n selectFields[path] = sql`${adapter.tables[joinCollectionTableName][path]}`.as(path)\n // Allow to filter by collectionSlug\n } else if (path !== 'relationTo') {\n // For timestamp fields like deletedAt, we need to cast to timestamp in Postgres\n // SQLite doesn't require explicit type casting for UNION queries\n if (path === 'deletedAt' && adapter.name === 'postgres') {\n selectFields[path] = sql`null::timestamp with time zone`.as(path)\n } else {\n selectFields[path] = sql`null`.as(path)\n }\n }\n }\n\n let query: any = db.select(selectFields).from(adapter.tables[joinCollectionTableName])\n if (collectionQueryWhere.length) {\n query = query.where(and(...collectionQueryWhere))\n }\n if (currentQuery === null) {\n currentQuery = query as unknown as SQLSelect\n } else {\n currentQuery = currentQuery.unionAll(query) as SQLSelect\n }\n }\n\n const subQueryAlias = `${columnName}_subquery`\n\n let sqlWhere = eq(\n sql.raw(`\"${currentTableName}\".\"id\"`),\n sql.raw(`\"${subQueryAlias}\".\"${onPath}\"`),\n )\n\n if (where && Object.keys(where).length > 0) {\n sqlWhere = and(sqlWhere, buildSQLWhere(where, subQueryAlias))\n }\n\n if (shouldCount) {\n currentArgs.extras[`${columnName}_count`] = sql`${db\n .select({ count: count() })\n .from(sql`${currentQuery.as(subQueryAlias)}`)\n .where(sqlWhere)}`.as(`${columnName}_count`)\n }\n\n // Sort direction for the batch / window-function query.\n // NOTE: sanitizedSort has already had its '-' stripped by this point (line ~503),\n // so we derive direction from sortOrder (computed before the strip) instead.\n const sortDir: 'ASC' | 'DESC' = sortOrder === desc ? 'DESC' : 'ASC'\n const sortedUnionAlias = `${columnName}_sorted`\n\n if (currentArgs._polymorphicJoins) {\n // Batch mode (enabled by findMany.ts): defer loading to a single\n // post-query batch instead of executing a correlated subquery per parent row.\n // Pre-build the WHERE SQL using the alias that findMany.ts will use for the\n // UNION subquery (${columnName}_pre), so it can be applied without re-importing\n // buildSQLWhere.\n const sqlWhere =\n where && Object.keys(where).length > 0\n ? buildSQLWhere(where, `${columnName}_pre`)\n : undefined\n\n currentArgs._polymorphicJoins.push({\n columnName,\n countColumnName: shouldCount ? `${columnName}_count` : undefined,\n currentQuery,\n limit,\n onPath,\n page,\n sortDir,\n sqlWhere,\n where,\n })\n } else {\n // Fallback: correlated subquery per parent row.\n // Used for single-doc reads (upsertRow / deleteOne) where N=1 and N+1 is negligible.\n let limitOffsetSQL = sql.empty()\n if (limit) {\n limitOffsetSQL = sql` LIMIT ${limit}`\n }\n if (page && limit !== 0) {\n const offset = (page - 1) * limit\n if (offset > 0) {\n limitOffsetSQL = sql`${limitOffsetSQL} OFFSET ${offset}`\n }\n }\n\n currentQuery = currentQuery.orderBy(sortOrder(sql`\"sortPath\"`)) as SQLSelect\n\n let innerWhere = sql.raw(\n `\"${sortedUnionAlias}\".\"${onPath}\" = \"${currentTableName}\".\"id\"`,\n )\n if (where && Object.keys(where).length > 0) {\n const additionalWhere = buildSQLWhere(where, sortedUnionAlias)\n innerWhere = sql`${innerWhere} AND ${additionalWhere}`\n }\n\n // IMPORTANT: For polymorphic joins, LIMIT must be applied AFTER correlating\n // to the parent row. Otherwise, the limit applies globally across ALL parents,\n // not per-parent.\n currentArgs.extras[columnName] = sql`(\n SELECT ${jsonAggBuildObject(adapter, {\n id: sql.raw(`\"${columnName}_subquery\".\"id\"`),\n relationTo: sql.raw(`\"${columnName}_subquery\".\"relationTo\"`),\n })}\n FROM (\n SELECT * FROM ${sql`${currentQuery.as(sortedUnionAlias)}`}\n WHERE ${innerWhere}${limitOffsetSQL}\n ) AS ${sql.raw(`\"${columnName}_subquery\"`)}\n )`.as(columnName)\n }\n } else {\n const useDrafts =\n (versions || draftsEnabled) &&\n hasDraftsEnabled(adapter.payload.collections[field.collection].config)\n\n const fields = useDrafts\n ? buildVersionCollectionFields(\n adapter.payload.config,\n adapter.payload.collections[field.collection].config,\n true,\n )\n : adapter.payload.collections[field.collection].config.flattenedFields\n\n const joinCollectionTableName = adapter.tableNameMap.get(\n useDrafts\n ? `_${toSnakeCase(field.collection)}${adapter.versionsSuffix}`\n : toSnakeCase(field.collection),\n )\n\n const joins: BuildQueryJoinAliases = []\n\n const currentIDColumn = versions\n ? adapter.tables[currentTableName].parent\n : adapter.tables[currentTableName].id\n\n let joinQueryWhere: Where\n\n const currentIDRaw = sql.raw(\n `\"${getNameFromDrizzleTable(currentIDColumn.table)}\".\"${currentIDColumn.name}\"`,\n )\n\n if (Array.isArray(field.targetField.relationTo)) {\n joinQueryWhere = {\n [field.on]: {\n equals: {\n relationTo: collectionSlug,\n value: rawConstraint(currentIDRaw),\n },\n },\n }\n } else {\n joinQueryWhere = {\n [field.on]: {\n equals: rawConstraint(currentIDRaw),\n },\n }\n }\n\n if (where && Object.keys(where).length) {\n joinQueryWhere = {\n and: [joinQueryWhere, where],\n }\n }\n\n if (useDrafts) {\n joinQueryWhere = combineQueries(appendVersionToQueryKey(joinQueryWhere), {\n latest: { equals: true },\n })\n }\n\n const columnName = `${path.replaceAll('.', '_')}${field.name}`\n\n const subQueryAlias = `${columnName}_alias`\n\n const { newAliasTable } = getTableAlias({\n adapter,\n tableName: joinCollectionTableName,\n })\n\n const {\n orderBy,\n selectFields,\n where: subQueryWhere,\n } = buildQuery({\n adapter,\n aliasTable: newAliasTable,\n fields,\n joins,\n locale,\n parentIsLocalized,\n selectLocale: true,\n sort: useDrafts\n ? getQueryDraftsSort({\n collectionConfig: adapter.payload.collections[field.collection].config,\n sort,\n })\n : sort,\n tableName: joinCollectionTableName,\n where: joinQueryWhere,\n })\n\n for (let key in selectFields) {\n const val = selectFields[key]\n\n if (val.table && getNameFromDrizzleTable(val.table) === joinCollectionTableName) {\n delete selectFields[key]\n key = key.split('.').pop()\n selectFields[key] = newAliasTable[key]\n }\n }\n\n if (useDrafts) {\n selectFields.parent = newAliasTable.parent\n }\n\n let query: SQLiteSelect = db\n .select(selectFields as any)\n .from(newAliasTable)\n .where(subQueryWhere)\n .orderBy(() => orderBy.map(({ column, order }) => order(column)))\n .$dynamic()\n\n joins.forEach(({ type, condition, table }) => {\n query = query[type ?? 'leftJoin'](table, condition)\n })\n\n if (page && limit !== 0) {\n const offset = (page - 1) * limit - 1\n if (offset > 0) {\n query = query.offset(offset)\n }\n }\n\n if (limit !== 0) {\n query = query.limit(limit)\n }\n\n const subQuery = query.as(subQueryAlias)\n\n if (shouldCount) {\n let countSubquery: SQLiteSelect = db\n .select(selectFields as any)\n\n .from(newAliasTable)\n .where(subQueryWhere)\n .$dynamic()\n\n joins.forEach(({ type, condition, table }) => {\n countSubquery = countSubquery[type ?? 'leftJoin'](table, condition)\n })\n\n currentArgs.extras[`${columnName}_count`] = sql`${db\n .select({\n count: count(),\n })\n .from(sql`${countSubquery.as(`${subQueryAlias}_count_subquery`)}`)}`.as(\n `${subQueryAlias}_count`,\n )\n }\n\n currentArgs.extras[columnName] = sql`${db\n .select({\n result: jsonAggBuildObject(adapter, {\n id: sql.raw(`\"${subQueryAlias}\".${useDrafts ? 'parent_id' : 'id'}`),\n ...(selectFields._locale && {\n locale: sql.raw(`\"${subQueryAlias}\".${selectFields._locale.name}`),\n }),\n }),\n })\n .from(sql`${subQuery}`)}`.as(subQueryAlias)\n }\n\n break\n }\n\n case 'point': {\n if (adapter.name === 'sqlite') {\n break\n }\n\n const args = isFieldLocalized ? _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' && Boolean(select[field.name])) ||\n (selectMode === 'exclude' && typeof select[field.name] === 'undefined')\n ) {\n shouldSelect = true\n }\n } else {\n shouldSelect = true\n }\n const tableName = fieldShouldBeLocalized({ field, parentIsLocalized })\n ? `${currentTableName}${adapter.localesSuffix}`\n : currentTableName\n\n if (shouldSelect) {\n args.extras[name] = sql\n .raw(`ST_AsGeoJSON(\"${adapter.tables[tableName][name].name}\")::jsonb`)\n .as(name)\n }\n break\n }\n\n case 'select': {\n if (select && !selectAllOnCurrentLevel) {\n if (\n (selectMode === 'include' && !select[field.name]) ||\n (selectMode === 'exclude' && select[field.name] === false)\n ) {\n break\n }\n }\n\n if (field.hasMany) {\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 break\n }\n\n if (select || selectAllOnCurrentLevel) {\n const fieldPath = `${path}${field.name}`\n\n if ((isFieldLocalized || parentIsLocalized) && _locales) {\n _locales.columns[fieldPath] = true\n } else if (adapter.tables[currentTableName]?.[fieldPath]) {\n currentArgs.columns[fieldPath] = true\n }\n }\n\n break\n }\n\n default: {\n if (forceWithFields) {\n if (\n (field.type === 'relationship' || field.type === 'upload') &&\n (field.hasMany || Array.isArray(field.relationTo))\n ) {\n withTabledFields.rels = true\n }\n\n if (field.type === 'number' && field.hasMany) {\n withTabledFields.numbers = true\n }\n\n if (field.type === 'text' && field.hasMany) {\n withTabledFields.texts = true\n }\n }\n\n if (!select && !selectAllOnCurrentLevel) {\n break\n }\n\n if (\n selectAllOnCurrentLevel ||\n (selectMode === 'include' && Boolean(select[field.name])) ||\n (selectMode === 'exclude' && typeof select[field.name] === 'undefined')\n ) {\n const fieldPath = `${path}${field.name}`\n\n if ((isFieldLocalized || parentIsLocalized) && _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' || field.type === 'upload') &&\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 return topLevelArgs\n}\n"],"names":["and","asc","count","desc","eq","getTableName","or","sql","appendVersionToQueryKey","buildVersionCollectionFields","combineQueries","getFieldByPath","getQueryDraftsSort","fieldIsVirtual","fieldShouldBeLocalized","hasDraftsEnabled","toSnakeCase","buildQuery","getTableAlias","operatorMap","getArrayRelationName","getNameFromDrizzleTable","jsonAggBuildObject","rawConstraint","sanitizePathSegment","InternalBlockTableNameIndex","resolveBlockTableName","flattenAllWherePaths","where","paths","k","includes","toUpperCase","Array","isArray","whereField","push","path","split","join","ref","buildSQLWhere","alias","op","accumulated","payloadOperator","Object","keys","value","undefined","raw","sanitizedColumnName","map","s","traverseFields","_locales","adapter","collectionSlug","currentArgs","currentTableName","depth","draftsEnabled","fields","forceWithFields","joinQuery","joins","locale","parentIsLocalized","select","selectAllOnCurrentLevel","selectMode","tablePath","topLevelArgs","topLevelTableName","versions","withTabledFields","forEach","field","isFieldLocalized","type","hasMany","relationTo","with","name","arraySelect","withArray","columns","id","_order","_parentID","orderBy","arrayTableName","tableNameMap","get","tables","_locale","_uuid","arrayTableNameWithLocales","localesSuffix","relationName","tableName","flattenedFields","localized","length","blocksSelect","blocksAsJSON","fieldPath","blockReferences","blocks","_block","block","payload","blockKey","slug","blockSelect","blockSelectMode","Boolean","withBlock","_path","fieldSelect","joinSchemaPath","replaceAll","shouldCount","limit","limitArg","defaultLimit","page","sort","defaultSort","columnName","db","drizzle","collection","currentQuery","onPath","on","Error","sanitizedSort","some","collections","config","f","sortOrder","startsWith","replace","sortPath","wherePaths","joinCollectionTableName","table","sortColumn","selectFields","parent","as","collectionQueryWhere","collectioConfig","parentTable","schemaName","constraint","operator","values","query","createJSONQuery","column","pathSegments","$raw","from","unionAll","subQueryAlias","sqlWhere","extras","sortDir","sortedUnionAlias","_polymorphicJoins","countColumnName","limitOffsetSQL","empty","offset","innerWhere","additionalWhere","useDrafts","versionsSuffix","currentIDColumn","joinQueryWhere","currentIDRaw","targetField","equals","latest","newAliasTable","subQueryWhere","aliasTable","selectLocale","collectionConfig","key","val","pop","order","$dynamic","condition","subQuery","countSubquery","result","args","shouldSelect","withSelect","rels","numbers","texts"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/queries/getTableColumnFromPath.ts"],"sourcesContent":["import type { SQL, Table } from 'drizzle-orm'\nimport type { SQLiteTableWithColumns } from 'drizzle-orm/sqlite-core'\nimport type {\n FlattenedBlock,\n FlattenedField,\n NumberField,\n RelationshipField,\n TextField,\n} from 'payload'\n\nimport { and, eq, getTableName, like, or, sql } from 'drizzle-orm'\nimport { type PgTableWithColumns } from 'drizzle-orm/pg-core'\nimport { APIError, getFieldByPath } from 'payload'\nimport { fieldShouldBeLocalized, tabHasName } from 'payload/shared'\nimport toSnakeCase from 'to-snake-case'\nimport { validate as uuidValidate } from 'uuid'\n\nimport type { DrizzleAdapter, GenericColumn } from '../types.js'\nimport type { BuildQueryJoinAliases } from './buildQuery.js'\n\nimport { isPolymorphicRelationship } from '../utilities/isPolymorphicRelationship.js'\nimport { jsonBuildObject } from '../utilities/json.js'\nimport { DistinctSymbol } from '../utilities/rawConstraint.js'\nimport { resolveBlockTableName } from '../utilities/validateExistingBlockIsIdentical.js'\nimport { addJoinTable } from './addJoinTable.js'\nimport { getTableAlias } from './getTableAlias.js'\n\ntype Constraint = {\n columnName: string\n table: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n value: unknown\n}\n\ntype TableColumn = {\n columnName?: string\n columns?: {\n idType: 'number' | 'text' | 'uuid'\n rawColumn: SQL<unknown>\n }[]\n constraints: Constraint[]\n field: FlattenedField\n getNotNullColumnByValue?: (val: unknown) => string\n pathSegments?: string[]\n rawColumn?: SQL\n table: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n}\n\ntype Args = {\n adapter: DrizzleAdapter\n aliasTable?: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n collectionPath: string\n columnPrefix?: string\n constraintPath?: string\n constraints?: Constraint[]\n fields: FlattenedField[]\n joins: BuildQueryJoinAliases\n locale?: string\n parentAliasTable?: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n parentIsLocalized: boolean\n pathSegments: string[]\n rootTableName?: string\n selectFields: Record<string, GenericColumn>\n selectLocale?: boolean\n tableName: string\n /**\n * If creating a new table name for arrays and blocks, this suffix should be appended to the table name\n */\n tableNameSuffix?: string\n /**\n * The raw value of the query before sanitization\n */\n value: unknown\n}\n/**\n * Transforms path to table and column name or to a list of OR columns\n * Adds tables to `join`\n * @returns TableColumn\n */\nexport const getTableColumnFromPath = ({\n adapter,\n aliasTable,\n collectionPath,\n columnPrefix = '',\n constraintPath: incomingConstraintPath,\n constraints = [],\n fields,\n joins,\n locale: incomingLocale,\n parentAliasTable,\n parentIsLocalized,\n pathSegments: incomingSegments,\n rootTableName: incomingRootTableName,\n selectFields,\n selectLocale,\n tableName,\n tableNameSuffix = '',\n value,\n}: Args): TableColumn => {\n const fieldPath = incomingSegments[0]\n let locale = incomingLocale\n const rootTableName = incomingRootTableName || tableName\n let constraintPath = incomingConstraintPath || ''\n\n const field = fields.find((fieldToFind) => fieldToFind.name === fieldPath)\n let newTableName = tableName\n\n if (!field && fieldPath === 'id') {\n selectFields.id = adapter.tables[newTableName].id\n return {\n columnName: 'id',\n constraints,\n field: {\n name: 'id',\n type: adapter.idType === 'uuid' ? 'text' : 'number',\n } as NumberField | TextField,\n table: adapter.tables[newTableName],\n }\n }\n\n let localizedPathQuery = false\n if (field) {\n const pathSegments = [...incomingSegments]\n\n const isFieldLocalized = fieldShouldBeLocalized({ field, parentIsLocalized })\n\n // If next segment is a locale,\n // we need to take it out and use it as the locale from this point on\n if (isFieldLocalized && adapter.payload.config.localization) {\n const matchedLocale = adapter.payload.config.localization.localeCodes.find(\n (locale) => locale === pathSegments[1],\n )\n\n if (matchedLocale) {\n locale = matchedLocale\n localizedPathQuery = true\n pathSegments.splice(1, 1)\n }\n }\n\n switch (field.type) {\n case 'array': {\n newTableName = adapter.tableNameMap.get(\n `${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`,\n )\n\n const arrayParentTable = aliasTable || adapter.tables[tableName]\n\n constraintPath = `${constraintPath}${field.name}.%.`\n if (locale && isFieldLocalized && adapter.payload.config.localization) {\n const conditions = [eq(arrayParentTable.id, adapter.tables[newTableName]._parentID)]\n\n if (selectLocale) {\n selectFields._locale = adapter.tables[newTableName]._locale\n }\n\n if (locale !== 'all') {\n conditions.push(eq(adapter.tables[newTableName]._locale, locale))\n }\n addJoinTable({\n condition: and(...conditions),\n isOneToMany: true,\n joins,\n table: adapter.tables[newTableName],\n })\n } else {\n addJoinTable({\n condition: eq(arrayParentTable.id, adapter.tables[newTableName]._parentID),\n isOneToMany: true,\n joins,\n table: adapter.tables[newTableName],\n })\n }\n\n return getTableColumnFromPath({\n adapter,\n collectionPath,\n constraintPath,\n constraints,\n fields: field.flattenedFields,\n joins,\n locale,\n parentAliasTable: aliasTable,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n selectLocale,\n tableName: newTableName,\n value,\n })\n }\n case 'blocks': {\n if (adapter.blocksAsJSON) {\n break\n }\n let blockTableColumn: TableColumn\n let newTableName: string\n\n // handle blockType queries\n if (pathSegments[1] === 'blockType') {\n // find the block config using the value\n const blockTypes = Array.isArray(value) ? value : [value]\n blockTypes.forEach((blockType) => {\n const block =\n adapter.payload.blocks[blockType] ??\n ((field.blockReferences ?? field.blocks).find(\n (block) => typeof block !== 'string' && block.slug === blockType,\n ) as FlattenedBlock | undefined)\n\n newTableName = resolveBlockTableName(\n block,\n adapter.tableNameMap.get(`${tableName}_blocks_${toSnakeCase(block.slug)}`),\n )\n\n const { newAliasTable } = getTableAlias({ adapter, tableName: newTableName })\n\n joins.push({\n condition: eq(adapter.tables[tableName].id, newAliasTable._parentID),\n table: newAliasTable,\n })\n constraints.push({\n columnName: '_path',\n table: newAliasTable,\n value: pathSegments[0],\n })\n })\n return {\n constraints,\n field,\n getNotNullColumnByValue: () => 'id',\n table: adapter.tables[tableName],\n }\n }\n\n const hasBlockField = (field.blockReferences ?? field.blocks).some((_block) => {\n const block = typeof _block === 'string' ? adapter.payload.blocks[_block] : _block\n\n newTableName = resolveBlockTableName(\n block,\n adapter.tableNameMap.get(`${tableName}_blocks_${toSnakeCase(block.slug)}`),\n )\n\n constraintPath = `${constraintPath}${field.name}.%.`\n\n let result: TableColumn\n const blockConstraints = []\n const blockSelectFields = {}\n\n let blockJoin: BuildQueryJoinAliases[0]\n if (isFieldLocalized && adapter.payload.config.localization) {\n const conditions = [\n eq(\n (aliasTable || adapter.tables[tableName]).id,\n adapter.tables[newTableName]._parentID,\n ),\n ]\n\n if (locale !== 'all') {\n conditions.push(eq(adapter.tables[newTableName]._locale, locale))\n }\n\n blockJoin = {\n condition: and(...conditions),\n table: adapter.tables[newTableName],\n }\n } else {\n blockJoin = {\n condition: eq(\n (aliasTable || adapter.tables[tableName]).id,\n adapter.tables[newTableName]._parentID,\n ),\n table: adapter.tables[newTableName],\n }\n }\n\n // Create a new reference for nested joins\n const newJoins = [...joins]\n\n try {\n result = getTableColumnFromPath({\n adapter,\n collectionPath,\n constraintPath,\n constraints: blockConstraints,\n fields: block.flattenedFields,\n joins: newJoins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields: blockSelectFields,\n selectLocale,\n tableName: newTableName,\n value,\n })\n } catch (_) {\n // this is fine, not every block will have the field\n }\n if (!result) {\n return\n }\n blockTableColumn = result\n constraints = constraints.concat(blockConstraints)\n selectFields = { ...selectFields, ...blockSelectFields }\n\n const previousLength = joins.length\n joins.push(blockJoin)\n // Append new joins AFTER the block join to prevent errors with missing FROM clause.\n if (newJoins.length > previousLength) {\n for (let i = previousLength; i < newJoins.length; i++) {\n joins.push(newJoins[i])\n }\n }\n return true\n })\n if (hasBlockField) {\n return {\n columnName: blockTableColumn.columnName,\n constraints,\n field: blockTableColumn.field,\n pathSegments: pathSegments.slice(1),\n rawColumn: blockTableColumn.rawColumn,\n table: blockTableColumn.table,\n }\n }\n break\n }\n\n case 'group': {\n if (locale && isFieldLocalized && adapter.payload.config.localization) {\n newTableName = `${tableName}${adapter.localesSuffix}`\n\n let condition = eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID)\n\n if (locale !== 'all') {\n condition = and(condition, eq(adapter.tables[newTableName]._locale, locale))\n }\n\n addJoinTable({\n condition,\n joins,\n table: adapter.tables[newTableName],\n })\n }\n return getTableColumnFromPath({\n adapter,\n aliasTable,\n collectionPath,\n columnPrefix: `${columnPrefix}${field.name}_`,\n constraintPath: `${constraintPath}${field.name}.`,\n constraints,\n fields: field.flattenedFields,\n joins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n selectLocale,\n tableName: newTableName,\n tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n value,\n })\n }\n\n case 'join': {\n if (Array.isArray(field.collection)) {\n throw new APIError('Not supported')\n }\n\n const newCollectionPath = pathSegments.slice(1).join('.')\n\n if (field.hasMany) {\n const relationTableName = `${adapter.tableNameMap.get(toSnakeCase(field.collection))}${adapter.relationshipsSuffix}`\n\n const existingTable = joins.find(\n (e) => e.queryPath === `${constraintPath}${field.name}._rels`,\n )\n\n const aliasRelationshipTable = (existingTable?.table ??\n getTableAlias({\n adapter,\n tableName: relationTableName,\n }).newAliasTable) as PgTableWithColumns<any>\n\n const relationshipField = getFieldByPath({\n fields: adapter.payload.collections[field.collection].config.flattenedFields,\n path: field.on,\n })\n if (!relationshipField) {\n throw new APIError('Relationship was not found')\n }\n\n if (!existingTable) {\n addJoinTable({\n condition: and(\n eq(\n adapter.tables[rootTableName].id,\n aliasRelationshipTable[\n `${(relationshipField.field as RelationshipField).relationTo as string}ID`\n ],\n ),\n like(aliasRelationshipTable.path, field.on),\n ),\n joins,\n queryPath: `${constraintPath}${field.name}._rels`,\n table: aliasRelationshipTable,\n })\n }\n\n if (newCollectionPath === 'id') {\n return {\n columnName: 'parent',\n constraints,\n field: {\n name: 'id',\n type: adapter.idType === 'uuid' ? 'text' : 'number',\n } as NumberField | TextField,\n table: aliasRelationshipTable,\n }\n }\n\n const relationshipConfig = adapter.payload.collections[field.collection].config\n const relationshipTableName = adapter.tableNameMap.get(\n toSnakeCase(relationshipConfig.slug),\n )\n\n // parent to relationship join table\n const relationshipFields = relationshipConfig.flattenedFields\n\n const existingMainTable = joins.find(\n (e) => e.queryPath === `${constraintPath}${field.name}`,\n )\n\n const relationshipTable = (existingMainTable?.table ??\n getTableAlias({\n adapter,\n tableName: relationshipTableName,\n }).newAliasTable) as PgTableWithColumns<any>\n\n if (!existingMainTable) {\n joins.push({\n condition: eq(aliasRelationshipTable.parent, relationshipTable.id),\n queryPath: `${constraintPath}${field.name}`,\n table: relationshipTable,\n })\n }\n\n return getTableColumnFromPath({\n adapter,\n aliasTable: relationshipTable,\n collectionPath: newCollectionPath,\n constraints,\n // relationshipFields are fields from a different collection => no parentIsLocalized\n fields: relationshipFields,\n joins,\n locale,\n parentIsLocalized: false,\n pathSegments: pathSegments.slice(1),\n rootTableName: relationshipTableName,\n selectFields,\n selectLocale,\n tableName: relationshipTableName,\n value,\n })\n }\n\n const newTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[field.collection].config.slug),\n )\n\n const existingTable = joins.find(\n (e) => e.queryPath === `${constraintPath}${field.name}`,\n )?.table\n const newAliasTable =\n existingTable || getTableAlias({ adapter, tableName: newTableName }).newAliasTable\n\n if (!existingTable) {\n joins.push({\n condition: eq(\n newAliasTable[field.on.replaceAll('.', '_')],\n aliasTable ? aliasTable.id : adapter.tables[tableName].id,\n ),\n queryPath: `${constraintPath}${field.name}`,\n table: newAliasTable,\n })\n }\n\n if (newCollectionPath === 'id') {\n return {\n columnName: 'id',\n constraints,\n field: {\n name: 'id',\n type: adapter.idType === 'uuid' ? 'text' : 'number',\n } as NumberField | TextField,\n table: newAliasTable,\n }\n }\n\n return getTableColumnFromPath({\n adapter,\n aliasTable: newAliasTable,\n collectionPath: newCollectionPath,\n constraintPath: '',\n constraints,\n fields: adapter.payload.collections[field.collection].config.flattenedFields,\n joins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n selectFields,\n tableName: newTableName,\n value,\n })\n\n break\n }\n\n case 'number':\n case 'text': {\n if (field.hasMany) {\n let tableType = 'texts'\n let columnName = 'text'\n if (field.type === 'number') {\n tableType = 'numbers'\n columnName = 'number'\n }\n newTableName = `${rootTableName}_${tableType}`\n\n const existingTable = joins.find((e) => e.queryPath === `${constraintPath}${field.name}`)\n\n const table = (existingTable?.table ??\n getTableAlias({ adapter, tableName: newTableName })\n .newAliasTable) as PgTableWithColumns<any>\n\n const joinConstraints = [\n eq(adapter.tables[rootTableName].id, table.parent),\n like(table.path, `${constraintPath}${field.name}`),\n ]\n\n if (locale && isFieldLocalized && adapter.payload.config.localization) {\n const conditions = [...joinConstraints]\n\n if (locale !== 'all') {\n conditions.push(eq(table._locale, locale))\n }\n\n addJoinTable({\n condition: and(...conditions),\n joins,\n queryPath: `${constraintPath}${field.name}`,\n table,\n })\n } else {\n addJoinTable({\n condition: and(...joinConstraints),\n joins,\n queryPath: `${constraintPath}${field.name}`,\n table,\n })\n }\n\n return {\n columnName,\n constraints,\n field,\n table,\n }\n }\n break\n }\n case 'relationship':\n case 'upload': {\n const newCollectionPath = pathSegments.slice(1).join('.')\n\n if (Array.isArray(field.relationTo) || field.hasMany) {\n let relationshipFields: FlattenedField[]\n const relationTableName = `${rootTableName}${adapter.relationshipsSuffix}`\n\n const existingJoin = joins.find((e) => e.queryPath === `${constraintPath}.${field.name}`)\n\n let aliasRelationshipTable: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n let aliasRelationshipTableName: string\n if (existingJoin) {\n aliasRelationshipTable = existingJoin.table\n aliasRelationshipTableName = getTableName(existingJoin.table)\n } else {\n const res = getTableAlias({\n adapter,\n tableName: relationTableName,\n })\n aliasRelationshipTable = res.newAliasTable\n aliasRelationshipTableName = res.newAliasTableName\n }\n\n if (selectLocale && isFieldLocalized && adapter.payload.config.localization) {\n selectFields._locale = aliasRelationshipTable.locale\n }\n\n // Join in the relationships table\n if (locale && isFieldLocalized && adapter.payload.config.localization) {\n const conditions = [\n eq(\n (parentAliasTable || aliasTable || adapter.tables[rootTableName]).id,\n aliasRelationshipTable.parent,\n ),\n like(aliasRelationshipTable.path, `${constraintPath}${field.name}`),\n ]\n\n if (locale !== 'all') {\n conditions.push(eq(aliasRelationshipTable.locale, locale))\n }\n\n addJoinTable({\n condition: and(...conditions),\n joins,\n queryPath: `${constraintPath}.${field.name}`,\n table: aliasRelationshipTable,\n })\n } else {\n // Join in the relationships table\n addJoinTable({\n condition: and(\n eq(\n (parentAliasTable || aliasTable || adapter.tables[rootTableName]).id,\n aliasRelationshipTable.parent,\n ),\n like(aliasRelationshipTable.path, `${constraintPath}${field.name}`),\n ),\n joins,\n queryPath: `${constraintPath}.${field.name}`,\n table: aliasRelationshipTable,\n })\n }\n\n selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path\n\n let newAliasTable\n\n if (typeof field.relationTo === 'string') {\n const relationshipConfig = adapter.payload.collections[field.relationTo].config\n\n newTableName = adapter.tableNameMap.get(toSnakeCase(relationshipConfig.slug))\n\n // parent to relationship join table\n relationshipFields = relationshipConfig.flattenedFields\n ;({ newAliasTable } = getTableAlias({ adapter, tableName: newTableName }))\n\n joins.push({\n condition: eq(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),\n table: newAliasTable,\n })\n\n if (newCollectionPath === '' || newCollectionPath === 'id') {\n return {\n columnName: `${field.relationTo}ID`,\n constraints,\n field,\n table: aliasRelationshipTable,\n }\n }\n } else if (newCollectionPath === 'value') {\n const hasCustomCollectionWithCustomID = field.relationTo.some(\n (relationTo) => !!adapter.payload.collections[relationTo].customIDType,\n )\n\n const columns: TableColumn['columns'] = field.relationTo\n .map((relationTo) => {\n let idType: 'number' | 'text' | 'uuid' =\n adapter.idType === 'uuid' ? 'uuid' : 'number'\n\n const { customIDType } = adapter.payload.collections[relationTo]\n\n if (customIDType) {\n idType = customIDType\n }\n\n const idTypeTextOrUuid = idType === 'text' || idType === 'uuid'\n\n // Do not add the column to OR if we know that it can't match by the type\n // We can't do the same with idType: 'number' because `value` can be from the REST search query params\n if (typeof value === 'number' && idTypeTextOrUuid) {\n return null\n }\n\n if (\n Array.isArray(value) &&\n value.every((val) => typeof val === 'number') &&\n idTypeTextOrUuid\n ) {\n return null\n }\n\n // Do not add the UUID type column if incoming query value doesn't match UUID. If there aren't any collections with\n // a custom ID type, we skip this check\n // We need this because Postgres throws an error if querying by UUID column with a value that isn't a valid UUID.\n if (\n value &&\n !Array.isArray(value) &&\n idType === 'uuid' &&\n hasCustomCollectionWithCustomID\n ) {\n if (!uuidValidate(value)) {\n return null\n }\n }\n\n if (\n Array.isArray(value) &&\n idType === 'uuid' &&\n hasCustomCollectionWithCustomID &&\n !value.some((val) => uuidValidate(val))\n ) {\n return null\n }\n\n const relationTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[relationTo].config.slug),\n )\n\n return {\n idType,\n rawColumn: sql.raw(`\"${aliasRelationshipTableName}\".\"${relationTableName}_id\"`),\n }\n })\n .filter(Boolean)\n\n return {\n columns,\n constraints,\n field,\n table: aliasRelationshipTable,\n }\n } else if (newCollectionPath === 'relationTo') {\n const relationTo = Array.isArray(field.relationTo)\n ? field.relationTo\n : [field.relationTo]\n\n return {\n constraints,\n field,\n getNotNullColumnByValue: (val) => {\n const matchedRelation = relationTo.find((relation) => relation === val)\n if (matchedRelation) {\n return `${matchedRelation}ID`\n }\n return undefined\n },\n table: aliasRelationshipTable,\n }\n } else if (isPolymorphicRelationship(value)) {\n const { relationTo } = value\n\n const relationTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[relationTo].config.slug),\n )\n\n return {\n constraints,\n field,\n rawColumn: sql.raw(`\"${aliasRelationshipTableName}\".\"${relationTableName}_id\"`),\n table: aliasRelationshipTable,\n }\n } else if (value === DistinctSymbol) {\n const obj: Record<string, SQL> = {}\n\n field.relationTo.forEach((relationTo) => {\n const relationTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[relationTo].config.slug),\n )\n\n obj[relationTo] = sql.raw(`\"${aliasRelationshipTableName}\".\"${relationTableName}_id\"`)\n })\n\n let rawColumn = jsonBuildObject(adapter, obj)\n if (adapter.name === 'postgres') {\n rawColumn = sql`${rawColumn}::text`\n }\n\n return {\n constraints,\n field,\n rawColumn,\n table: aliasRelationshipTable,\n }\n } else {\n throw new APIError('Not supported')\n }\n\n return getTableColumnFromPath({\n adapter,\n aliasTable: newAliasTable,\n collectionPath: newCollectionPath,\n constraints,\n // relationshipFields are fields from a different collection => no parentIsLocalized\n fields: relationshipFields,\n joins,\n locale,\n parentIsLocalized: false,\n pathSegments: pathSegments.slice(1),\n rootTableName: newTableName,\n selectFields,\n selectLocale,\n tableName: newTableName,\n value,\n })\n } else if (\n pathSegments.length > 1 &&\n !(pathSegments.length === 2 && pathSegments[1] === 'id')\n ) {\n // simple relationships\n const columnName = `${columnPrefix}${field.name}`\n const newTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[field.relationTo].config.slug),\n )\n const { newAliasTable } = getTableAlias({ adapter, tableName: newTableName })\n\n if (isFieldLocalized && adapter.payload.config.localization) {\n const { newAliasTable: aliasLocaleTable } = getTableAlias({\n adapter,\n tableName: `${rootTableName}${adapter.localesSuffix}`,\n })\n\n const condtions = [eq(aliasLocaleTable._parentID, adapter.tables[rootTableName].id)]\n\n if (selectLocale) {\n selectFields._locale = aliasLocaleTable._locale\n }\n\n if (locale !== 'all') {\n condtions.push(eq(aliasLocaleTable._locale, locale))\n }\n\n const localesTable = adapter.tables[`${rootTableName}${adapter.localesSuffix}`]\n\n addJoinTable({\n condition: and(...condtions),\n joins,\n table: localesTable,\n })\n\n joins.push({\n condition: eq(localesTable[columnName], newAliasTable.id),\n table: newAliasTable,\n })\n } else {\n joins.push({\n condition: eq(\n newAliasTable.id,\n aliasTable ? aliasTable[columnName] : adapter.tables[tableName][columnName],\n ),\n table: newAliasTable,\n })\n }\n\n return getTableColumnFromPath({\n adapter,\n aliasTable: newAliasTable,\n collectionPath: newCollectionPath,\n constraintPath: '',\n constraints,\n fields: adapter.payload.collections[field.relationTo].config.flattenedFields,\n joins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n selectFields,\n tableName: newTableName,\n value,\n })\n }\n\n break\n }\n\n case 'select': {\n if (field.hasMany) {\n const newTableName = adapter.tableNameMap.get(\n `${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`,\n )\n\n const idColumn = (aliasTable ?? adapter.tables[tableName]).id\n if (locale && isFieldLocalized && adapter.payload.config.localization) {\n const conditions = [\n eq(idColumn, adapter.tables[newTableName].parent),\n eq(adapter.tables[newTableName]._locale, locale),\n ]\n\n if (locale !== 'all') {\n conditions.push(eq(adapter.tables[newTableName]._locale, locale))\n }\n\n addJoinTable({\n condition: and(...conditions),\n joins,\n table: adapter.tables[newTableName],\n })\n } else {\n addJoinTable({\n condition: eq(idColumn, adapter.tables[newTableName].parent),\n joins,\n table: adapter.tables[newTableName],\n })\n }\n\n return {\n columnName: 'value',\n constraints,\n field,\n table: adapter.tables[newTableName],\n }\n }\n break\n }\n\n case 'tab': {\n if (tabHasName(field)) {\n return getTableColumnFromPath({\n adapter,\n aliasTable,\n collectionPath,\n columnPrefix: `${columnPrefix}${field.name}_`,\n constraintPath: `${constraintPath}${field.name}.`,\n constraints,\n fields: field.flattenedFields,\n joins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n selectLocale,\n tableName: newTableName,\n tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n value,\n })\n }\n return getTableColumnFromPath({\n adapter,\n aliasTable,\n collectionPath,\n columnPrefix,\n constraintPath,\n constraints,\n fields: field.flattenedFields,\n joins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n selectLocale,\n tableName: newTableName,\n tableNameSuffix,\n value,\n })\n }\n\n default: {\n // fall through\n break\n }\n }\n\n let newTable = adapter.tables[newTableName]\n\n if (isFieldLocalized && adapter.payload.config.localization) {\n // If localized, we go to localized table and set aliasTable to undefined\n // so it is not picked up below to be used as targetTable\n const parentTable = aliasTable || adapter.tables[tableName]\n newTableName = `${tableName}${adapter.localesSuffix}`\n\n // use an alias because the same query may contain constraints with different locale value\n if (localizedPathQuery) {\n const { newAliasTable } = getTableAlias({ adapter, tableName: newTableName })\n newTable = newAliasTable\n } else {\n newTable = adapter.tables[newTableName]\n }\n\n let condition = eq(parentTable.id, newTable._parentID)\n\n if (locale !== 'all') {\n condition = and(condition, eq(newTable._locale, locale))\n }\n\n if (selectLocale) {\n selectFields._locale = newTable._locale\n }\n\n addJoinTable({\n condition,\n joins,\n table: newTable,\n })\n\n aliasTable = undefined\n }\n\n const targetTable = aliasTable || newTable\n\n selectFields[`${newTableName}.${columnPrefix}${field.name}`] =\n targetTable[`${columnPrefix}${field.name}`]\n\n return {\n columnName: `${columnPrefix}${field.name}`,\n constraints,\n field,\n pathSegments,\n table: targetTable,\n }\n }\n\n throw new APIError(`Cannot find field for path at ${fieldPath}`)\n}\n"],"names":["and","eq","getTableName","like","sql","APIError","getFieldByPath","fieldShouldBeLocalized","tabHasName","toSnakeCase","validate","uuidValidate","isPolymorphicRelationship","jsonBuildObject","DistinctSymbol","resolveBlockTableName","addJoinTable","getTableAlias","getTableColumnFromPath","adapter","aliasTable","collectionPath","columnPrefix","constraintPath","incomingConstraintPath","constraints","fields","joins","locale","incomingLocale","parentAliasTable","parentIsLocalized","pathSegments","incomingSegments","rootTableName","incomingRootTableName","selectFields","selectLocale","tableName","tableNameSuffix","value","fieldPath","field","find","fieldToFind","name","newTableName","id","tables","columnName","type","idType","table","localizedPathQuery","isFieldLocalized","payload","config","localization","matchedLocale","localeCodes","splice","tableNameMap","get","arrayParentTable","conditions","_parentID","_locale","push","condition","isOneToMany","flattenedFields","localized","slice","blocksAsJSON","blockTableColumn","blockTypes","Array","isArray","forEach","blockType","block","blocks","blockReferences","slug","newAliasTable","getNotNullColumnByValue","hasBlockField","some","_block","result","blockConstraints","blockSelectFields","blockJoin","newJoins","_","concat","previousLength","length","i","rawColumn","localesSuffix","collection","newCollectionPath","join","hasMany","relationTableName","relationshipsSuffix","existingTable","e","queryPath","aliasRelationshipTable","relationshipField","collections","path","on","relationTo","relationshipConfig","relationshipTableName","relationshipFields","existingMainTable","relationshipTable","parent","replaceAll","tableType","joinConstraints","existingJoin","aliasRelationshipTableName","res","newAliasTableName","hasCustomCollectionWithCustomID","customIDType","columns","map","idTypeTextOrUuid","every","val","raw","filter","Boolean","matchedRelation","relation","undefined","obj","aliasLocaleTable","condtions","localesTable","idColumn","newTable","parentTable","targetTable"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../src/queries/getTableColumnFromPath.ts"],"sourcesContent":["import type { SQL, Table } from 'drizzle-orm'\nimport type { SQLiteTableWithColumns } from 'drizzle-orm/sqlite-core'\nimport type {\n FlattenedBlock,\n FlattenedField,\n NumberField,\n RelationshipField,\n TextField,\n} from 'payload'\n\nimport { and, eq, getTableName, like, or, sql } from 'drizzle-orm'\nimport { type PgTableWithColumns } from 'drizzle-orm/pg-core'\nimport { APIError, getFieldByPath } from 'payload'\nimport { fieldShouldBeLocalized, tabHasName } from 'payload/shared'\nimport toSnakeCase from 'to-snake-case'\nimport { validate as uuidValidate } from 'uuid'\n\nimport type { DrizzleAdapter, GenericColumn } from '../types.js'\nimport type { BuildQueryJoinAliases } from './buildQuery.js'\n\nimport { isPolymorphicRelationship } from '../utilities/isPolymorphicRelationship.js'\nimport { jsonBuildObject } from '../utilities/json.js'\nimport { DistinctSymbol } from '../utilities/rawConstraint.js'\nimport { resolveBlockTableName } from '../utilities/validateExistingBlockIsIdentical.js'\nimport { addJoinTable } from './addJoinTable.js'\nimport { getTableAlias } from './getTableAlias.js'\n\ntype Constraint = {\n columnName: string\n table: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n value: unknown\n}\n\ntype TableColumn = {\n columnName?: string\n columns?: {\n idType: 'number' | 'text' | 'uuid'\n rawColumn: SQL<unknown>\n }[]\n constraints: Constraint[]\n field: FlattenedField\n getNotNullColumnByValue?: (val: unknown) => string\n pathSegments?: string[]\n rawColumn?: SQL\n table: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n}\n\ntype Args = {\n adapter: DrizzleAdapter\n aliasTable?: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n collectionPath: string\n columnPrefix?: string\n constraintPath?: string\n constraints?: Constraint[]\n fields: FlattenedField[]\n joins: BuildQueryJoinAliases\n locale?: string\n parentAliasTable?: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n parentIsLocalized: boolean\n pathSegments: string[]\n rootTableName?: string\n selectFields: Record<string, GenericColumn>\n selectLocale?: boolean\n tableName: string\n /**\n * If creating a new table name for arrays and blocks, this suffix should be appended to the table name\n */\n tableNameSuffix?: string\n /**\n * The raw value of the query before sanitization\n */\n value: unknown\n}\n/**\n * Transforms path to table and column name or to a list of OR columns\n * Adds tables to `join`\n * @returns TableColumn\n */\nexport const getTableColumnFromPath = ({\n adapter,\n aliasTable,\n collectionPath,\n columnPrefix = '',\n constraintPath: incomingConstraintPath,\n constraints = [],\n fields,\n joins,\n locale: incomingLocale,\n parentAliasTable,\n parentIsLocalized,\n pathSegments: incomingSegments,\n rootTableName: incomingRootTableName,\n selectFields,\n selectLocale,\n tableName,\n tableNameSuffix = '',\n value,\n}: Args): TableColumn => {\n const fieldPath = incomingSegments[0]\n let locale = incomingLocale\n const rootTableName = incomingRootTableName || tableName\n let constraintPath = incomingConstraintPath || ''\n\n const field = fields.find((fieldToFind) => fieldToFind.name === fieldPath)\n let newTableName = tableName\n\n if (!field && fieldPath === 'id') {\n selectFields.id = adapter.tables[newTableName].id\n return {\n columnName: 'id',\n constraints,\n field: {\n name: 'id',\n type: adapter.idType === 'uuid' ? 'text' : 'number',\n } as NumberField | TextField,\n table: adapter.tables[newTableName],\n }\n }\n\n let localizedPathQuery = false\n if (field) {\n const pathSegments = [...incomingSegments]\n\n const isFieldLocalized = fieldShouldBeLocalized({ field, parentIsLocalized })\n\n // If next segment is a locale,\n // we need to take it out and use it as the locale from this point on\n if (isFieldLocalized && adapter.payload.config.localization) {\n const matchedLocale = adapter.payload.config.localization.localeCodes.find(\n (locale) => locale === pathSegments[1],\n )\n\n if (matchedLocale) {\n locale = matchedLocale\n localizedPathQuery = true\n pathSegments.splice(1, 1)\n }\n }\n\n switch (field.type) {\n case 'array': {\n newTableName = adapter.tableNameMap.get(\n `${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`,\n )\n\n const arrayParentTable = aliasTable || adapter.tables[tableName]\n\n constraintPath = `${constraintPath}${field.name}.%.`\n if (locale && isFieldLocalized && adapter.payload.config.localization) {\n const conditions = [eq(arrayParentTable.id, adapter.tables[newTableName]._parentID)]\n\n if (selectLocale) {\n selectFields._locale = adapter.tables[newTableName]._locale\n }\n\n if (locale !== 'all') {\n conditions.push(eq(adapter.tables[newTableName]._locale, locale))\n }\n addJoinTable({\n condition: and(...conditions),\n isOneToMany: true,\n joins,\n table: adapter.tables[newTableName],\n })\n } else {\n addJoinTable({\n condition: eq(arrayParentTable.id, adapter.tables[newTableName]._parentID),\n isOneToMany: true,\n joins,\n table: adapter.tables[newTableName],\n })\n }\n\n return getTableColumnFromPath({\n adapter,\n collectionPath,\n constraintPath,\n constraints,\n fields: field.flattenedFields,\n joins,\n locale,\n parentAliasTable: aliasTable,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n selectLocale,\n tableName: newTableName,\n value,\n })\n }\n case 'blocks': {\n if (adapter.blocksAsJSON) {\n break\n }\n let blockTableColumn: TableColumn\n let newTableName: string\n\n // handle blockType queries\n if (pathSegments[1] === 'blockType') {\n // find the block config using the value\n const blockTypes = Array.isArray(value) ? value : [value]\n blockTypes.forEach((blockType) => {\n const block =\n adapter.payload.blocks[blockType] ??\n ((field.blockReferences ?? field.blocks).find(\n (block) => typeof block !== 'string' && block.slug === blockType,\n ) as FlattenedBlock | undefined)\n\n newTableName = resolveBlockTableName(\n block,\n adapter.tableNameMap.get(`${tableName}_blocks_${toSnakeCase(block.slug)}`),\n )\n\n const { newAliasTable } = getTableAlias({ adapter, tableName: newTableName })\n\n joins.push({\n condition: eq(adapter.tables[tableName].id, newAliasTable._parentID),\n table: newAliasTable,\n })\n constraints.push({\n columnName: '_path',\n table: newAliasTable,\n value: `${constraintPath}${pathSegments[0]}`,\n })\n })\n return {\n constraints,\n field,\n getNotNullColumnByValue: () => 'id',\n table: adapter.tables[tableName],\n }\n }\n\n const hasBlockField = (field.blockReferences ?? field.blocks).some((_block) => {\n const block = typeof _block === 'string' ? adapter.payload.blocks[_block] : _block\n\n newTableName = resolveBlockTableName(\n block,\n adapter.tableNameMap.get(`${tableName}_blocks_${toSnakeCase(block.slug)}`),\n )\n\n constraintPath = `${constraintPath}${field.name}.%.`\n\n let result: TableColumn\n const blockConstraints = []\n const blockSelectFields = {}\n\n let blockJoin: BuildQueryJoinAliases[0]\n if (isFieldLocalized && adapter.payload.config.localization) {\n const conditions = [\n eq(\n (aliasTable || adapter.tables[tableName]).id,\n adapter.tables[newTableName]._parentID,\n ),\n ]\n\n if (locale !== 'all') {\n conditions.push(eq(adapter.tables[newTableName]._locale, locale))\n }\n\n blockJoin = {\n condition: and(...conditions),\n table: adapter.tables[newTableName],\n }\n } else {\n blockJoin = {\n condition: eq(\n (aliasTable || adapter.tables[tableName]).id,\n adapter.tables[newTableName]._parentID,\n ),\n table: adapter.tables[newTableName],\n }\n }\n\n // Create a new reference for nested joins\n const newJoins = [...joins]\n\n try {\n result = getTableColumnFromPath({\n adapter,\n collectionPath,\n constraintPath,\n constraints: blockConstraints,\n fields: block.flattenedFields,\n joins: newJoins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields: blockSelectFields,\n selectLocale,\n tableName: newTableName,\n value,\n })\n } catch (_) {\n // this is fine, not every block will have the field\n }\n if (!result) {\n return\n }\n blockTableColumn = result\n constraints = constraints.concat(blockConstraints)\n selectFields = { ...selectFields, ...blockSelectFields }\n\n const previousLength = joins.length\n joins.push(blockJoin)\n // Append new joins AFTER the block join to prevent errors with missing FROM clause.\n if (newJoins.length > previousLength) {\n for (let i = previousLength; i < newJoins.length; i++) {\n joins.push(newJoins[i])\n }\n }\n return true\n })\n if (hasBlockField) {\n return {\n columnName: blockTableColumn.columnName,\n constraints,\n field: blockTableColumn.field,\n pathSegments: pathSegments.slice(1),\n rawColumn: blockTableColumn.rawColumn,\n table: blockTableColumn.table,\n }\n }\n break\n }\n\n case 'group': {\n if (locale && isFieldLocalized && adapter.payload.config.localization) {\n newTableName = `${tableName}${adapter.localesSuffix}`\n\n let condition = eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID)\n\n if (locale !== 'all') {\n condition = and(condition, eq(adapter.tables[newTableName]._locale, locale))\n }\n\n addJoinTable({\n condition,\n joins,\n table: adapter.tables[newTableName],\n })\n }\n return getTableColumnFromPath({\n adapter,\n aliasTable,\n collectionPath,\n columnPrefix: `${columnPrefix}${field.name}_`,\n constraintPath: `${constraintPath}${field.name}.`,\n constraints,\n fields: field.flattenedFields,\n joins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n selectLocale,\n tableName: newTableName,\n tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n value,\n })\n }\n\n case 'join': {\n if (Array.isArray(field.collection)) {\n throw new APIError('Not supported')\n }\n\n const newCollectionPath = pathSegments.slice(1).join('.')\n\n if (field.hasMany) {\n const relationTableName = `${adapter.tableNameMap.get(toSnakeCase(field.collection))}${adapter.relationshipsSuffix}`\n\n const existingTable = joins.find(\n (e) => e.queryPath === `${constraintPath}${field.name}._rels`,\n )\n\n const aliasRelationshipTable = (existingTable?.table ??\n getTableAlias({\n adapter,\n tableName: relationTableName,\n }).newAliasTable) as PgTableWithColumns<any>\n\n const relationshipField = getFieldByPath({\n fields: adapter.payload.collections[field.collection].config.flattenedFields,\n path: field.on,\n })\n if (!relationshipField) {\n throw new APIError('Relationship was not found')\n }\n\n if (!existingTable) {\n addJoinTable({\n condition: and(\n eq(\n adapter.tables[rootTableName].id,\n aliasRelationshipTable[\n `${(relationshipField.field as RelationshipField).relationTo as string}ID`\n ],\n ),\n like(aliasRelationshipTable.path, field.on),\n ),\n joins,\n queryPath: `${constraintPath}${field.name}._rels`,\n table: aliasRelationshipTable,\n })\n }\n\n if (newCollectionPath === 'id') {\n return {\n columnName: 'parent',\n constraints,\n field: {\n name: 'id',\n type: adapter.idType === 'uuid' ? 'text' : 'number',\n } as NumberField | TextField,\n table: aliasRelationshipTable,\n }\n }\n\n const relationshipConfig = adapter.payload.collections[field.collection].config\n const relationshipTableName = adapter.tableNameMap.get(\n toSnakeCase(relationshipConfig.slug),\n )\n\n // parent to relationship join table\n const relationshipFields = relationshipConfig.flattenedFields\n\n const existingMainTable = joins.find(\n (e) => e.queryPath === `${constraintPath}${field.name}`,\n )\n\n const relationshipTable = (existingMainTable?.table ??\n getTableAlias({\n adapter,\n tableName: relationshipTableName,\n }).newAliasTable) as PgTableWithColumns<any>\n\n if (!existingMainTable) {\n joins.push({\n condition: eq(aliasRelationshipTable.parent, relationshipTable.id),\n queryPath: `${constraintPath}${field.name}`,\n table: relationshipTable,\n })\n }\n\n return getTableColumnFromPath({\n adapter,\n aliasTable: relationshipTable,\n collectionPath: newCollectionPath,\n constraints,\n // relationshipFields are fields from a different collection => no parentIsLocalized\n fields: relationshipFields,\n joins,\n locale,\n parentIsLocalized: false,\n pathSegments: pathSegments.slice(1),\n rootTableName: relationshipTableName,\n selectFields,\n selectLocale,\n tableName: relationshipTableName,\n value,\n })\n }\n\n const newTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[field.collection].config.slug),\n )\n\n const existingTable = joins.find(\n (e) => e.queryPath === `${constraintPath}${field.name}`,\n )?.table\n const newAliasTable =\n existingTable || getTableAlias({ adapter, tableName: newTableName }).newAliasTable\n\n if (!existingTable) {\n joins.push({\n condition: eq(\n newAliasTable[field.on.replaceAll('.', '_')],\n aliasTable ? aliasTable.id : adapter.tables[tableName].id,\n ),\n queryPath: `${constraintPath}${field.name}`,\n table: newAliasTable,\n })\n }\n\n if (newCollectionPath === 'id') {\n return {\n columnName: 'id',\n constraints,\n field: {\n name: 'id',\n type: adapter.idType === 'uuid' ? 'text' : 'number',\n } as NumberField | TextField,\n table: newAliasTable,\n }\n }\n\n return getTableColumnFromPath({\n adapter,\n aliasTable: newAliasTable,\n collectionPath: newCollectionPath,\n constraintPath: '',\n constraints,\n fields: adapter.payload.collections[field.collection].config.flattenedFields,\n joins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n selectFields,\n tableName: newTableName,\n value,\n })\n\n break\n }\n\n case 'number':\n case 'text': {\n if (field.hasMany) {\n let tableType = 'texts'\n let columnName = 'text'\n if (field.type === 'number') {\n tableType = 'numbers'\n columnName = 'number'\n }\n newTableName = `${rootTableName}_${tableType}`\n\n const existingTable = joins.find((e) => e.queryPath === `${constraintPath}${field.name}`)\n\n const table = (existingTable?.table ??\n getTableAlias({ adapter, tableName: newTableName })\n .newAliasTable) as PgTableWithColumns<any>\n\n const joinConstraints = [\n eq(adapter.tables[rootTableName].id, table.parent),\n like(table.path, `${constraintPath}${field.name}`),\n ]\n\n if (locale && isFieldLocalized && adapter.payload.config.localization) {\n const conditions = [...joinConstraints]\n\n if (locale !== 'all') {\n conditions.push(eq(table._locale, locale))\n }\n\n addJoinTable({\n condition: and(...conditions),\n joins,\n queryPath: `${constraintPath}${field.name}`,\n table,\n })\n } else {\n addJoinTable({\n condition: and(...joinConstraints),\n joins,\n queryPath: `${constraintPath}${field.name}`,\n table,\n })\n }\n\n return {\n columnName,\n constraints,\n field,\n table,\n }\n }\n break\n }\n case 'relationship':\n case 'upload': {\n const newCollectionPath = pathSegments.slice(1).join('.')\n\n if (Array.isArray(field.relationTo) || field.hasMany) {\n let relationshipFields: FlattenedField[]\n const relationTableName = `${rootTableName}${adapter.relationshipsSuffix}`\n\n const existingJoin = joins.find((e) => e.queryPath === `${constraintPath}.${field.name}`)\n\n let aliasRelationshipTable: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n let aliasRelationshipTableName: string\n if (existingJoin) {\n aliasRelationshipTable = existingJoin.table\n aliasRelationshipTableName = getTableName(existingJoin.table)\n } else {\n const res = getTableAlias({\n adapter,\n tableName: relationTableName,\n })\n aliasRelationshipTable = res.newAliasTable\n aliasRelationshipTableName = res.newAliasTableName\n }\n\n if (selectLocale && isFieldLocalized && adapter.payload.config.localization) {\n selectFields._locale = aliasRelationshipTable.locale\n }\n\n // Join in the relationships table\n if (locale && isFieldLocalized && adapter.payload.config.localization) {\n const conditions = [\n eq(\n (parentAliasTable || aliasTable || adapter.tables[rootTableName]).id,\n aliasRelationshipTable.parent,\n ),\n like(aliasRelationshipTable.path, `${constraintPath}${field.name}`),\n ]\n\n if (locale !== 'all') {\n conditions.push(eq(aliasRelationshipTable.locale, locale))\n }\n\n addJoinTable({\n condition: and(...conditions),\n joins,\n queryPath: `${constraintPath}.${field.name}`,\n table: aliasRelationshipTable,\n })\n } else {\n // Join in the relationships table\n addJoinTable({\n condition: and(\n eq(\n (parentAliasTable || aliasTable || adapter.tables[rootTableName]).id,\n aliasRelationshipTable.parent,\n ),\n like(aliasRelationshipTable.path, `${constraintPath}${field.name}`),\n ),\n joins,\n queryPath: `${constraintPath}.${field.name}`,\n table: aliasRelationshipTable,\n })\n }\n\n selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path\n\n let newAliasTable\n\n if (typeof field.relationTo === 'string') {\n const relationshipConfig = adapter.payload.collections[field.relationTo].config\n\n newTableName = adapter.tableNameMap.get(toSnakeCase(relationshipConfig.slug))\n\n // parent to relationship join table\n relationshipFields = relationshipConfig.flattenedFields\n ;({ newAliasTable } = getTableAlias({ adapter, tableName: newTableName }))\n\n joins.push({\n condition: eq(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),\n table: newAliasTable,\n })\n\n if (newCollectionPath === '' || newCollectionPath === 'id') {\n return {\n columnName: `${field.relationTo}ID`,\n constraints,\n field,\n table: aliasRelationshipTable,\n }\n }\n } else if (newCollectionPath === 'value') {\n const hasCustomCollectionWithCustomID = field.relationTo.some(\n (relationTo) => !!adapter.payload.collections[relationTo].customIDType,\n )\n\n const columns: TableColumn['columns'] = field.relationTo\n .map((relationTo) => {\n let idType: 'number' | 'text' | 'uuid' =\n adapter.idType === 'uuid' ? 'uuid' : 'number'\n\n const { customIDType } = adapter.payload.collections[relationTo]\n\n if (customIDType) {\n idType = customIDType\n }\n\n const idTypeTextOrUuid = idType === 'text' || idType === 'uuid'\n\n // Do not add the column to OR if we know that it can't match by the type\n // We can't do the same with idType: 'number' because `value` can be from the REST search query params\n if (typeof value === 'number' && idTypeTextOrUuid) {\n return null\n }\n\n if (\n Array.isArray(value) &&\n value.every((val) => typeof val === 'number') &&\n idTypeTextOrUuid\n ) {\n return null\n }\n\n // Do not add the UUID type column if incoming query value doesn't match UUID. If there aren't any collections with\n // a custom ID type, we skip this check\n // We need this because Postgres throws an error if querying by UUID column with a value that isn't a valid UUID.\n if (\n value &&\n !Array.isArray(value) &&\n idType === 'uuid' &&\n hasCustomCollectionWithCustomID\n ) {\n if (!uuidValidate(value)) {\n return null\n }\n }\n\n if (\n Array.isArray(value) &&\n idType === 'uuid' &&\n hasCustomCollectionWithCustomID &&\n !value.some((val) => uuidValidate(val))\n ) {\n return null\n }\n\n const relationTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[relationTo].config.slug),\n )\n\n return {\n idType,\n rawColumn: sql.raw(`\"${aliasRelationshipTableName}\".\"${relationTableName}_id\"`),\n }\n })\n .filter(Boolean)\n\n return {\n columns,\n constraints,\n field,\n table: aliasRelationshipTable,\n }\n } else if (newCollectionPath === 'relationTo') {\n const relationTo = Array.isArray(field.relationTo)\n ? field.relationTo\n : [field.relationTo]\n\n return {\n constraints,\n field,\n getNotNullColumnByValue: (val) => {\n const matchedRelation = relationTo.find((relation) => relation === val)\n if (matchedRelation) {\n return `${matchedRelation}ID`\n }\n return undefined\n },\n table: aliasRelationshipTable,\n }\n } else if (isPolymorphicRelationship(value)) {\n const { relationTo } = value\n\n const relationTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[relationTo].config.slug),\n )\n\n return {\n constraints,\n field,\n rawColumn: sql.raw(`\"${aliasRelationshipTableName}\".\"${relationTableName}_id\"`),\n table: aliasRelationshipTable,\n }\n } else if (value === DistinctSymbol) {\n const obj: Record<string, SQL> = {}\n\n field.relationTo.forEach((relationTo) => {\n const relationTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[relationTo].config.slug),\n )\n\n obj[relationTo] = sql.raw(`\"${aliasRelationshipTableName}\".\"${relationTableName}_id\"`)\n })\n\n let rawColumn = jsonBuildObject(adapter, obj)\n if (adapter.name === 'postgres') {\n rawColumn = sql`${rawColumn}::text`\n }\n\n return {\n constraints,\n field,\n rawColumn,\n table: aliasRelationshipTable,\n }\n } else {\n throw new APIError('Not supported')\n }\n\n return getTableColumnFromPath({\n adapter,\n aliasTable: newAliasTable,\n collectionPath: newCollectionPath,\n constraints,\n // relationshipFields are fields from a different collection => no parentIsLocalized\n fields: relationshipFields,\n joins,\n locale,\n parentIsLocalized: false,\n pathSegments: pathSegments.slice(1),\n rootTableName: newTableName,\n selectFields,\n selectLocale,\n tableName: newTableName,\n value,\n })\n } else if (\n pathSegments.length > 1 &&\n !(pathSegments.length === 2 && pathSegments[1] === 'id')\n ) {\n // simple relationships\n const columnName = `${columnPrefix}${field.name}`\n const newTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[field.relationTo].config.slug),\n )\n const { newAliasTable } = getTableAlias({ adapter, tableName: newTableName })\n\n if (isFieldLocalized && adapter.payload.config.localization) {\n const { newAliasTable: aliasLocaleTable } = getTableAlias({\n adapter,\n tableName: `${rootTableName}${adapter.localesSuffix}`,\n })\n\n const condtions = [eq(aliasLocaleTable._parentID, adapter.tables[rootTableName].id)]\n\n if (selectLocale) {\n selectFields._locale = aliasLocaleTable._locale\n }\n\n if (locale !== 'all') {\n condtions.push(eq(aliasLocaleTable._locale, locale))\n }\n\n const localesTable = adapter.tables[`${rootTableName}${adapter.localesSuffix}`]\n\n addJoinTable({\n condition: and(...condtions),\n joins,\n table: localesTable,\n })\n\n joins.push({\n condition: eq(localesTable[columnName], newAliasTable.id),\n table: newAliasTable,\n })\n } else {\n joins.push({\n condition: eq(\n newAliasTable.id,\n aliasTable ? aliasTable[columnName] : adapter.tables[tableName][columnName],\n ),\n table: newAliasTable,\n })\n }\n\n return getTableColumnFromPath({\n adapter,\n aliasTable: newAliasTable,\n collectionPath: newCollectionPath,\n constraintPath: '',\n constraints,\n fields: adapter.payload.collections[field.relationTo].config.flattenedFields,\n joins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n selectFields,\n tableName: newTableName,\n value,\n })\n }\n\n break\n }\n\n case 'select': {\n if (field.hasMany) {\n const newTableName = adapter.tableNameMap.get(\n `${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`,\n )\n\n const idColumn = (aliasTable ?? adapter.tables[tableName]).id\n if (locale && isFieldLocalized && adapter.payload.config.localization) {\n const conditions = [\n eq(idColumn, adapter.tables[newTableName].parent),\n eq(adapter.tables[newTableName]._locale, locale),\n ]\n\n if (locale !== 'all') {\n conditions.push(eq(adapter.tables[newTableName]._locale, locale))\n }\n\n addJoinTable({\n condition: and(...conditions),\n joins,\n table: adapter.tables[newTableName],\n })\n } else {\n addJoinTable({\n condition: eq(idColumn, adapter.tables[newTableName].parent),\n joins,\n table: adapter.tables[newTableName],\n })\n }\n\n return {\n columnName: 'value',\n constraints,\n field,\n table: adapter.tables[newTableName],\n }\n }\n break\n }\n\n case 'tab': {\n if (tabHasName(field)) {\n return getTableColumnFromPath({\n adapter,\n aliasTable,\n collectionPath,\n columnPrefix: `${columnPrefix}${field.name}_`,\n constraintPath: `${constraintPath}${field.name}.`,\n constraints,\n fields: field.flattenedFields,\n joins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n selectLocale,\n tableName: newTableName,\n tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n value,\n })\n }\n return getTableColumnFromPath({\n adapter,\n aliasTable,\n collectionPath,\n columnPrefix,\n constraintPath,\n constraints,\n fields: field.flattenedFields,\n joins,\n locale,\n parentIsLocalized: parentIsLocalized || field.localized,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n selectLocale,\n tableName: newTableName,\n tableNameSuffix,\n value,\n })\n }\n\n default: {\n // fall through\n break\n }\n }\n\n let newTable = adapter.tables[newTableName]\n\n if (isFieldLocalized && adapter.payload.config.localization) {\n // If localized, we go to localized table and set aliasTable to undefined\n // so it is not picked up below to be used as targetTable\n const parentTable = aliasTable || adapter.tables[tableName]\n newTableName = `${tableName}${adapter.localesSuffix}`\n\n // use an alias because the same query may contain constraints with different locale value\n if (localizedPathQuery) {\n const { newAliasTable } = getTableAlias({ adapter, tableName: newTableName })\n newTable = newAliasTable\n } else {\n newTable = adapter.tables[newTableName]\n }\n\n let condition = eq(parentTable.id, newTable._parentID)\n\n if (locale !== 'all') {\n condition = and(condition, eq(newTable._locale, locale))\n }\n\n if (selectLocale) {\n selectFields._locale = newTable._locale\n }\n\n addJoinTable({\n condition,\n joins,\n table: newTable,\n })\n\n aliasTable = undefined\n }\n\n const targetTable = aliasTable || newTable\n\n selectFields[`${newTableName}.${columnPrefix}${field.name}`] =\n targetTable[`${columnPrefix}${field.name}`]\n\n return {\n columnName: `${columnPrefix}${field.name}`,\n constraints,\n field,\n pathSegments,\n table: targetTable,\n }\n }\n\n throw new APIError(`Cannot find field for path at ${fieldPath}`)\n}\n"],"names":["and","eq","getTableName","like","sql","APIError","getFieldByPath","fieldShouldBeLocalized","tabHasName","toSnakeCase","validate","uuidValidate","isPolymorphicRelationship","jsonBuildObject","DistinctSymbol","resolveBlockTableName","addJoinTable","getTableAlias","getTableColumnFromPath","adapter","aliasTable","collectionPath","columnPrefix","constraintPath","incomingConstraintPath","constraints","fields","joins","locale","incomingLocale","parentAliasTable","parentIsLocalized","pathSegments","incomingSegments","rootTableName","incomingRootTableName","selectFields","selectLocale","tableName","tableNameSuffix","value","fieldPath","field","find","fieldToFind","name","newTableName","id","tables","columnName","type","idType","table","localizedPathQuery","isFieldLocalized","payload","config","localization","matchedLocale","localeCodes","splice","tableNameMap","get","arrayParentTable","conditions","_parentID","_locale","push","condition","isOneToMany","flattenedFields","localized","slice","blocksAsJSON","blockTableColumn","blockTypes","Array","isArray","forEach","blockType","block","blocks","blockReferences","slug","newAliasTable","getNotNullColumnByValue","hasBlockField","some","_block","result","blockConstraints","blockSelectFields","blockJoin","newJoins","_","concat","previousLength","length","i","rawColumn","localesSuffix","collection","newCollectionPath","join","hasMany","relationTableName","relationshipsSuffix","existingTable","e","queryPath","aliasRelationshipTable","relationshipField","collections","path","on","relationTo","relationshipConfig","relationshipTableName","relationshipFields","existingMainTable","relationshipTable","parent","replaceAll","tableType","joinConstraints","existingJoin","aliasRelationshipTableName","res","newAliasTableName","hasCustomCollectionWithCustomID","customIDType","columns","map","idTypeTextOrUuid","every","val","raw","filter","Boolean","matchedRelation","relation","undefined","obj","aliasLocaleTable","condtions","localesTable","idColumn","newTable","parentTable","targetTable"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@payloadcms/drizzle",
|
|
3
|
-
"version": "3.81.0-internal
|
|
3
|
+
"version": "3.81.0-internal.181753b",
|
|
4
4
|
"description": "A library of shared functions used by different payload database adapters",
|
|
5
5
|
"homepage": "https://payloadcms.com",
|
|
6
6
|
"repository": {
|
|
@@ -60,10 +60,10 @@
|
|
|
60
60
|
"@types/pg": "8.10.2",
|
|
61
61
|
"@types/to-snake-case": "1.0.0",
|
|
62
62
|
"@payloadcms/eslint-config": "3.28.0",
|
|
63
|
-
"payload": "3.81.0-internal
|
|
63
|
+
"payload": "3.81.0-internal.181753b"
|
|
64
64
|
},
|
|
65
65
|
"peerDependencies": {
|
|
66
|
-
"payload": "3.81.0-internal
|
|
66
|
+
"payload": "3.81.0-internal.181753b"
|
|
67
67
|
},
|
|
68
68
|
"scripts": {
|
|
69
69
|
"build": "pnpm build:swc && pnpm build:types",
|