@payloadcms/db-postgres 3.0.0-alpha.18 → 3.0.0-alpha.19

Sign up to get free protection for your applications and to get access to all the features.
Files changed (80) hide show
  1. package/dist/connect.js +17 -32
  2. package/dist/create.js +6 -21
  3. package/dist/createGlobal.js +6 -21
  4. package/dist/createGlobalVersion.js +10 -25
  5. package/dist/createMigration.js +11 -26
  6. package/dist/createVersion.js +10 -25
  7. package/dist/deleteMany.js +8 -23
  8. package/dist/deleteOne.js +10 -25
  9. package/dist/deleteVersions.js +10 -25
  10. package/dist/destroy.js +2 -12
  11. package/dist/find/buildFindManyArgs.js +6 -14
  12. package/dist/find/chainMethods.js +2 -11
  13. package/dist/find/findMany.js +14 -29
  14. package/dist/find/traverseFields.js +8 -23
  15. package/dist/find.js +6 -21
  16. package/dist/findGlobal.js +6 -21
  17. package/dist/findGlobalVersions.js +8 -23
  18. package/dist/findOne.js +6 -21
  19. package/dist/findVersions.js +8 -23
  20. package/dist/index.js +72 -87
  21. package/dist/init.js +17 -32
  22. package/dist/migrate.js +15 -30
  23. package/dist/migrateDown.js +12 -22
  24. package/dist/migrateFresh.js +15 -28
  25. package/dist/migrateRefresh.js +18 -26
  26. package/dist/migrateReset.js +13 -21
  27. package/dist/migrateStatus.js +9 -19
  28. package/dist/queries/buildAndOrConditions.js +4 -14
  29. package/dist/queries/buildQuery.js +10 -20
  30. package/dist/queries/createJSONQuery/convertPathToJSONTraversal.js +4 -14
  31. package/dist/queries/createJSONQuery/formatJSONPathSegment.js +2 -12
  32. package/dist/queries/createJSONQuery/index.js +6 -16
  33. package/dist/queries/getTableColumnFromPath.js +38 -49
  34. package/dist/queries/operatorMap.js +17 -27
  35. package/dist/queries/parseParams.js +32 -42
  36. package/dist/queries/sanitizeQueryValue.js +8 -18
  37. package/dist/queryDrafts.js +10 -25
  38. package/dist/schema/build.js +49 -64
  39. package/dist/schema/createIndex.js +5 -15
  40. package/dist/schema/idToUUID.js +2 -12
  41. package/dist/schema/parentIDColumnMap.js +7 -17
  42. package/dist/schema/setColumnID.js +10 -20
  43. package/dist/schema/traverseFields.js +62 -77
  44. package/dist/schema/validateExistingBlockIsIdentical.js +9 -19
  45. package/dist/transactions/beginTransaction.js +4 -14
  46. package/dist/transactions/commitTransaction.js +2 -12
  47. package/dist/transactions/rollbackTransaction.js +2 -12
  48. package/dist/transform/read/hasManyNumber.js +2 -12
  49. package/dist/transform/read/hasManyText.js +2 -12
  50. package/dist/transform/read/index.js +12 -20
  51. package/dist/transform/read/relationship.js +2 -12
  52. package/dist/transform/read/traverseFields.js +15 -23
  53. package/dist/transform/write/array.js +6 -16
  54. package/dist/transform/write/blocks.js +6 -21
  55. package/dist/transform/write/index.js +4 -14
  56. package/dist/transform/write/numbers.js +2 -12
  57. package/dist/transform/write/relationships.js +4 -14
  58. package/dist/transform/write/selects.js +4 -14
  59. package/dist/transform/write/texts.js +2 -12
  60. package/dist/transform/write/traverseFields.js +30 -45
  61. package/dist/transform/write/types.js +2 -5
  62. package/dist/types.js +2 -5
  63. package/dist/update.js +11 -26
  64. package/dist/updateGlobal.js +6 -21
  65. package/dist/updateGlobalVersion.js +10 -25
  66. package/dist/updateVersion.js +10 -25
  67. package/dist/upsertRow/deleteExistingArrayRows.js +5 -15
  68. package/dist/upsertRow/deleteExistingRowsByPath.js +9 -19
  69. package/dist/upsertRow/index.js +24 -34
  70. package/dist/upsertRow/insertArrays.js +2 -12
  71. package/dist/upsertRow/types.js +2 -5
  72. package/dist/utilities/appendPrefixToKeys.js +2 -12
  73. package/dist/utilities/createBlocksMap.js +2 -12
  74. package/dist/utilities/createMigrationTable.js +4 -14
  75. package/dist/utilities/createRelationshipMap.js +2 -12
  76. package/dist/utilities/hasLocalesTable.js +5 -15
  77. package/dist/utilities/isArrayOfRows.js +2 -12
  78. package/dist/utilities/migrationTableExists.js +4 -14
  79. package/dist/utilities/parseError.js +6 -14
  80. package/package.json +4 -4
@@ -1,23 +1,13 @@
1
- /* eslint-disable no-await-in-loop */ "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "parseParams", {
6
- enumerable: true,
7
- get: function() {
8
- return parseParams;
9
- }
10
- });
11
- const _drizzleorm = require("drizzle-orm");
12
- const _errors = require("payload/errors");
13
- const _types = require("payload/types");
14
- const _buildAndOrConditions = require("./buildAndOrConditions");
15
- const _createJSONQuery = require("./createJSONQuery");
16
- const _convertPathToJSONTraversal = require("./createJSONQuery/convertPathToJSONTraversal");
17
- const _getTableColumnFromPath = require("./getTableColumnFromPath");
18
- const _operatorMap = require("./operatorMap");
19
- const _sanitizeQueryValue = require("./sanitizeQueryValue");
20
- async function parseParams({ adapter, fields, joinAliases, joins, locale, selectFields, tableName, where }) {
1
+ /* eslint-disable no-await-in-loop */ import { and, ilike, isNotNull, isNull, ne, notInArray, or, sql } from 'drizzle-orm';
2
+ import { QueryError } from 'payload/errors';
3
+ import { validOperators } from 'payload/types';
4
+ import { buildAndOrConditions } from './buildAndOrConditions';
5
+ import { createJSONQuery } from './createJSONQuery';
6
+ import { convertPathToJSONTraversal } from './createJSONQuery/convertPathToJSONTraversal';
7
+ import { getTableColumnFromPath } from './getTableColumnFromPath';
8
+ import { operatorMap } from './operatorMap';
9
+ import { sanitizeQueryValue } from './sanitizeQueryValue';
10
+ export async function parseParams({ adapter, fields, joinAliases, joins, locale, selectFields, tableName, where }) {
21
11
  let result;
22
12
  const constraints = [];
23
13
  if (typeof where === 'object' && Object.keys(where).length > 0) {
@@ -32,7 +22,7 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
32
22
  conditionOperator = 'or';
33
23
  }
34
24
  if (Array.isArray(condition)) {
35
- const builtConditions = await (0, _buildAndOrConditions.buildAndOrConditions)({
25
+ const builtConditions = await buildAndOrConditions({
36
26
  adapter,
37
27
  fields,
38
28
  joinAliases,
@@ -43,7 +33,7 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
43
33
  where: condition
44
34
  });
45
35
  if (builtConditions.length > 0) {
46
- result = _operatorMap.operatorMap[conditionOperator](...builtConditions);
36
+ result = operatorMap[conditionOperator](...builtConditions);
47
37
  }
48
38
  } else {
49
39
  // It's a path - and there can be multiple comparisons on a single path.
@@ -52,9 +42,9 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
52
42
  const pathOperators = where[relationOrPath];
53
43
  if (typeof pathOperators === 'object') {
54
44
  for (const operator of Object.keys(pathOperators)){
55
- if (_types.validOperators.includes(operator)) {
45
+ if (validOperators.includes(operator)) {
56
46
  const val = where[relationOrPath][operator];
57
- const { columnName, constraints: queryConstraints, field, getNotNullColumnByValue, pathSegments, rawColumn, table } = (0, _getTableColumnFromPath.getTableColumnFromPath)({
47
+ const { columnName, constraints: queryConstraints, field, getNotNullColumnByValue, pathSegments, rawColumn, table } = getTableColumnFromPath({
58
48
  adapter,
59
49
  collectionPath: relationOrPath,
60
50
  fields,
@@ -68,9 +58,9 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
68
58
  });
69
59
  queryConstraints.forEach(({ columnName: col, table: constraintTable, value })=>{
70
60
  if (typeof value === 'string' && value.indexOf('%') > -1) {
71
- constraints.push(_operatorMap.operatorMap.like(constraintTable[col], value));
61
+ constraints.push(operatorMap.like(constraintTable[col], value));
72
62
  } else {
73
- constraints.push(_operatorMap.operatorMap.equals(constraintTable[col], value));
63
+ constraints.push(operatorMap.equals(constraintTable[col], value));
74
64
  }
75
65
  });
76
66
  if ([
@@ -80,7 +70,7 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
80
70
  const segments = pathSegments.slice(1);
81
71
  segments.unshift(table[columnName].name);
82
72
  if (field.type === 'richText') {
83
- const jsonQuery = (0, _createJSONQuery.createJSONQuery)({
73
+ const jsonQuery = createJSONQuery({
84
74
  operator,
85
75
  pathSegments: segments,
86
76
  treatAsArray: [
@@ -89,10 +79,10 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
89
79
  treatRootAsArray: true,
90
80
  value: val
91
81
  });
92
- constraints.push(_drizzleorm.sql.raw(jsonQuery));
82
+ constraints.push(sql.raw(jsonQuery));
93
83
  break;
94
84
  }
95
- const jsonQuery = (0, _convertPathToJSONTraversal.convertPathToJSONTraversal)(pathSegments);
85
+ const jsonQuery = convertPathToJSONTraversal(pathSegments);
96
86
  const operatorKeys = {
97
87
  contains: {
98
88
  operator: 'ilike',
@@ -118,15 +108,15 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
118
108
  if (operator === 'exists') {
119
109
  formattedValue = '';
120
110
  }
121
- constraints.push(_drizzleorm.sql.raw(`${table[columnName].name}${jsonQuery} ${operatorKeys[operator].operator} ${formattedValue}`));
111
+ constraints.push(sql.raw(`${table[columnName].name}${jsonQuery} ${operatorKeys[operator].operator} ${formattedValue}`));
122
112
  break;
123
113
  }
124
114
  if (getNotNullColumnByValue) {
125
115
  const columnName = getNotNullColumnByValue(val);
126
116
  if (columnName) {
127
- constraints.push((0, _drizzleorm.isNotNull)(table[columnName]));
117
+ constraints.push(isNotNull(table[columnName]));
128
118
  } else {
129
- throw new _errors.QueryError([
119
+ throw new QueryError([
130
120
  {
131
121
  path: relationOrPath
132
122
  }
@@ -135,10 +125,10 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
135
125
  break;
136
126
  }
137
127
  if (operator === 'like') {
138
- constraints.push((0, _drizzleorm.and)(...val.split(' ').map((word)=>(0, _drizzleorm.ilike)(table[columnName], `%${word}%`))));
128
+ constraints.push(and(...val.split(' ').map((word)=>ilike(table[columnName], `%${word}%`))));
139
129
  break;
140
130
  }
141
- const sanitizedQueryValue = (0, _sanitizeQueryValue.sanitizeQueryValue)({
131
+ const sanitizedQueryValue = sanitizeQueryValue({
142
132
  adapter,
143
133
  field,
144
134
  operator,
@@ -150,25 +140,25 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
150
140
  }
151
141
  const { operator: queryOperator, value: queryValue } = sanitizedQueryValue;
152
142
  if (queryOperator === 'not_equals' && queryValue !== null) {
153
- constraints.push((0, _drizzleorm.or)((0, _drizzleorm.isNull)(rawColumn || table[columnName]), /* eslint-disable @typescript-eslint/no-explicit-any */ (0, _drizzleorm.ne)(rawColumn || table[columnName], queryValue)));
143
+ constraints.push(or(isNull(rawColumn || table[columnName]), /* eslint-disable @typescript-eslint/no-explicit-any */ ne(rawColumn || table[columnName], queryValue)));
154
144
  break;
155
145
  }
156
146
  if ((field.type === 'relationship' || field.type === 'upload') && Array.isArray(queryValue) && operator === 'not_in') {
157
- constraints.push((0, _drizzleorm.sql)`${(0, _drizzleorm.notInArray)(table[columnName], queryValue)} OR
147
+ constraints.push(sql`${notInArray(table[columnName], queryValue)} OR
158
148
  ${table[columnName]}
159
149
  IS
160
150
  NULL`);
161
151
  break;
162
152
  }
163
153
  if (operator === 'equals' && queryValue === null) {
164
- constraints.push((0, _drizzleorm.isNull)(rawColumn || table[columnName]));
154
+ constraints.push(isNull(rawColumn || table[columnName]));
165
155
  break;
166
156
  }
167
157
  if (operator === 'not_equals' && queryValue === null) {
168
- constraints.push((0, _drizzleorm.isNotNull)(rawColumn || table[columnName]));
158
+ constraints.push(isNotNull(rawColumn || table[columnName]));
169
159
  break;
170
160
  }
171
- constraints.push(_operatorMap.operatorMap[queryOperator](rawColumn || table[columnName], queryValue));
161
+ constraints.push(operatorMap[queryOperator](rawColumn || table[columnName], queryValue));
172
162
  }
173
163
  }
174
164
  }
@@ -178,9 +168,9 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
178
168
  }
179
169
  if (constraints.length > 0) {
180
170
  if (result) {
181
- result = (0, _drizzleorm.and)(result, ...constraints);
171
+ result = and(result, ...constraints);
182
172
  } else {
183
- result = (0, _drizzleorm.and)(...constraints);
173
+ result = and(...constraints);
184
174
  }
185
175
  }
186
176
  if (constraints.length === 1 && !result) {
@@ -189,4 +179,4 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
189
179
  return result;
190
180
  }
191
181
 
192
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/parseParams.ts"],"sourcesContent":["/* eslint-disable no-await-in-loop */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, Operator, Where } from 'payload/types'\n\nimport { and, ilike, isNotNull, isNull, ne, notInArray, or, sql } from 'drizzle-orm'\nimport { QueryError } from 'payload/errors'\nimport { validOperators } from 'payload/types'\n\nimport type { GenericColumn, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\nimport { buildAndOrConditions } from './buildAndOrConditions'\nimport { createJSONQuery } from './createJSONQuery'\nimport { convertPathToJSONTraversal } from './createJSONQuery/convertPathToJSONTraversal'\nimport { getTableColumnFromPath } from './getTableColumnFromPath'\nimport { operatorMap } from './operatorMap'\nimport { sanitizeQueryValue } from './sanitizeQueryValue'\n\ntype Args = {\n  adapter: PostgresAdapter\n  fields: Field[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n  where: Where\n}\n\nexport async function parseParams({\n  adapter,\n  fields,\n  joinAliases,\n  joins,\n  locale,\n  selectFields,\n  tableName,\n  where,\n}: Args): Promise<SQL> {\n  let result: SQL\n  const constraints: SQL[] = []\n\n  if (typeof where === 'object' && Object.keys(where).length > 0) {\n    // We need to determine if the whereKey is an AND, OR, or a schema path\n    for (const relationOrPath of Object.keys(where)) {\n      if (relationOrPath) {\n        const condition = where[relationOrPath]\n        let conditionOperator: 'and' | 'or'\n        if (relationOrPath.toLowerCase() === 'and') {\n          conditionOperator = 'and'\n        } else if (relationOrPath.toLowerCase() === 'or') {\n          conditionOperator = 'or'\n        }\n        if (Array.isArray(condition)) {\n          const builtConditions = await buildAndOrConditions({\n            adapter,\n            fields,\n            joinAliases,\n            joins,\n            locale,\n            selectFields,\n            tableName,\n            where: condition,\n          })\n          if (builtConditions.length > 0) {\n            result = operatorMap[conditionOperator](...builtConditions)\n          }\n        } else {\n          // It's a path - and there can be multiple comparisons on a single path.\n          // For example - title like 'test' and title not equal to 'tester'\n          // So we need to loop on keys again here to handle each operator independently\n          const pathOperators = where[relationOrPath]\n          if (typeof pathOperators === 'object') {\n            for (const operator of Object.keys(pathOperators)) {\n              if (validOperators.includes(operator as Operator)) {\n                const val = where[relationOrPath][operator]\n                const {\n                  columnName,\n                  constraints: queryConstraints,\n                  field,\n                  getNotNullColumnByValue,\n                  pathSegments,\n                  rawColumn,\n                  table,\n                } = getTableColumnFromPath({\n                  adapter,\n                  collectionPath: relationOrPath,\n                  fields,\n                  joinAliases,\n                  joins,\n                  locale,\n                  pathSegments: relationOrPath.replace(/__/g, '.').split('.'),\n                  selectFields,\n                  tableName,\n                  value: val,\n                })\n\n                queryConstraints.forEach(({ columnName: col, table: constraintTable, value }) => {\n                  if (typeof value === 'string' && value.indexOf('%') > -1) {\n                    constraints.push(operatorMap.like(constraintTable[col], value))\n                  } else {\n                    constraints.push(operatorMap.equals(constraintTable[col], value))\n                  }\n                })\n\n                if (\n                  ['json', 'richText'].includes(field.type) &&\n                  Array.isArray(pathSegments) &&\n                  pathSegments.length > 1\n                ) {\n                  const segments = pathSegments.slice(1)\n                  segments.unshift(table[columnName].name)\n\n                  if (field.type === 'richText') {\n                    const jsonQuery = createJSONQuery({\n                      operator,\n                      pathSegments: segments,\n                      treatAsArray: ['children'],\n                      treatRootAsArray: true,\n                      value: val,\n                    })\n\n                    constraints.push(sql.raw(jsonQuery))\n                    break\n                  }\n\n                  const jsonQuery = convertPathToJSONTraversal(pathSegments)\n                  const operatorKeys = {\n                    contains: { operator: 'ilike', wildcard: '%' },\n                    equals: { operator: '=', wildcard: '' },\n                    exists: { operator: val === true ? 'is not null' : 'is null' },\n                    like: { operator: 'like', wildcard: '%' },\n                    not_equals: { operator: '<>', wildcard: '' },\n                  }\n                  let formattedValue = `'${operatorKeys[operator].wildcard}${val}${operatorKeys[operator].wildcard}'`\n\n                  if (operator === 'exists') {\n                    formattedValue = ''\n                  }\n\n                  constraints.push(\n                    sql.raw(\n                      `${table[columnName].name}${jsonQuery} ${operatorKeys[operator].operator} ${formattedValue}`,\n                    ),\n                  )\n\n                  break\n                }\n\n                if (getNotNullColumnByValue) {\n                  const columnName = getNotNullColumnByValue(val)\n                  if (columnName) {\n                    constraints.push(isNotNull(table[columnName]))\n                  } else {\n                    throw new QueryError([{ path: relationOrPath }])\n                  }\n                  break\n                }\n\n                if (operator === 'like') {\n                  constraints.push(\n                    and(...val.split(' ').map((word) => ilike(table[columnName], `%${word}%`))),\n                  )\n                  break\n                }\n\n                const sanitizedQueryValue = sanitizeQueryValue({\n                  adapter,\n                  field,\n                  operator,\n                  relationOrPath,\n                  val,\n                })\n\n                if (sanitizedQueryValue === null) {\n                  break\n                }\n\n                const { operator: queryOperator, value: queryValue } = sanitizedQueryValue\n\n                if (queryOperator === 'not_equals' && queryValue !== null) {\n                  constraints.push(\n                    or(\n                      isNull(rawColumn || table[columnName]),\n                      /* eslint-disable @typescript-eslint/no-explicit-any */\n                      ne<any>(rawColumn || table[columnName], queryValue),\n                    ),\n                  )\n                  break\n                }\n\n                if (\n                  (field.type === 'relationship' || field.type === 'upload') &&\n                  Array.isArray(queryValue) &&\n                  operator === 'not_in'\n                ) {\n                  constraints.push(\n                    sql`${notInArray(table[columnName], queryValue)} OR\n                    ${table[columnName]}\n                    IS\n                    NULL`,\n                  )\n\n                  break\n                }\n\n                if (operator === 'equals' && queryValue === null) {\n                  constraints.push(isNull(rawColumn || table[columnName]))\n                  break\n                }\n\n                if (operator === 'not_equals' && queryValue === null) {\n                  constraints.push(isNotNull(rawColumn || table[columnName]))\n                  break\n                }\n\n                constraints.push(\n                  operatorMap[queryOperator](rawColumn || table[columnName], queryValue),\n                )\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n  if (constraints.length > 0) {\n    if (result) {\n      result = and(result, ...constraints)\n    } else {\n      result = and(...constraints)\n    }\n  }\n  if (constraints.length === 1 && !result) {\n    ;[result] = constraints\n  }\n\n  return result\n}\n"],"names":["parseParams","adapter","fields","joinAliases","joins","locale","selectFields","tableName","where","result","constraints","Object","keys","length","relationOrPath","condition","conditionOperator","toLowerCase","Array","isArray","builtConditions","buildAndOrConditions","operatorMap","pathOperators","operator","validOperators","includes","val","columnName","queryConstraints","field","getNotNullColumnByValue","pathSegments","rawColumn","table","getTableColumnFromPath","collectionPath","replace","split","value","forEach","col","constraintTable","indexOf","push","like","equals","type","segments","slice","unshift","name","jsonQuery","createJSONQuery","treatAsArray","treatRootAsArray","sql","raw","convertPathToJSONTraversal","operatorKeys","contains","wildcard","exists","not_equals","formattedValue","isNotNull","QueryError","path","and","map","word","ilike","sanitizedQueryValue","sanitizeQueryValue","queryOperator","queryValue","or","isNull","ne","notInArray"],"mappings":"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"}
182
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/parseParams.ts"],"sourcesContent":["/* eslint-disable no-await-in-loop */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, Operator, Where } from 'payload/types'\n\nimport { and, ilike, isNotNull, isNull, ne, notInArray, or, sql } from 'drizzle-orm'\nimport { QueryError } from 'payload/errors'\nimport { validOperators } from 'payload/types'\n\nimport type { GenericColumn, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\nimport { buildAndOrConditions } from './buildAndOrConditions'\nimport { createJSONQuery } from './createJSONQuery'\nimport { convertPathToJSONTraversal } from './createJSONQuery/convertPathToJSONTraversal'\nimport { getTableColumnFromPath } from './getTableColumnFromPath'\nimport { operatorMap } from './operatorMap'\nimport { sanitizeQueryValue } from './sanitizeQueryValue'\n\ntype Args = {\n  adapter: PostgresAdapter\n  fields: Field[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n  where: Where\n}\n\nexport async function parseParams({\n  adapter,\n  fields,\n  joinAliases,\n  joins,\n  locale,\n  selectFields,\n  tableName,\n  where,\n}: Args): Promise<SQL> {\n  let result: SQL\n  const constraints: SQL[] = []\n\n  if (typeof where === 'object' && Object.keys(where).length > 0) {\n    // We need to determine if the whereKey is an AND, OR, or a schema path\n    for (const relationOrPath of Object.keys(where)) {\n      if (relationOrPath) {\n        const condition = where[relationOrPath]\n        let conditionOperator: 'and' | 'or'\n        if (relationOrPath.toLowerCase() === 'and') {\n          conditionOperator = 'and'\n        } else if (relationOrPath.toLowerCase() === 'or') {\n          conditionOperator = 'or'\n        }\n        if (Array.isArray(condition)) {\n          const builtConditions = await buildAndOrConditions({\n            adapter,\n            fields,\n            joinAliases,\n            joins,\n            locale,\n            selectFields,\n            tableName,\n            where: condition,\n          })\n          if (builtConditions.length > 0) {\n            result = operatorMap[conditionOperator](...builtConditions)\n          }\n        } else {\n          // It's a path - and there can be multiple comparisons on a single path.\n          // For example - title like 'test' and title not equal to 'tester'\n          // So we need to loop on keys again here to handle each operator independently\n          const pathOperators = where[relationOrPath]\n          if (typeof pathOperators === 'object') {\n            for (const operator of Object.keys(pathOperators)) {\n              if (validOperators.includes(operator as Operator)) {\n                const val = where[relationOrPath][operator]\n                const {\n                  columnName,\n                  constraints: queryConstraints,\n                  field,\n                  getNotNullColumnByValue,\n                  pathSegments,\n                  rawColumn,\n                  table,\n                } = getTableColumnFromPath({\n                  adapter,\n                  collectionPath: relationOrPath,\n                  fields,\n                  joinAliases,\n                  joins,\n                  locale,\n                  pathSegments: relationOrPath.replace(/__/g, '.').split('.'),\n                  selectFields,\n                  tableName,\n                  value: val,\n                })\n\n                queryConstraints.forEach(({ columnName: col, table: constraintTable, value }) => {\n                  if (typeof value === 'string' && value.indexOf('%') > -1) {\n                    constraints.push(operatorMap.like(constraintTable[col], value))\n                  } else {\n                    constraints.push(operatorMap.equals(constraintTable[col], value))\n                  }\n                })\n\n                if (\n                  ['json', 'richText'].includes(field.type) &&\n                  Array.isArray(pathSegments) &&\n                  pathSegments.length > 1\n                ) {\n                  const segments = pathSegments.slice(1)\n                  segments.unshift(table[columnName].name)\n\n                  if (field.type === 'richText') {\n                    const jsonQuery = createJSONQuery({\n                      operator,\n                      pathSegments: segments,\n                      treatAsArray: ['children'],\n                      treatRootAsArray: true,\n                      value: val,\n                    })\n\n                    constraints.push(sql.raw(jsonQuery))\n                    break\n                  }\n\n                  const jsonQuery = convertPathToJSONTraversal(pathSegments)\n                  const operatorKeys = {\n                    contains: { operator: 'ilike', wildcard: '%' },\n                    equals: { operator: '=', wildcard: '' },\n                    exists: { operator: val === true ? 'is not null' : 'is null' },\n                    like: { operator: 'like', wildcard: '%' },\n                    not_equals: { operator: '<>', wildcard: '' },\n                  }\n                  let formattedValue = `'${operatorKeys[operator].wildcard}${val}${operatorKeys[operator].wildcard}'`\n\n                  if (operator === 'exists') {\n                    formattedValue = ''\n                  }\n\n                  constraints.push(\n                    sql.raw(\n                      `${table[columnName].name}${jsonQuery} ${operatorKeys[operator].operator} ${formattedValue}`,\n                    ),\n                  )\n\n                  break\n                }\n\n                if (getNotNullColumnByValue) {\n                  const columnName = getNotNullColumnByValue(val)\n                  if (columnName) {\n                    constraints.push(isNotNull(table[columnName]))\n                  } else {\n                    throw new QueryError([{ path: relationOrPath }])\n                  }\n                  break\n                }\n\n                if (operator === 'like') {\n                  constraints.push(\n                    and(...val.split(' ').map((word) => ilike(table[columnName], `%${word}%`))),\n                  )\n                  break\n                }\n\n                const sanitizedQueryValue = sanitizeQueryValue({\n                  adapter,\n                  field,\n                  operator,\n                  relationOrPath,\n                  val,\n                })\n\n                if (sanitizedQueryValue === null) {\n                  break\n                }\n\n                const { operator: queryOperator, value: queryValue } = sanitizedQueryValue\n\n                if (queryOperator === 'not_equals' && queryValue !== null) {\n                  constraints.push(\n                    or(\n                      isNull(rawColumn || table[columnName]),\n                      /* eslint-disable @typescript-eslint/no-explicit-any */\n                      ne<any>(rawColumn || table[columnName], queryValue),\n                    ),\n                  )\n                  break\n                }\n\n                if (\n                  (field.type === 'relationship' || field.type === 'upload') &&\n                  Array.isArray(queryValue) &&\n                  operator === 'not_in'\n                ) {\n                  constraints.push(\n                    sql`${notInArray(table[columnName], queryValue)} OR\n                    ${table[columnName]}\n                    IS\n                    NULL`,\n                  )\n\n                  break\n                }\n\n                if (operator === 'equals' && queryValue === null) {\n                  constraints.push(isNull(rawColumn || table[columnName]))\n                  break\n                }\n\n                if (operator === 'not_equals' && queryValue === null) {\n                  constraints.push(isNotNull(rawColumn || table[columnName]))\n                  break\n                }\n\n                constraints.push(\n                  operatorMap[queryOperator](rawColumn || table[columnName], queryValue),\n                )\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n  if (constraints.length > 0) {\n    if (result) {\n      result = and(result, ...constraints)\n    } else {\n      result = and(...constraints)\n    }\n  }\n  if (constraints.length === 1 && !result) {\n    ;[result] = constraints\n  }\n\n  return result\n}\n"],"names":["and","ilike","isNotNull","isNull","ne","notInArray","or","sql","QueryError","validOperators","buildAndOrConditions","createJSONQuery","convertPathToJSONTraversal","getTableColumnFromPath","operatorMap","sanitizeQueryValue","parseParams","adapter","fields","joinAliases","joins","locale","selectFields","tableName","where","result","constraints","Object","keys","length","relationOrPath","condition","conditionOperator","toLowerCase","Array","isArray","builtConditions","pathOperators","operator","includes","val","columnName","queryConstraints","field","getNotNullColumnByValue","pathSegments","rawColumn","table","collectionPath","replace","split","value","forEach","col","constraintTable","indexOf","push","like","equals","type","segments","slice","unshift","name","jsonQuery","treatAsArray","treatRootAsArray","raw","operatorKeys","contains","wildcard","exists","not_equals","formattedValue","path","map","word","sanitizedQueryValue","queryOperator","queryValue"],"mappings":"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"}
@@ -1,20 +1,10 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "sanitizeQueryValue", {
6
- enumerable: true,
7
- get: function() {
8
- return sanitizeQueryValue;
9
- }
10
- });
11
- const _errors = require("payload/errors");
12
- const _types = require("payload/types");
13
- const _utilities = require("payload/utilities");
14
- const sanitizeQueryValue = ({ adapter, field, operator: operatorArg, relationOrPath, val })=>{
1
+ import { APIError } from 'payload/errors';
2
+ import { fieldAffectsData } from 'payload/types';
3
+ import { createArrayFromCommaDelineated } from 'payload/utilities';
4
+ export const sanitizeQueryValue = ({ adapter, field, operator: operatorArg, relationOrPath, val })=>{
15
5
  let operator = operatorArg;
16
6
  let formattedValue = val;
17
- if (!(0, _types.fieldAffectsData)(field)) return {
7
+ if (!fieldAffectsData(field)) return {
18
8
  operator,
19
9
  value: formattedValue
20
10
  };
@@ -42,7 +32,7 @@ const sanitizeQueryValue = ({ adapter, field, operator: operatorArg, relationOrP
42
32
  'not_in'
43
33
  ].includes(operator)) {
44
34
  if (typeof formattedValue === 'string') {
45
- formattedValue = (0, _utilities.createArrayFromCommaDelineated)(formattedValue);
35
+ formattedValue = createArrayFromCommaDelineated(formattedValue);
46
36
  if (field.type === 'number') {
47
37
  formattedValue = formattedValue.map((arrayVal)=>parseFloat(arrayVal));
48
38
  }
@@ -77,7 +67,7 @@ const sanitizeQueryValue = ({ adapter, field, operator: operatorArg, relationOrP
77
67
  }
78
68
  }
79
69
  if (operator === 'near' || operator === 'within' || operator === 'intersects') {
80
- throw new _errors.APIError(`Querying with '${operator}' is not supported with the postgres database adapter.`);
70
+ throw new APIError(`Querying with '${operator}' is not supported with the postgres database adapter.`);
81
71
  }
82
72
  if (operator === 'contains') {
83
73
  formattedValue = `%${formattedValue}%`;
@@ -94,4 +84,4 @@ const sanitizeQueryValue = ({ adapter, field, operator: operatorArg, relationOrP
94
84
  };
95
85
  };
96
86
 
97
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL3Nhbml0aXplUXVlcnlWYWx1ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBUElFcnJvciB9IGZyb20gJ3BheWxvYWQvZXJyb3JzJ1xuaW1wb3J0IHsgdHlwZSBGaWVsZCwgdHlwZSBUYWJBc0ZpZWxkLCBmaWVsZEFmZmVjdHNEYXRhIH0gZnJvbSAncGF5bG9hZC90eXBlcydcbmltcG9ydCB7IGNyZWF0ZUFycmF5RnJvbUNvbW1hRGVsaW5lYXRlZCB9IGZyb20gJ3BheWxvYWQvdXRpbGl0aWVzJ1xuXG5pbXBvcnQgdHlwZSB7IFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4uL3R5cGVzJ1xuXG50eXBlIFNhbml0aXplUXVlcnlWYWx1ZUFyZ3MgPSB7XG4gIGFkYXB0ZXI6IFBvc3RncmVzQWRhcHRlclxuICBmaWVsZDogRmllbGQgfCBUYWJBc0ZpZWxkXG4gIG9wZXJhdG9yOiBzdHJpbmdcbiAgcmVsYXRpb25PclBhdGg6IHN0cmluZ1xuICB2YWw6IGFueVxufVxuXG5leHBvcnQgY29uc3Qgc2FuaXRpemVRdWVyeVZhbHVlID0gKHtcbiAgYWRhcHRlcixcbiAgZmllbGQsXG4gIG9wZXJhdG9yOiBvcGVyYXRvckFyZyxcbiAgcmVsYXRpb25PclBhdGgsXG4gIHZhbCxcbn06IFNhbml0aXplUXVlcnlWYWx1ZUFyZ3MpOiB7IG9wZXJhdG9yOiBzdHJpbmc7IHZhbHVlOiB1bmtub3duIH0gPT4ge1xuICBsZXQgb3BlcmF0b3IgPSBvcGVyYXRvckFyZ1xuICBsZXQgZm9ybWF0dGVkVmFsdWUgPSB2YWxcblxuICBpZiAoIWZpZWxkQWZmZWN0c0RhdGEoZmllbGQpKSByZXR1cm4geyBvcGVyYXRvciwgdmFsdWU6IGZvcm1hdHRlZFZhbHVlIH1cblxuICBpZiAoXG4gICAgKGZpZWxkLnR5cGUgPT09ICdyZWxhdGlvbnNoaXAnIHx8IGZpZWxkLnR5cGUgPT09ICd1cGxvYWQnKSAmJlxuICAgICFyZWxhdGlvbk9yUGF0aC5lbmRzV2l0aCgncmVsYXRpb25UbycpICYmXG4gICAgQXJyYXkuaXNBcnJheShmb3JtYXR0ZWRWYWx1ZSlcbiAgKSB7XG4gICAgY29uc3QgYWxsUG9zc2libGVJRFR5cGVzOiAobnVtYmVyIHwgc3RyaW5nKVtdID0gW11cbiAgICBmb3JtYXR0ZWRWYWx1ZS5mb3JFYWNoKCh2YWwpID0+IHtcbiAgICAgIGlmIChhZGFwdGVyLmlkVHlwZSAhPT0gJ3V1aWQnICYmIHR5cGVvZiB2YWwgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGFsbFBvc3NpYmxlSURUeXBlcy5wdXNoKHZhbCwgcGFyc2VJbnQodmFsKSlcbiAgICAgIH0gZWxzZSBpZiAodHlwZW9mIHZhbCA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgYWxsUG9zc2libGVJRFR5cGVzLnB1c2godmFsKVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgYWxsUG9zc2libGVJRFR5cGVzLnB1c2godmFsLCBTdHJpbmcodmFsKSlcbiAgICAgIH1cbiAgICB9KVxuICAgIGZvcm1hdHRlZFZhbHVlID0gYWxsUG9zc2libGVJRFR5cGVzXG4gIH1cblxuICAvLyBDYXN0IGluY29taW5nIHZhbHVlcyBhcyBwcm9wZXIgc2VhcmNoYWJsZSB0eXBlc1xuICBpZiAoZmllbGQudHlwZSA9PT0gJ2NoZWNrYm94JyAmJiB0eXBlb2YgdmFsID09PSAnc3RyaW5nJykge1xuICAgIGlmICh2YWwudG9Mb3dlckNhc2UoKSA9PT0gJ3RydWUnKSBmb3JtYXR0ZWRWYWx1ZSA9IHRydWVcbiAgICBpZiAodmFsLnRvTG93ZXJDYXNlKCkgPT09ICdmYWxzZScpIGZvcm1hdHRlZFZhbHVlID0gZmFsc2VcbiAgfVxuXG4gIGlmIChbJ2FsbCcsICdpbicsICdub3RfaW4nXS5pbmNsdWRlcyhvcGVyYXRvcikpIHtcbiAgICBpZiAodHlwZW9mIGZvcm1hdHRlZFZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBjcmVhdGVBcnJheUZyb21Db21tYURlbGluZWF0ZWQoZm9ybWF0dGVkVmFsdWUpXG5cbiAgICAgIGlmIChmaWVsZC50eXBlID09PSAnbnVtYmVyJykge1xuICAgICAgICBmb3JtYXR0ZWRWYWx1ZSA9IGZvcm1hdHRlZFZhbHVlLm1hcCgoYXJyYXlWYWwpID0+IHBhcnNlRmxvYXQoYXJyYXlWYWwpKVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmICghQXJyYXkuaXNBcnJheShmb3JtYXR0ZWRWYWx1ZSkgfHwgZm9ybWF0dGVkVmFsdWUubGVuZ3RoID09PSAwKSB7XG4gICAgICByZXR1cm4gbnVsbFxuICAgIH1cbiAgfVxuXG4gIGlmIChmaWVsZC50eXBlID09PSAnbnVtYmVyJyAmJiB0eXBlb2YgZm9ybWF0dGVkVmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgZm9ybWF0dGVkVmFsdWUgPSBOdW1iZXIodmFsKVxuICB9XG5cbiAgaWYgKGZpZWxkLnR5cGUgPT09ICdkYXRlJykge1xuICAgIGlmICh0eXBlb2YgdmFsID09PSAnc3RyaW5nJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBuZXcgRGF0ZSh2YWwpXG4gICAgICBpZiAoTnVtYmVyLmlzTmFOKERhdGUucGFyc2UoZm9ybWF0dGVkVmFsdWUpKSkge1xuICAgICAgICByZXR1cm4geyBvcGVyYXRvciwgdmFsdWU6IHVuZGVmaW5lZCB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiB2YWwgPT09ICdudW1iZXInKSB7XG4gICAgICBmb3JtYXR0ZWRWYWx1ZSA9IG5ldyBEYXRlKHZhbClcbiAgICB9XG4gIH1cblxuICBpZiAoWydyZWxhdGlvbnNoaXAnLCAndXBsb2FkJ10uaW5jbHVkZXMoZmllbGQudHlwZSkpIHtcbiAgICBpZiAodmFsID09PSAnbnVsbCcpIHtcbiAgICAgIGZvcm1hdHRlZFZhbHVlID0gbnVsbFxuICAgIH1cbiAgfVxuXG4gIGlmIChvcGVyYXRvciA9PT0gJ25lYXInIHx8IG9wZXJhdG9yID09PSAnd2l0aGluJyB8fCBvcGVyYXRvciA9PT0gJ2ludGVyc2VjdHMnKSB7XG4gICAgdGhyb3cgbmV3IEFQSUVycm9yKFxuICAgICAgYFF1ZXJ5aW5nIHdpdGggJyR7b3BlcmF0b3J9JyBpcyBub3Qgc3VwcG9ydGVkIHdpdGggdGhlIHBvc3RncmVzIGRhdGFiYXNlIGFkYXB0ZXIuYCxcbiAgICApXG4gIH1cblxuICBpZiAob3BlcmF0b3IgPT09ICdjb250YWlucycpIHtcbiAgICBmb3JtYXR0ZWRWYWx1ZSA9IGAlJHtmb3JtYXR0ZWRWYWx1ZX0lYFxuICB9XG5cbiAgaWYgKG9wZXJhdG9yID09PSAnZXhpc3RzJykge1xuICAgIGZvcm1hdHRlZFZhbHVlID0gZm9ybWF0dGVkVmFsdWUgPT09ICd0cnVlJyB8fCBmb3JtYXR0ZWRWYWx1ZSA9PT0gdHJ1ZVxuICAgIGlmIChmb3JtYXR0ZWRWYWx1ZSA9PT0gZmFsc2UpIHtcbiAgICAgIG9wZXJhdG9yID0gJ2lzTnVsbCdcbiAgICB9XG4gIH1cblxuICByZXR1cm4geyBvcGVyYXRvciwgdmFsdWU6IGZvcm1hdHRlZFZhbHVlIH1cbn1cbiJdLCJuYW1lcyI6WyJzYW5pdGl6ZVF1ZXJ5VmFsdWUiLCJhZGFwdGVyIiwiZmllbGQiLCJvcGVyYXRvciIsIm9wZXJhdG9yQXJnIiwicmVsYXRpb25PclBhdGgiLCJ2YWwiLCJmb3JtYXR0ZWRWYWx1ZSIsImZpZWxkQWZmZWN0c0RhdGEiLCJ2YWx1ZSIsInR5cGUiLCJlbmRzV2l0aCIsIkFycmF5IiwiaXNBcnJheSIsImFsbFBvc3NpYmxlSURUeXBlcyIsImZvckVhY2giLCJpZFR5cGUiLCJwdXNoIiwicGFyc2VJbnQiLCJTdHJpbmciLCJ0b0xvd2VyQ2FzZSIsImluY2x1ZGVzIiwiY3JlYXRlQXJyYXlGcm9tQ29tbWFEZWxpbmVhdGVkIiwibWFwIiwiYXJyYXlWYWwiLCJwYXJzZUZsb2F0IiwibGVuZ3RoIiwiTnVtYmVyIiwiRGF0ZSIsImlzTmFOIiwicGFyc2UiLCJ1bmRlZmluZWQiLCJBUElFcnJvciJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFjYUE7OztlQUFBQTs7O3dCQWRZO3VCQUNxQzsyQkFD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
87
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL3Nhbml0aXplUXVlcnlWYWx1ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBUElFcnJvciB9IGZyb20gJ3BheWxvYWQvZXJyb3JzJ1xuaW1wb3J0IHsgdHlwZSBGaWVsZCwgdHlwZSBUYWJBc0ZpZWxkLCBmaWVsZEFmZmVjdHNEYXRhIH0gZnJvbSAncGF5bG9hZC90eXBlcydcbmltcG9ydCB7IGNyZWF0ZUFycmF5RnJvbUNvbW1hRGVsaW5lYXRlZCB9IGZyb20gJ3BheWxvYWQvdXRpbGl0aWVzJ1xuXG5pbXBvcnQgdHlwZSB7IFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4uL3R5cGVzJ1xuXG50eXBlIFNhbml0aXplUXVlcnlWYWx1ZUFyZ3MgPSB7XG4gIGFkYXB0ZXI6IFBvc3RncmVzQWRhcHRlclxuICBmaWVsZDogRmllbGQgfCBUYWJBc0ZpZWxkXG4gIG9wZXJhdG9yOiBzdHJpbmdcbiAgcmVsYXRpb25PclBhdGg6IHN0cmluZ1xuICB2YWw6IGFueVxufVxuXG5leHBvcnQgY29uc3Qgc2FuaXRpemVRdWVyeVZhbHVlID0gKHtcbiAgYWRhcHRlcixcbiAgZmllbGQsXG4gIG9wZXJhdG9yOiBvcGVyYXRvckFyZyxcbiAgcmVsYXRpb25PclBhdGgsXG4gIHZhbCxcbn06IFNhbml0aXplUXVlcnlWYWx1ZUFyZ3MpOiB7IG9wZXJhdG9yOiBzdHJpbmc7IHZhbHVlOiB1bmtub3duIH0gPT4ge1xuICBsZXQgb3BlcmF0b3IgPSBvcGVyYXRvckFyZ1xuICBsZXQgZm9ybWF0dGVkVmFsdWUgPSB2YWxcblxuICBpZiAoIWZpZWxkQWZmZWN0c0RhdGEoZmllbGQpKSByZXR1cm4geyBvcGVyYXRvciwgdmFsdWU6IGZvcm1hdHRlZFZhbHVlIH1cblxuICBpZiAoXG4gICAgKGZpZWxkLnR5cGUgPT09ICdyZWxhdGlvbnNoaXAnIHx8IGZpZWxkLnR5cGUgPT09ICd1cGxvYWQnKSAmJlxuICAgICFyZWxhdGlvbk9yUGF0aC5lbmRzV2l0aCgncmVsYXRpb25UbycpICYmXG4gICAgQXJyYXkuaXNBcnJheShmb3JtYXR0ZWRWYWx1ZSlcbiAgKSB7XG4gICAgY29uc3QgYWxsUG9zc2libGVJRFR5cGVzOiAobnVtYmVyIHwgc3RyaW5nKVtdID0gW11cbiAgICBmb3JtYXR0ZWRWYWx1ZS5mb3JFYWNoKCh2YWwpID0+IHtcbiAgICAgIGlmIChhZGFwdGVyLmlkVHlwZSAhPT0gJ3V1aWQnICYmIHR5cGVvZiB2YWwgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGFsbFBvc3NpYmxlSURUeXBlcy5wdXNoKHZhbCwgcGFyc2VJbnQodmFsKSlcbiAgICAgIH0gZWxzZSBpZiAodHlwZW9mIHZhbCA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgYWxsUG9zc2libGVJRFR5cGVzLnB1c2godmFsKVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgYWxsUG9zc2libGVJRFR5cGVzLnB1c2godmFsLCBTdHJpbmcodmFsKSlcbiAgICAgIH1cbiAgICB9KVxuICAgIGZvcm1hdHRlZFZhbHVlID0gYWxsUG9zc2libGVJRFR5cGVzXG4gIH1cblxuICAvLyBDYXN0IGluY29taW5nIHZhbHVlcyBhcyBwcm9wZXIgc2VhcmNoYWJsZSB0eXBlc1xuICBpZiAoZmllbGQudHlwZSA9PT0gJ2NoZWNrYm94JyAmJiB0eXBlb2YgdmFsID09PSAnc3RyaW5nJykge1xuICAgIGlmICh2YWwudG9Mb3dlckNhc2UoKSA9PT0gJ3RydWUnKSBmb3JtYXR0ZWRWYWx1ZSA9IHRydWVcbiAgICBpZiAodmFsLnRvTG93ZXJDYXNlKCkgPT09ICdmYWxzZScpIGZvcm1hdHRlZFZhbHVlID0gZmFsc2VcbiAgfVxuXG4gIGlmIChbJ2FsbCcsICdpbicsICdub3RfaW4nXS5pbmNsdWRlcyhvcGVyYXRvcikpIHtcbiAgICBpZiAodHlwZW9mIGZvcm1hdHRlZFZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBjcmVhdGVBcnJheUZyb21Db21tYURlbGluZWF0ZWQoZm9ybWF0dGVkVmFsdWUpXG5cbiAgICAgIGlmIChmaWVsZC50eXBlID09PSAnbnVtYmVyJykge1xuICAgICAgICBmb3JtYXR0ZWRWYWx1ZSA9IGZvcm1hdHRlZFZhbHVlLm1hcCgoYXJyYXlWYWwpID0+IHBhcnNlRmxvYXQoYXJyYXlWYWwpKVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmICghQXJyYXkuaXNBcnJheShmb3JtYXR0ZWRWYWx1ZSkgfHwgZm9ybWF0dGVkVmFsdWUubGVuZ3RoID09PSAwKSB7XG4gICAgICByZXR1cm4gbnVsbFxuICAgIH1cbiAgfVxuXG4gIGlmIChmaWVsZC50eXBlID09PSAnbnVtYmVyJyAmJiB0eXBlb2YgZm9ybWF0dGVkVmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgZm9ybWF0dGVkVmFsdWUgPSBOdW1iZXIodmFsKVxuICB9XG5cbiAgaWYgKGZpZWxkLnR5cGUgPT09ICdkYXRlJykge1xuICAgIGlmICh0eXBlb2YgdmFsID09PSAnc3RyaW5nJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBuZXcgRGF0ZSh2YWwpXG4gICAgICBpZiAoTnVtYmVyLmlzTmFOKERhdGUucGFyc2UoZm9ybWF0dGVkVmFsdWUpKSkge1xuICAgICAgICByZXR1cm4geyBvcGVyYXRvciwgdmFsdWU6IHVuZGVmaW5lZCB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiB2YWwgPT09ICdudW1iZXInKSB7XG4gICAgICBmb3JtYXR0ZWRWYWx1ZSA9IG5ldyBEYXRlKHZhbClcbiAgICB9XG4gIH1cblxuICBpZiAoWydyZWxhdGlvbnNoaXAnLCAndXBsb2FkJ10uaW5jbHVkZXMoZmllbGQudHlwZSkpIHtcbiAgICBpZiAodmFsID09PSAnbnVsbCcpIHtcbiAgICAgIGZvcm1hdHRlZFZhbHVlID0gbnVsbFxuICAgIH1cbiAgfVxuXG4gIGlmIChvcGVyYXRvciA9PT0gJ25lYXInIHx8IG9wZXJhdG9yID09PSAnd2l0aGluJyB8fCBvcGVyYXRvciA9PT0gJ2ludGVyc2VjdHMnKSB7XG4gICAgdGhyb3cgbmV3IEFQSUVycm9yKFxuICAgICAgYFF1ZXJ5aW5nIHdpdGggJyR7b3BlcmF0b3J9JyBpcyBub3Qgc3VwcG9ydGVkIHdpdGggdGhlIHBvc3RncmVzIGRhdGFiYXNlIGFkYXB0ZXIuYCxcbiAgICApXG4gIH1cblxuICBpZiAob3BlcmF0b3IgPT09ICdjb250YWlucycpIHtcbiAgICBmb3JtYXR0ZWRWYWx1ZSA9IGAlJHtmb3JtYXR0ZWRWYWx1ZX0lYFxuICB9XG5cbiAgaWYgKG9wZXJhdG9yID09PSAnZXhpc3RzJykge1xuICAgIGZvcm1hdHRlZFZhbHVlID0gZm9ybWF0dGVkVmFsdWUgPT09ICd0cnVlJyB8fCBmb3JtYXR0ZWRWYWx1ZSA9PT0gdHJ1ZVxuICAgIGlmIChmb3JtYXR0ZWRWYWx1ZSA9PT0gZmFsc2UpIHtcbiAgICAgIG9wZXJhdG9yID0gJ2lzTnVsbCdcbiAgICB9XG4gIH1cblxuICByZXR1cm4geyBvcGVyYXRvciwgdmFsdWU6IGZvcm1hdHRlZFZhbHVlIH1cbn1cbiJdLCJuYW1lcyI6WyJBUElFcnJvciIsImZpZWxkQWZmZWN0c0RhdGEiLCJjcmVhdGVBcnJheUZyb21Db21tYURlbGluZWF0ZWQiLCJzYW5pdGl6ZVF1ZXJ5VmFsdWUiLCJhZGFwdGVyIiwiZmllbGQiLCJvcGVyYXRvciIsIm9wZXJhdG9yQXJnIiwicmVsYXRpb25PclBhdGgiLCJ2YWwiLCJmb3JtYXR0ZWRWYWx1ZSIsInZhbHVlIiwidHlwZSIsImVuZHNXaXRoIiwiQXJyYXkiLCJpc0FycmF5IiwiYWxsUG9zc2libGVJRFR5cGVzIiwiZm9yRWFjaCIsImlkVHlwZSIsInB1c2giLCJwYXJzZUludCIsIlN0cmluZyIsInRvTG93ZXJDYXNlIiwiaW5jbHVkZXMiLCJtYXAiLCJhcnJheVZhbCIsInBhcnNlRmxvYXQiLCJsZW5ndGgiLCJOdW1iZXIiLCJEYXRlIiwiaXNOYU4iLCJwYXJzZSIsInVuZGVmaW5lZCJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsUUFBUSxRQUFRLGlCQUFnQjtBQUN6QyxTQUFz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
@@ -1,32 +1,17 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "queryDrafts", {
6
- enumerable: true,
7
- get: function() {
8
- return queryDrafts;
9
- }
10
- });
11
- const _database = require("payload/database");
12
- const _versions = require("payload/versions");
13
- const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
14
- const _findMany = require("./find/findMany");
15
- function _interop_require_default(obj) {
16
- return obj && obj.__esModule ? obj : {
17
- default: obj
18
- };
19
- }
20
- const queryDrafts = async function queryDrafts({ collection, limit, locale, page = 1, pagination, req = {}, sort, where }) {
1
+ import { combineQueries } from 'payload/database';
2
+ import { buildVersionCollectionFields } from 'payload/versions';
3
+ import toSnakeCase from 'to-snake-case';
4
+ import { findMany } from './find/findMany';
5
+ export const queryDrafts = async function queryDrafts({ collection, limit, locale, page = 1, pagination, req = {}, sort, where }) {
21
6
  const collectionConfig = this.payload.collections[collection].config;
22
- const tableName = `_${(0, _tosnakecase.default)(collection)}_v`;
23
- const fields = (0, _versions.buildVersionCollectionFields)(collectionConfig);
24
- const combinedWhere = (0, _database.combineQueries)({
7
+ const tableName = `_${toSnakeCase(collection)}_v`;
8
+ const fields = buildVersionCollectionFields(collectionConfig);
9
+ const combinedWhere = combineQueries({
25
10
  latest: {
26
11
  equals: true
27
12
  }
28
13
  }, where);
29
- const result = await (0, _findMany.findMany)({
14
+ const result = await findMany({
30
15
  adapter: this,
31
16
  fields,
32
17
  limit,
@@ -53,4 +38,4 @@ const queryDrafts = async function queryDrafts({ collection, limit, locale, page
53
38
  };
54
39
  };
55
40
 
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9xdWVyeURyYWZ0cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFBheWxvYWRSZXF1ZXN0LCBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgdHlwZSBRdWVyeURyYWZ0cywgY29tYmluZVF1ZXJpZXMgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHsgYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyB9IGZyb20gJ3BheWxvYWQvdmVyc2lvbnMnXG5pbXBvcnQgdG9TbmFrZUNhc2UgZnJvbSAndG8tc25ha2UtY2FzZSdcblxuaW1wb3J0IHsgZmluZE1hbnkgfSBmcm9tICcuL2ZpbmQvZmluZE1hbnknXG5cbmV4cG9ydCBjb25zdCBxdWVyeURyYWZ0czogUXVlcnlEcmFmdHMgPSBhc3luYyBmdW5jdGlvbiBxdWVyeURyYWZ0cyh7XG4gIGNvbGxlY3Rpb24sXG4gIGxpbWl0LFxuICBsb2NhbGUsXG4gIHBhZ2UgPSAxLFxuICBwYWdpbmF0aW9uLFxuICByZXEgPSB7fSBhcyBQYXlsb2FkUmVxdWVzdCxcbiAgc29ydCxcbiAgd2hlcmUsXG59KSB7XG4gIGNvbnN0IGNvbGxlY3Rpb25Db25maWc6IFNhbml0aXplZENvbGxlY3Rpb25Db25maWcgPSB0aGlzLnBheWxvYWQuY29sbGVjdGlvbnNbY29sbGVjdGlvbl0uY29uZmlnXG4gIGNvbnN0IHRhYmxlTmFtZSA9IGBfJHt0b1NuYWtlQ2FzZShjb2xsZWN0aW9uKX1fdmBcbiAgY29uc3QgZmllbGRzID0gYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyhjb2xsZWN0aW9uQ29uZmlnKVxuXG4gIGNvbnN0IGNvbWJpbmVkV2hlcmUgPSBjb21iaW5lUXVlcmllcyh7IGxhdGVzdDogeyBlcXVhbHM6IHRydWUgfSB9LCB3aGVyZSlcblxuICBjb25zdCByZXN1bHQgPSBhd2FpdCBmaW5kTWFueSh7XG4gICAgYWRhcHRlcjogdGhpcyxcbiAgICBmaWVsZHMsXG4gICAgbGltaXQsXG4gICAgbG9jYWxlLFxuICAgIHBhZ2UsXG4gICAgcGFnaW5hdGlvbixcbiAgICByZXEsXG4gICAgc29ydCxcbiAgICB0YWJsZU5hbWUsXG4gICAgd2hlcmU6IGNvbWJpbmVkV2hlcmUsXG4gIH0pXG5cbiAgcmV0dXJuIHtcbiAgICAuLi5yZXN1bHQsXG4gICAgZG9jczogcmVzdWx0LmRvY3MubWFwKChkb2MpID0+IHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1wYXJhbS1yZWFzc2lnblxuICAgICAgZG9jID0ge1xuICAgICAgICBpZDogZG9jLnBhcmVudCxcbiAgICAgICAgLi4uZG9jLnZlcnNpb24sXG4gICAgICAgIGNyZWF0ZWRBdDogZG9jLmNyZWF0ZWRBdCxcbiAgICAgICAgdXBkYXRlZEF0OiBkb2MudXBkYXRlZEF0LFxuICAgICAgfVxuXG4gICAgICByZXR1cm4gZG9jXG4gICAgfSksXG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJxdWVyeURyYWZ0cyIsImNvbGxlY3Rpb24iLCJsaW1pdCIsImxvY2FsZSIsInBhZ2UiLCJwYWdpbmF0aW9uIiwicmVxIiwic29ydCIsIndoZXJlIiwiY29sbGVjdGlvbkNvbmZpZyIsInBheWxvYWQiLCJjb2xsZWN0aW9ucyIsImNvbmZpZyIsInRhYmxlTmFtZSIsInRvU25ha2VDYXNlIiwiZmllbGRzIiwiYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyIsImNvbWJpbmVkV2hlcmUiLCJjb21iaW5lUXVlcmllcyIsImxhdGVzdCIsImVxdWFscyIsInJlc3VsdCIsImZpbmRNYW55IiwiYWRhcHRlciIsImRvY3MiLCJtYXAiLCJkb2MiLCJpZCIsInBhcmVudCIsInZlcnNpb24iLCJjcmVhdGVkQXQiLCJ1cGRhdGVkQXQiXSwibWFwcGluZ3MiOiI7Ozs7K0JBUWFBOzs7ZUFBQUE7OzswQkFOb0M7MEJBQ0o7b0VBQ3JCOzBCQUVDOzs7Ozs7QUFFbEIsTUFBTUEsY0FBMkIsZUFBZUEsWUFBWSxFQUNqRUMsVUFBVSxFQUNWQyxLQUFLLEVBQ0xDLE1BQU0sRUFDTkMsT0FBTyxDQUFDLEVBQ1JDLFVBQVUsRUFDVkMsTUFBTSxDQUFDLENBQW1CLEVBQzFCQyxJQUFJLEVBQ0pDLEtBQUssRUFDTjtJQUNDLE1BQU1DLG1CQUE4QyxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsV0FBVyxDQUFDVixXQUFXLENBQUNXLE1BQU07SUFDL0YsTUFBTUMsWUFBWSxDQUFDLENBQUMsRUFBRUMsSUFBQUEsb0JBQVcsRUFBQ2IsWUFBWSxFQUFFLENBQUM7SUFDakQsTUFBTWMsU0FBU0MsSUFBQUEsc0NBQTRCLEVBQUNQO0lBRTVDLE1BQU1RLGdCQUFnQkMsSUFBQUEsd0JBQWMsRUFBQztRQUFFQyxRQUFRO1lBQUVDLFFBQVE7UUFBSztJQUFFLEdBQUdaO0lBRW5FLE1BQU1hLFNBQVMsTUFBTUMsSUFBQUEsa0JBQVEsRUFBQztRQUM1QkMsU0FBUyxJQUFJO1FBQ2JSO1FBQ0FiO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FNO1FBQ0FMLE9BQU9TO0lBQ1Q7SUFFQSxPQUFPO1FBQ0wsR0FBR0ksTUFBTTtRQUNURyxNQUFNSCxPQUFPRyxJQUFJLENBQUNDLEdBQUcsQ0FBQyxDQUFDQztZQUNyQiw2Q0FBNkM7WUFDN0NBLE1BQU07Z0JBQ0pDLElBQUlELElBQUlFLE1BQU07Z0JBQ2QsR0FBR0YsSUFBSUcsT0FBTztnQkFDZEMsV0FBV0osSUFBSUksU0FBUztnQkFDeEJDLFdBQVdMLElBQUlLLFNBQVM7WUFDMUI7WUFFQSxPQUFPTDtRQUNUO0lBQ0Y7QUFDRiJ9
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9xdWVyeURyYWZ0cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFBheWxvYWRSZXF1ZXN0LCBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgdHlwZSBRdWVyeURyYWZ0cywgY29tYmluZVF1ZXJpZXMgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHsgYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyB9IGZyb20gJ3BheWxvYWQvdmVyc2lvbnMnXG5pbXBvcnQgdG9TbmFrZUNhc2UgZnJvbSAndG8tc25ha2UtY2FzZSdcblxuaW1wb3J0IHsgZmluZE1hbnkgfSBmcm9tICcuL2ZpbmQvZmluZE1hbnknXG5cbmV4cG9ydCBjb25zdCBxdWVyeURyYWZ0czogUXVlcnlEcmFmdHMgPSBhc3luYyBmdW5jdGlvbiBxdWVyeURyYWZ0cyh7XG4gIGNvbGxlY3Rpb24sXG4gIGxpbWl0LFxuICBsb2NhbGUsXG4gIHBhZ2UgPSAxLFxuICBwYWdpbmF0aW9uLFxuICByZXEgPSB7fSBhcyBQYXlsb2FkUmVxdWVzdCxcbiAgc29ydCxcbiAgd2hlcmUsXG59KSB7XG4gIGNvbnN0IGNvbGxlY3Rpb25Db25maWc6IFNhbml0aXplZENvbGxlY3Rpb25Db25maWcgPSB0aGlzLnBheWxvYWQuY29sbGVjdGlvbnNbY29sbGVjdGlvbl0uY29uZmlnXG4gIGNvbnN0IHRhYmxlTmFtZSA9IGBfJHt0b1NuYWtlQ2FzZShjb2xsZWN0aW9uKX1fdmBcbiAgY29uc3QgZmllbGRzID0gYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyhjb2xsZWN0aW9uQ29uZmlnKVxuXG4gIGNvbnN0IGNvbWJpbmVkV2hlcmUgPSBjb21iaW5lUXVlcmllcyh7IGxhdGVzdDogeyBlcXVhbHM6IHRydWUgfSB9LCB3aGVyZSlcblxuICBjb25zdCByZXN1bHQgPSBhd2FpdCBmaW5kTWFueSh7XG4gICAgYWRhcHRlcjogdGhpcyxcbiAgICBmaWVsZHMsXG4gICAgbGltaXQsXG4gICAgbG9jYWxlLFxuICAgIHBhZ2UsXG4gICAgcGFnaW5hdGlvbixcbiAgICByZXEsXG4gICAgc29ydCxcbiAgICB0YWJsZU5hbWUsXG4gICAgd2hlcmU6IGNvbWJpbmVkV2hlcmUsXG4gIH0pXG5cbiAgcmV0dXJuIHtcbiAgICAuLi5yZXN1bHQsXG4gICAgZG9jczogcmVzdWx0LmRvY3MubWFwKChkb2MpID0+IHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1wYXJhbS1yZWFzc2lnblxuICAgICAgZG9jID0ge1xuICAgICAgICBpZDogZG9jLnBhcmVudCxcbiAgICAgICAgLi4uZG9jLnZlcnNpb24sXG4gICAgICAgIGNyZWF0ZWRBdDogZG9jLmNyZWF0ZWRBdCxcbiAgICAgICAgdXBkYXRlZEF0OiBkb2MudXBkYXRlZEF0LFxuICAgICAgfVxuXG4gICAgICByZXR1cm4gZG9jXG4gICAgfSksXG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJjb21iaW5lUXVlcmllcyIsImJ1aWxkVmVyc2lvbkNvbGxlY3Rpb25GaWVsZHMiLCJ0b1NuYWtlQ2FzZSIsImZpbmRNYW55IiwicXVlcnlEcmFmdHMiLCJjb2xsZWN0aW9uIiwibGltaXQiLCJsb2NhbGUiLCJwYWdlIiwicGFnaW5hdGlvbiIsInJlcSIsInNvcnQiLCJ3aGVyZSIsImNvbGxlY3Rpb25Db25maWciLCJwYXlsb2FkIiwiY29sbGVjdGlvbnMiLCJjb25maWciLCJ0YWJsZU5hbWUiLCJmaWVsZHMiLCJjb21iaW5lZFdoZXJlIiwibGF0ZXN0IiwiZXF1YWxzIiwicmVzdWx0IiwiYWRhcHRlciIsImRvY3MiLCJtYXAiLCJkb2MiLCJpZCIsInBhcmVudCIsInZlcnNpb24iLCJjcmVhdGVkQXQiLCJ1cGRhdGVkQXQiXSwibWFwcGluZ3MiOiJBQUVBLFNBQTJCQSxjQUFjLFFBQVEsbUJBQWtCO0FBQ25FLFNBQVNDLDRCQUE0QixRQUFRLG1CQUFrQjtBQUMvRCxPQUFPQyxpQkFBaUIsZ0JBQWU7QUFFdkMsU0FBU0MsUUFBUSxRQUFRLGtCQUFpQjtBQUUxQyxPQUFPLE1BQU1DLGNBQTJCLGVBQWVBLFlBQVksRUFDakVDLFVBQVUsRUFDVkMsS0FBSyxFQUNMQyxNQUFNLEVBQ05DLE9BQU8sQ0FBQyxFQUNSQyxVQUFVLEVBQ1ZDLE1BQU0sQ0FBQyxDQUFtQixFQUMxQkMsSUFBSSxFQUNKQyxLQUFLLEVBQ047SUFDQyxNQUFNQyxtQkFBOEMsSUFBSSxDQUFDQyxPQUFPLENBQUNDLFdBQVcsQ0FBQ1YsV0FBVyxDQUFDVyxNQUFNO0lBQy9GLE1BQU1DLFlBQVksQ0FBQyxDQUFDLEVBQUVmLFlBQVlHLFlBQVksRUFBRSxDQUFDO0lBQ2pELE1BQU1hLFNBQVNqQiw2QkFBNkJZO0lBRTVDLE1BQU1NLGdCQUFnQm5CLGVBQWU7UUFBRW9CLFFBQVE7WUFBRUMsUUFBUTtRQUFLO0lBQUUsR0FBR1Q7SUFFbkUsTUFBTVUsU0FBUyxNQUFNbkIsU0FBUztRQUM1Qm9CLFNBQVMsSUFBSTtRQUNiTDtRQUNBWjtRQUNBQztRQUNBQztRQUNBQztRQUNBQztRQUNBQztRQUNBTTtRQUNBTCxPQUFPTztJQUNUO0lBRUEsT0FBTztRQUNMLEdBQUdHLE1BQU07UUFDVEUsTUFBTUYsT0FBT0UsSUFBSSxDQUFDQyxHQUFHLENBQUMsQ0FBQ0M7WUFDckIsNkNBQTZDO1lBQzdDQSxNQUFNO2dCQUNKQyxJQUFJRCxJQUFJRSxNQUFNO2dCQUNkLEdBQUdGLElBQUlHLE9BQU87Z0JBQ2RDLFdBQVdKLElBQUlJLFNBQVM7Z0JBQ3hCQyxXQUFXTCxJQUFJSyxTQUFTO1lBQzFCO1lBRUEsT0FBT0w7UUFDVDtJQUNGO0FBQ0YsRUFBQyJ9